/* 
 TOP
----------------------------------------------------------- */ 
.fv{
	width:100%;
	height:100vh;
	position: relative;
	z-index: 0;
	background: url("../img/top/top-fv01.webp") center center / cover no-repeat;
}
.fv::before{
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-image: linear-gradient(to bottom, rgba(21,75,10,0.2) 0%, rgba(13,52,70,0.2) 40%, rgba(9,39,53,0.3) 60%, rgba(5,28,39,0.5) 100%);
	z-index: 1;
	pointer-events: none;
}
.fv-list{
	position: relative;
	z-index: -1;
}
.fv-list__item picture {
	height: 100%;
	width: 100%;
}
.fv-list__item img {
	transform: scale(1.1);
	transition: transform 10s linear;
	height: 100%;
	width: 100%;
	object-fit: cover;
}
.swiper-slide-active.fv-list__item img {
	transform: scale(1);
}
.fv-pagination {
	display: flex;
	gap: 12px;
	position: absolute;
	bottom: clamp(15px, 2vw, 40px);
	left: 3.5%;
	z-index: 10;
}
.fv-pagination__dot {
	width: 24px;
	height: 24px;
	position: relative;
}
.fv-pagination__dot::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: #fff;
}
.fv-pagination__dot svg {
	width: 100%;
	height: 100%;
	transform: rotate(-90deg);
}
.fv-pagination__dot circle {
	fill: none;
	stroke: transparent;
	stroke-width: 2;
	stroke-dasharray: 113;
	stroke-dashoffset: 0;
}
.fv-pagination__dot.is-active circle {
	stroke: #fff;
	stroke-dashoffset: 113;
	animation: dot-progress 10s linear forwards;
}
@keyframes dot-progress {
	to {
		stroke-dashoffset: 0;
	}
}
.fv-catch{
	position: absolute;
	left: 3.5%;
	bottom: clamp(60px, 4.7vw, 90px);
	z-index: 1;
	color: #fff;
}
.fv-catch__text{
	font-family: var(--font-mincho);
	font-size: clamp(18px, 1.5vw, 28px);
	margin-bottom: clamp(10px, 1.8vw, 35px);
	line-height: 1.6;
	opacity: 0;
	transform: translateX(-20px);
	transition: opacity var(--trans-slow), transform var(--trans-slow);
}
.fv-catch__text.is-show {
	opacity: 1;
	transform: translateX(0);
}
.fv-catch__title{
	font-family: var(--font-en);
	line-height: 1.1;
	font-size: clamp(40px, 6.2vw, 120px);
	visibility: hidden;
}
.fv-catch__title.is-ready {
	visibility: visible;
}
.fv-catch__title span {
	display: inline-block;
	opacity: 0;
	transform: translateX(-10px);
	transition: opacity var(--trans-slow), transform var(--trans-slow);
}
.fv-catch__title span.is-show {
	opacity: 1;
	transform: translateX(0);
}
.fv-surgery{
	position: absolute;
	right: 0;
	top: 0;
	height: 100vh;
	z-index: 1;
	background-color: rgba(255,255,255,0);
	-webkit-backdrop-filter: blur(25px) brightness(1.1);
	backdrop-filter: blur(25px) brightness(1.1);
	min-width: 250px;
}
@media screen and (max-height: 799px) {
	.fv-surgery{
		display: none;
	}
}
.fv-surgery__list{
	display: flex;
	flex-direction: column;
	margin-top: 100px;
	height: calc(100% - 100px);
}
.fv-surgery__item{
	border-top: 1px solid rgba(195,209,215,0.5);
	padding: 20px clamp(20px, 1.6vw, 30px);
	color: #fff;
	display: flex;
	align-items: center;
	flex-direction: column;
	justify-content: center;
	flex: 1;
}
.fv-surgery__item:last-child{
	padding: clamp(20px, 1.6vw, 30px);
	flex: none;
}
.fv-surgery__text{
	font-weight: 500;
	font-size: var(--fontsize-17);
	width: 100%;
}
.fv-surgery__text::before{
	content: "｛";
}
.fv-surgery__text::after {
	content: "｝";
}
.fv-surgery__total{
	text-align: center;
	width: 100%;
}
.fv-surgery__number{
	font-family: var(--font-en);
	font-size: clamp(50px, 4.4vw, 85px);
	line-height: 1;
}
.fv-surgery__unit{
	font-size: clamp(20px, 1.5vw, 28px);
	font-family: var(--font-mincho);
	padding-left: 10px;
}
.fv-surgery-links{
	width: 100%;
}
.fv-surgery-links__item:not(:last-child){
	margin-bottom: 15px;
}
.fv-surgery-links__link{
	display: flex;
	position: relative;
	background-color: rgba(16,60,80,0.4);
	padding: 9px 20px;
	border-radius: 6px;
	color: #fff;
	font-size: var(--fontsize-15);
	font-weight: 500;
	align-items: center;
	width: 100%;
	transition: background-color var(--trans-base);
}
.fv-surgery-links__link:hover{
	background-color: rgba(16,60,80,0.8);
}
.fv-surgery-links__icon{
	margin-right: clamp(10px, 1vw, 20px);
}
.fv-surgery-links__icon svg{
	height: 23px;
	width: auto;
	overflow: inherit;
}
.fv-surgery-links__arrow{
	position: absolute;
	right: 16px;
	top: 50%;
	transform: translateY(-50%);
}
.fv-surgery-links__arrow svg{
	width: 16px;
	transform: rotate(-90deg);
}
.fv-surgery-links__arrow svg path{
	fill: #fff;
}
.about{
	padding-block: clamp(40px, 4.1vw, 80px) clamp(40px, 4.9vw, 95px);
}
.about__flex{
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	margin-bottom: 12px;
}
.about__heading{
	background-color: var(--bg-color);
	border-radius: 15px;
	width: clamp(200px, 13.5vw, 260px);
	padding-block: clamp(30px, 2.9vw, 55px);
}
.about__title{
	padding-left: 70px;
	font-family: var(--font-en);
	font-size: 29px;
	position: relative;
}
.about__title::before{
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	height: 1px;
	width: 45px;
	background-color: var(--font-pale);
}
.about__title::after{
	content: "";
	position: absolute;
	left: 43px;
	top: 50%;
	transform: translateY(-50%);
	width: 6px;
	height: 6px;
	border-radius: 3px;
	background-color: var(--font-pale);
}
.about__link{
	background-color: var(--bg-color);
	border-radius: 15px;
	flex: 1;
	padding: clamp(25px, 2.6vw, 50px) clamp(25px, 2.6vw, 50px) clamp(20px, 2vw, 40px) clamp(30px, 4.1vw, 80px);
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	background-image: url("../img/top/about-link-bg.svg");
	background-position: top right 9%;
	background-repeat: no-repeat;
	background-size: auto 100%;
	transition: background-color var(--trans-base);
	border: 1px solid var(--bg-color);
	flex-wrap: wrap;
	gap: 10px; 
}
@media (hover: hover) {
	.about__link:hover{
		background-color: var(--pale-color);
	}
}
.about__link .c-view{
	margin-left: auto;
}
.about__text{
	font-family: var(--font-mincho);
	line-height: 1.6;
}
.about__text-sub{
	font-size: clamp(23px, 1.7vw, 33px);
}
.about__text-main{
	font-size: clamp(20px, 1.5vw, 28px);
}
.about__text-main > span{
	font-size: clamp(35px, 2.6vw, 50px);
}
.about__list{
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(2, 1fr);
}
.about__item{
	border-radius: 15px;
	background-color: var(--bg-color);
	padding: 24px clamp(25px, 2.6vw, 50px) 24px clamp(20px, 2vw, 40px);
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	background-image: url("../img/top/achievements-double.svg");
	background-position: left clamp(30px, 3.4vw, 65px) center;
	background-size: clamp(60px, 6.2vw, 120px) auto;
	background-repeat: no-repeat;
}
.about__item:nth-child(2){
	background-image: url("../img/top/achievements-circles.svg");
}
.about__content{
	font-size: var(--fontsize-16);
}
.about__content::before{
	content: "｛";
}
.about__content::after {
	content: "｝";
}
.about__number{
	font-family: var(--font-en);
	font-size: clamp(50px, 4.4vw, 85px);
	line-height: 1;
}
.about__total{
	text-align: right;
}
.about__unit{
	font-size: clamp(20px, 1.5vw, 28px);
	font-family: var(--font-mincho);
	color: var(--font-pale);
	padding-left: 24px;
}
.case-heading{
	padding-top: clamp(70px, 7.6vw, 145px);
}
.case-heading .c-main-title{
	margin-bottom: clamp(30px, 3.4vw, 65px);
}
.case-heading .c-main-title__ja{
	display: flex;
	align-items: center;
}
.case-heading .c-main-title__ja:after {
    content: "";
    height: 1px;
    flex-grow: 1;
	background-color: #A3B9C3;
	margin-left: 24px;
}
.case__tab{
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(3, 1fr);
}
.case__tab-btn{
	border-radius: 6px 6px 0 0;
	background-color: var(--pale-color);
	padding: 22px;
	width: 100%;
	transition: background-color var(--trans-base), margin-top var(--trans-base);
	margin-top: 8px;
}
.case__tab-btn.is-active{
	background-color: var(--bg-color);
	margin-top: 0;
}
@media (hover: hover) {
	.case__tab-btn:hover{
		background-color: var(--bg-color);
		margin-top: 0;
	}
}
.case__tab-title{
	text-align: center;
	width: fit-content;
	margin: 0 auto;
	padding-right: 28px;
	font-family: var(--font-mincho);
	display: block;
	background: url("../img/common/tab-arrow.svg") center right / 1em auto no-repeat;
	font-size: var(--fontsize-16);
}
.case-main{
	margin-top: -8px;
	position: relative;
	z-index: 1;
	background-color: var(--bg-color);
	padding-block: clamp(30px, 3.1vw, 60px) clamp(60px, 7.6vw, 145px);
}
.case-links{
	display: grid;
	grid-row-gap: 16px;
	grid-column-gap: 30px;
	grid-template-columns: repeat(4, 1fr);
	margin-bottom: 30px;
}
.case-slider{
	position: relative;
	z-index: 0;
}
.case-slider .swiper-button-prev, 
.case-slider .swiper-button-next {
	margin-top: 0 !important;
	top: calc(50% - clamp(75px, 4.7vw, 90px)) !important;
}
.case-slider .swiper-button-prev{
	left: -90px !important;
}
.case-slider .swiper-button-next {
	right: -90px !important;
}
.case-slider .swiper{
	padding-bottom: clamp(40px, 2.9vw, 55px);
}
.case-slider .swiper-pagination {
	width: fit-content !important;
	bottom: 0 !important;
	right: 0 !important;
	left: auto !important;
	z-index: 3 !important;
}
.case-slider .swiper-pagination-bullet{
	margin: 0 8px !important;
	color: var(--border-color) !important;
}
.case-slider .swiper-pagination-bullet-active{
	background: var(--main-color) !important;
	position: relative;
}
.case__cta{
	margin-top: 24px;
}
.case__cta .c-more-btn{
	margin-inline: auto;
}
.promise{
	background-image: var(--bg-gradation);
	position: relative;
	z-index: 0;
}
.promise::before{
	content: "";
	position: absolute;
	left: 4%;
	bottom: 65px;
	display: block;
	width: clamp(220px, 22.9vw, 440px);
	height: clamp(290px, 30.7vw, 590px);
	background: url("../img/common/bg-logo-white.svg") center center / contain no-repeat;
	opacity: 0.02;
	z-index: -1;
}
.promise .l-inner{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 30px;
}
.promise__body{
	flex: 1;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: clamp(20px, 2vw, 40px);
}
.promise__read{
	margin-block: 30px clamp(40px, 4.9vw, 95px);
	font-size: var(--fontsize-15);
	color: var(--border-color);
}
.promise__img{
	flex: 1;
}
.promise__img img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 6px;
}
.promise__list{
	width: 400px;
}
.promise__item:not(:last-child){
	margin-bottom: 24px;
}
.promise__item{
	display: flex;
	align-items: center;
	gap: 20px;
	padding: 20px;
	border-radius: 6px;
	color: #fff;
	border: 1px solid var(--border-color);
	font-size: var(--fontsize-15);
	font-weight: 500;
}
.promise__icon{
	width: 40px;
}
.promise__text{
	flex: 1;
}
.menu{
	position: relative;
	z-index: 0;
	background-color: var(--bg-color);
}
.menu__heading{
	display: flex;
	align-items: flex-end;
	flex-wrap: wrap;
	gap: 30px;
	justify-content: space-between;
	margin-bottom: clamp(30px, 3.4vw, 65px);
}
.menu__read{
	flex: 1;
}
.menu__cta{
	width: 245px;
	margin-bottom: 20px;
}
.menu__read{
	display: flex;
	align-items: flex-end;
	flex-wrap: wrap;
	column-gap: clamp(30px, 6.8vw, 130px);
	row-gap: 30px;
}
.menu__read-text{
	margin-bottom: 20px;
	line-height: 2;
}
.menu__en {
	display:flex;
	position:absolute;
	left: 0;
	bottom: 0;
	z-index: -1;
	pointer-events: none;
}
.menu__en li {
	animation:text-loop 200s linear 0s infinite;
	line-height: 1;
	font-size: clamp(120px, 11.5vw, 220px);
	white-space: nowrap;
	font-family: var(--font-en);
	padding-right: 0.5em;
	color: #F1F4F5;
}
.menu__en li:nth-child(2) {
	animation:text-loop2 200s linear -100s infinite;
}
.menu__lsit{
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	border: 1px solid var(--border-color);
	margin-right: calc(50% - 50vw);
}
.menu__item:not(:last-child){
	border-right: 1px solid var(--border-color);
}
.menu__link{
	padding: clamp(30px, 2.3vw, 45px) 30px;
	background-color: rgba(253,253,253,0.6);
	display: flex;
	flex-direction: column;
	height: 100%;
}
.menu__title{
	display: flex;
	align-items: center;
	gap: 24px;
	font-family: var(--font-mincho);
	font-size: var(--fontsize-20);
	margin-bottom: 20px;
}
.menu__title-num{
	width: 53px;
	height: 53px;
	display: grid;
	place-content: center;
	place-items: center center;
	background: url("../img/common/arrow-maru-pale.svg") center center / contain no-repeat;
	font-family: var(--font-en);
	font-size: var(--fontsize-20);
}
.menu__img{
	width: clamp(250px, 15.6vw, 300px);
	height: clamp(250px, 15.6vw, 300px);
	border-radius: 150px;
	margin: 0 auto clamp(20px, 2.3vw, 45px);
}
.menu__item-text{
	color: var(--font-pale);
	margin-bottom: 24px;
	line-height: 2;
}
.menu__item .c-view{
	margin: auto auto 0;
}
.price{
	background-color: var(--bg-color);
	padding-block: clamp(40px, 5.7vw, 110px);
	background-image: url("../img/top/price-bg.webp");
	background-position: center bottom clamp(40px, 5.7vw, 110px);
	background-size: contain;
	background-repeat: no-repeat;
}
.price .l-inner{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	column-gap: clamp(30px, 12.5vw, 240px);
	row-gap: 30px;
}
.price .c-main-title{
	margin-bottom: clamp(30px, 3.4vw, 65px);
}
.price__heading{
	width: 245px;
}
.price-list{
	display: grid;
	gap: 24px;
	grid-template-columns: repeat(2, 1fr);
	flex: 1;
}
.price-list__item{
	display: flex;
	flex-direction: column;
	gap: 23px;
}
.price-list__pick{
	font-size: var(--fontsize-20);
	font-family: var(--font-mincho);
	padding-left: 24px;
	position: relative;
	left: 0;
	font-weight: 500;
}
.price-list__pick::before{
	content: "";
	width: 12px;
	height: 12px;
	border-radius: 6px;
	border: 1px solid var(--main-color);
	position: absolute;
	left: 0;
	top: 16px;
}
.price-list__pick::after{
	content: "";
	width: 8px;
	height: 8px;
	border-radius: 4px;
	background-color: var(--main-color);
	position: absolute;
	left: 2px;
	top: 18px;
}
.price-list__bg{
	background-image: radial-gradient(circle at bottom center, #9A532D, #154B64 65%, #0B425C 100%);
	overflow: hidden;
	position: relative;
	z-index: 0;
	color: #fff;
	border-radius: 6px;
	padding: 33px clamp(20px, 2vw, 40px);
	flex: 1;
	display: block;
}
.price-list__item--circle .price-list__bg{
	background-image: radial-gradient(circle at bottom center, #154B64, #7797A4 65%, #7797A4 100%);
}
.price-list__bg::before{
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-image: url("../img/common/texture-noise.webp");
	pointer-events: none;
}
.price-list__bg::after{
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(21,75,100,0.8);
	pointer-events: none;
	opacity: 0;
	transition: opacity var(--trans-base);
	z-index: -1;
}
.price-list__bg:hover::after{
	opacity: 1;
}
.price-list__flex{
	display: flex;
	align-items: center;
	column-gap: 16px;
}
.price-list__title{
	font-size: var(--fontsize-25);
	font-family: var(--font-mincho);
	flex: 1;
}
.price-list__title > span{
	font-size: var(--fontsize-14);
}
.price-list__arrow{
	display: block;
	width: 21px;
	height: 21px;
	border-radius: 5px;
	background-color: rgba(255,255,255,0.15);
	position: relative;
	z-index: 0;
	overflow: hidden;
}
.price-list__arrow::after{
	content: "";
	display: block;
	width: 17px;
	height: 17px;
	position: absolute;
	top: calc(50% - 2px);
	transform: translateY(-50%);
	left: 2px;
	transition: top var(--trans-base), right var(--trans-base);
	background: url("../img/common/diagonal-arrow-white.svg") center right / contain no-repeat;
}
@media (hover: hover) {
	a .price-list__arrow::after,
	a.price-list__arrow::after {
		animation: var(--trans-base) forwards arrow-anim-diagonal-rev;
	}
	a:hover .price-list__arrow::after,
	a.price-list__arrow:hover::after {
		animation: var(--trans-base) forwards arrow-anim-diagonal;
	}
}
.price-list__sub{
	font-size: var(--fontsize-14);
	color: var(--border-color);
	margin-bottom: 24px;
}
.price-list__sub::before {
    content: "├ ";
    display: inline-block;
}
.price-list__num{
	font-size: clamp(40px, 3.1vw, 60px);
	font-family: var(--font-en);
	line-height: 1.1;
}
.price-list__tax{
	font-size: var(--fontsize-16);
	font-family: var(--font-text);
	padding-left: 8px;
}
.price-list__point{
	display: flex;
	gap: 12px;
	margin-top: 20px;
	flex-wrap: wrap;
}
.price-list__point-item{
	white-space: nowrap;
	padding: 2px 12px;
	font-size: var(--fontsize-14);
	border: 1px solid rgba(255,255,255,0.5);
	border-radius: 5px;
	background-color: rgba(255,255,255,0.08);
}
.price-list__point-item > span::before{
	content: "＃";
}
.doctor{
	background: url("../img/top/doctor-wave.png") center bottom -1px / 101% auto no-repeat;
}
.doctor::before{
	content:"";
	display:block;
	position:fixed;
	top:0;
	left:0;
	z-index:-10;
	width:100%;
	height:100vh;
	background: url("../img/common/common-bg.webp") center center / cover no-repeat;
}
.doctor .l-inner{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.doctor__img{
	width: 45%;
}
.doctor__contents{
	width: 50%;
}
.doctor__heading{
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	flex-wrap: wrap;
	margin-bottom: clamp(20px, 2vw, 40px);
}
.doctor__heading .c-view{
	margin-bottom: 16px;
}
.doctor__title{
	font-size: var(--fontsize-33);
	font-family: var(--font-mincho);
	margin-bottom: clamp(20px, 2.3vw, 45px);
}
.doctor__text{
	margin-bottom: clamp(30px, 3.4vw, 65px);
}
.doctor__text > p {
	line-height: 2;
}
.doctor__text > p:not(:first-of-type) {
	margin-top: 1.6em;
}
.doctor .c-career-list{
	background-color: var(--bg-color);
	border-top: 1px solid var(--main-color);
	border-radius: 0 0 15px 15px;
	box-shadow: 0 3px 30px rgba(21,75,100,0.08);
}
.doctor .c-career-list__title{
	background-image: none;
	padding-right: 45px;
	transition: background-image var(--trans-base); 
}
.doctor .is-open .c-career-list__title{
	background-image: radial-gradient(circle, var(--main-color) 0.5px, transparent 0.5px);
}
.doctor .c-accordion__icon{
	right: 24px;
}
.doctor .c-accordion__panel{
	padding: 0;
}
.links{
	background-color: var(--bg-color);
	padding-block: clamp(40px, 5.7vw, 110px);
}
.links__list{
	display: grid;
	column-gap: clamp(20px, 2vw, 40px);
	row-gap: 20px;
	grid-template-columns: repeat(3, 1fr);
}
.links__link{
	padding: 10px 50px 10px 10px;
	font-size: var(--fontsize-16);
	display: flex;
	align-items: center;
	gap: 28px;
	position: relative;
	background-color: var(--bg-color);
	border-radius: 6px;
	border: 1px solid var(--border-color);
}
.links__num{
	background-color: var(--sub-color);
	font-size: var(--fontsize-15);
	border-radius: 4px;
	width: 30px;
	height: 30px;
	display: grid;
	place-content: center;
	place-items: center center;
	text-align: center;
	font-family: var(--font-mincho);
	transition: background-color var(--trans-base), color var(--trans-base);
	border: 1px solid var(--main-color);
}
@media (hover: hover) {
	.links__link:hover .links__num{
		background-color: var(--main-color);
		color: #fff;
	}
}
.links__link .c-link-arrow{
	position: absolute;
	right: 20px;
	top: 50%;
	transform: translateY(-50%);
}
.instagram{
	background-color: var(--bg-color);
	padding-block: clamp(40px, 4.9vw, 95px) clamp(70px, 7.6vw, 145px);
}
.instagram__heading{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: flex-end;
	gap: 25px;
	margin-bottom: clamp(30px, 3.4vw, 65px);
}
#sb_instagram{
	padding-bottom: 0 !important;
}
.campaign{
	background-image: var(--bg-gradation);
	padding-block: clamp(50px, 5.7vw, 110px);
}
.campaign .c-main-title{
	margin-bottom: clamp(30px, 3.4vw, 65px);
}
.campaign__cta{
	margin-top: clamp(30px, 4.1vw, 80px);
}
.campaign__cta .c-more-btn{
	margin-inline: auto;
}
.campaign-list__link{
	padding: 30px;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: clamp(20px, 3.4vw, 65px);
	border-radius: 6px;
	background-color: rgba(255,255,255,0.15);
	transition: background-color var(--trans-base);
	height: 100%;
}
@media (hover: hover) {
	.campaign-list__link:hover{
		background-color: rgba(255,255,255,0.25);
	}
}
.campaign-list__img{
	width: 37%;
	border-radius: 6px;
}
.campaign-list__contents{
	flex: 1;
	color: #fff;
}
.swiper-slide {
	height: auto;
}
.campaign-list__title{
	font-size: var(--fontsize-25);
	font-family: var(--font-mincho);
	margin-block: 30px 12px;
	line-height: 1.6;
}
.campaign-list__text{
	line-height: 1.6;
	color: var(--border-color);
	font-size: var(--fontsize-15);
	margin-bottom: clamp(20px, 2.3vw, 45px);
	display: -webkit-box;
	overflow: hidden;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
}
.campaign-list__date{
	font-size: var(--fontsize-14);
	margin-top: auto;
}
.campaign-slider{
	position: relative;
}
.campaign-slider .swiper{
	overflow: inherit;
	width: min(100%,1200px);
	margin-inline: auto;
}
.campaign .swiper-button-prev {
	background-image: url('../img/common/swiper-prev-ellipse.svg');
	top: -50px !important;
	left: auto !important;
	right: 55px !important;
}
.campaign .swiper-button-next {
	background-image: url('../img/common/swiper-next-ellipse.svg');
	top: -50px !important;
}
.news{
	background-color: var(--bg-color);
	padding-bottom: clamp(50px, 7.6vw, 145px);
}
.news__link{
	position: relative;
	z-index: 0;
	overflow: hidden;
	border-bottom: 1px solid var(--border-color);
	display: block;
	padding-block: 12px;
}
.news__item:first-child .news__link{
	border-top: 1px solid var(--border-color);
}
.news__link::after{
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	height: 100%;
	width: 100%;
	background-color: var(--main-color);
	transform: scaleY(0);
	transform-origin: bottom;
	transition: transform var(--trans-base);
	z-index: -1;
}
@media (hover: hover) {
	.news__link:hover::after {
		transform: scaleY(1);
	}
}
.news__link .l-inner{
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	grid-row-gap: 5px;
	position: relative;
}
.news__link .c-post-meta__date{
	width: 11%;
}
.news__link .c-post-meta__cats{
	width: 18%;
}
.news__title{
	flex: 1;
	padding-right: 25px;
	transition: color var(--trans-base);
	font-size: var(--fontsize-16);
	line-height: 1.6;
}
@media (hover: hover) {
	.news__link:hover .news__title{
		color: #fff;
	}
}
.news__arrow{
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%) rotate(-90deg);
}
.news__arrow svg path{
	transition: fill var(--trans-base);
}
@media (hover: hover) {
	.news__link:hover .news__arrow svg path{
		fill: #fff;
	}
}
@media screen and (max-width: 1440px) {
	.about__unit{
		padding-left: 10px;
	}
	.fv-surgery-links__link{
		padding: 9px 12px;
	}
	.fv-surgery-links__icon svg{
		height: 20px;
	}
	.fv-surgery-links__icon {
		margin-right: 5px;
	}
}
@media screen and (max-width: 1280px) {
	.promise__body{
		width: calc(100% - 345px);
	}
	.price-list{
		width: calc(100% - 275px);
	}
	.promise__list{
		width: 380px;
	}
}
@media screen and (max-width: 1024px){
	/*.fv-surgery{
		width: 260px;
	}*/
	.fv-surgery__list{
		margin-top: 120px;
		height: calc(100% - 120px);
	}
	.fv-surgery-links__link{
		padding: 9px 12px;
	}
	.fv-surgery-links__icon{
		margin-right: 8px;
	}
	.fv-surgery-links__item:not(:last-child){
		margin-bottom: 10px;
	}
	.about__heading{
		width: 150px;
	}
	.about__title{
		padding-left: 50px;
	}
	.about__title::before{
		width: 40px;
	}
	.about__title::after{
		left: 36px;
	}
	.about__content,
	.about__total{
		width: 100%;
	}
	.case-links{
		grid-row-gap: 10px;
		grid-column-gap: 20px;
		grid-template-columns: repeat(3, 1fr);
	}
	.promise__link{
		gap: 15px;
		padding: 12px 40px 12px 20px;
	}
	.promise__link .c-link-arrow{
		right: 18px;
	}
	.price .l-inner{
		display: inherit;
	}
	.price__heading .price__cta{
		display: none;
	}
	.price-list__cta .c-more-btn{
		margin: 0 auto;
	}
	.price-list{
		width: 100%;
		margin-bottom: 30px;
	}
	.price-list__item{
		gap: 10px;
	}
	.price-list__pick::before{
		top: 13px;
	}
	.price-list__pick::after{
		top: 15px;
	}
	.price__cta .c-more-btn{
		margin-inline: auto;
	}
	.price-list__title{
		margin-top: 5px;
	}
	.doctor__img{
		width: 40%;
	}
	.doctor__contents{
		width: 55%;
	}
	.links__list{
		grid-template-columns: repeat(2, 1fr);
	}
	.promise .l-inner{
		display: inherit;
	}
	.promise__body{
		width: 100%;
		margin-bottom: 30px;
	}
	.promise__heading .promise__cta{
		display: none;
	}
	.promise__cta .c-more-btn{
		margin-inline: auto;
	}
	.promise::before{
		left: auto;
		bottom: auto;
		right: 4%;
		top: 30px;
	}
}
@media screen and (max-width: 767px){
	.fv-surgery{
		display: none;
	}
	.about__heading{
		width: 100%;
		padding-block: clamp(10px, 2.9vw, 55px);
	}
	.about__title{
		font-size: 24px;
	}
	.about__link{
		padding: 20px;
	}
	.case__tab{
		gap: 10px;
	}
	.case__tab-btn{
		padding: 15px 5px;
	}
	.case__tab-title{
		padding-right: 20px;
	}
	.case-links{
		display: none !important;
	}
	.menu__heading{
		display: inherit;
	}
	.menu__read-text{
		margin-bottom: 0;
	}
	.menu__heading .menu__cta{
		display: none;
	}
	.menu__cta{
		margin-bottom: 0;
		margin-top: 30px;
		width: 100%;
	}
	.menu__cta .c-more-btn{
		margin-inline: auto;
	}
	.menu__link{
		padding: 20px;
	}
	.menu__title{
		gap: 10px;
	}
	.menu__read-text,
	.menu__item-text{
		line-height: 1.8;
	}
	.price-list {
		gap: 15px;
		grid-template-columns: repeat(1, 1fr);
	}
	.price-list__flex{
		display: flex;
		column-gap: 10px;
	}
	.doctor .l-inner > .doctor__img{
		display: none;
	}
	.doctor__contents{
		width: 100%;
	}
	.doctor__img{
		width: 300px;
		margin: 0 auto 30px;
	}
	.links__list{
		grid-template-columns: repeat(1, 1fr);
	}
	.promise__img{
		flex: auto;
		width: 100%;
	}
	.promise__list{
		width: 100%;
	}
	.promise__item:not(:last-child){
		margin-bottom: 12px;
	}
	.campaign-list__img{
		width: 100%;
	}
	.campaign-list__link{
		display: block;
	}
	.campaign-list__contents{
		flex: auto;
		width: 100%;
		display: flex;
		flex-direction: column;
		margin-top: 20px;
	}
	.campaign-list__title{
		margin-block: 12px;
	}
	.campaign-list__text{
		margin-bottom: 45px;
	}
	.campaign-list__date{
		position: absolute;
		left: 30px;
		bottom: 30px;
	}
	.news__link .c-post-meta__date{
		width: 70px;
	}
	.news__link .c-post-meta__cats{
		width: calc(100% - 70px);
		padding-right: 25px;
	}
	.news__title{
		flex: auto;
		width: 100%;
		margin-top: 5px;
	}
}
@media screen and (max-width: 480px){
	.about__list{
		grid-template-columns: repeat(1, 1fr);
	}
	.doctor{
		background-image: url("../img/top/doctor-wave-sp.png");
		padding-bottom: 80px;
	}
	.case__tab{
		grid-template-columns: repeat(2, 1fr);
		padding-bottom: 10px;
	}
	.case__tab-btn{
		border-radius: 6px;
		margin-top: 0;
	}
	.case-main{
		margin-top: 0;
	}
	.instagram__heading .instagram__cta {
		display: none;
	}
	.instagram__cta {
		margin-top: 30px;
	}
	.instagram__cta .c-pill-btn{
		margin-inline: auto;
	}
	.campaign-list__link{
		padding: 25px;
	}
	.campaign .c-main-title{
		margin-bottom: 70px;
	}
	.campaign .swiper-button-prev,
	.campaign .swiper-button-next {
		top: -35px !important;
	}
	
}