/*-----------------------------------------
	2024/11 LPセラミック
-----------------------------------------*/
/* Google font読み込み */
@import url('https://fonts.googleapis.com/css2?family=Allura&family=Zen+Old+Mincho:wght@400;500;600;700;900&display=swap');
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}
body.lp-ceramic {
	font-family: 'Noto Sans JP', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro',
		sans-serif;
	font-weight: 300;
	color: #515050;
}
.lp-ceramic section {
	position: relative;
	overflow: hidden;
	z-index: 1;
}
:root {
	--font-family-serif: 'Zen Old Mincho', 'Noto-Serif-JP', 'ヒラギノ明朝 ProN',
		'Hiragino Mincho ProN', 'Yu Mincho Light', sans-serif;
	--font-family-serif-sub: 'Allura';
	--font-family-sans: 'Noto Sans JP', 'Hiragino Kaku Gothic Pro',
		'ヒラギノ角ゴ Pro', sans-serif;
	--color-main: #515050;
	--color-bule: #33b1bf;
	--color-white: #fff;
	margin-top: 0 !important;
}
img {
	display: block;
	margin: 0;
	vertical-align: middle;
	width: 100%;
	height: auto;
}
a {
	color: var(--fg-color);
	text-decoration: none;
	transition: opacity 0.5s;
}
@media (hover: hover) {
	a:hover {
		opacity: 0.5;
	}
}
p {
	font-size: min(4vw, 20px);
	line-height: 1.6;
	letter-spacing: 0.04em;
	text-align: justify;
}
.bold {
	font-weight: 900;
}
.red {
	color: #d60000;
}
.full-screen {
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	max-width: 100vw;
	margin-bottom: 0;
}
.pc-only {
	display: block;
}
.sp-only {
	display: none;
}
@media (width < 768px) {
	.pc-only {
		display: none;
	}
	.sp-only {
		display: block;
	}
}
/*  reset
------------------------*/
:where(.wp-block-columns) {
	margin: 0 !important;
}
/*  common
------------------------*/
/* セラミックLPサイト PC最大幅 */
.lp-ceramic .c--inner {
	width: 100%;
	max-width: calc(1040px + 6%);
	margin: 0 auto;
	padding: 0 3%;
}
.lp-ceramic .inner-wide {
	width: 100%;
	max-width: calc(1380px + 6%);
	margin: 0 auto;
	padding: 0 3%;
}
.lp-ceramic .inner-medium {
	width: 100%;
	max-width: calc(1240px + 6%);
	margin: 0 auto;
	padding: 0 3%;
}
.lp-ceramic .inner-min {
	width: 100%;
	max-width: calc(840px + 6%);
	margin: 0 auto;
	padding: 0 3%;
}

/* セラミックLPサイト header ctv button */
.lp-ceramic .h--cta-button-list {
	position: fixed;
	top: 11px;
	right: 3%;
	display: flex;
	justify-content: right;
	width: 450px;
	gap: 8px;
}
.lp-ceramic .h--cta-button-list li {
	flex-basis: 50%;
}
.lp-ceramic .h--cta-button-list li a {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	font-family: var(--font-family-sans);
	font-size: min(6vw, 25px);
	font-weight: 900;
	color: #fff;
	width: 100%;
	height: min(4vw, 60px);
	padding: 0 20px;
	border-radius: 6px;
}

.lp-ceramic .h--cta-button-list li a > span {
	position: relative;
	display: inline-block;
	text-shadow: 0px 0px 10px rgba(28, 28, 28, 0.1),
		0px 0px 10px rgba(28, 28, 28, 0.1);
}
/*  WEB button
-----------*/
.lp-ceramic .h--cta-button-list li a.button-web {
	background: #1996ce;
	box-shadow: 0px 3px 0 #106991;
}
.lp-ceramic .h--cta-button-list li a.button-web span {
	font-size: min(3vw, 25px);
	letter-spacing: 0.04em;
	padding-left: 1.3em;
	background: url(../images/lp/icon-pc.webp) no-repeat left / 15%;
}
.lp-ceramic .h--cta-button-list li a.button-web small {
	font-size: min(4vw, 21px);
}

/*  TEL button
-----------*/
.lp-ceramic .h--cta-button-list li a.button-tel {
	background: #ef8c2c;
	box-shadow: 0px 3px 0 #b36519;
	gap: 4px;
}
.lp-ceramic .h--cta-button-list li a.button-tel span {
	font-size: min(2vw, 23px);
	letter-spacing: 0.04em;
	line-height: 1;
	background: url(../images/lp/icon-tel.webp) no-repeat left bottom/ 15%;
	padding-left: 1em;
}
.lp-ceramic .h--cta-button-list li a.button-tel span.num {
	font-size: min(2vw, 20px);
	line-height: 1;
	background: none;
	padding-left: 0;
}

/* セラミックLP header */
.lp-ceramic header .inner-wide {
	position: absolute;
	top: 11px;
	display: flex;
	justify-content: space-between;
	z-index: 100;
}
.lp-ceramic header .logo {
	max-width: min(25vw, 330px);
}

/* セラミックLPサイト 共通見出し */
.lp-ceramic h1,
.lp-ceramic h2,
.lp-ceramic h3,
.lp-ceramic h4,
.lp-ceramic h5,
.lp-ceramic h6 {
	font-family: var(--font-family-serif);
	font-weight: 900;
}

.lp-ceramic .section-title {
	text-align: center;
}
.lp-ceramic .section-title span {
	display: block;
	font-family: var(--font-family-serif);
	font-weight: 900;
	color: #9a977b;
}
.lp-ceramic .section-title .title-main {
	font-size: min(10vw, 45px);
	letter-spacing: 0.01em;
	margin-bottom: 10px;
}
.lp-ceramic .section-title .title-sub {
	font-size: min(8vw, 1rem);
	letter-spacing: 0.52em;
}
.lp-ceramic .section-title-sub {
	margin-top: 0;
	margin-bottom: 80px;
}
.lp-ceramic .section-title-sub .title-main {
	position: relative;
	font-family: var(--font-family-serif);
	font-size: min(10vw, 36px);
	font-weight: 900;
	color: #515050;
	letter-spacing: 0.04em;
	padding-bottom: 8px;
}
.lp-ceramic .section-title-sub .title-main::after {
	content: '';
	position: absolute;
	bottom: -5px;
	left: 40%;
	width: 60%;
	height: 4px;
	background: #eee;
}
.lp-ceramic .section-title-sub .title-main::before {
	content: '';
	position: absolute;
	bottom: -5px;
	left: 0;
	width: 40%;
	height: 4px;
	background: #31b0bd;
}
.lp-ceramic .section-title-content {
	font-family: var(--font-family-serif);
	font-weight: 900;
	color: #515050;
	letter-spacing: 0.04em;
	border-left: 4px solid #31b0bd;
	margin-bottom: 18px;
}

/*  header
------------------------*/
/* ハンバーガーメニュー */
.lp-ceramic header .gnav {
	display: none;
}
@media (width < 768px) {
	.lp-ceramic header .inner-wide {
		gap: 0;
		max-height: 44px;
	}
	.lp-ceramic header .logo {
		max-width: 260px;
	}
	.lp-ceramic header .logo img {
		height: 50px;
		object-fit: contain;
	}
	.lp-ceramic header .container {
		margin-right: 50px;
	}

	/* 診療時間 */
	.lp-ceramic header .hours {
		width: 150px;
		height: 44px;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		line-height: 1;
		background: rgb(108, 210, 204);
		background: linear-gradient(
			180deg,
			rgba(108, 210, 204, 1) 0%,
			rgba(146, 237, 232, 1) 100%
		);
	}
	.lp-ceramic header .hours .s01 {
		font-size: min(3vw, 14px);
		color: #1c8f97;
	}
	.lp-ceramic header .hours .s02 {
		font-size: min(4vw, 16px);
		font-weight: bold;
		color: #fff;
		line-height: 1.3;
	}
	html #wpadminbar {
		display: none;
	}
	/* ハンバーガーボタン */
	.navToggle {
		position: fixed;
		top: 11px;
		right: 3%;
		display: block !important;
		width: 50px;
		height: 44px;
		text-align: center;
		cursor: pointer;
		z-index: 101;
	}
	.navToggle span {
		display: block;
		position: absolute;
		right: 0;
		width: 70%;
		border-bottom: solid 5px #7f888c;
		-webkit-transition: 0.35s ease-in-out;
		-moz-transition: 0.35s ease-in-out;
		transition: 0.35s ease-in-out;
	}
	.navToggle span:nth-child(1) {
		top: 3px;
	}
	.navToggle span:nth-child(2) {
		top: 13px;
	}
	.navToggle span:nth-child(3) {
		top: 23px;
	}
	.navToggle span:nth-child(4) {
		border: none;
		bottom: -2px;
		right: -7px;
		width: 100%;
		letter-spacing: 0;
		font-size: 13px;
		font-family: var(--font-family-serif);
		font-weight: bold;
	}
	.navToggle.active span:nth-child(1),
	.navToggle.active span:nth-child(2) {
		top: 12px;
	}
	.navToggle.active span:nth-child(1) {
		-webkit-transform: rotate(-20deg);
		-moz-transform: rotate(-20deg);
		transform: rotate(-20deg);
	}
	.navToggle.active span:nth-child(2) {
		-webkit-transform: rotate(20deg);
		-moz-transform: rotate(20deg);
		transform: rotate(20deg);
	}
	.navToggle.active span:nth-child(3) {
		display: none;
	}
	/* ハンバーガーボタン 展開後 */
	.globalMenuSp {
		position: fixed;
		z-index: 100;
		top: 0;
		right: 0;
		text-align: left;
		transform: translateY(-100%);
		transition: all 0.6s;
		width: 100%;
		margin: 0;
	}
	.globalMenuSp .inner {
		display: flex;
		justify-content: center;
		align-items: center;
		padding: 80px 8% 0;
		overflow: auto;
		-webkit-overflow-scrolling: touch;
		width: auto;
		background: url(../images/lp/bg-header-sp.webp) no-repeat center / cover;
		height: 100vh;
	}

	/* このクラスを、Jsで付与・削除する */
	.globalMenuSp.active {
		position: fixed;
		display: block;
		right: 0;
		bottom: 0;
		transform: translateY(0%);
		z-index: 99;
		overflow-y: auto;
		margin-left: auto;
	}
	.globalMenuSp ul {
		flex-grow: 1;
	}
	.globalMenuSp ul > li {
		margin-bottom: 1em;
	}
	.globalMenuSp ul > li a {
		position: relative;
		display: block;
		font-family: var(--font-family-serif);
		font-size: min(6vw, 36px);
		font-weight: normal;
		color: #515050;
		text-align: center;
		border: 2px solid #5ed3cd;
		border-radius: 50px;
		padding: 0.3em 0;
		background: #fff url(../images/lp/favicon.webp) no-repeat center left 10px /
			8%;
		box-shadow: 0 5px 10px #228b9e3b;
	}
}

/*  footer
------------------------*/
.lp-ceramic footer .f--cta-button-list {
	display: none;
}
@media (width < 768px) {
	.lp-ceramic footer .f--cta-button-list {
		position: fixed;
		bottom: 0;
		left: 0;
		width: 100%;
		display: flex;
		z-index: 90;
	}
	.f--cta-button-list li {
		flex-basis: 50%;
	}
	.f--cta-button-list li a {
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		font-family: var(--font-family-sans);
		font-size: min(6vw, 25px);
		font-weight: 900;
		color: #fff;
		line-height: 1;
		width: 100%;
		height: 60px;
	}

	.f--cta-button-list li a > span {
		position: relative;
		display: inline-block;
		line-height: 1;
		text-shadow: 0px 0px 10px rgba(28, 28, 28, 0.1),
			0px 0px 10px rgba(28, 28, 28, 0.1);
	}
	/*  WEB button
	-----------*/
	.f--cta-button-list li a.button-web {
		background: #1996ce;
	}
	.f--cta-button-list li a.button-web span {
		font-size: min(4.5vw, 38px);
		letter-spacing: 0.04em;
		padding-left: 1.5em;
		background: url(../images/lp/icon-pc.webp) no-repeat left / 13%;
	}
	.f--cta-button-list li a.button-web small {
		font-size: min(3vw, 21px);
	}

	/*  TEL button
	-----------*/
	.f--cta-button-list li a.button-tel {
		background: #ef8c2c;
	}
	.f--cta-button-list li a.button-tel span {
		font-size: min(4vw, 20px);
		letter-spacing: 0.04em;
		line-height: 1;
		background: url(../images/lp/icon-tel.webp) no-repeat left bottom/ 10%;
		padding-left: 1em;
	}
	.f--cta-button-list li a.button-tel span.num {
		font-size: min(5vw, 27px);
		line-height: 1;
		background: none;
		padding-left: 0;
	}
}

/*  LP 固定ページここから
------------------------------------------*/
/*  症例
------------------------*/
.case-container {
	background: rgb(255, 255, 255);
	background: linear-gradient(
		0deg,
		rgba(255, 255, 255, 1) 0%,
		rgb(227 252 255) 100%
	);
}
.lp-ceramic .case-container .inner-medium {
	padding-bottom: 70px;
}
.case-container .case-title01 span {
	font-size: min(8vw, 36px);
	font-weight: 600;
	border-bottom: 1px solid;
	padding-bottom: 6px;
}
.case-container .section-title {
	margin-top: min(64px);
	margin-bottom: min(64px);
}
.case-container .p01 {
	font-size: min(5vw, 24px);
	font-family: var(--font-family-serif);
	font-weight: 600;
	margin-bottom: 72px;
}
.case-content-column > div {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: min(76px);
}
.case-content-column .case-content p {
	line-height: 3;
}
.case-content-column .case-content-img-column {
	gap: min(4vw, 18px);
}
.case-content-column .case-content-img-column figure {
	position: relative;
	flex-grow: 1;
}
.case-content-column .case-content-img-column figure::before {
	content: 'Before';
	position: absolute;
	top: 0;
	left: 0;
	width: min(6vw, 80px);
	font-family: var(--font-family-serif-sub);
	font-size: min(3vw, 24px);
	text-align: center;
	background: #fff;
}
.case-content-column .case-content-img-column figure:nth-child(1) {
	content: 'Before';
}
.case-content-column .case-content-img-column figure:nth-child(2)::before {
	content: 'After';
}
/*  お悩み
------------------------*/
.worries-container {
	background: url(../images/lp/bg-worries.webp) no-repeat top / cover;
}
.worries-container .p01 {
	font-family: var(--font-family-serif);
	font-size: min(4vw, 24px);
	font-weight: 600;
	margin-top: min(40px);
	margin-bottom: min(40px);
}
.worries-container p strong,
.case-record-container p strong {
	color: #309e96;
}
/*  症例
------------------------*/
.case-record-container {
	background: url(../images/lp/bg-case-record.webp) no-repeat top / cover;
}
.case-record-container .inner-wide {
	padding-top: 30px;
	padding-bottom: 50px;
}
.case-record-container .case-record-doctor-column {
	align-items: center !important;
	gap: 0;
}
.case-record-container .case-record-doctor-column h3 {
	font-size: min(3.5vw, 45px);
	font-weight: 900;
	color: #fff;
	text-shadow: 2px 3px 24px rgb(92 189 206), 2px 3px 24px rgb(92 189 206),
		2px 3px 24px rgba(92, 189, 206, 0.7), 2px 3px 10px rgba(92, 189, 206, 0.7);
	margin-bottom: min(4vw, 72px);
}
.case-record-container .doctor-content-column {
	display: flex;
}
.case-record-container .case-record-doctor-column .doctor-content {
	flex-basis: min(45vw, 500px) !important;
	flex-grow: inherit !important;
}
.case-record-container .case-record-doctor-column .doctor-content .doctor-img {
	margin: -40px;
}
.case-record-container .case-record-doctor-column .doctor-content .name {
	font-size: min(4vw, 24px);
	font-weight: bold;
}
.case-record-container .case-record-doctor-column .text-content {
	flex-basis: 50% !important;
	flex-grow: initial !important;
}
.case-record-container .case-record-doctor-column .text-content p {
	font-family: var(--font-family-serif);
	font-weight: 600;
	letter-spacing: 0;
}
/*  CTA
------------------------*/
.cta-container {
	background: url(../images/lp/bg-cta.webp) no-repeat top / cover;
}
.cta-container .c--inner {
	padding-top: 70px;
	padding-bottom: 70px;
}
.cta-container .section-title-contact {
	position: relative;
	font-size: min(44px);
	font-weight: 900;
	color: #9a977b;
	text-align: center;
	line-height: 1;
	letter-spacing: 0.12em;
}
.cta-container .section-title-contact:before,
.cta-container .section-title-contact:after {
	position: absolute;
	top: 50%;
	width: calc(50% - 200px);
	height: 1px;
	content: '';
	border-bottom: 1px solid #9a977b;
}
.cta-container .section-title-contact:before {
	left: 0;
}
.cta-container .section-title-contact:after {
	right: 0;
}
.cta-container .c--cta-button-list {
	display: flex;
	justify-content: center;
	gap: min(5vw, 100px);
	margin: 38px 0 32px;
}
.cta-container .c--cta-button-list li {
	flex-basis: calc(50% - 50px);
}
.cta-container .c--cta-button-list li a {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	font-family: var(--font-family-sans);
	font-size: min(3.5vw, 38px);
	font-weight: 900;
	color: #fff;
	padding: 0 min(3.5vw, 32px);
	height: 170px;
	background: rgb(85, 172, 214);
	background: linear-gradient(
		90deg,
		rgba(85, 172, 214, 1) 0%,
		rgba(92, 190, 205, 1) 100%
	);
	box-shadow: 0px 10px 0 #47a4c4;
	border-radius: 13px;
}
.cta-container .c--cta-button-list li a > span {
	position: relative;
	display: inline-block;
	text-shadow: 0px 3px 10px #47a4c4, 0px 0px 10px #47a4c4, 0px 0px 10px #47a4c4;
	letter-spacing: 0.04em;
}
/*  WEB button
-----------*/
.cta-container .c--cta-button-list li a.button-web span {
	font-size: min(3.3vw, 38px);
	padding-left: 1.7em;
	background: url(../images/lp/icon-pc.webp) no-repeat left / 15%;
}

/*  TEL button
-----------*/
.cta-container .c--cta-button-list li a.button-tel {
	font-size: min(3.5vw, 36px);
}
.cta-container .c--cta-button-list li a.button-tel span.num {
	background: url(../images/lp/icon-tel.webp) no-repeat left center/ 10%;
	font-size: min(4vw, 47px);
	padding-left: 1em;
	letter-spacing: 0.04em;
}
.cta-container p {
	font-family: var(--font-family-serif);
	font-size: min(4vw, 30px);
	font-weight: 900;
	color: #9a977b;
	letter-spacing: 0.04em;
}

/*  セラミック治療とは
------------------------*/
.ceramic-container {
	position: relative;
	background: url(../images/lp/bg-ceramic.webp) no-repeat bottom/ cover;
}
.ceramic-container::after {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	width: 115px;
	height: 100%;
	background: url(../images/lp/bg-title-ceramic.webp) no-repeat;
	z-index: -1;
}
.ceramic-container::before {
	content: '';
	position: absolute;
	bottom: 0;
	right: -30px;
	width: 115px;
	height: calc(100% - 660px);
	background: url(../images/lp/bg-ceramic-line.webp) repeat-y;
	z-index: -1;
}
.ceramic-container .c--inner {
	padding-top: 65px;
	padding-bottom: 115px;
}
.ceramic-container .ceramic-title-img {
	margin-bottom: min(60px);
}
.ceramic-container .ceramic-title-sub-img {
	margin-bottom: min(30px);
}
.ceramic-container .p01 {
	font-weight: 500;
	margin-bottom: 115px;
}
.ceramic-container .p01 strong {
	color: #31b0bd;
	font-weight: bold;
}
.ceramic-container .ceramic-table-img-column {
	gap: 0 !important;
}

/*  セラミックと銀歯の違い
------------------------*/
.ceramic-difference-container {
	position: relative;
	background: url(../images/lp/bg-ceramic-difference.webp) no-repeat bottom /
		cover;
}
.ceramic-difference-container::before {
	content: '';
	position: absolute;
	bottom: 0;
	right: -30px;
	width: 115px;
	height: 100%;
	background: url(../images/lp/bg-ceramic-line.webp) repeat-y;
	z-index: -1;
}
.ceramic-difference-container .c--inner {
	padding-bottom: 130px;
}
/*  セラミックと銀歯の違い
------------------------*/
.commitment-container {
	position: relative;
	background: url(../images/lp/bg-commitment.webp) no-repeat bottom / cover;
}
.commitment-container::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 115px;
	height: 100%;
	background: url(../images/lp/bg-title-commitment.webp) no-repeat top / contain;
	z-index: 0;
}
.commitment-container::before {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50px;
	width: 115px;
	height: calc(100% - 950px);
	background: url(../images/lp/bg-commitment-line.webp) repeat-y;
	z-index: 0;
}
.commitment-container .c--inner {
	padding-top: 75px;
	padding-bottom: 75px;
}
.commitment-container .commitment-img {
	max-width: 1280px;
}
.commitment-container .commitment-img:nth-child(odd) {
	margin-left: auto;
}
.commitment-container .commitment-img.img04 {
	margin-top: -1.5em !important;
}

/*  6つの理由
------------------------*/
.reason-container {
	position: relative;
	background: url(../images/lp/bg-reason.webp) repeat top;
}
.reason-container::after {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	width: 115px;
	height: 100%;
	background: url(../images/lp/bg-titile-reason.webp) no-repeat;
	z-index: -1;
}
.reason-container::before {
	content: '';
	position: absolute;
	bottom: 0;
	right: -30px;
	width: 115px;
	height: calc(100% - 560px);
	background: url(../images/lp/bg-reason-line.webp) repeat-y;
	z-index: -1;
}
.reason-container .c--inner {
	padding-top: 70px;
	padding-bottom: 90px;
}
.reason-container .reason-title-img {
	margin-bottom: 72px;
}
.reason-container .reason-content {
	gap: 0;
	padding-top: min(4vw, 70px);
	padding-bottom: min(4vw, 80px);
	background: url(../images/lp/bg-line.webp) no-repeat bottom / contain;
}
.reason-container .reason-record-img {
	padding-bottom: min(3vw, 80px);
}

/* title */
.reason-container .reason-title-container {
	font-family: var(--font-family-serif);
	justify-content: center;
	margin-bottom: min(4vw, 28px);
}
.reason-container .content01 .reason-title-container {
	margin-bottom: min(4vw, 46px);
}
.reason-container .content03 .reason-title-container,
.reason-container .content04 .reason-title-container {
	margin-bottom: 16px;
}
.reason-container .reason-title-container h3 span {
	display: block;
	font-size: min(4vw, 36px);
	color: #3cb5c1;
}
.reason-container .reason-title-container h3 small {
	font-size: min(4vw, 24px);
	color: #3cb5c1;
}
.reason-container .reason-content-img {
	flex-basis: 580px;
}
.reason-container .content04 .reason-content-img {
	flex-basis: min(5vw, 580px);
}
.reason-container .content01 .reason-content-text,
.reason-container .content02 .reason-content-text {
	flex-basis: 670px;
	margin-left: -10em;
}
.reason-container .reason-content-text p {
	font-size: min(18px);
}
.reason-container .reason-content-text p strong {
	font-weight: 900;
	color: #3cb5c1;
}
.reason-container .content03 .reason-content-text p,
.reason-container .content04 .reason-content-text p {
	margin-left: 4.5em;
}
.reason-container .content03 .reason-content-text p {
	margin-bottom: 60px;
}
.reason-container .content05 .reason-content-column,
.reason-container .reason-content.content06 {
	gap: 45px;
}
.reason-container .content05 .reason-content-column .reason-content-img,
.reason-container .content06 .reason-content-img {
	flex-basis: auto;
}
.reason-container .content05 .reason-content-column .reason-content-text,
.reason-container .content06 .reason-content-text {
	flex-basis: 570px;
}
.reason-container .content06 .reason-title-container {
	justify-content: flex-start;
}

/*  院長紹介
------------------------*/
.doctor-container {
	position: relative;
	background: url(../images/lp/bg-doctor.webp) no-repeat top / cover;
}
.doctor-container::after {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	width: 115px;
	height: 100%;
	background: url(../images/lp/bg-title-doctor.webp) no-repeat;
	z-index: -1;
}
.doctor-container .c--inner {
	padding-top: 60px;
	padding-bottom: 75px;
}
.doctor-container .section-title {
	margin-bottom: 16px;
}
.doctor-container .doctor-title-content {
	font-size: min(21px);
	margin-bottom: 34px;
}
.doctor-container .doctor-title .name {
	font-size: min(28px);
}
.doctor-container .doctor-title .name-en {
	font-family: 'Futura', var(--font-family-serif);
	font-size: min(28px);
	font-weight: lighter;
	color: #b2b2b2;
}
.doctor-container .doctor-message-content {
	border-top: 1px solid #3cb5c1;
	border-bottom: 1px solid #3cb5c1;
	padding: 28px 0;
}
.doctor-container .doctor-message-content h3 {
	font-family: var(--font-family-sans);
	font-weight: 900;
	color: #33b1bf;
	margin-bottom: 24px;
}
.doctor-container .doctor-message-content p {
	font-size: min(18px);
}
.doctor-container .doctor-content-column {
	gap: 30px;
}
.doctor-content-column.sp-only {
	display: none;
}
.doctor-container .doctor-content-column .doctor-title-content {
	flex-basis: 60%;
}
.doctor-container .doctor-content-column .doctor-title-content .name {
	font-size: min(5vw, 28px);
	font-weight: 500;
}
.doctor-container .doctor-content-column .doctor-title-content .name-en {
	font-family: 'Futura', var(--font-family-sans), sans-serif;
	font-weight: lighter;
	color: #b2b2b2;
}
.doctor-container .doctor-content-column .doctor-img {
	flex-basis: 535px;
	flex-grow: 1;
}
.doctor-container .doctor-detail-column {
	padding: 40px 56px;
	background: rgba(238, 238, 238, 0.5);
}
.doctor-container .doctor-detail-column h4 {
	font-family: var(--font-family-sans);
	font-size: min(20px);
	font-weight: 500;
}
.doctor-container .doctor-detail-column p {
	font-size: min(18px);
}
/*  料金表
------------------------*/
.price-container {
	position: relative;
	background: url(../images/lp/bg-price.webp) no-repeat top / cover;
}
.price-container::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 175px;
	height: 100%;
	background: url(../images/lp/bg-title-price.webp) no-repeat top / contain;
	z-index: -1;
}
.price-container .c--inner {
	padding-top: 62px;
	padding-bottom: 90px;
}
.price-container .section-title {
	margin-bottom: 54px;
}
.price-container .table-style-price {
	margin-bottom: 18px;
}
/* デフォルトのテーブルリセット */
table tbody > tr:nth-child(odd) > td,
table tbody > tr:nth-child(odd) > th,
table tbody tr:hover > td,
table tbody tr:hover > th {
	background: none;
}
.table-style-price table,
.table-style-price table tr,
.table-style-price table td,
.table-style-price table th {
	background: none;
	border: none;
	border-block-start: none !important;
	color: #515050;
	font-size: min(18px);
}
.table-style-price table thead {
	border: 1px solid #8b8a8a;
}
.table-style-price table td,
.table-style-price table th {
	font-weight: 500;
	border: 1px solid #8b8a8a;
	background: #fff !important;
}
.table-style-price table td {
	padding: 18px 8px;
}
.table-style-price table thead tr th {
	font-size: min(20px);
	text-align: center;
	background: #e1f4fb !important;
}
.table-style-price table tbody tr td:first-child th {
	font-size: min(20px);
	letter-spacing: 0;
}
.table-style-price table tbody tr td:first-child {
	width: min(30vw, 350px);
}
.table-style-price table tbody tr td:last-child {
	text-align: right;
}

.price-container .price-pay-content {
	background: #e1f4fb;
	margin-top: 28px;
}
.price-container .price-pay-content h3 {
	font-family: var(--font-family-sans);
	font-size: min(4vw, 36px);
	font-weight: 500;
	color: #1e4d96;
	border-bottom: 1px solid #1e4d96;
	padding: 30px 10px;
}
.price-container .price-pay-content .price-img-column {
	justify-content: center;
	gap: min(3vw, 82px);
	padding: 50px 30px;
}
.price-container .price-pay-content .price-img-column figure {
	width: min(27vw, 240px);
}

/*  診療の流れ
------------------------*/
.flow-container {
	position: relative;
	background: #d2f0f5 url(../images/lp/bg-flow.webp) no-repeat top / cover;
}
.flow-container::after {
	content: '';
	position: absolute;
	top: 10px;
	right: 0;
	width: 115px;
	height: 100%;
	background: url(../images/lp/bg-title-flow.webp) no-repeat top / cover;
	z-index: -1;
}
.flow-container .inner-min {
	padding-top: 50px;
	padding-bottom: 50px;
}
.flow-container .section-title {
	margin-bottom: 61px;
}
.flow-container .flow-content {
	position: relative;
	gap: 0;
	background: #fff;
	margin-bottom: 72px;
	border-radius: 56px 0 56px 0;
}
.flow-container .flow-content::after {
	content: '';
	position: absolute;
	top: 110px;
	left: 30px;
	display: block;
	width: 1px;
	height: 85%;
	background: #33b1bf;
}
.flow-content.content04::after {
	height: 60%;
}
.flow-container .flow-content .flow-content-inner {
	max-width: 640px;
	margin: 0 auto;
	padding: 28px;
	align-items: center;
	gap: 0;
}
.flow-container .flow-content .step-num {
	content: '';
	position: absolute;
	top: -20px;
	left: -20px;
}
.flow-container .flow-content .step-num img {
	width: 180px;
	height: 131px;
}
.flow-container .flow-content h3 {
	font-size: min(4vw, 32px);
	color: #33b1bf;
	margin-bottom: 24px;
}
.flow-container .flow-content .flow-message-content p {
	font-family: var(--font-family-serif);
	font-size: min(4vw, 18px);
	font-weight: 900;
	color: #817e67;
	margin-top: 26px;
}

/*  FAQ
------------------------*/
.faq-container {
	position: relative;
	background: #fff;
}
.faq-container::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 175px;
	height: 100%;
	background: url(../images/lp/bg-title-question.webp) no-repeat top / contain;
	z-index: -1;
}
.faq-container .inner-min {
	padding-top: 70px;
	padding-bottom: 70px;
}
.faq-container .section-title {
	margin-bottom: 65px;
}
.faq-container .faq-content:not(:last-child) {
	margin-bottom: 50px;
}
.faq-container .faq-content h3 {
	font-size: min(4vw, 24px);
	color: #33b1bf;
	margin-bottom: 10px;
}
.faq-container .faq-content p {
	font-family: var(--font-family-serif);
	font-size: min(4vw, 18px);
	font-weight: 500;
}

/*  医院概要
------------------------*/
.overview-container {
	position: relative;
	background: #d2f0f5 url(../images/lp/bg-overview.webp) no-repeat top / cover;
}
.overview-container::after {
	content: '';
	position: absolute;
	top: 10px;
	right: 0;
	width: 115px;
	height: 100%;
	background: url(../images/lp/bg-title-overview.webp) no-repeat top / cover;
	z-index: -1;
}
.overview-container .c--inner {
	padding-top: 60px;
	padding-bottom: 60px;
}
.overview-container .section-title {
	margin-bottom: 60px;
}
.overview-container .overview-content {
	position: relative;
	width: 100%;
	max-width: 820px;
	margin: 0 auto;
	margin-right: 140px;
	background: rgba(255, 255, 255, 0.4);
	padding: 30px min(10vw, 120px) 30px min(5vw, 90px);
}
.overview-container .overview-content .overview-button-img.pc-only {
	position: absolute;
	bottom: -50px;
	right: 0;
	transform: translateX(70%);
	width: min(25vw, 292px);
}
@media (width < 1000px) {
	.overview-button-img.pc-only {
		transform: translateX(0) !important;
		top: -110px;
	}
}
.overview-container .overview-content .table-style-about {
	font-family: var(--font-family-serif);
	font-weight: 900;
	color: #9a977b;
	margin-bottom: min(6vw, 24px);
}
.table-style-about table tbody,
.table-style-about table tbody tr td,
.table-style-about table tbody th {
	padding: 0;
	font-size: min(5vw, 20px);
	line-height: 2.679;
	margin-bottom: 32px;
	border: none !important;
}
.table-style-about table tbody tr td:first-child {
	width: 28%;
}
.overview-content .table-style-about strong {
	color: #ce7989;
}
/* 診療時間 */
.table-style-overview table thead:first-child tr:first-child th {
	background: #9a977b;
	font-family: var(--font-family-serif);
	font-size: min(5vw, 22px);
	color: #fff;
	border: none;
}
.table-style-overview table thead,
.table-style-overview table th,
.table-style-overview table td {
	border: none;
	font-size: min(5vw, 36px);
	line-height: 1;
	color: #9a977b;
	padding: 14px 16px 16px 16px;
}
.table-style-overview table thead,
.table-style-overview table tbody {
	border: 1px solid #9a977b;
}

/*  ギャラリー
------------------------*/
.gallery-container {
	position: relative;
	background: #d2f0f5 url(../images/lp/bg-flow.webp) no-repeat top / cover;
}
.gallery-container .inner-wide {
	padding-top: 60px;
	padding-bottom: 60px;
}
.swiper-lp {
	position: relative;
}
.swiper-wrapper {
	padding-bottom: 3em;
}
.swiper-slide {
	opacity: 0.3;
	transform: scale(0.7) !important;
	transition: 0.7s;
	width: 300px;
	flex-grow: inherit !important;
}
.swiper-slide img {
	width: 100%;
	height: 100%;
	aspect-ratio: 1/1;
	object-fit: cover;
	border: 4px solid #fff;
	border-radius: 50vh;
}
.swiper-slide-active {
	opacity: 1;
	transform: scale(1.2) !important;
	z-index: 1;
}
.swiper-backface-hidden .swiper-slide {
	width: 100%;
	height: 100%;
	border: 4px solid #fff;
	aspect-ratio: 1/1;
	border-radius: 50vh;
	overflow: hidden;
}
/* コンテンツ幅のみ表示 */
.swiper-horizontal {
	touch-action: pan-y;
	overflow: hidden;
	padding: 100px 0;
}
/* ページネーション */
.swiper-pagination-clickable .swiper-pagination-bullet {
	width: min(1.5vw, 1.125rem);
	height: min(1.5vw, 1.125rem);
}
.swiper-pagination-bullet {
	margin: 0 min(4vw, 20px) !important;
}
.swiper-pagination-bullet-active {
	background: #6b6b6b;
	--swiper-theme-color: #6b6b6b;
}
.swiper-button-next,
.swiper-button-prev {
	background: #fff;
	width: 57px !important;
	height: 57px !important;
	border-radius: 50vh;
	color: #9a977b !important;
	transform: translateY(-50%);
}
.swiper-button-next:after,
.swiper-button-prev:after {
	font-size: 2rem !important;
}

/*  アクセス（Googleマップ）
------------------------*/
.access .access-content {
	height: 487px;
}

/*  Tablet用設定
------------------------*/
@media (width < 1000px) {
	.lp-ceramic .h--cta-button-list li a.button-tel span {
		font-size: min(6vw, 23px);
	}
	.lp-ceramic .h--cta-button-list li a.button-tel span.num {
		display: none;
	}
}
/*  SP用設定
------------------------*/
@media (width < 768px) {
	.lp-ceramic .h--cta-button-list {
		display: none !important;
	}
	.lp-ceramic .section-title .title-main {
		font-size: 36px;
		margin-bottom: 0;
	}
	.lp-ceramic .section-title .title-sub {
		font-size: 17.5px;
	}
	.lp-ceramic .section-title-sub {
		margin-bottom: 34.5px;
	}
	.lp-ceramic .section-title-sub .title-main {
		font-size: min(6vw, 33.5px);
	}
	.lp-ceramic main {
		margin-bottom: 60px; /* SP buttom btn分の高さ */
	}
	/*  症例
	------------*/
	.case-container .section-title .title-main {
		font-size: 24px;
	}
	.case-container.section-title .title-sub {
		font-size: 12px;
	}
	.case-container .case-title01 span {
		font-size: min(4vw, 21px);
	}
	.case-container .section-title {
		margin-top: 20.5px;
		margin-bottom: min(7vw, 37px);
	}
	.case-container .p01 {
		font-size: 17.5px;
		margin-bottom: min(7vw, 39px);
	}
	.case-content-column > div {
		grid-template-columns: 1fr;
		gap: min(8vw, 37px);
	}
	.case-content-column .case-content p {
		font-size: 16px;
	}
	.case-content-column .case-content-img-column figure::before {
		width: 70px;
	}
	.case-content-column .case-content-img-column figure::before,
	.case-content-column .case-content-img-column figure:nth-child(2)::before {
		font-size: min(5vw, 21px);
	}
	.case-container .inner-medium {
		padding-bottom: 55px;
	}
	/*  お悩み
	------------*/
	.worries-container .p01 {
		font-size: min(5vw, 21px);
		margin-bottom: 50px;
	}
	/*  症例の実績
	------------*/
	.case-record-container .case-record-doctor-column h3 {
		font-size: min(7vw, 28px);
	}
	.case-record-container .case-record-doctor-column .text-content p {
		font-size: min(5vw, 21px);
	}
	.case-record-container .case-record-doctor-column {
		flex-direction: column-reverse;
	}
	.case-record-container .case-record-doctor-column .doctor-content .job,
	.case-record-container .case-record-doctor-column .doctor-content .name {
		font-size: min(5vw, 21px);
		font-weight: 500;
	}
	.case-record-container .inner-wide {
		padding-top: 14px;
		padding-bottom: 22.5px;
	}
	/*  CTA
	------------*/
	.cta-container figure {
		max-width: 245.5px;
	}
	.cta-container .c--inner {
		padding-top: 15.5px;
		padding-bottom: 43px;
	}
	.cta-container .section-title-contact {
		font-size: 24px;
	}
	.cta-container .section-title-contact:before,
	.cta-container .section-title-contact:after {
		width: calc(50% - 90px);
	}
	.cta-container .c--cta-button-list {
		flex-direction: column;
	}
	.cta-container .c--cta-button-list li a {
		font-size: min(7vw, 33.5px);
		height: 102px;
	}
	.cta-container .c--cta-button-list li a > span {
		line-height: 1.2;
	}
	.cta-container .c--cta-button-list li a.button-web span,
	.cta-container .c--cta-button-list li a.button-tel {
		font-size: min(7vw, 33.5px);
	}
	.cta-container .c--cta-button-list li a.button-tel span.num {
		font-size: min(10vw, 40.5px);
	}
	.cta-container p {
		font-size: min(3.5vw, 21px);
	}

	/*  セラミック治療とは
	------------*/
	.ceramic-container::before,
	.ceramic-container::after {
		content: none;
	}
	.ceramic-container .c--inner {
		padding-top: 65px;
		padding-bottom: 72.5px;
	}
	.ceramic-container .p01 {
		font-size: min(5vw, 21px);
		margin-bottom: 60px;
	}
	/*  セラミックの違い
	------------*/
	.ceramic-difference-container::before {
		content: none;
	}
	.ceramic-difference-container .c--inner {
		padding-bottom: 98px;
	}
	.ceramic-difference-container .ceramic-table-img-column {
		flex-direction: column;
		gap: 40.5px;
	}
	/*  こだわり
	------------*/
	.section-title-obi {
		position: relative;
		font-family: var(--font-family-serif);
		font-size: min(6vw, 30px);
		font-weight: bold;
		color: #515050;
		background: #fff;
		padding: 8px 8px 8px 36px;
		margin-bottom: 24px;
		width: fit-content;
	}
	.section-title-obi::after {
		content: '';
		position: absolute;
		top: 50%;
		left: 15px;
		transform: translateY(-50%);
		width: 5px;
		height: 80%;
		background: #3cb5c1;
	}
	.commitment-container::after,
	.commitment-container::before {
		content: none;
	}
	.commitment-container .c--inner {
		padding-top: 15px;
		padding-bottom: 31.5px;
	}
	.commitment-container .commitment-content .box {
		padding-left: 3%;
		padding-right: 3%;
	}
	.commitment-container .commitment-content {
		margin-bottom: 25px;
	}
	.commitment-container .commitment-img {
		width: 70%;
		max-width: 653px;
		margin: 0 auto 22px;
	}
	.commitment-container .commitment-content p {
		font-size: min(5vw, 21px);
	}
	.commitment-container .commitment-content strong {
		font-weight: 900;
		color: #3cb5c1;
	}

	/*  6つの理由
	------------*/
	.reason-container::before,
	.reason-container::after {
		content: none;
	}
	.reason-container .c--inner {
		padding-top: 15px;
	}

	.reason-container .reason-title-img {
		margin-bottom: 42px;
	}
	.reason-container .reason-content {
		flex-direction: column;
	}
	.reason-container .reason-content .reason-content-img-column {
		flex-direction: column;
		gap: min(6vw, 35px);
	}
	.reason-container .reason-content.content01 {
		padding-top: 0;
		background: none;
	}
	.reason-container .reason-content-img {
		flex-basis: auto;
	}
	.reason-container .content01 .reason-content-text,
	.reason-container .content02 .reason-content-text {
		flex-basis: auto;
		margin-left: 0;
	}
	.reason-container .reason-title-container {
		margin-bottom: min(5vw, 32px) !important;
		justify-content: flex-start;
	}
	.reason-container .reason-title-container .num-img {
		width: min(15vw, 57px);
	}
	.reason-container .reason-title-container h3 span {
		font-size: min(6vw, 29px);
	}
	.reason-container .content03 .reason-content-text p,
	.reason-container .content04 .reason-content-text p {
		margin-left: 0;
	}
	.reason-container .content03,
	.reason-container .content04,
	.reason-container .content05,
	.reason-container .content06 {
		align-items: center;
	}
	.reason-container .content05 .reason-content-column .reason-content-text,
	.reason-container .content06 .reason-content-text {
		flex-basis: auto;
	}
	.reason-container .content05 .reason-content-column {
		flex-direction: column;
		gap: min(6vw, 35px);
	}
	.reason-container .content06 {
		gap: 32px;
	}
	.reason-container .content06 .reason-title-container {
		justify-content: center;
	}
	.reason-container .reason-content.content06 p {
		margin-top: 32px;
	}
	/*  院長
	------------*/
	.doctor-container::after {
		width: 10%;
		height: 100%;
		background: url(../images/lp/bg-title-doctor.webp) no-repeat top / contain;
	}
	.doctor-container .c--inner {
		padding-top: 28px;
		padding-bottom: 40px;
	}
	.doctor-container .doctor-content-column {
		/* gap: 30px; */
		flex-direction: column-reverse;
	}
	.doctor-container .doctor-content-column .doctor-img {
		width: 80%;
		max-width: 646px;
		margin: 0 auto;
		flex-basis: auto;
	}
	.doctor-container .doctor-message-content {
		border-top: none;
		margin: 0 3%;
	}
	.doctor-container {
		position: relative;
	}
	.doctor-container .doctor-content-column .doctor-title-content::after {
		content: '';
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 50%;
		background: #fff;
		z-index: -1;
	}
	.doctor-content-column.pc-only {
		display: none;
	}
	.doctor-content-column.sp-only {
		display: block;
	}
	.doctor-container .doctor-title-content {
		background: #fff;
		z-index: -1;
		margin-top: 23px;
		margin-left: calc(50% - 50vw);
		margin-right: calc(50% - 50vw);
		margin-bottom: 20px;
	}
	.doctor-container .doctor-message-content p {
		font-size: min(5vw, 21px);
	}
	.doctor-container .doctor-message-content h3 {
		font-size: min(5vw, 22.5px);
		margin-left: calc(50% - 49vw);
		margin-right: calc(50% - 49vw);
	}
	.doctor-container .doctor-name-content {
		align-items: center;
		gap: 0;
		font-size: min(5vw, 21px);
	}
	.doctor-container .doctor-name-content .name {
		font-size: min(5vw, 28px);
		font-weight: 500;
	}
	.doctor-container .doctor-name-content .name-en {
		font-family: 'Futura', var(--font-family-sans), sans-serif;
		font-weight: lighter;
		color: #b2b2b2;
	}
	.doctor-container .doctor-detail-column {
		padding: 18px 14px;
	}
	.doctor-container .doctor-detail-column h4 {
		font-size: min(5.5vw, 24px);
	}
	.doctor-container .doctor-detail-column p {
		font-size: min(5vw, 21px);
	}

	/*  料金
	------------*/
	.price-container::after {
		content: none;
	}
	.price-container .c--inner {
		padding-top: 19px;
		padding-bottom: 41.5px;
	}
	.price-container .section-title {
		margin-bottom: 35px;
	}
	.table-style-price table,
	.table-style-price table tr,
	.table-style-price table td,
	.table-style-price table th {
		font-size: min(5vw, 21px);
	}
	.table-style-price table tbody tr td:first-child {
		width: 70%;
	}
	.price-container .price-pay-content {
		margin-left: calc(50% - 50vw);
		margin-right: calc(50% - 50vw);
	}
	.price-container .price-pay-content h3 {
		font-size: min(5vw, 26px);
	}
	.price-container .price-pay-content h3 {
		padding: 25.5px 20.5px 20.5px 20.5px;
	}
	.price-container .price-pay-content .price-img-column {
		padding: 3%;
	}
	/*  治療の流れ
	------------*/
	.flow-container::after {
		content: none;
	}
	.flow-container .inner-min {
		padding-top: 48.5px;
		padding-bottom: 76.5px;
	}
	.flow-container .section-title {
		margin-bottom: min(10vw 53px);
	}
	.flow-container .flow-content {
		margin-bottom: 42.5px;
	}
	.flow-container .flow-content.content04 {
		margin-bottom: 0;
	}
	.flow-container .flow-content h3 {
		font-size: min(5vw, 24px);
		margin-bottom: 18px;
	}
	.flow-container .flow-content .flow-message-content p {
		font-size: min(4vw, 21px);
	}
	.flow-container .flow-content .flow-content-inner {
		padding-left: 36.5px;
	}
	.flow-container .flow-content::after {
		top: 61px;
		left: 20px;
		height: min(500px, 88%);
	}
	.flow-container .flow-content .step-num {
		left: -1%;
	}
	.flow-container .flow-content .step-num img {
		width: 65%;
		height: auto;
	}
	.flow-container .flow-content.content04::after {
		height: 60%;
	}
	.flow-container .flow-content .flow-img {
		width: 70%;
		max-width: 523px;
	}
	/*  よくある質問
	------------*/
	.faq-container::after {
		content: none;
	}
	.faq-container .inner-min {
		padding-top: 30px;
		padding-bottom: 55px;
	}
	.faq-container .section-title {
		margin-bottom: min(10vw, 53px);
	}
	.faq-container .faq-content {
		gap: 0;
	}
	.faq-container .faq-content h3 {
		font-size: min(5vw, 26.5px);
		margin-bottom: 0;
	}
	.faq-container .faq-content p {
		font-size: min(4vw, 21px);
	}
	/*  医院
	------------*/
	.overview-container::after {
		content: none;
	}
	.overview-container .c--inner {
		padding-top: 27px;
		padding-bottom: 27px;
	}
	.overview-container .section-title {
		margin-bottom: 8px;
	}
	.overview-container .overview-content {
		margin-right: 0;
		padding: 1%;
	}

	.table-style-about table tbody,
	.table-style-about table tbody tr td,
	.table-style-about table tbody th {
		font-size: min(3.8vw, 21px);
		line-height: 1.786;
		margin-bottom: 32px;
	}
	.table-style-about table tbody tr td:first-child {
		width: 40%;
	}
	.overview-container .table-style-overview {
		width: 90%;
		max-width: 436px;
		margin: 0 auto;
	}
	.table-style-overview table tbody td {
		border: none;
		/* font-size: min(5vw, 20px); */
		padding: 10px 16px;
	}
	.table-style-overview table thead:first-child tr:first-child th {
		font-size: min(4vw, 20px);
		padding: 10px 6px;
	}
	.overview-button-img.sp-only {
		margin-top: 16.5px;
	}
	/*  ギャラリー
	------------*/
	.swiper-horizontal > .swiper-pagination-bullets,
	.swiper-pagination-bullets.swiper-pagination-horizontal,
	.swiper-pagination-custom,
	.swiper-pagination-fraction {
		max-width: 280px !important;
		left: 50% !important;
		transform: translateX(-50%) !important;
	}
	.swiper-horizontal {
		padding: 20% 0 24%;
	}
	.swiper-pagination-bullet {
		margin: 0 min(4vw, 10px) !important;
	}
	.swiper-pagination-clickable .swiper-pagination-bullet {
		width: min(3vw, 1.125rem);
		height: min(3vw, 1.125rem);
		margin-bottom: 8px !important;
	}
	.swiper-slide {
		opacity: 0.3;
		transform: scale(0.7) !important;
		transform: translateY(50%) !important;
		transition: 0.7s;
		width: 200px;
		flex-grow: inherit !important;
	}
	.swiper-slide img {
		width: 100%;
		height: 100%;
		aspect-ratio: 1/1;
		object-fit: cover;
		border: 2px solid #fff;
		border-radius: 50vh;
	}
	.swiper-slide-active {
		opacity: 1;
		transform: scale(2) !important;
		z-index: 1;
	}
	.gallery-container .inner-wide {
		padding-top: 43px;
		padding-bottom: 35.5px;
	}
}
