 @charset "UTF-8";


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

   common.css

	- Variable
	- Reset
	- Base
	- Layout
	- Navigation
	- Component
	- Animation
	- Utility

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



/* ========================================================
  
  Variable

======================================================== */
:root {
	--fw-bold: 600;

	--ff-gothic: "Hiragino Kaku Gothic ProN","Hiragino Sans","游ゴシック","Yu Gothic",Meiryo,sans-serif;

	--font-min: normal normal 400 100%/1.6 "Noto Serif JP", serif;
	--font-en: normal normal 400 100%/1 "Sorts Mill Goudy", serif;
	--font-no: normal normal 400 100%/1 "Cardo", serif;

	--color-base: #333;
	--color-bdr: #d9d9d9;

	--color-primary: #faed00;
	--color-primary-400: #FBF37C;
	--color-secondary: #ff968a;

	--color-blu: #59a3ad;
	--color-grn: #4ca08c;
	--color-gld: #a0934c;
	--color-pnk: #d97f84;
	--color-ppl: #997c97;
	--color-ppl-100: #f6f1fa;
	--color-ppl-300: #b184d9;
	--color-wine: #a51f52;
	--color-red: #cc2d2d;
	--color-bei: #f2f2ed;
	--color-ivo: #f9faf3;
	--color-gry-100: #e6e6e6;
	--color-brw-600: #372308;

	--accent-color: var(--color-grn);
	--job-color: var(--accent-color);
}

.u-accent-blu { --accent-color: var(--color-blu );}
.u-accent-pnk { --accent-color: var(--color-pnk );}
.u-accent-ppl { --accent-color: var(--color-ppl );}
.u-accent-job { --accent-color: var(--job-color );}

.u-accent-primary { --accent-color: var(--color-primary);}
.u-accent-secondary { --accent-color: var(--color-secondary);}

.page-dh {
	--job-color: var(--color-pnk );
	--job-color-rgb: 217 127 132;;
}
.page-staff {
	--job-color: var(--color-ppl-300 );
	--job-color-rgb: 177 132 217;
}


/* ========================================================
  
  Reset

======================================================== */
*, *::before, *::after {
	box-sizing: border-box;
}

div,
dl,dt,dd,ul,ol,li,
h1,h2,h3,h4,h5,h6,
pre,form,fildset,p,blockquote,
figure,figcaption,hr {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font-style: normal;
	font-weight: inherit;
}

ul{
	list-style:none;
}

img{
	display: block;
    /* width: 100%; */
    max-width: 100%;
    height: auto;
    /* object-fit: cover; */
}

picture {
	display:block;
}

table {
	width:100%;
	font-size:inherit;
	font:100%;
	border-collapse:separate;
	border-spacing:0;
}

button {
	display: block;
	padding: 0;
	border: none;
	outline: none;
	font: inherit;
	color: inherit;
	background: none;
	cursor: pointer;
}






/* ========================================================
  
  Base

======================================================== */
html {
	font-size: 17px;
}
body {
	font-family: "Hiragino Kaku Gothic ProN","Hiragino Sans","游ゴシック","Yu Gothic",Meiryo,sans-serif;
	font-style: normal;
	color: var(--color-base);
	letter-spacing: .1em;
	line-height: 2;
	margin: 0;
	-webkit-text-size-adjust: 100%;
}

main {
	position: relative;
}

a {
	color: inherit;
	text-decoration: none;
	outline: 0;
	transition: color .8s, background-color .8s;
}

address {
	font-style: normal;
}

section {
	position: relative;
}

main {
	position: relative;
}

cite {
	display: block;
	text-align: right;
	font-size: min(1.5vw,100%);
	letter-spacing: normal;
	font-style: normal;
	line-height: 1.4;
	margin-top: 1em;
}

sup {
	font-size:60%;
}

hr {
	display: block;
	height: 1px;
	background: #e6e6e6;
	width: 100%;
	border: none;
	margin: 7% auto;
}

b {font-weight: var(--fw-bold);}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {

body {
	line-height: 1.8;
}
}

@media(min-width: 768px) {
/* PC時はaタグ無効 */
  a[href^="tel:"] {
    pointer-events: none;
  }
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
/* スマホのときはビューポートを基準にサイズ調節する */
/* スマホ時：emまたは%で指定する */
/* スマホ以外でビューポート基準にするときは、その都度「vw」で指定する */
html {
	font-size: 4vw;
	letter-spacing: .06em;
}
body {
	line-height: 1.7;
}
cite {
	font-size: 80%;
}
hr {
	margin: 12% auto;
}
}






/* ========================================================
  
  Layout

======================================================== */
.l-wrapper { overflow: clip; }


/*-----------------------------------------------
 Layout - header
-----------------------------------------------*/
header {
	position: relative;
	width: 100%;
	left: 0;
	top: 0;
	padding: min(3vw,40px) min(1.6vw,25px);
	z-index: 100;
}
.l-header__left {
	max-width: max-content;
}
/* c-logo */
.c-logo {
	display: block;
	text-align: left;
	
	font: var(--font-min);
	font-size: min(1.2vw,105%);
	letter-spacing: .15em;
	line-height: 1.4;
	white-space: nowrap;
}
.c-logo img {
	width: 8.28em;
}
.c-logo span {
	display: block;
}
.c-logo .c-logo__corp span {
	font-size: 150%;
	letter-spacing: .15em;
}
.c-logo .c-logo__site {
	font-size: 305%;
	letter-spacing: .12em;
	line-height: 1.2;
}

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

/* c-logo */
.c-logo {
	display: flex;
	align-items: center;
	column-gap: 1em;
}
.c-logo .c-logo__site {
	padding-left: .6em;
	border-left: 1px solid var(--color-bdr);
}
/* l-header__right */
.l-header__right {
	position: absolute;
	right: 0;
	top: 0;
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

header {
	padding: 4vw;
}
.c-logo {
	font-size: 2.4vw;
}
.c-logo .c-logo__corp {
	margin: .6em auto .5em;
}

.l-header__right {
	display: none;
}
}

/*-----------------------------------------------
 Layout - l-cta-nav
-----------------------------------------------*/

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

.l-cta-nav {
	width: 42%;
	max-width: 610px;
	font-size: min(1.16vw,100%);
}
.l-cta-nav .c-cta-wrap {
	justify-content: flex-start;
	column-gap: 1.6%;
}
.l-cta-nav .c-cta-btn {
	width: 32%;
	min-width: 7em;
	height: 3.2em;
	font-size: 105%;
}
.l-cta-nav .c-cta-btn--entry {
	height: 7.1em;
	font-size: 82%;
	border-radius: 0;
	margin-left: auto;
}
.l-cta-nav .c-cta-btn--entry span {
	display: block;
	font-size: 170%;
}

header .c-cta-wrap {
	align-items: flex-end;
}
header .l-cta-nav .c-cta-btn--entry {
	height: 8.5em;
	margin-left: auto;
}
header .l-cta-nav .u-font-min {
	position: absolute;
	width: 64%;
	text-align: center;
	font-size: 88%;
	line-height: 1.5;
	left: 0;
	top: 1.2em;
}
}


/*-----------------------------------------------
 Layout - l-nav
-----------------------------------------------*/
.l-nav {
	position: absolute;
	max-width: 950px;
	max-width: max-content;
	background-color: rgba(238,242,237,0.9);
	z-index: 1;
	inset: auto 0 0 0;
	margin: auto;
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.l-nav {
	display: none;
}
}

/*-----------------------------------------------
 Layout - scl_header
-----------------------------------------------*/
#scl_header {
	position: fixed;
	background-color: rgba(238,242,237,0.9);
	z-index: 500;
	left: 0;
	top: 0;
	width: 100%;
	translate: 0 -101%;
}
#scl_header.is-show {
	display: block;
	translate: 0 0;
	opacity: 1;
    animation: sclAnimation 1.0s;
}
.l-scroll__inner {
	position: relative;
	display: flex;
	justify-content: space-between;
}

.l-scroll .c-cta-btn--entry div::after {
    content: "見学・応募";
}
@keyframes sclAnimation {
	0% {
		translate: 0 -100%;
	}
	100% {
		translate: 0 0;
	}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
#scl_header {
	display: none !important;
}
}

/*-----------------------------------------------
 Layout - drawer
-----------------------------------------------*/
.l-drawer__inner {
	color: #FFF;
	padding: 10% 6%;
}

/* Layout - drawer - l-drawer__menu
-----------------------------------------------*/
.l-drawer__menu {
	width: 70vw;
	text-align: center;
	font: var(--font-min);
	font-size: 4vw;
	letter-spacing: .2em;
	line-height: 1.3;
	margin-inline: auto;
}
.l-drawer__menu > li {
	border-bottom: 1px solid currentColor;
}
.l-drawer__menu > li > a {
	position: relative;
	display: block;
	padding: 1.5em .5em;
}


/*-----------------------------------------------
 Layout - Info
-----------------------------------------------*/
.l-info {
	padding-top: 90px;
}
.l-info__box {
	width: 94vw;
	max-width: 1340px;
	background: linear-gradient(to bottom, rgba(242,242,237,1), rgba(242,242,237,0.3));
	padding: min(10vw,80px) 3%;
	margin-inline: auto;
}
.l-info__box iframe {
	display: block;
}
.l-info__box__inner {
	display: grid;
	row-gap: 7vw;
}
.l-info__box address {
	margin: 1.2em 0 1em;
}

.l-info__box__inner .c-txt--radi {
	background-color: var(--color-secondary);
	align-self: center;
}

.l-info .l-bnr-m {
	margin-bottom: 5%;
}
/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {

.l-info__box__inner {
	max-width: 1200px;
	justify-content: space-between;
	grid-template-columns: min(510px,46%) 50%;
	margin-inline: auto;
}
.l-info__box__inner.comingsoon {
	grid-template-columns: 32% 64%;
}

.l-info__box .c-btn-wrap {
	position: absolute;
	width: 100%;
	left: 50%;
	bottom: 0;
	translate: -50% 50%;
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.l-info {
	padding-top: 12%;
}
.l-info__box {
	padding: 10% 5%;
}
.l-info iframe {
	height: 70vw;
}

.l-info .l-bnr-m {
	margin-bottom: 10%;
}
}

/* Layout - Info - access
-----------------------------------------------*/
.l-info__access {
	display: flex;
	flex-wrap: wrap;
	gap: .8em 2em;
	font-size: 88%;
	line-height: 1.4;
	margin-top: 1.4em;
}
.l-info__access > li {
	position: relative;
	padding-left: 1.8em;
}
.l-info__access > li i {
	position: absolute;
	font-size: 115%;
	left: 0;
	top: -0.1em;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.l-info__access {
	font-size: 82%;
	margin-top: 1.2em;
}
}


/*-----------------------------------------------
 Layout - footer
-----------------------------------------------*/
footer {
	position: relative;
	background-color: var(--color-lgry);
}

/* Layout - footer - l-footer__bottom
-----------------------------------------------*/
.l-footer__bottom {
	position: relative;
	text-align: center;
	padding: 60px 0;
}
.l-footer__bottom img {
	margin: auto;
}
/* copyright */
.copyright {
	display: block;
	text-align: center;
	font: var(--font-min);
	font-size: 76%;
	line-height: 1.4;
	letter-spacing: .14em;
	margin-top: 1.5em;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.l-footer__bottom {
	padding: 10% 5% 16vw;
}

.copyright {
	font-size: 60%;
}
}

/*-----------------------------------------------
 Layout - sp_footer
-----------------------------------------------*/
#sp_footer {
	position: fixed;
	width: 100%;
	inset: auto 0 0 0;
	z-index: 501;
}

.l-fixed-cta .c-cta-wrap {
	display: grid;
	grid-template-columns: repeat(3, 33.33%);
	gap: 0;
	box-shadow: 0 0 10px rgba(0,0,0,0.2);
}
.l-fixed-cta .c-cta-btn {
	border-radius: 0;
	box-shadow: none;
}
.l-fixed-cta .c-cta-btn::before {
	min-width: 1.6em;
	min-height: 1.6em;
}

.l-fixed-cta .c-cta-btn--tel {
	color: var(--color-grn);
}
.l-fixed-cta .c-cta-btn--tel::before {
	content: "";
	background-image: url(../images/common/icon-tel.svg);
}

.l-fixed-cta .c-cta-btn--line {
	color: #FFF;
	background-color: #06c755;
}
.l-fixed-cta .c-cta-btn--line::before {
	content: '\e806';
	background: none;
	font-size: 150%;
	translate: 0 0.25em;
}

.l-fixed-cta .c-cta-btn--entry div::after {
	display: block;
	content: "見学・応募";
	font-size: 64%;
	margin-top: .2em;
}
/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {

.l-fixed-cta {
	display: none !important;
}
}

/*-----------------------------------------------
 Layout - FV
-----------------------------------------------*/
.l-fv {
	position: relative;
	width: 100%;
}
.l-fv__img {
	position: relative;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	width: 100%;
	height: 100%;
	inset: 0;
	margin: auto;
}
/* .l-fv__img::before {
	position: absolute;
	content: "";
	background: rgba(0,0,0,0.2);
	width: 100%;
	height: 100%;
	inset: 0;
} */


/*-----------------------------------------------
 Layout - float
-----------------------------------------------*/
.l-flt {
	position: relative;
	text-align: left;
}
.l-flt::after {
	content: "";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}
.l-flt__img {
	position: relative;
	max-width: max-content;
}
.l-flt__img .abs {
	position: absolute;
}

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

.l-flt__img {
	width: 40%;
	margin-bottom: .5em;
}

.l-flt .is-right {
	float: right;
}
.l-flt .is-left {
	float: left;
}

.l-flt__img.is-left {
	margin-right: 5%;
}
.l-flt__img.is-right {
	margin-left: 5%;
}

.l-flt__txt {
	
}
.l-flt__txt .c-heading--min {
	text-align: left;
}
}
/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {

.l-flt__img.is-w {
	width: 45%;
}
.l-flt__txt {
	width: 100% !important;
	float: none;
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.l-flt__img {
	width: 80%;
	margin: 0 auto 6%;
}
.l-flt__img.is-w {
	width: 96%;
}
}

/*-----------------------------------------------
 Layout - box
-----------------------------------------------*/

/* Layout - box - l-box--wide
-----------------------------------------------*/
.l-box--wide {
	position: relative;
	width: 96vw;
	background-color: var(--color-bei);
	padding: 6% 4%;
	left: 50%;
	translate: -50% 0;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.l-box--wide {
	padding: 10% 5%;
}
}

/* Layout - box - l-box--bg
-----------------------------------------------*/
.l-box--bg {
	position: relative;
	background-color: #fff;
	padding: min(6%,60px) 4%;
	margin-inline: auto;
}
.l-box--bg .l-flt {
	margin-inline: auto;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.l-box--bg {
	padding: 8% 6%;
}
}

/* Layout - box - l-boxlist
-----------------------------------------------*/
.l-boxlist {
    display: grid;
	row-gap: 2em;
}
.l-boxlist__img {
	position: relative;
	max-width: max-content;
	margin: 0 auto 5%;
}
/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {

.l-boxlist {
	justify-content: space-between;
	grid-template-columns: repeat(2,min(47%,560px));
	margin-inline: auto;
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

}


/* Layout - l-item-list
-----------------------------------------------*/
.l-item-list {
    display: grid;
    row-gap: 2.5em;
    margin-inline: auto;
}
.l-item-list > * {
	position: relative;
    background-color: var(--color-bei);
    padding: 10%;
    border-radius: 1.2em;
}
.l-item-list .c-heading--min {
	text-align: center;
	color: var(--accent-color);
}
.l-item-list.has-icon .c-heading--min::before {
    display: block;
    content: "";
    background-repeat: no-repeat;
	background-position: center center;
    background-size: contain;
    width: 2.5em;
    height: 2.5em;
    margin: auto;
}

.l-item-list .c-list {
	font-weight: var(--fw-bold);
}
/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {

.l-item-list {
    justify-content: space-between;
}
.l-item-list.col-3 {
    grid-template-columns: repeat(3,31%);
}
.l-item-list.col-4 {
    grid-template-columns: repeat(4,24.2%);
}
.l-item-list.col-4 .c-heading--min {
	font-size: min(2.1vw,176%);
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.l-item-list {
    row-gap: 1em;
}
.l-item-list > * {
    padding: 8%;
}
}


/*-----------------------------------------------
 Layout - l-anchor-list
-----------------------------------------------*/
.l-anchor-list {
	max-width: 660px;
	display: grid;
	justify-content: space-between;
	row-gap: 1.6em;
	font: var(--font-min);
	font-size: 105%;
	margin-inline: auto;
}
.l-anchor-list > li {
	position: relative;
	padding-right: 1.5em;
}
.l-anchor-list a {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	height: 2.7em;
	border-bottom: 1px solid var(--accent-color);
}
.l-anchor-list a:hover {
	color: var(--accent-color);
}
.l-anchor-list .c-icon {
	position: absolute;
	font-size: 120%;
	background-color: var(--accent-color);
	right: 0;
	bottom: 0;
	rotate: 90deg;
}
/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {

.l-anchor-list {
	grid-template-columns: repeat(3,30.4%);
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.l-anchor-list {
	grid-template-columns: repeat(2,48%);
	row-gap: 1em;
	font-size: 95%;
}
}


/*---------------------------------------------------------
 Layout - bnr
---------------------------------------------------------*/
.l-bnr-m {
	display: block;
	width: 45vw;
	max-width: max-content;
	margin-inline: auto;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.l-bnr-m {
	width: 80%;
}
}


/*---------------------------------------------------------
 Layout - modal
---------------------------------------------------------*/
.l-modal {
	width: 94%;
	max-width: 810px;
	background: transparent;
	border: none;
	padding: 0;
	opacity: 0;
	transition:
        opacity .6s,
        translate .6s,
        overlay .6s allow-discrete,
        display .6s allow-discrete;
		overflow: visible;
}
.l-modal[open] {
	opacity: 1;
	translate: 0 0;
	@starting-style {
		opacity: 0;
	}
}
.l-modal::backdrop {
	opacity: 0;
	background: rgba(51,51,51,0.8);
	transition: opacity .6s;
}
.l-modal[open]::backdrop {
	opacity: 1;
	@starting-style {
		opacity: 0;
	}
}

.l-modal__box {
	text-align: center;
	padding: 0 2em;
}

.l-modal button {
	position: relative;
	font-size: 0;
	width: 75px;
	aspect-ratio: 1;
	margin-left: auto;
	margin-bottom: 2%;
}
.l-modal button::before,
.l-modal button::after {
	position: absolute;
	display: block;
	content: "";
	background: #FFF;
	width: 100%;
	height: 1px;
	left: 0;
	top: 50%;
}
.l-modal button::before {
	rotate: 45deg;
}
.l-modal button::after {
	rotate: -45deg;
}
/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {

}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

#modalCont {
	width: 95%;
}

.l-modal button {
	width: 12vw;
	margin-bottom: 2%;
}

.l-modal__box {
	padding: 0;
}
}



/*---------------------------------------------------------
 Layout - l-cta-list
---------------------------------------------------------*/
.l-cta-list {
	display: grid;
	grid-template-columns: repeat(2,49.4%);
	gap: 10px;
}
.l-cta-list > li {
	display: grid;
	grid-template-rows: subgrid;
	grid-row: span 2;
	row-gap: 0;
	background-color: #fff;
	border-radius: 20px;
	padding: 7.5%;
}
.l-cta-list .c-txt--clinic {
	font-size: 105%;
	margin-bottom: .5em;
}
.l-cta-list .c-txt--clinic::before {
	display: block;
	font-family: 'fontello';
	content: '\e800';
	color: var(--accent-color);
	font-size: 220%;
}
/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {

.l-cta-list {
	grid-template-columns: repeat(2,49.4%);
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.l-cta-list > li {
	border-radius: 15px;
	padding: 5% 5% 10%;
}
.l-cta-list .c-txt--clinic {
	font-size: 85%;
}
.l-cta-list .c-txt--clinic span {
	font-size: 120%;
}
}





/* ========================================================
  
  Navigation

======================================================== */

/*-----------------------------------------------
 Navigation - l-nav__list
-----------------------------------------------*/
.l-nav__list {
	position: relative;
	width: 100%;
	height: 5.5em;
	display: flex;
	font: var(--font-min);
	font-size: min(1.8vw,1.05rem);
	letter-spacing: .2em;
	line-height: 1.3;
}
.l-nav__list > li {
	position: relative;
	/* height: 100%; */
}
.l-nav__list > li.menu_hom {
	font: var(--font-en);
}
.l-nav__list > li::after {
	position: absolute;
	content: "";
	background-color: var(--color-grn);
	width: 1px;
	height: 1em;
	left: 100%;
	top: 50%;
	translate: 0 -50%;
	transition: opacity .5s;
}
.l-nav__list > li:hover::after,
.l-nav__list > li.is-active::after,
.l-nav__list > li:last-of-type::after {
	opacity: 0;
}

.l-nav__list > li > a {
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: center;
	height: 100%;
	text-align: center;
	padding: 1em 2em;
	white-space: nowrap;
}
.l-nav__list > li > a:hover,
.l-nav__list > li.is-active > a {
	color: #FFF;
	background-color: var(--color-grn);
}
.l-nav__list > li > a small {
	font-size: 88%;
}

.l-nav .l-nav__list {
	justify-content: center;
}
.l-nav .l-nav__list > li > a {
	min-width: 9.4em;
}

.l-scroll .l-nav__list {
	height: 100%;
	font-size: min(1.3vw,0.94rem);
}


/*-----------------------------------------------
 Navigation - menu
-----------------------------------------------*/

/* Navigation - menu - c-menu--arw
-----------------------------------------------*/
.c-menu--arw {
	display: flex;
	flex-wrap: wrap;
	gap: 1em 2em;
	font-size: 94%;
	line-height: 1.4;
}
.c-menu--arw a {
	position: relative;
	display: block;
	padding-left: 1.4em;
}
.c-menu--arw a::before {
	position: absolute;
	font-family: 'fontello';
	content: '\e801';
	left: 0;
	top: 0;
}
.c-menu--arw a:hover {
	color: var(--color-mgrn);
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.c-menu--arw {
	display: grid;
	grid-template-columns: repeat(2,50%);
	column-gap: 1em;
	font-size: 82%;
	font-feature-settings: "palt"
}
}


/*-----------------------------------------------
 Navigation - bnr
-----------------------------------------------*/

/* Navigation - bnr - com_bnr_insta
-----------------------------------------------*/
.com_bnr_insta a {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	height: 100%;
	text-align: center;
	font-size: min(2.4vw,186%);
	line-height: 1.3;
}
.com_bnr_insta .insta_txt::before {
	display: block;
	content: "";
	background: url(../images/common/icon-instagram@2x.png) no-repeat center center;
	background-size: contain;
	width: 1.5em;
	height: 1.5em;
	margin: 0 auto .6em;
}
.com_bnr_insta b {
	display: block;
	font-size: 46%;
	margin-bottom: .8em;
}
.com_bnr_insta .c-icon {
	font-size: 56%;
	margin: 1em auto 0;
}

.com_bnr_insta a:hover .c-icon {
	background-color: var(--color-pnk);
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.com_bnr_insta a {
	font-size: 4.8vw;
	padding: .5em 5%;
}
.com_bnr_insta b {
	font-size: 60%;
}
/* sp_row */
.com_bnr_insta.sp_row a {
	flex-direction: row;
	column-gap: .5em;
}
.com_bnr_insta.sp_row .insta_txt {
	display: flex;
	align-items: center;
	column-gap: .5em;
}
.com_bnr_insta.sp_row .insta_txt::before {
	margin: 0;
}
.com_bnr_insta.sp_row .c-icon {
	margin: 0;
}
}






/* ========================================================
  
  Component

======================================================== */


/*-----------------------------------------------
 Component - text
-----------------------------------------------*/
.c-txt--link {
	text-decoration: underline;
	text-underline-offset: .1em;
}
.c-txt--link:hover {
	text-decoration: none;
	color: var(--accent-color);
}

.c-txt--asterisk {
	display: block;
	color: #999;
	font-size: 80%;
	line-height: 1.8;
	letter-spacing: .08em;
	margin-top: 1em;
}
ul.c-txt--asterisk {
	display: grid;
	row-gap: .2em;
}

.c-txt--radi {
	position: relative;
	text-align: center;
	font: var(--font-min);
	font-size: min(2vw,129%);
	letter-spacing: .08em;
	line-height: 1.3;
	color: #FFF;
	background-color: var(--accent-color);
	border-radius: 100vmax;
	padding: .8em 1.2em;
	margin-bottom: 1.6em;
}

.c-txt--temp {
	position: relative;
	text-align: center;
	font: var(--font-min);
	letter-spacing: .08em;
	line-height: 1.3;
	color: #FFF;
	background-color: var(--accent-color);
	border-radius: 100vmax;
	padding: .2em 1.2em;
}

.c-txt-center {
	text-align: center;
	font-size: 112%;
	font-weight: var(--fw-bold);
	line-height: 1.8;
	margin-top: 2em;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.c-txt--asterisk {
	font-size: 78%;
	letter-spacing: .04em;
}

.c-txt--radi {
	font-size: 110%;
}

.c-txt-center {
	font-size: 105%;
	line-height: 1.6;
	margin-top: 1.6em;
}
}


/*-----------------------------------------------
 Component - scroll
-----------------------------------------------*/
.scl-area {
	position: relative;

	--scr-bg-color: #d6d4c8;
}
.scl-area__txt {
	text-align: center;
	color: #9194A1;
	font-size: 80%;
	letter-spacing: .1em;
	line-height: 1.4;
	margin-bottom: 1em;
}
/* scrollbar */
.scl-area::-webkit-scrollbar {
	width: 4px;
	height: 4px;
}

.scl-area::-webkit-scrollbar-track {
	background: var(--scr-bg-color);
	border-radius: 2px;
}

.scl-area::-webkit-scrollbar-thumb {
	background-color: var(--accent-color);
	border-radius: 2px;
}

.scl-area::-webkit-scrollbar-thumb:hover {
	background-color: #555;
}

/* Firefox */
@-moz-document url-prefix(){
.scl-area {
	scrollbar-width: thin;         /* auto, thin, none */
	scrollbar-color: var(--accent-color) transparent; /* thumb track */
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.scl-area {
	overflow-x: scroll;
	padding-bottom: 8%;
}
}

/*-----------------------------------------------
 Component - accordion
-----------------------------------------------*/
.c-acd {
	position: relative;
}
.c-acd__trigger {
	position: relative;
	cursor: pointer;
	transition: color .5s, background-color .5s;
}
.c-acd__content {
	display: none;
}
/*c-acd__icon*/
.c-acd__icon {
	position: relative;
	letter-spacing: normal;
	line-height: 1.0em;
	display: inline-block;
	vertical-align: middle;
	width: 1.2em;
	height: 1.2em;
	border-radius: 50%;
	translate: 0 -0.1em;
	transition: background-color .5s;
}
.c-acd__icon::before,
.c-acd__icon::after {
	content: "";
	position: absolute;
	width: .6em;
	height: 1px;
	background: currentcolor;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;
}
.c-acd__icon::after {
	transform: rotate(90deg);
	transition: transform 0.4s;
}
.is-active .c-acd__icon::after {
	transform: rotate(0deg);
}

/*-----------------------------------------------
 Component - hover
-----------------------------------------------*/
.c-hover--zoom {
	position: relative;
	overflow: hidden;
}
.c-hover--zoom img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: translateZ(0);
	transition: scale .6s;
}
a:hover .c-hover--zoom img {
	scale: 1.08;
}


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

/* Component - contact - c-cta-tel
-----------------------------------------------*/
.c-cta-tel {
	position: relative;
	font: var(--font-no);
	font-size: min(3.6vw,217%);
	letter-spacing: .05em;
	white-space: nowrap;
}
.c-cta-tel::before {
	font-family: 'fontello';
	content: '\e805';
	font-size: 60%;
	font-weight: normal;
	vertical-align: 0.15em;
	margin-right: .3em;
}

.c-cta-tel .c-txt--temp {
	position: absolute;
	font-size: 35%;
	inset: 50% auto auto 50%;
	translate: -50% -50%;
}
.c-cta-tel:has(.c-txt--temp) {
	pointer-events: none;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.c-cta-tel {
	font-size: 5.2vw;
}
}

/* Component - contact - c-cta-btn
-----------------------------------------------*/
.c-cta-btn {
	position: relative;
	width: 100%;
	min-width: 9.5em;
	max-width: 100%;
	height: 3.9em;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	gap: .4em;
	color: var(--color-base);
	font: var(--font-min);
	font-size: min(2vw,135%);
	letter-spacing: .1em;
	line-height: 1.2;
	white-space: nowrap;
	background-color: #FFF;
	border-radius: 100vmax;
	padding: .2em 2em;
	box-shadow: 0 0 5px rgba(0,0,0,0.2);
	transition: color .6s, background-color .6s;
}
.c-cta-btn::before {
	display: inline-block;
	content: "";
	font-family: 'fontello';
	font-weight: normal;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	min-width: 1em;
	min-height: 1em;
}
.c-cta-btn span {
	font: var(--font-en);
	letter-spacing: .2em;
}
.c-cta-btn:hover {
	color: #FFF;
	background-color: var(--color-grn);
}

.c-cta-btn--tel::before {
	font-family: 'fontello';
	content: '\e805';
}

.c-cta-btn--line::before {
	background-image: url(../images/common/icon-line.svg);
}

.c-cta-btn--entry {
	color: #FFF;
	background-color: var(--color-brw-600);
}
.c-cta-btn--entry::before {
	position: absolute;
	background: radial-gradient(rgba(255,255,255,0.15), rgba(255,255,255,0));
	width: 100%;
	height: 100%;
	clip-path: polygon(100% 0, 100% 100%, 0 100%);
	inset: 0;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.c-cta-btn {
	flex-direction: row;
	width: auto;
	font-size: 3.5vw;
}
}

/* Component - contact - c-cta-wrap
-----------------------------------------------*/
.c-cta-wrap {
	position: relative;
	width: 100%;
	max-width: 800px;
	display: flex;
	align-items: center;
	column-gap: 3%;
}
.c-cta-wrap > div {
	flex: 1;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.c-cta-wrap {
	justify-content: center;
	gap: .8em;
}
}


/*-----------------------------------------------
 Component - title
-----------------------------------------------*/
.c-title--enjp {
	text-align: center;
	margin-bottom: 5%;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

}


/*-----------------------------------------------
 Component - heading
-----------------------------------------------*/

/* c-heading--min */
.c-heading--min {
	position: relative;
	font: var(--font-min);
	font-size: min(176%,2.8vw);
	line-height: 1.4;
	letter-spacing: .16em;
	margin-bottom: .6em;
}
.c-heading--min small {
	display: inline-block;
	font-size: 85%;
}

/* c-heading--var */
.c-heading--var {
	position: relative;
	font: var(--font-min);
	font-size: min(2vw,117%);
	line-height: 1.5;
	letter-spacing: .16em;
	white-space: nowrap;
	writing-mode: vertical-rl;
}
.c-heading--var > span span {
	color: var(--accent-color);
}

/* c-heading--bg */
.c-heading--bg {
	position: relative;
	text-align: center;
	color: #FFF;
	font: var(--font-min);
	font-size: min(211%,2.8vw);
	line-height: 1.3;
	letter-spacing: .16em;
	background-color: var(--accent-color);
	padding: .8em 1em;
	margin-bottom: 1.2em;
}

.c-heading--bdr {
	position: relative;
	text-align: center;
	font: var(--font-min);
	font-size: min(3.2vw,264%);
	line-height: 1.4;
	letter-spacing: .06em;
	padding-bottom: .8em;
	margin-bottom: 1em;
	border-bottom: 1px solid currentColor;
}

.c-heading--bbl {
	position: relative;
	text-align: center;
	color: var(--color-nvy);
	font: var(--font-min);
	font-size: min(2.8vw,188%);
	line-height: 1.5;
	letter-spacing: .04em;
	/* color: var(--color-base); */
	background-color: #fff;
	border-radius: .6em;
	padding: .6em 1em;
	margin-bottom: .6em;
	box-shadow: 0 0 7px rgba(0,0,0,0.1);
}
.c-heading--bbl small {
	font-size: 82%;
}
.c-heading--bbl span {
	color: var(--color-taq);
}
.c-heading--bbl::before {
	position: absolute;
	content: "";
	background-color: inherit;
	width: 1em;
	height: .7em;
	clip-path: polygon(0 0, 100% 0, 50% 100%);
	inset: auto 0 -0.6em 0;
	margin: auto;
}

.c-heading--bld {
	position: relative;
	font-size: min(2.4vw,164%);
	font-weight: var(--fw-bold);
	line-height: 1.5;
	letter-spacing: .12em;
	margin-bottom: .5em;
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.c-heading--min {
	font-size: 130%;
	line-height: 1.5;
	letter-spacing: .08em;
}

.c-heading--var {
	font-size: 3.4vw;
}

.c-heading--bg {
	font-size: 130%;
	letter-spacing: .1em;
}

.c-heading--bbl {
	font-size: 120%;
}

.c-heading--bdr {
	font-size: 130%;
}

.c-heading--bld {
	font-size: 115%;
	letter-spacing: .05em;
}
}

/* Component - heading - deco
-----------------------------------------------*/
.c-heading--en {
	position: relative;
	color: var(--color-bei-600);
	color: var(--accent-color);
	font: var(--font-en);
	font-size: min(2.6vw,1.7rem);
	letter-spacing: .18em;
	margin-bottom: 1em;
}
.c-heading--en:last-child {
	margin-bottom: 0;
}

.c-heading--deco {
	position: relative;
	display: inline-block;
	color: #FFF;
	font: var(--font-en);
	font-size: min(7vw,4.7rem);
	letter-spacing: .15em;
	white-space: nowrap;
	margin-bottom: .2em;
}
.c-heading--deco.bg-grd {
	background-color: var(--color-gry-100);
	background-image: radial-gradient(var(--color-primary-400), rgba(250,237,0,0));
    background-position: left -0.6em center;
    background-size: 2em auto;
    background-repeat: no-repeat;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.c-heading--en {
	font-size: 3.5vw;
	margin-bottom: .8em;
}
.c-heading--deco {
	font-size: 10vw;
}

.c-heading--en.u-size-20 {
	font-size: 3vw;
}
}

/* Component - heading - size
-----------------------------------------------*/
.u-size-20 {font-size: min(2vw,117%);}
.u-size-25 {font-size: min(2.2vw,147%);}
.u-size-35 {font-size: min(3.2vw,205%);}
.u-size-40 {font-size: min(3.5vw,235%);}
.u-size-45 {font-size: min(4vw,264%);}
.u-size-50 {font-size: min(4.4vw,333%);}
.u-size-60 {font-size: min(5.2vw,352%);}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.u-size-20 {font-size: 115%;}
.u-size-25 {font-size: 120%;}
.u-size-35 {font-size: 135%;}
.u-size-40 {font-size: 140%;}
.u-size-45 {font-size: 145%;}
.u-size-50 {font-size: 160%;}
.u-size-60 {font-size: 165%;}
}


/*-----------------------------------------------
 Component - text_deco
-----------------------------------------------*/
.c-txt--marker {
	position: relative;
}
.c-txt--marker::before {
	position: absolute;
	content: "";
	background-color: rgba(57,158,177,0.2);
	width: 100%;
	height: .25em;
	border-radius: .2em;
	left: 0;
	bottom: -0.18em;
}
/*c-txt--fukidashi*/
.c-txt--fukidashi {
	position: relative;
	text-align: center;
	max-width: max-content;
	letter-spacing: .12em;
	line-height: 1.5;
	margin: 0 auto 1.5em;
}
.c-txt--fukidashi::before,
.c-txt--fukidashi::after {
	position: absolute;
	display: inline-block;
	content: "";
	background-color: currentColor;
	width: 1px;
	height: 1.2em;
	bottom: 0;
}
.c-txt--fukidashi::before {
	rotate: -32deg;
	right: calc(100% + 1em);
}
.c-txt--fukidashi::after {
	rotate: 32deg;
	left: calc(100% + 1em);
}
/*c-txt--circle */
.c-txt--circle {
    position: relative;
    display: flex;
	flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
	/* font-size: min(2vw,1.35rem); */
    letter-spacing: .1em;
    line-height: 1.6;
    width: min(9.5em);
	min-width: 9.5em;
	aspect-ratio: 1;
    border-radius: 50%;
	transition-duration: .5s;
	transition-property: color, background-color, scale;
}
.c-txt--circle.pdg_t {
	padding-top: .5em;
}
.c-txt--circle .c-icon {
	margin-top: .4em;
	margin-bottom: -0.8em;
}
a.c-txt--circle:hover {
	background-color: var(--color-brw-600);
}
a.c-txt--circle:hover .c-icon {
	color: var(--color-brw-600);
	background-color: #FFF;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
/*c-txt--fukidashi*/
.c-txt--fukidashi {
	font-size: 120%;
	letter-spacing: .1em;
}
}


/*-----------------------------------------------
 Component - list
-----------------------------------------------*/
.c-list {
	display: grid;
	row-gap: .4em;
	text-align: left;
	line-height: 1.5;
}
.c-list > li {
	position: relative;
	padding-left: 1.4em;
}
.c-list > li::before {
	position: absolute;
	content: "";
	font-family: 'fontello';
	font-weight: normal;
	left: 0;
	top: 0;
}

.c-list--point > li::before {
	display: block;
	background-color: var(--accent-color);
	width: .3em;
	height: .3em;
	border-radius: 50%;
	left: .5em;
	top: .6em;
}

.c-list--dot > li::before {
	content: "・";
}

.c-list--check > li::before {
	content: '\e808';
	color: var(--accent-color);
}

.c-list--ast {
	margin-top: 1em;
}
.c-list--ast > li {
	padding-left: 1.2em;
}
.c-list--ast > li::before {
	content: "＊";
}
/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {

.c-list--col2 {
	column-count: 2;
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.c-list {
	row-gap: .4em;
}

.aster_list {
	font-size: 90%;
}
}


/*-----------------------------------------------
 Component - bg
-----------------------------------------------*/
.c-bg-color {
	position: absolute;
	background-color: #f7f7f7;
	background-repeat: no-repeat;
	background-size: contain;
	width: 100vw;
	height: 100%;
	left: 0;
	top: 0;
	margin-inline: calc(50% - 50vw);
	z-index: -2;
	overflow: clip;
	pointer-events: none;
}

.c-bg-img {
	position: absolute;
	height: auto;
	max-height: 100%;
	top: 0;
	z-index: -2;
	overflow: clip;
}
.c-bg-img img {
	width: 100%;
    height: 100%;
    object-fit: cover;
	object-position: center center;
	pointer-events: none;
}
.c-bg-img.size__max {
	width: 100vw;
	-webkit-mask-image: linear-gradient(to top, transparent 10%, black 80%);
	mask-image: linear-gradient(to top, transparent 10%, black 80%);
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-size: auto;
    mask-size: auto;
	left: calc(50% - 50vw);
}

.c-bg-img.pos-l,
.c-bg-img.pos-r {
	width: 50vw;
	max-width: 680px;
	color: var(--color-bei);
	/* --color-bg: currentColor; */
	background-color: currentColor;
}
.c-bg-img.pos-l::after,
.c-bg-img.pos-r::after {
	position: absolute;
	content: "";
	width: 101%;
	height: 101%;
	inset: 0;
	pointer-events: none;
	background:
		linear-gradient(to right, transparent 30%, currentColor 100%),
		linear-gradient(to bottom, transparent 50%, currentColor 100%);
	/* background:
		linear-gradient(to right, transparent 30%, currentColor 100%),
		linear-gradient(to top, transparent 50%, currentColor 100%),
		linear-gradient(to bottom, transparent 50%, currentColor 100%); */
}
.c-bg-img.pos-l {
	left: calc(50% - 50vw);
}
.c-bg-img.pos-r {
	left: auto;
	right: calc(50% - 50vw);
}
.c-bg-img.pos-r::after {
	scale: -1 1;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.c-bg-img.pos-l,
.c-bg-img.pos-r {
	width: 70vw;
}
.c-bg__wave.pos-r {
	right: 0;
	top: 60px;
}
}

/*-----------------------------------------------
 Component - c-icon
-----------------------------------------------*/
.c-icon {
    position: relative;
	display: inline-block;
    text-align: center;
	letter-spacing: normal;
	color: #FFF;
	line-height: 1.2;
	background-color: var(--color-base);
    border-radius: 50%;
    width: 1.2em;
	height: 1.2em;
	transition: color .4s, background-color .4s;
}
.c-icon::before {
	position: absolute;
	display: block;
	font-family: 'fontello';
	content: '\e801';
	font-weight: normal;
	text-align: center;
	width: 100%;
	left: 0;
	top: 0;
}
.c-icon.wh {
	color: var(--color-base);
	background-color: #FFF;
}
.c-icon.out::before {
	content: '\e803';
	padding: 0;
	padding-top: .06em;
}

/*-----------------------------------------------
 Component - link
-----------------------------------------------*/

/* Component - link - com_btn__radi
-----------------------------------------------*/
.c-btn-radi {
	margin-top: 1.6em;
}
.c-btn-radi > a {
	position: relative;
	width: 15em;
	max-width: 100%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: .4em;
	color: #FFF;
	font: var(--font-min);
	font-size: min(1.8vw,1.17rem);
	letter-spacing: .15em;
	line-height: 1.2;
	background-color: var(--accent-color);
	padding: .9em 1em;
	border-radius: 100vmax;
}

.c-btn-radi .c-icon {
	color: var(--color-base);
	background-color: #FFF;
}
.c-btn-radi > a:hover {
	background-color: var(--color-brw-600);
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.c-btn-radi {
	text-align: center;
	margin-top: 1em;
}
.c-btn-radi > a {
	height: 3.2em;
	font-size: 100%;
}
}

/* Component - link - com_btn__icon
-----------------------------------------------*/
.c-btn-icon {
	margin-top: 1em;
}
.c-btn-icon > a {
	position: relative;
	display: inline-block;
	color: #FFF;
	font: var(--font-min);
	font-size: min(1.6vw,1rem);
	letter-spacing: .12em;
	line-height: 1.2;
	white-space: nowrap;
	background-color: var(--color-brw-600);
	padding: .7em 1.6em;
	border-radius: 100vmax;
}
.c-btn-icon a::before {
	content: "";
	background-repeat: no-repeat;
	background-size: contain;
	width: 1.2em;
	height: 1.2em;
	vertical-align: -0.25em;
	margin-right: .4em;
}
.c-btn-icon > a:hover {
	background-color: var(--color-grn);
}
.c-btn-icon--insta a::before {
	display: inline-block;
	background-image: url(../images/common/icon-insta@2x.png);
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.c-btn-icon {
	text-align: center;
	margin-top: 1em;
}
.c-btn-icon a {
	font-size: 3.4vw;
}
}

/* Component - link - c-btn-wrap
-----------------------------------------------*/
.c-btn-wrap {
	display: flex;
	flex-wrap: wrap;
	gap: 1em 1.2%;
	margin-top: 1.4em;
}
.c-btn-wrap > * {
	margin-top: 0;
}
.c-btn-wrap.is-center {
	justify-content: center;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.c-btn-wrap {
	justify-content: center;
	row-gap: .6em;
}
}


/*---------------------------------------------------------
 Component - info
---------------------------------------------------------*/
.c-address {
	font-size: 88%;
	line-height: 1.8;
	letter-spacing: .1em;
}
.c-txt--clinic {
	font: var(--font-min);
	font-size: min(2.4vw,147%);
	letter-spacing: .08em;
	line-height: 1.4;
	margin-bottom: .4em;
}
.c-txt--clinic span {
	display: block;
	font-size: 140%;
	letter-spacing: .18em;
	margin-top: .1em;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.c-address {
	font-size: 90%;
	line-height: 1.6;
	letter-spacing: .1em;
}
.c-txt--clinic {
	font-size: 120%;
	letter-spacing: .06em;
}
}

/* Component - info - c-timetable
-----------------------------------------------*/
.c-timetable_wrap {
	max-width: 480px;
	background-color: #fff;
	padding: 3% 5% 5%;
	border-radius: 10px;
}

.c-timetable {
	width: 100%;
	max-width: 390px;
	font-size: min(1.5vw,1.06rem);
	line-height: 1.2;
	border-collapse: separate;
	border-spacing: 0 1em;
	margin-inline: auto
}
.c-timetable thead,
.c-timetable tbody {
	color: var(--color-base);
}
.c-timetable th,
.c-timetable td {
	text-align: center;
	font-weight: var(--fw-bold);
	vertical-align: middle;
	white-space: nowrap;
}
.c-timetable th {
	width: 34%;
	letter-spacing: .14em;
}
.c-timetable td {
	width: 9.4%;
}
.c-timetable thead th {
	letter-spacing: .4em;
}
.c-timetable tbody th {
	font: var(--font-en);
	font-size: 107%;
	letter-spacing: .04em;
}
.c-timetable tbody td {
	font-size: 86%;
	font-weight: normal;
	vertical-align: middle;
}
.c-timetable tbody td.closed {
	color: #a19f9f;
}
.c-timetable caption {
	caption-side: bottom;
	white-space: wrap;
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.c-timetable {
	font-size: 3.2vw;
	padding: 2% 3%;
}
}

/* Component - info - c-schedule
-----------------------------------------------*/
.c-schedule {
	display: flex;
	flex-wrap: wrap;
	gap: .5em 1em;
	font-size: 88%;
	line-height: 1.4;
	letter-spacing: .12em;
	margin-top: 1em;
}
.c-schedule span {
	color: var(--color-grn);
}
.c-timetable .c-schedule {
	font-size: min(1.5vw,1rem);
	margin-top: .2em;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.c-schedule {
	row-gap: .3em;
	font-size: 82%;
	letter-spacing: .06em;
	font-feature-settings: "halt";
	margin-top: .8em;
}
}


/*---------------------------------------------------------
 Component - slider
---------------------------------------------------------*/
.c-slide--ticker .splide__track {
	overflow: visible;
}
.c-slide--ticker .splide__slide {
	width: 27vw;
	max-width: max-content;
}
.c-slide--ticker.is-large .splide__slide {
	width: 41vw;
}
/* dot */
.c-slide--fade .splide__pagination {
	gap: 14px;
	margin-top: 15px;
}
.c-slide--fade .splide__pagination button {
	display: block;
	background-color: #FFF;
	border: none;
	border-radius: 50%;
	width: 7px;
	height: 7px;
	padding: 0;
	opacity: 0.4;
	transition: opacity .5s;
	cursor: pointer;
	outline: none;
}
.c-slide--fade .splide__pagination button.is-active,
.c-slide--fade .splide__pagination button:hover {
	opacity: 1;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.c-slide--ticker .splide__slide {
	width: 50vw;
}
.c-slide--ticker.is-large .splide__slide {
	width: 60vw;
}
}


/*-----------------------------------------------
 Component - decoration
-----------------------------------------------*/
.c-deco--underline {
	position: relative;
	max-width: max-content;
}
.c-deco--underline::before {
	position: absolute;
	content: "";
	background-color: var(--color-primary-400);
	width: 100%;
	height: 5px;
	rotate: -5deg;
	inset: auto 0 0.2em 0;
}
.c-deco--underline > * {
	position: relative;
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {


}



/* ========================================================
  
  Animation

======================================================== */
.u-anm--fade,
.u-anm--fadelist > li {
	opacity: 0;
	transition: opacity 2s ease;
}
.is-animated .u-anm--fade,
.is-animated.u-anm--fade,
.u-anm--fadelist.is-animated > li {
	opacity: 1;
}
.u-anm--fadelist > li:nth-of-type(2) {transition-delay: .2s}
.u-anm--fadelist > li:nth-of-type(3) {transition-delay: .4s}
.u-anm--fadelist > li:nth-of-type(4) {transition-delay: .6s}
.u-anm--fadelist > li:nth-of-type(5) {transition-delay: .8s}
.u-anm--fadelist > li:nth-of-type(6) {transition-delay: 1.0s}
.u-anm--fadelist > li:nth-of-type(7) {transition-delay: 1.2s}

.u-anm--up {
	opacity: 0;
	translate: 0 10px;
	transition: opacity 1s .2s, translate 1s .2s;
}
.is-animated .u-anm--up,
.is-animated.u-anm--up{
	opacity: 1;
	translate: 0 0;
}

.u-anm--zoom {
	opacity: 0;
	scale: 0.8;
	transition: scale 1s .3s, opacity 1s .4s;
}
.is-animated .u-anm--zoom,
.is-animated.u-anm--zoom {
	opacity: 1;
	scale: 1;
}

.u-anm--clip {
	clip-path: inset(50% round 1rem);
}
.is-animated .u-anm--clip,
.is-animated.u-anm--clip {
	animation: CLIP_SHOW_FROM_CENTER 1s cubic-bezier(.87, 0, .13, 1) .2s forwards;
}

.u-anm--txt {
	display: inline-block;
}
.u-anm--txt > * {
	display: inline-block;
	width: 0;
	overflow: hidden;
}
.u-anm--txt.is-animated > * {
	animation: TEXT_SHOW_CLIP 1s linear forwards;
}

@keyframes CLIP_SHOW_FROM_CENTER {
    0% {
        clip-path: inset(50%);
    }

    99% {
        clip-path: inset(0);
    }

    to {
        clip-path: none;
    }
}

@keyframes CLIP_SHOW_FROM_CENTER_ROUND {
    0% {
        clip-path: inset(50% round 1rem)
    }

    15% {
        clip-path: inset(0 round 1rem)
    }

    90% {
        clip-path: inset(0 round 1rem)
    }

    to {
        clip-path: inset(50% round 1rem)
    }
}

@keyframes TEXT_SHOW_CLIP {
	from {
		width: 0%;
	}
	to {
		width: 100%;
	}
}
@keyframes TEXT_SHOW_CLIP_VERTICAL {
	from {
		height: 0%;
	}
	to {
		height: 100%;
	}
}
/*PC,Tablet
------------------------------------------*/
@media only screen and (min-width: 768px) {

.u-anm--up:nth-of-type(2),
.u-anm--fade:nth-of-type(2) {transition-delay: .2s}
.u-anm--up:nth-of-type(3),
.u-anm--fade:nth-of-type(3) {transition-delay: .4s}
}

/* Animation: c-txt--split
---------------------------------------------------------*/
.c-txt--split span {
	display: inline-block;
	opacity: 0;
	transition: opacity 0.6s cubic-bezier(0.77, 0, 0.175, 1);
	will-change: opacity;
}
.c-txt--split.is-animated span {
	opacity: 1;
}



/* ========================================================
  
  Utility

======================================================== */
/* font */
.u-font-min {
	font-family: "Shippori Mincho", serif;
	font-weight: 400;
	letter-spacing: .06em;
}
.u-font-en {
	font: var(--font-en);
	letter-spacing: .1em;
	line-height: 1;
	font-optical-sizing: auto;
}

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

/* Font-weight */
.u-fz-sm{font-size: 94%;}
.u-fz-lg{font-size: 112%;}

/* Text-align */
.u-align-l{text-align:left;}
.u-align-r{text-align:right;}
.u-align-c{text-align:center;}
.u-align-l-sp{text-align:center;}

/* Block-link */
.blocklink,
.blocklink_out,
.blocklink_ank{
	cursor:pointer;
}

/* text color */
.u-color-accent { color: var(--accent-color);}
.u-color-grn { color: var(--color-grn);}
.u-color-red { color: var(--color-red);}
.u-color-wine { color: var(--color-wine);}

/* background color */
.u-bg-wh {background-color: #fff;}
.u-bg-ivo {background-color: var(--color-ivo);}
.u-bg-bei {background-color: var(--color-bei);}

/* img */
img.size-max {width: 100%;}

/* radius */
.u-rounded-full {border-radius:50%;}
.u-rounded-10px {border-radius: 10px;}
.u-rounded-20px {border-radius: min(2.4vw,20px);}
.u-rounded-30px {border-radius: min(2.6vw,30px);}
.u-rounded-50px {border-radius: clamp(30px,4.5vw,50px);}
.u-rounded-60px {border-radius: clamp(40px,5vw,60px);}


/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {

/* Font-weight */
.u-fz-lg{font-size: 105%;}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

/* Text-align */
.u-align-l-sp{text-align:left;}

/* Font-weight */
.u-fz-sm{font-size: 90%;}
.u-fz-lg{font-size: 100%;}
}


/*-----------------------------------------------
 Utility - border/padding
-----------------------------------------------*/
.u-pdg-s,
.u-pdg-m,
.u-pdg-l {
	position: relative;
}
.u-pdg-s {
	padding: min(6vw,80px) 0;
}
.u-pdg-m {
	padding: min(8vw,100px) 0;
}
.u-pdg-l {
	padding: min(10vw,120px) 0;
}

.u-border-btm {
	padding-bottom: min(6%,60px);
	margin-bottom: min(6%,60px);
	border-bottom: 1px solid var(--color-bdr);
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.u-pdg-s {
	padding: 10% 0;
}
.u-pdg-m {
	padding: 12% 0;
}
.u-pdg-l {
	padding: 15% 0;
}
.u-border-btm {
	padding-bottom: 10%;
	margin-bottom: 10%;
	border-width: 1px;
}
}


/*---------------------------------------------------------
 anchor
---------------------------------------------------------*/
/* [id] {
	position: relative;
} */
/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {
[id] {
	scroll-margin-top: min(14vw,100px);
}
}

/*---------------------------------------------------------
 Utility - width
---------------------------------------------------------*/
.max_width,
.w1440,.w1400,
.w1360,.w1340,.w1300,
.w1280,.w1240,.w1200,
.w1100 {
	box-sizing: content-box;
	width: 92%;
	padding: 0 4%;
	margin-inline: auto;
}
.max_1500 {
	max-width: 1500px;
	margin-inline: auto;
}
.w1440 {max-width: 1440px;}
.w1400 {max-width: 1400px;}
.w1360 {max-width: 1360px;}
.w1340 {max-width: 1340px;}
.w1300 {max-width: 1300px;}
.w1280 {max-width: 1280px;}
.w1240 {max-width: 1240px;}
.w1200 {max-width: 1200px;}
.w1100 {max-width: 1100px;}

.u-inner {
	width: 96%;
	max-width: 1200px;
	margin-inline: auto;
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.max_width,
.w1440,.w1400,
.w1360,.w1340,.w1300,
.w1280,.w1260,.w1200,
.w1100 {
	width: 90%;
	padding: 0 5%;
}
}

/*---------------------------------------------------------
margin
---------------------------------------------------------*/
.u-mb-xl {margin-bottom: 150px;}
.u-mb-lg {margin-bottom: 120px;}
.u-mb-md {margin-bottom: 100px;}
.u-mb-sm {margin-bottom: 80px;}
.u-mb-xs {margin-bottom: 60px;}
.mgn_b_1em {margin-bottom: 1em;}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {

.u-mb-xlg {margin-bottom: 12%;}
.u-mb-lg {margin-bottom: 10%;}
.u-mb-md {margin-bottom: 8%;}
.u-mb-sm {margin-bottom: 7%;}
.u-mb-xs {margin-bottom: 5%;}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.u-mb-xlg {margin-bottom: 15%;}
.u-mb-lg {margin-bottom: 14%;}
.u-mb-md {margin-bottom: 12%;}
.u-mb-sm {margin-bottom: 10%;}
.u-mb-xs {margin-bottom: 8%;}
}


/* PC
------------------------------------------*/
@media only screen and (min-width: 960px)  {
.tb_only{display:none !important;}
.sp_only{display:none !important;}
.sp_tb{display:none !important;}
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.pc_only{display:none !important;}
.sp_only{display:none !important;}
.sp_pc{display:none !important;}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.pc_only{display:none !important;}
.tb_only{display:none !important;}
.tb_pc{display:none !important;}
}
