@charset "UTF-8";
/* レイアウト */
.l-container {
	min-width: var(--min-device-width);
}
.l-inner {
	max-width: var(--site-width);
	margin-inline: auto;
	padding-inline: var(--space-inline);
}
.l-inner._wide {
	max-width: 1200px;
}
.l-inner._narrow {
	max-width: 800px;
}
.l-padding._top {
	-webkit-padding-before: var(--space-block);
	padding-block-start: var(--space-block);
}
.l-padding._top_small {
	-webkit-padding-before: var(--space-block-small);
	padding-block-start: var(--space-block-small);
}
.l-padding._top_small2 {
	-webkit-padding-before: var(--space-block-small2);
	padding-block-start: var(--space-block-small2);
}
.l-padding._top_xs {
	-webkit-padding-before: var(--space-block-xs);
	padding-block-start: var(--space-block-xs);
}
.l-padding._top_large {
	-webkit-padding-before: var(--space-block-large);
	padding-block-start: var(--space-block-large);
}
.l-padding._bottom {
	-webkit-padding-after: var(--space-block);
	padding-block-end: var(--space-block);
}
.l-padding._bottom_small {
	-webkit-padding-after: var(--space-block-small);
	padding-block-end: var(--space-block-small);
}
.l-padding._bottom_small2 {
	-webkit-padding-after: var(--space-block-small2);
	padding-block-end: var(--space-block-small2);
}
.l-padding._bottom_xs {
	-webkit-padding-after: var(--space-block-xs);
	padding-block-end: var(--space-block-xs);
}
.l-padding._bottom_large {
	-webkit-padding-after: var(--space-block-large);
	padding-block-end: var(--space-block-large);
}
@media not all and (max-width: 768px) {
	.l-inner {
		box-sizing: content-box;
	}
}
/* カラム */
.l-column {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-block) 40px;
}
.l-column._gap2 {
	row-gap: var(--space-block-small);
}
.l-column._mb_gap2 {
	-webkit-margin-after: var(--space-block);
	margin-block-end: var(--space-block);
}
.l-column._subgrid {
	grid-template-columns: repeat(1, 1fr);
}
.l-column._subgrid > .l-column__item {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-block-small) 40px;
}
@media not all and (max-width: 768px) {
	.l-column._reverse_1line > .l-column__item {
		grid-row: 1/2;
	}
	.l-column._reverse_1line > .l-column__item:nth-child(2n+1) {
		grid-column: 2/3;
	}
	.l-column._reverse_1line > .l-column__item:nth-child(2n) {
		grid-column: 1/2;
	}
}
@media (max-width: 768px) {
	.l-column {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: var(--space-block-small2) 20px;
	}
	.l-column._mb_gap2 {
		-webkit-margin-after: var(--space-block-xs);
		margin-block-end: var(--space-block-xs);
	}
}
/*=====

ヘッダー　フッター

=====*/
/*ヘッダー*/
.g-header {
	position: relative;
	background-color: var(--color-light);
	z-index: 5000;
}
.g-header .container {
	display: flex;
	align-items: center;
	justify-content: space-between;
	-moz-column-gap: 20px;
	column-gap: 20px;
	min-height: var(--header-size);
	padding-bottom: 10px;
}
.g-header .logo {
	display: flex;
	align-items: center;
	color: var(--color-base-light);
	column-gap: 24px;
}
.g-header .logo .desc {
	font-size: 14px;
	line-height: var(--line-height-small2);
}
.g-header .content {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	gap: 20px;
}
.g-header .navi {
	display: flex;
	flex-direction: column;
	row-gap: 12px;
	-webkit-padding-before: 7px;
	padding-block-start: 7px;
	font-family: var(--ff-noto-serif);
	--letter-spacing: 0;
}
.g-header .navi a {
	text-decoration: none;
}
.g-header .navi1 {
	display: flex;
	justify-content: flex-end;
	font-weight: 500;
	font-size: 18px;
}
.g-header .navi1__item {
	position: relative;
	display: flex;
	align-items: first baseline;
}
.g-header .navi1__item:before {
	content: "";
	display: inline-block;
	margin-inline-end: 5px;
	width: 4px;
	height: 18px;
	border-radius: 2px;
	background: rgba(255, 255, 255, 0.4);
	transform: translateY(2px);
}
.g-header .navi1__item a {
	display: block;
	padding: 4px 16px;
	text-decoration: none;
	flex-grow: 1;
}
/*.g-header .navi1__item:not(:first-child) {
	-webkit-margin-start: 20px;
	margin-inline-start: 20px;
}*/
/* スマホメニュー内アコーディオン */
.g-header .navi1__item .toggle {
	display: none;
}
.g-header .navi1__item .Label { /*タイトル*/
	padding: 4px 16px;
	display: block;
	color: #fff;
}
.g-header .navi1__item .Label::after { /*タイトル横の矢印*/
	content: "";
	width: 10px;
	height: 10px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	-webkit-transform: rotate(45deg);
	display: inline-block;
	/*position: absolute;
	top:calc( 50% - 3px );
	right: 20px;*/
	transform: rotate(135deg);
	margin-inline-start: 10px;
}
.g-header .navi1__item .accordion {
	flex-wrap: wrap;
	width: 100%;
}
.g-header .navi1__item .Label, .accordion-inner {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	transform: translateZ(0);
	transition: all 0.3s;
}
.g-header .navi1__item .accordion-inner { /*本文*/
	height: 0;
	margin-bottom: 10px;
	overflow: hidden;
}
.g-header .navi1__item .toggle:checked + .Label + .accordion-inner { /*開閉時*/
	height: auto;
	padding-block: 14px;
	transition: all .3s;
}
.g-header .navi1__item .toggle:checked + .Label::after {
	transform: rotate(-45deg) !important;
}
.g-header .navi1__item .about-nav {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	grid-column-gap: 22px;
}
.g-header .navi1__item .about-nav._wide {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	grid-column-gap: 22px;
}
.g-header .navi1__item .about-nav li:after {
	content: "";
	display: block;
	width: 100%;
	height: 1px;
	background: rgba(255, 255, 255, 0.4);
}
.g-header .navi1__item .about-nav li a {
	color: var(--color-light);
	display: block;
	padding: 5px;
	margin-block: 12px;
}
/* PCグローバルメニュー */
.g-header .navi2 {
	display: flex;
	-moz-column-gap: 20px;
	column-gap: 12px;
	font-family: var(--ff-zen-maru);
	font-size: 17px;
	font-weight: 500;
}
.g-header .navi2 a:hover {
	color: var(--color-primary);
	opacity: 1;
}
.g-header .navi2 a:after {
	content: "";
	width: 18px;
	height: 4px;
	border-radius: 2px;
	/*background:rgba(var(--color-primary-rgb),0.4);*/
	display: block;
	margin: 5px auto 0;
}
.g-header .navi2 a:hover:after {
	content: "";
	background: rgba(var(--color-primary-rgb), 0.4);
}
.g-header .navi2 a.__current {
	color: var(--color-primary);
	opacity: 1;
}
.g-header .navi2 a.__current:after {
	content: "";
	width: 18px;
	height: 4px;
	border-radius: 2px;
	background: rgba(var(--color-primary-rgb), 0.4);
	display: block;
	margin: 5px auto 0;
}
/* スマホメニューボタン */
.g-header .menu-button {
	position: relative;
	width: 53px;
	height: 53px;
	/*box-shadow: 0 3px 6px rgba(var(--color-dark-rgb), 0.16);*/
	background-color: var(--color-primary);
	z-index: 6000;
}
.g-header .menu-button::before, .g-header .menu-button::after, .g-header .menu-button__border {
	content: "";
	display: block;
	width: 16px;
	height: 1px;
	position: absolute;
	inset: -13px 0 0;
	margin: auto;
	background-color: var(--color-light);
	transition: transform var(--sec-fast);
}
.g-header .menu-button__border {
	visibility: var(--g-header-menu-button-border-visibility, visible);
}
.g-header .menu-button::before {
	transform: translate(0, -6px);
}
.g-header .menu-button::after {
	transform: translate(0, 6px);
}
.g-header .menu-button.is-open {
	--g-header-menu-button-border-visibility: hidden;
}
.g-header .menu-button.is-open::before {
	transform: translate(0, 0) rotate(45deg);
}
.g-header .menu-button.is-open::after {
	transform: translate(0, 0) rotate(-45deg);
}
.g-header .menu-button__text {
	position: absolute;
	bottom: 8px;
	left: 0;
	width: 100%;
	color: var(--color-light);
	font-size: 0.6875rem;
	line-height: 1;
	--letter-spacing: -0.04em;
	text-align: center;
}
.g-header .menu-button__text._close {
	display: none;
}
.g-header .menu-button.is-open .menu-button__text._open {
	display: none;
}
.g-header .menu-button.is-open .menu-button__text._close {
	display: block;
}
/* スマホメニュー展開時 */
.g-menu {
	--g-menu-padding-inline: 23px;
	position: fixed;
	z-index: 4990;
	inset: 0;
	background-color: var(--color-primary);
	color: var(--color-light);
	opacity: 0;
	visibility: hidden;
	/*	padding-top: var(--header-size);*/
	transition: opacity var(--sec), visibility var(--sec);
}
.g-menu.is-open {
	opacity: 1;
	visibility: visible;
}
.g-menu .wrapper {
	padding-top: var(--header-size);
	border-top: 1px solid var(--color-border2);
	height: 100%;
	overflow-y: auto;
}
.g-menu .inner {
	min-height: 100%;
	display: flex;
	flex-direction: column;
}
.g-menu .area1 {
	justify-content: center;
	padding: 25px var(--g-menu-padding-inline) 50px;
}
.g-menu .navi1 {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	row-gap: var(--space-block-xs);
	font-family: var(--ff-zen-maru);
	line-height: 1.4375;
}
.g-menu .navi1__link._type2 {
	font-family: var(--ff-zen-maru);
	color: var(--color-light);
}
.g-menu .area2 {
	max-width: 80%;
	margin-inline: auto;
}
.g-menu .c-tel__ttl {
	text-align: center;
	margin-block-end: 12px;
}
.g-menu .c-reservation {
	border-radius: 12px;
	background: #fff;
	padding: 12px;
	margin: 20px auto;
	width: fit-content;
	width: 100%;
}
.g-menu .c-reservation a {
	text-decoration: none;
	font-size: 18px;
}
.g-menu .c-reservation:hover {
	background-color: currentColor;
}
.g-menu .c-reservation-box {
	display: flex;
	margin-inline: auto;
	gap: 10px;
	align-items: center;
	justify-content: center;
}
.g-menu .c-reservation-icn {
	width: 40px;
	flex-shrink: 0;
}
.g-menu .c-reservation-ttl {
	font-family: var(--ff-zen-maru);
	font-size: 18px;
	font-weight: 500;
}
.g-menu .c-reservation-ttl span {
	display: inline-flex;
	align-items: first baseline;
	/*margin-inline-start: 10px;*/
	gap: 5px;
	color: var(--color-primary);
}
.g-menu .c-reservation-ttl span:after {
	content: "";
	display: block;
	background: url("../img/cmn/icon_arrow.svg") no-repeat left top;
	width: 14px;
	height: 14px;
	filter: none;
}
.g-menu .c-instagram {
	border-radius: 12px;
	background: #fff;
	padding: 12px;
	margin: 20px auto;
	width: fit-content;
}
.g-menu .c-instagram a {
	text-decoration: none;
	font-size: 18px;
}
.g-menu .c-instagram-box {
	display: flex;
	margin-inline: auto;
	gap: 10px;
	align-items: center;
}
.g-menu .c-instagram-icn {
	width: 40px;
	flex-shrink: 0;
}
.g-menu .c-instagram-ttl {
	font-family: var(--ff-zen-maru);
	font-size: 16px;
	font-weight: 500;
}
.g-menu .c-instagram-ttl span {
	display: inline-flex;
	align-items: first baseline;
	margin-inline-start: 10px;
	gap: 5px
}
.g-menu .c-instagram-ttl span:after {
	content: "";
	display: block;
	background: url("../img/cmn/icon_arrow_w.svg")no-repeat left top;
	width: 14px;
	height: 14px;
}
.navi-cta {}
@media (max-width: 1000px) {
	.navi-cta {
		display: none;
	}
}
/* ヘッダーお問い合わせボタン */
.g-header .c-t-tel {
	display: flex;
	justify-content: center;
	flex-direction: column;
	width: 232px;
	height: 72px;
	border-bottom-left-radius: 12px;
	border-bottom-right-radius: 12px;
	background: #003ea2;
	font-family: var(--ff-zen-maru);
	font-weight: 500;
	color: var(--color-light);
	text-align: center;
	line-height: 1.35;
}
.g-header .c-t-tel a {
	color: var(--color-light);
}
.g-header .c-t-tel__ttl {
	font-size: 14px;
}
.g-header .c-t-tel__main {
	display: flex;
	align-items: center;
	justify-content: center;
}
.g-header .c-t-tel__number {
	font-size: 24px;
	margin-inline-start: 5px;
}
@media (max-width: 1200px) {
	.g-header .logo {
		/*	width: 100px;*/
		flex-direction: column;
		align-items: flex-start;
	}
	.g-header .logo .desc {
		font-size: 12px;
		display: block;
		margin-block-start: 4px;
	}
	.g-header .logo .desc br {
		display: none;
	}
}
@media (max-width: 1000px) {
	.g-header {
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
	}
	.g-header .logo .desc {
		font-size: 10px;
		color: var(--color-base);
	}
	.g-header .navi {
		display: none;
	}
	.g-header .c-t-tel {
		display: none;
	}
}
@media not all and (max-width: 1000px) {
	.g-header .menu-button {
		display: none;
	}
	.g-menu {
		display: none !important;
	}
}
.navi-cta {}
/*web予約ボタン*/
.navi-cta .c-reservation {
	border-radius: 12px;
	background: var(--color-primary);
	/*background: var(--color-sub2);*/
	/*background: var(--color-primary);*/
	padding: 7px;
	margin: 10px 0 0;
	width: 100%;
	max-width: 280px;
}
@media (max-width: 768px) {
	.navi-cta .c-reservation {
		margin: 20px auto;
	}
}
.navi-cta .c-reservation:hover {
	background-color: rgba(0, 158, 162, 0.8);
}
.navi-cta .c-reservation a {
	text-decoration: none;
	font-size: 16px;
}
.navi-cta .c-reservation-box {
	display: flex;
	margin-inline: auto;
	gap: 10px;
	align-items: center;
	justify-content: center;
}
.navi-cta .c-reservation-icn {
	width: 40px;
	flex-shrink: 0;
}
.navi-cta .c-reservation-ttl {
	font-family: var(--ff-zen-maru);
	font-size: 16px;
	font-weight: 500;
}
.navi-cta .c-reservation-ttl span {
	display: inline-flex;
	align-items: first baseline;
	/*margin-inline-start: 10px;*/
	gap: 5px;
	color: #ffffff;
}
.navi-cta .c-reservation-ttl span:after {
	content: "";
	display: block;
	background: url("../img/cmn/icon_arrow.svg") no-repeat left top;
	filter: brightness(0) invert(1);
	width: 12px;
	height: 12px;
}
/*フッター*/
.g-footer {
	position: relative;
	-webkit-padding-before: 65px;
	padding-block-start: 65px;
	-webkit-padding-after: 10px;
	padding-block-end: 10px;
	/*	color: var(--color-light);
	font-family: var(--ff-noto-serif);*/
	background-color: var(--color-base-light3);
	--g-footer-navi-gap: 9px;
}
.g-footer a {
	/*color: inherit;*/
	text-decoration: none;
}
.g-footer .pagetop {
	pointer-events: none;
	position: fixed;
	z-index: 4980;
	bottom: 65px;
	left: 0;
	width: 100%;
	min-width: 360px;
	-webkit-padding-end: 12px;
	padding-inline-end: 12px;
	text-align: right;
}
body.is-footer-visible .g-footer .pagetop {
	position: absolute;
	bottom: calc(100% + 5px);
}
.g-footer .pagetop__button {
	pointer-events: auto;
	opacity: 0;
	visibility: hidden;
	display: inline-flex;
	border-radius: 9999px;
	background-color: var(--color-sub2);
	transition-property: background-color, opacity, visibility;
	transition-duration: var(--sec);
	width: 60px;
	height: 60px;
	align-items: center;
	justify-content: center;
}
.g-footer .pagetop__button img {
	width: 30px;
	height: 30px;
}
body:not(.is-page-top) .g-footer .pagetop__button {
	opacity: 1;
	visibility: visible;
}
.g-footer .pagetop__button:focus:focus-visible {
	background: var(--color-primary);
	--svg-main-color: var(--color-light);
}
.g-footer .container {
	display: flex;
	justify-content: space-between;
	-moz-column-gap: 20px;
	column-gap: 20px;
}
.g-footer .area1 {
	font-size: 0.875rem;
	line-height: 1.7;
	--letter-spacing: 0;
}
.g-footer .logo {
	-webkit-margin-after: 28px;
	margin-block-end: 28px;
}
.g-footer .logo__img {
	width: 307px;
}
.g-footer .area2 {
	flex-basis: 54%;
}
.g-footer .area2__column {
	display: grid;
	/*grid-template-columns: repeat(3, 1fr);*/
	-moz-column-gap: 32px;
	column-gap: 32px;
	flex-grow: 2;
}
.g-footer .catchcopy {
	font-family: var(--ff-zen-maru);
	font-size: 20px;
	margin-block-end: 5px;
	font-weight: 500;
}
.g-footer .navi {
	display: flex;
	align-items: center;
	-moz-column-gap: 20px;
	column-gap: 20px;
	margin-block: 20px;
	border-top: 1px solid var(--color-sub2);
	padding-block-start: 20px;
}
.g-footer .button {
	-webkit-margin-before: 12px;
	margin-block-start: 12px;
}
.g-footer .button__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	-moz-column-gap: 8px;
	column-gap: 8px;
	max-width: 100%;
	width: 165px;
	min-height: 32px;
	padding: 5px 20px;
	border: 1px solid;
	font-size: 0.875rem;
	line-height: normal;
	transition-property: outline-offset, background-color;
}
.g-footer .button__link:focus:focus-visible {
	text-decoration: none;
	color: var(--color-base);
	background-color: var(--color-light);
	--g-button-filter: none;
}
.g-footer .button__link::after {
	content: "";
	display: block;
	width: 10px;
	height: 7px;
	background: url(../img/cmn/icon_external.svg) no-repeat left top;
	background-size: 100% 100%;
	filter: var(--g-button-filter, invert(1));
}
.g-footer .copyright {
	margin-block-start: 28px;
	/*	font-family: var(--ff-cormorant);*/
	font-size: 12px;
	text-align: right;
}
@media (max-width: 1000px) {
	.g-footer .container {
		display: flex;
		flex-direction: column-reverse;
		column-gap: 20px;
	}
	.g-footer .logo {
		-webkit-margin-after: 0;
		margin-block-end: 0;
	}
	.g-footer .num {
		display: flex;
		-moz-column-gap: 20px;
		column-gap: 20px;
	}
}
@media (max-width: 768px) {
	.g-footer {
		-webkit-padding-after: 33px;
		padding-block-end: 33px;
	}
	.g-footer .pagetop__button {
		width: 50px;
		height: 50px;
	}
	body.is-footer-visible .g-footer .pagetop {
		bottom: 100%;
	}
	.g-footer .navi {
		font-size: 0.875rem;
		display: block;
		margin-block-start: 0;
	}
	.g-footer .button__link {
		width: 198px;
	}
	.g-footer .area1 {
		display: block;
		width: -webkit-fit-content;
		width: -moz-fit-content;
		width: fit-content;
		/*margin-inline: auto;*/
		/*	padding-inline:30px;*/
		-webkit-margin-after: var(--space-block-xs);
		margin-block-end: var(--space-block-xs);
	}
	.g-footer .logo {
		-webkit-margin-after: var(--space-block-small);
		margin-block-end: var(--space-block-small);
	}
	.g-footer .num {
		display: grid;
	}
	.g-footer .area2__column {
		grid-template-columns: repeat(1, 1fr);
		width: auto;
		/*padding-inline: 30px;*/
		margin-block-end: var(--space-block-small);
	}
	.g-footer .area2__item:not(.root) {
		grid-column: auto;
		grid-row: auto;
	}
	.g-footer .copyright {
		-webkit-margin-before: 35px;
		margin-block-start: 35px;
	}
}
/*web予約ボタン*/
.g-footer .c-reservation {
	border-radius: 12px;
	background: var(--color-primary);
	padding: 12px;
	margin: 20px 0;
	width: 100%;
	max-width: 280px;
}
@media (max-width: 768px) {
	.g-footer .c-reservation {
		margin: 20px auto;
	}
}
.g-footer .c-reservation:hover {
	background-color: rgba(0, 158, 162, 0.8);
}
.g-footer .c-reservation a {
	text-decoration: none;
	font-size: 18px;
}
.g-footer .c-reservation-box {
	display: flex;
	margin-inline: auto;
	gap: 10px;
	align-items: center;
	justify-content: center;
}
.g-footer .c-reservation-icn {
	width: 40px;
	flex-shrink: 0;
}
.g-footer .c-reservation-ttl {
	font-family: var(--ff-zen-maru);
	font-size: 18px;
	font-weight: 500;
}
.g-footer .c-reservation-ttl span {
	display: inline-flex;
	align-items: first baseline;
	/*margin-inline-start: 10px;*/
	gap: 5px;
	color: #ffffff;
}
.g-footer .c-reservation-ttl span:after {
	content: "";
	display: block;
	background: url("../img/cmn/icon_arrow.svg") no-repeat left top;
	filter: brightness(0) invert(1);
	width: 12px;
	height: 12px;
}
/*=====
背景・ぱんくず・下層タイトル

=====*/
/*メイン*/
.g-main {
	display: block;
	flex-grow: 1;
}
.g-main:after {
	content: " ";
	display: block;
	clear: both;
}
/* 背景指定 */
.c-bg {
	position: relative;
	z-index: 10;
}
.c-bg._base {
	background-color: var(--color-base);
}
.c-bg._base-light {
	background-color: var(--color-base-light);
}
.c-bg._base-light2 {
	background-color: var(--color-base-light2);
}
.c-bg._base-light3 {
	background-color: var(--color-base-light3);
}
.c-bg._primary {
	background-color: var(--color-primary);
}
.c-bg__image img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
	pointer-events: none;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	z-index: -10;
}
/* 下層ページタイトル*/
.p-pagetitle {
	position: relative;
	isolation: isolate;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-height: 240px;
	padding: var(--space-block-small) var(--space-inline) var(--space-block-xs);
	--letter-spacing: 0;
}
.p-pagetitle__title {
	font-family: var(--ff-zen-maru);
	font-size: 36px;
	font-weight: 500;
	/*line-height: 1.42857;*/
	background: var(--color-bg-base);
	padding-inline: 20px;
}
.p-pagetitle__sub {
	-webkit-margin-before: 6px;
	margin-block-start: 6px;
	font-family: var(--ff-cormorant);
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.25;
}
.p-pagetitle__bg {
	position: absolute;
	z-index: -10;
	inset: 0;
	pointer-events: none;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}
.p-pagetitle__bg::before {
	content: "";
	position: absolute;
	z-index: 10;
	inset: 0;
	background-image: linear-gradient(to bottom, rgba(var(--color-dark-rgb), 0.1) 0%, rgba(var(--color-dark-rgb), 0.3) 100%);
}
.p-pagetitle__mv {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}
@media (max-width: 1080px) {
	.p-pagetitle {
		min-height: 240px;
		/*margin-inline: var(--space-inline);*/
	}
}
@media (max-width: 768px) {
	.p-pagetitle {
		min-height: 180px;
	}
	.p-pagetitle__title {
		font-size: 1.5rem;
	}
}
/* パンくず */
.c-bread {
	margin-block: var(--space-block-xs) var(--space-block);
	color: var(--color-base-light);
	font-size: 0.875rem;
	--letter-spacing: 0;
}
.c-bread img {
	display: block;
	translate: 0 -1px;
}
.c-bread__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	-moz-column-gap: 10px;
	column-gap: 10px;
	word-break: break-all;
	justify-content: flex-end;
}
.c-bread__list > li {
	display: flex;
	-moz-column-gap: 10px;
	column-gap: 10px;
}
.c-bread__list > li:first-child {
	--c-bread-content: "";
}
.c-bread__list > li:not(:first-child):before {
	content: "";
	display: block;
	width: 6px;
	height: 12px;
	background: url(../img/cmn/icon_arrow_bread.svg) no-repeat left top;
	background-size: 100% 100%;
	translate: 0 0.5rem;
}
.c-bread a {
	position: relative;
	display: block;
	/*color: var(--color-base-light3);*/
	color: var(--color-base-light);
}
.c-bread a::before {
	content: var(--c-bread-content, none);
	position: absolute;
	inset: -15px;
}
@media (max-width: 768px) {
	.c-bread {
		margin-block: var(--space-block-xs) var(--space-block-xs);
	}
}
/*=====

共通パーツ類

=====*/
/* ボタン */
.c-button {
	position: relative;
	isolation: isolate;
	display: inline-flex;
	max-width: 100%;
	/*justify-content: center;*/
	align-items: center;
	text-align: center;
	text-decoration: none;
	padding: 17px 54px 17px 24px;
	border-radius: 9999px;
	color: inherit;
	font-family: var(--ff-zen-maru);
	font-size: 20px;
	font-weight: 500;
	line-height: 1.35714;
	background-color: transparent;
	/*box-shadow: 0 0 6px rgba(var(--color-dark-rgb), 0.3);*/
	transition-duration: var(--sec-fast);
	transition-property: outline-offset, background-color;
	transition-timing-function: ease-in;
	-webkit-appearance: none;
	-moz-appearance: none;
	cursor: pointer;
}
.c-button_wrapper._center {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 10px 40px;
}
.c-button_wrapper._right {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 10px 40px;
}
.c-button_wrapper._left {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	gap: 10px 40px;
}
.c-button_wrapper._mt {
	-webkit-margin-before: 50px;
	margin-block-start: 50px;
}
.c-button._w_fluid {
	width: 100%;
}
.c-button._w_auto {
	padding-inline: 20px 50px;
}
.c-button._w_regular {
	width: fit-content;
	min-width: 260px;
}
.c-button._w_large {
	width: 420px;
}
.c-button._h_regular {
	min-height: 60px;
}
.c-button:is(._has_arrow, ._has_arrow-back, ._dropdown)::after {
	content: "";
	display: block;
	background-repeat: no-repeat;
	background-position: left top;
	background-size: 100% 100%;
	position: absolute;
	top: 0;
	bottom: 0;
	margin-block: auto;
	filter: var(--c-arrow-filter, none);
}
.c-button:is(._has_arrow, ._has_arrow-back)::after {
	right: 15px;
	width: 24px;
	height: 16px;
	background-image: url(../img/cmn/icon_arrow.svg);
}
.c-button._has_arrow-back::after {
	left: 15px;
	scale: -1 1;
}
.c-button._dropdown::after {
	right: 20px;
	width: 10px;
	height: 8px;
	background-image: url(../img/cmn/icon_dropdown.svg);
}
.c-button:focus:focus-visible {
	text-decoration: none;
}
.c-button._theme1 {
	border: 2px solid var(--color-primary);
	color: var(--color-primary);
	background-color: var(--color-light);
}
.c-button._theme1:focus:focus-visible {
	border-color: var(--color-primary);
	color: var(--color-light);
	background-color: var(--color-primary);
	--c-arrow-filter: invert(1) brightness(100);
}
.c-button._theme2 {
	border: 2px solid var(--color-sub1);
	color: var(--color-sub1);
	background-color: var(--color-light);
}
.c-button._theme2:focus:focus-visible {
	border-color: var(--color-sub1);
	color: var(--color-light);
	background-color: var(--color-sub1);
	--c-arrow-filter: invert(1) brightness(100);
}
.c-button._theme2::after {
	background-image: url(../img/cmn/icon_arrow2.svg);
}
@media (max-width: 768px) {
	.c-button._sp_center {
		margin: 32px auto;
	}
}
@media (max-width: 768px) {
	.c-button._w_auto {
		padding-inline: 10px 45px;
	}
	.c-button._w_regular {
		width: 300px;
	}
	.c-button._w_large {
		width: 360px;
	}
	.c-button._sp_w_regular {
		width: 355px;
	}
}
@media not all and (max-width: 768px) {
	.c-button._pc_w_regular {
		width: 355px;
	}
}
/* 改行 */
.c-br_pc {}
@media (max-width: 768px) {
	.c-br_pc {
		display: none;
	}
}
.c-br_sp {
	display: none;
}
@media (max-width: 768px) {
	.c-br_sp {
		display: block;
	}
}
/* 見出し共通スタイル */
.c-heading1 {
	-webkit-margin-after: var(--space-block-small);
	margin-block-end: var(--space-block-small);
	text-align: center;
}
.c-heading1__icon {
	display: block;
	margin-inline: auto;
}
.c-heading1__title {
	font-family: var(--ff-zen-maru);
	font-size: 36px;
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: 0.05em;
}
.c-heading1__title:after {
	content: "";
	display: block;
	width: 40px;
	height: 4px;
	border-radius: 4px;
	background: var(--color-primary);
	margin: 0 auto;
}
.c-heading2 {
	-webkit-margin-after: var(--space-block-small);
	margin-block-end: var(--space-block-small);
}
.c-heading2__title {
	font-family: var(--ff-zen-maru);
	font-size: 36px;
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: 0.05em;
	display: inline-flex;
	align-items: center;
}
.c-heading2__title:before {
	content: "";
	display: inline-block;
	width: 40px;
	height: 4px;
	border-radius: 4px;
	background: var(--color-primary);
	transform: translateY(5px);
	margin-inline-end:5px;
}
.c-heading3__title {
	font-family: var(--ff-zen-maru);
	font-weight: 500;
	font-size: 20px;
	letter-spacing: 0.05em;
	line-height: 1.6;
	display: inline-flex;
	align-items: center;
	gap: 12px;
	margin-block: 1rem;
}
.c-heading3__title:before {
	content: "";
	display: inline-block;
	width: 8px;
	height: 32px;
	border-radius: 4px;
	background: var(--color-primary);
}
.c-heading4__title {
	font-family: var(--ff-zen-maru);
	color: var(--color-primary);
	font-weight: 500;
	font-size: 24px;
	letter-spacing: 0.05em;
	line-height: 1.6;
	background: var(--color-base-light3);
	padding-inline: 12px;
	padding-block: 7px;
	margin-block: 1rem;
}
.c-heading5__title {
	font-family: var(--ff-zen-maru);
	color: var(--color-sub1);
	font-weight: 500;
	font-size: 24px;
	letter-spacing: 0.05em;
	line-height: 1.6;
	background: var(--color-base-light3);
	padding-inline: 12px;
	padding-block: 7px;
	margin-block: 1rem;
}
@media (max-width: 768px) {
	.c-heading3__title {
		font-size: 18px;
	}
	.c-heading4__title {
		font-size: 20px;
	}
	.c-heading5__title {
		font-size: 20px;
	}
}
.c-heading6__title {
	font-family: var(--ff-zen-maru);
	font-weight: 500;
	font-size: 28px;
	letter-spacing: 0.03em;
	line-height: 42px;
	text-align: center;
}
@media (max-width: 768px) {
	.c-heading6__title {
		font-size: 20px;
	}
}
@media (max-width: 768px) {
	.c-heading1__title {
		font-size: 24px;
	}
	.c-heading2__title {
		font-size: 24px;
	}
	.c-heading1__title:after {
		height: 2px;
	}
	.c-heading2__title:before {
		height: 2px;
		transform: translateY(2px);
	}
}
/* 共通電話番号 */
.c-tel {
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	margin-inline: auto;
	color: var(--color-primary);
	line-height: 1.85714;
	--letter-spacing: 0;
	border-radius: 24px;
	background: #fff;
	padding: 16px 46px;
}
.c-tel a {
	color: var(--color-primary);
}
.c-tel__main {
	display: flex;
	-moz-column-gap: 5px;
	column-gap: 5px;
	align-items: center;
}
.c-tel__icon {
	translate: 0 0.125rem;
	/*	width: var(--c-tel-icon-size, 27px);*/
	width: 45px;
	transform: translateY(-3px);
}
.c-tel__svg {
	width: 100%;
}
.c-tel__number {
	/*	font-size: var(--c-tel-number-font-size, 1.875rem);*/
	font-family: var(--ff-zen-maru);
	font-size: 48px;
	font-weight: 500;
	line-height: 1;
	letter-spacing: 0.05em;
	text-decoration: none;
}
.c-tel__number a {
	text-decoration: none;
}
.c-tel__time {
	-webkit-margin-before: 0;
	margin-block-start: 5px;
	-webkit-padding-start: 0;
	padding-inline-start: 0;
	font-family: var(--ff-noto-sans);
	font-size: 15px;
	color: var(--color-text-base);
}
@media (max-width: 768px) {
	.c-tel {
		border-radius: 12px;
		background: #fff;
		padding: 12px 24px;
	}
	.c-tel__icon {
		width: 36px;
	}
	.c-tel__number {
		font-size: 34px;
	}
	.c-tel__time {
		font-size: 11px;
	}
}
/*共通web予約*/
.c-reservation {
	border-radius: 12px;
	background: var(--color-primary);
	padding: 12px;
	margin: 20px 0;
	width: 100%;
	margin-inline: auto;
	max-width: 450px;
}
@media (max-width: 768px) {
	.c-reservation {
		margin: 20px auto;
		max-width: 306px;
	}
}
.c-reservation:hover {
	background-color: rgba(0, 158, 162, 0.8);
}
.c-reservation a {
	text-decoration: none;
	font-size: 18px;
}
.c-reservation-box {
	display: flex;
	margin-inline: auto;
	gap: 10px;
	align-items: center;
	justify-content: center;
}
.c-reservation-icn {
	width: 40px;
	flex-shrink: 0;
}
.c-reservation-ttl {
	font-family: var(--ff-zen-maru);
	font-size: 24px;
	font-weight: 500;
}
@media (max-width: 768px) {
	.c-reservation-ttl {
		font-size: 18px;
	}
}
.c-reservation-ttl span {
	display: inline-flex;
	align-items: first baseline;
	/*margin-inline-start: 10px;*/
	gap: 5px;
	color: #ffffff;
}
.c-reservation-ttl span:after {
	content: "";
	display: block;
	background: url("../img/cmn/icon_arrow.svg") no-repeat left top;
	filter: brightness(0) invert(1);
	width: 15px;
	height: 15px;
	background-size: contain;
}
@media (max-width: 768px) {
	.c-reservation-ttl span:after {
		width: 12px;
		height: 12px;
	}
}
/* 共通テキストスタイル */
.c-text :is(p, ol, ul, table, dl, .c-text__item):not(:first-child) {
	-webkit-margin-before: var(var(--c-text-gap), var(--space-block-small2));
	margin-block-start: var(--c-text-gap);
}
.c-text :is(p, ol, ul, table, dl, .c-text__item):not(:last-child) {
	-webkit-margin-after: var(var(--c-text-gap), var(--space-block-small2));
	margin-block-end: var(--c-text-gap);
}
.c-text._mb {
	-webkit-margin-after: var(--space-block-small2);
	margin-block-end: var(--space-block-small2);
}
.c-text._center {
	text-align: center;
}
.c-textlink {
	color: var(--c-textlink-color, var(--color-primary));
	text-decoration: underline;
}
.c-textlink[target="_blank"]:after {
	content: "";
	display: inline-block;
	width: 10px;
	height: 7px;
	margin-left: 5px;
	background: url(../img/cmn/icon_external3.svg) no-repeat left top;
	background-size: 100% 100%;
	translate: 0 -2px;
}
.c-textlink:focus:focus-visible {
	text-decoration: none;
}
.c-textlink2 {
	display: inline-flex;
	gap: 10px;
	color: var(--color-primary-light2);
	font-size: 1rem;
	text-decoration: underline;
}
.c-textlink2:focus:focus-visible {
	text-decoration: none;
}
@media not all and (max-width: 768px) {
	.c-text._pc_center {
		text-align: center;
	}
}
/* +++++++++

追加した共通パーツ

++++++++ */
/* googlemapテキストリンク */
.link-googlemap {
	margin-block-start: 0.25rem;
}
.link-googlemap a {
	color: var(--color-sub1);
	font-size: 14px;
	text-decoration: none;
}
.link-googlemap a:before {
	content: "";
	display: inline-block;
	background: url("../img/cmn/icon_pin.svg") no-repeat;
	width: 14px;
	height: 18px;
	margin-inline-end: 8px;
}
/* 注釈テキスト */
.c-notes {
	font-size: 14px;
}
/* 診療時間 */
.clinic-hours-table {
	width: 100%;
	max-width: 480px;
	text-align: center;
	border-collapse: separate;
	border-spacing: 0 10px;
	caption-side: bottom;
	font-weight: 500;
	/*margin-block-start: -10px;*/
}
.clinic-hours-table caption {
	text-align: left;
}
.clinic-hours-table caption span {
	font-size: 14px;
}
.clinic-hours-table td {
	font-size: 18px;
	padding: 5px 7px;
}
.clinic-hours-table th {
	font-size: 17px;
	padding: 5px 7px;
}
.clinic-hours-table tr:first-child th {
	padding: 0 5px;
}
.clinic-hours-table tr:first-child th:first-child {
	color: var(--color-primary);
	font-size: 18px;
	padding: 0 26px;
}
.clinic-hours-table tr:not(:first-child) td {
	color: var(--color-primary);
}
.clinic-hours-table tr:not(:first-child) {
	background: rgba(var(--color-border-rgb), 0.5);
}
.clinic-hours-table tr:first-child th:last-child {
	padding-inline-end: 26px;
}
/* Instagram */
.bnr-instagram {
	border-radius: 0px 20px;
	background: rgba(var(--color-sub2-rgb), 0.05);
	border: 3px solid var(--color-sub2);
	margin-block: var(--space-block);
}
.bnr-instagram a {
	display: block;
	padding: 32px;
	text-decoration: none !important;
	position: relative;
}
.bnr-instagram a:hover img {
	opacity: 0.7;
}
.bnr-instagram-box {
	display: flex;
	max-width: 600px;
	margin-inline: auto;
	gap: 20px;
}
.bnr-instagram-follow {
	position: absolute;
	top: -20px;
	right: 10%;
	width: 200px;
	height: auto;
}
.bnr-instagram-icn {
	width: 60px;
	flex-shrink: 0;
}
.bnr-instagram-ttl {
	font-family: var(--ff-zen-maru);
	font-size: 24px;
	font-weight: 500;
	margin-block-end: 0.5rem;
}
.bnr-instagram-ttl span {
	display: inline-flex;
	align-items: first baseline;
	margin-inline-start: 10px;
	gap: 5px
}
.bnr-instagram-ttl span:after {
	content: "";
	display: block;
	background: url("../img/cmn/icon_arrow_w.svg")no-repeat left top;
	width: 16px;
	height: 16px;
}
/* instagram カルーセル */
.carousel-instagram {
	margin-inline: calc(50% - 50vw);
	padding-inline: calc(50vw - 50%);
	/*		border-radius: 0px 20px;*/
	background: rgba(var(--color-sub2-rgb), 0.05);
	border-block: 3px solid var(--color-sub2);
	margin-block: var(--space-block-small);
}
.carousel-instagram-main {
	position: relative;
	padding-block-start: var(--space-block-small);
}
.carousel-instagram-follow {
	position: absolute;
	top: -30px;
	right: 10%;
	width: 200px;
	height: auto;
}
.carousel-instagram-main-inner {
	display: flex;
	max-width: 600px;
	margin-inline: auto;
	gap: 20px;
}
.carousel-instagram-icn {
	width: 60px;
	flex-shrink: 0;
}
.carousel-instagram-ttl {
	font-family: var(--ff-zen-maru);
	font-size: 24px;
	font-weight: 500;
	margin-block-end: 0.5rem;
}
.carousel-instagram-ttl span {
	display: inline-flex;
	align-items: first baseline;
	margin-inline-start: 10px;
	gap: 5px
}
.carousel-instagram-ttl span:after {
	content: "";
	display: block;
	background: url("../img/cmn/icon_arrow_w.svg")no-repeat left top;
	width: 16px;
	height: 16px;
}
.carousel-instagram-wrap {
	margin-inline: calc(50% - 50vw);
	padding-block: var(--space-block);
	overflow: hidden;
	display: flex;
}
/* 右から左に流れるアニメーション */
@keyframes infinity-scroll-left {
	from {
		transform: translateX(0);
	}
	to {
		transform: translateX(-100%);
	}
}
.carousel-instagram-list {
	display: flex;
	animation: infinity-scroll-left 80s infinite linear 0.5s both;
}
.carousel-instagram-wrap:hover .carousel-instagram-list {
	animation-play-state: paused;
}
.carousel-instagram-item {
	margin-inline: var(--space-block-small2);
	flex-shrink: 0;
	width: calc(100vw / 8);
	min-width: 200px;
	height: auto;
}
.carousel-instagram-item img {
	object-fit: cover;
}
@media (max-width: 768px) {
	.clinic-hours-table tr:first-child th:first-child {
		color: var(--color-primary);
		font-size: 13px;
		padding: 0 16px;
	}
	.clinic-hours-table th {
		font-size: 13px;
		padding: 5px 5px;
	}
	.clinic-hours-table td {
		font-size: 13px;
	}
	.bnr-instagram {
		margin-block: var(--space-block-small);
	}
	.bnr-instagram a {
		display: block;
		padding: 20px 16px;
	}
	.bnr-instagram-box, .carousel-instagram {
		gap: 12px;
		font-size: 12px;
	}
	.carousel-instagram {
		padding: 20px 16px;
		margin-block: var(--space-block-small);
	}
	.bnr-instagram-follow, .carousel-instagram-follow {
		position: absolute;
		top: -15px;
		right: 5%;
		width: 100px;
		height: auto;
	}
	.carousel-instagram-follow {
		top: -35px;
	}
	.carousel-instagram-main {
		padding-block-start: 0;
	}
	.bnr-instagram-icn, .carousel-instagram-icn {
		width: 40px;
		flex-shrink: 0;
	}
	.bnr-instagram-ttl, .carousel-instagram-ttl {
		font-size: 18px;
	}
	.bnr-instagram-ttl span {}
	.carousel-instagram-wrap {
		padding-block: var(--space-block-small2) 0;
	}
	.carousel-instagram-item {
		margin-inline: var(--space-block-xs);
	}
}
/*=====

CTA

=====*/
/*共通ご予約・お問い合わせ */
.p-contact-cta {
	background: url("../img/cmn/contact-f-img.png") no-repeat center bottom, url("../img/cmn/contact-bg.jpg") no-repeat left top;
	background-size: 1000px, cover;
	padding-block-end: 160px !important;
}
.p-contact-cta__heading {
	font-family: var(--ff-zen-maru);
	font-size: 32px;
	font-weight: 500;
	margin-block-end: 20px;
	background: rgba(var(--color-bg-base-rgb), 0.6);
}
.p-contact-cta__chatch {
	max-width: 420px;
	width: 80%;
	margin-inline: auto;
	text-align: center;
	margin-block-end: 20px;
}
.p-contact-cta__wrap {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 46px;
	font-family: var(--ff-zen-maru);
}
@media (max-width: 768px) {
	.p-contact-cta {
		background-size: 100% auto, cover;
		padding-block-end: 13% !important;
	}
	.p-contact-cta__heading {
		font-size: 20px;
	}
	.p-contact-cta__wrap {
		grid-template-columns: repeat(1, 1fr);
		gap: 26px;
		width: 90%;
		margin-inline: auto;
	}
	.p-contact-cta__wrap .contact-item {
		font-size: 12px;
	}
}
/* スマホフッター固定お問い合わせパーツ */
.p-f-contact__inquiry {
	display: none;
}
@media (max-width: 768px) {
	.p-f-contact__inquiry {
		display: grid;
		grid-template-columns: 2fr 1fr 1fr;
		position: fixed;
		left: 0;
		bottom: 0;
		width: 100%;
		background: #fff;
		z-index: 2000;
	}
	.p-f-contact__item {
		position: relative;
		display: flex;
		/*flex-direction: column;*/
		align-items: center;
		justify-content: center;
		min-height: 52px;
		padding: 10px 5px 10px 0px;
		/*column-gap: 3px;*/
		border: 1px solid var(--color-sub2);
	}
	.p-f-contact__item:not(:first-child) {
		border-left: none;
	}
	.p-f-contact__inquiry a {
		text-decoration: none;
	}
}
/*=====

カテゴリーページ

=====*/
/*  診療案内一覧  */
/* 一覧ページ　ナビ部分 */
.category-nav__wrap {
	border-radius: 12px;
	margin-block: var(--space-block-xs);
	padding: var(--space-block-small);
	display: grid;
	grid-template-columns: 100px auto;
	align-items: center;
	gap: 54px;
}
.menu-concerns {
	background: rgba(var(--color-primary-rgb), 0.1);
}
.menu-departments {
	background: rgba(var(--color-sub3-rgb), 0.1);
}
.category-nav__wrap .category-nav__title {
	font-family: var(--ff-zen-maru);
	font-size: 24px;
	text-align: center;
	line-height: 1.5;
	font-weight: 500;
}
.menu-concerns .category-nav__title {
	color: var(--color-primary);
}
.menu-departments .category-nav__title {
	color: var(--color-sub3);
}
.category-nav__wrap .category-nav__links {
	display: flex;
	width: 100%;
	flex-wrap: wrap;
	gap: 12px 11px;
}
.category-nav__wrap .category-nav__list-item {
	flex-shrink: 0;
	font-weight: 500;
}
.category-nav__wrap .category-nav__list-item a {
	display: block;
	padding: 0 12px 2px;
	font-weight: 500;
	border-radius: 16px;
	border: 1px solid currentcolor;
	background: var(--color-bg-base);
	transition-duration: var(--sec-fast);
	transition-property: outline-offset, background-color;
	transition-timing-function: ease-in;
	text-decoration: none;
}
.category-nav__wrap .category-nav__list-item a:hover {
	text-decoration: none;
	color: var(--color-light);
	border: 1px solid currentcolor;
}
.menu-departments .category-nav__list-item a {
	color: var(--color-sub1);
}
.menu-concerns .category-nav__list-item a {
	color: var(--color-primary);
}
.menu-departments .category-nav__list-item a:hover {
	border: 1px solid var(--color-sub1);
	background: var(--color-sub1);
}
.menu-departments .category-nav__list-item a.current {
	border: 1px solid var(--color-sub1);
	background: var(--color-sub1);
	color: var(--color-light);
}
.menu-concerns .category-nav__list-item a:hover {
	border: 1px solid var(--color-primary);
	background: var(--color-primary);
}
.menu-concerns .category-nav__list-item a.current {
	border: 1px solid var(--color-primary);
	background: var(--color-primary);
	color: var(--color-light);
}
@media (max-width: 768px) {
	.category-nav__wrap {
		padding: 24px 10px;
		display: grid;
		grid-template-columns: 100px auto;
		align-items: center;
		gap: 20px;
		grid-template-columns: auto;
	}
	.category-nav__wrap .category-nav__title {
		font-size: 20px;
	}
	.category-nav__wrap .category-nav__title br {
		display: none;
	}
	.category-nav__wrap .category-nav__list-item a {
		font-size: 12px;
	}
}
/* 診療案内一覧ページ　メイン部分 */
.q-treatment-entries-main {
	padding-block-start: 80px;
}
.q-treatment-entries__list {
	max-width: 1000px;
}
.q-treatment-entries__list-item {
	margin-bottom: 39px;
}
@media (max-width: 768px) {
	.q-treatment-entries__list-item {
		margin-bottom: 50px;
	}
}
.q-treatment-entries__list-item a {
	display: grid;
	grid-template-columns: 52% 48%;
	position: relative;
	margin-bottom: 40px;
	border-radius: 12px;
	overflow: hidden;
	background: var(--color-bg-base);
	text-decoration: none;
}
@media (max-width: 768px) {
	.q-treatment-entries__list-item a {
		grid-template-columns: auto;
	}
}
.q-treatment-entries__list-item a .entries--img img {
	transition: 0.3s ease-in-out;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.q-treatment-entries__list-item a:hover {
	text-decoration: none;
}
.q-treatment-entries__list-item a:hover .entries--img img {
	opacity: 1;
	transform: scale(1.1);
}
.q-treatment-entries__list-item .entries--img {
	overflow: hidden;
	width: auto;
	height: 100%;
	object-fit: cover;
	aspect-ratio: 480/270;
}
@media (max-width: 768px) {
	.q-treatment-entries__list-item .entries--img {
		width: auto;
		aspect-ratio: 336/140;
		order: 1;
	}
}
.q-treatment-entries__list-item .entries--summary {
	padding: 40px;
	position: relative;
}
@media (max-width: 768px) {
	.q-treatment-entries__list-item .entries--summary {
		padding: 12px 20px 24px;
		width: auto;
		order: 2;
	}
}
.q-treatment-entries__list-item .entries--ttl {
	font-family: var(--ff-zen-maru);
	font-size: 32px;
	font-weight: 500;
	margin-bottom: 23px;
	display: flex;
	align-items: center;
	gap: 9px;
}
.q-treatment-entries__list-item .entries--ttl .list-icon img {
	width: 60px;
	height: auto;
}
@media (max-width: 768px) {
	.q-treatment-entries__list-item .entries--ttl .list-icon img {
		width: 40px;
		height: auto;
	}
}
.q-treatment-entries__list-item .entries--desc {
	font-family: var(--ff-zen-maru);
	margin-block-end: 16px;
}
.q-treatment-entries__list-item .entries--summary .entries--meta {
	display: flex;
	flex-wrap: wrap;
	margin-block-end: 10px;
	gap: 8px;
}
.q-treatment-entries__list-item .entries--summary .entries--meta .meta-tag {
	flex-shrink: 0;
	font-size: 12px;
	padding: 0 12px 2px;
	font-weight: 500;
	border-radius: 16px;
	border: 1px solid currentcolor;
}
.q-treatment-entries__list-item .entries--summary .entries--meta .meta-tag.tag-concerns {
	color: var(--color-primary);
}
.q-treatment-entries__list-item .entries--summary .entries--meta .meta-tag.tag-departments {
	color: var(--color-sub1);
}
@media (max-width: 768px) {
	.q-treatment-entries__list-item .entries--ttl {
		font-size: 20px;
		margin-bottom: 10px;
	}
	.q-treatment-entries__list-item .entries--desc {
		font-size: 13px;
	}
}
/*  診療案内詳細  */
/*詳細ページマークアップ　single markup style*/
.q-treatment-single .entries--meta {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	margin-block-end: 10px;
	gap: 8px;
}
.q-treatment-single .entries--meta .meta-tag {
	flex-shrink: 0;
	font-size: 12px;
	padding: 0 12px 2px;
	font-weight: 500;
	border-radius: 16px;
	border: 1px solid currentcolor;
}
.q-treatment-single .entries--meta .meta-tag.tag-concerns {
	color: var(--color-primary);
}
.q-treatment-single .entries--meta .meta-tag.tag-departments {
	color: var(--color-sub1);
}
.q-treatment-single .head__detail {
	display: flex;
	flex-wrap: wrap;
	gap: 60px;
	margin-top: 60px;
}
@media (max-width: 768px) {
	.q-treatment-single .head__detail {
		margin-top: 40px;
		gap: 20px;
	}
}
.q-treatment-single .head__detail--summary {
	max-width: 560px;
}
.q-treatment-single .head__detail--copy {
	font-size: 24px;
	font-family: var(--ff-zen-maru);
}
@media (max-width: 768px) {
	.q-treatment-single .head__detail--copy {
		font-size: 18px;
	}
}
.q-treatment-single .head__detail--copy_sub {
	margin-top: 32px;
}
@media (max-width: 768px) {
	.q-treatment-single .head__detail--copy_sub {
		margin-top: 20px;
		font-size: 14px;
	}
}
.q-treatment-single .head__detail--img {
	max-width: 380px;
}
.q-treatment-single .head__detail--img img {
	border-radius: 12px;
}
/*下記のような症状・お悩みに対応します*/
.symptom-response-section {
	padding: 65px;
	background: rgba(var(--color-primary-rgb), 0.1);
}
@media (max-width: 768px) {
	.symptom-response-section {
		padding: 65px 0;
		background: rgba(var(--color-primary-rgb), 0.1);
	}
}
.symptom-response__list {
	margin-block: 40px var(--space-block);
	display: flex;
	justify-content: center;
	/*display: grid;*/
	/*grid-template-columns: repeat(4, 1fr);*/
	gap: 40px;
	max-width: 1000px;
	margin-inline: auto;
	font-family: var(--ff-zen-maru);
	font-weight: 500;
}
@media (max-width: 768px) {
	.symptom-response__list {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: 40px 20px;
	}
}
.symptom-response__item {
	max-width: 220px;
	width: 100%;
}
.symptom-response__item .symptom-response__span {
	display: flex;
	align-items: center;
	border-radius: 12px;
	background: var(--color-bg-base);
	border: 2px solid var(--color-primary);
	padding: 30px 24px 20px;
	position: relative;
	font-size: 20px;
	line-height: 1.4;
	height: 100%;
	text-decoration: none;
}
.symptom-response__item .list-icon img {
	position: absolute;
	transform: translate(-50%, -55%);
	top: 0;
	left: 50%;
}
@media (max-width: 768px) {
	.symptom-response__item .symptom-response__span {
		font-size: 15px;
		padding: 22px 12px 12px;
	}
	.symptom-response__item .list-icon img {
		width: 48px;
		height: 48px;
	}
	.symptom-response__item .concerns__list-txt span {
		transform: translateY(10%);
	}
}
/* 南国ひとせ歯科の虫歯治療 */
.cavity-treatment-overview {
	position: relative;
}
.treatment-philosophy-description {
	max-width: 680px;
	margin: 80px auto -50px;
}
@media (max-width: 768px) {
	.treatment-philosophy-description {
		margin: 80px auto 0px;
	}
}
.treatment-philosophy-description__message {
	margin: 0 20px;
	font-size: 20px;
}
@media (max-width: 768px) {
	.treatment-philosophy-description__message {
		margin: 0 10px;
		font-size: 18px;
	}
}
.treatment-image {
	width: 200px;
	margin: 0 0 0 auto;
}
@media (max-width: 768px) {
	.treatment-image {
		width: 140px;
		margin: 0 70px 0 auto;
	}
}
.cavity-treatment-overview .c-bg {
	margin-inline-start: calc(50% - 50vw);
	padding-inline-start: calc(50vw - 50%);
	border-radius: 0 100px 0 0;
	padding-inline-end: 120px;
	margin-inline-end: -120px;
	position: relative;
	background: url("../img/top/greeting-bg.png") no-repeat left bottom var(--color-bg2-rgb);
}
@media (max-width: 1240px) {
	.cavity-treatment-overview .c-bg {
		padding-inline-end: 15px;
		margin-inline-end: -15px;
		background-size: 50% auto;
	}
}
@media (max-width: 768px) {
	.cavity-treatment-overview .c-bg {
		background-size: 187px auto;
	}
}
.treatment-features-list {
	margin-top: 60px;
}
.treatment-feature-item {
	display: flex;
	gap: 40px;
	margin-bottom: 60px;
}
@media (max-width: 768px) {
	.treatment-feature-item {
		flex-direction: column;
	}
}
.feature-description {
	max-width: 540px;
	width: 100%;
}
.feature-description .features-number {
	font-family: var(--ff-zen-maru);
	font-size: 24px;
	display: flex;
	align-items: flex-start;
	gap: 14px;
}
@media (max-width: 768px) {
	.feature-description .features-number {
		font-size: 18px;
	}
}
.feature-description .features-number span {
	font-size: 40px;
	display: grid;
	transform: translateY(-0.75rem);
	line-height: 1.25;
}
@media (max-width: 768px) {
	.feature-description .features-number span {
		font-size: 32px;
	}
}
.feature-description .features-number span:after {
	content: "";
	display: block;
	width: 100%;
	height: 3px;
	border-radius: 2px;
	background: var(--color-sub1);
}
.feature-description.features__title {
	font-family: var(--ff-zen-maru);
	font-size: 32px;
	font-weight: 500;
	color: var(--color-sub1);
	line-height: 1.5;
}
.pain-management-description {
	color: var(--color-sub1);
	font-size: 24px;
	font-weight: 500;
	font-family: var(--ff-zen-maru);
}
@media (max-width: 768px) {
	.pain-management-description {
		font-size: 20px;
	}
}
.generic-text-description {
	margin-top: 24px;
}
/*.q-about-features.sub-color .features-number span:after, .q-about-features.sub-color .c-heading3__title::before {*/
/*	background: var(--color-sub1);*/
/*}*/
/*.q-about-features.sub-color .features__title, .q-about-features.sub-color strong {*/
/*	color: var(--color-sub1);*/
/*}*/
.feature-image {
	max-width: 480px;
	width: 100%;
	height: 100%;
	object-fit: cover;
	aspect-ratio: 480/270;
}
.feature-image img {
	width: 100%;
	height: auto;
	object-fit: cover;
	aspect-ratio: 480/270;
}
/* 治療に用いる技術・専門機器など */
.treatment-technology-section {
	margin-top: 120px;
}
.technology-list {
	margin-top: 60px;
}
.treatment-technology-section .c-heading3__title::before {
	background: var(--color-sub1);
}
.treatment-process-section {}
.process-list {}
/* 治療の流れ */
.process-step {
	border-radius: 12px;
	background: #f8f8f8;
	border: 1px solid #a7e2e3;
	padding: 32px;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	gap: 20px;
	position: relative;
	margin-bottom: 45px;
}
@media (max-width: 768px) {
	.process-step {
		padding: 16px;
		gap: 16px;
	}
}
.process-step::after {
	content: '';
	background: url('../img/treatment/arrow_bottom.png') no-repeat center; /* 背景画像として指定 */
	background-size: 100%; /* 背景画像をコンテナサイズに合わせて調整 */
	display: block;
	width: 18px; /* 画像の幅 */
	height: 18px; /* 高さは自動 */
	position: absolute;
	left: 50%; /* 左から50%の位置に */
	bottom: -32px; /* 要素の下辺から-25pxの位置に */
	transform: translateX(-50%); /* X軸方向に-50%ずらして中央寄せ */
}
.process-step:last-child::after {
	content: none; /* 最後の要素には矢印を表示しない */
}
.step-indicator {
	width: max(90px, min(10vw, 10vh));
	height: max(90px, min(10vw, 10vh));
	background: #a7e2e3;
	border-radius: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	color: #ffffff;
}
@media (max-width: 768px) {
	.step-indicator {
		width: max(70px, min(10vw, 10vh));
		height: max(70px, min(10vw, 10vh));
	}
}
.step-indicator, .step-content {
	flex-shrink: 0; /* コンテンツの縮小を防ぐ */
}
.step-content {
	max-width: calc(100% - 120px);
}
@media (max-width: 768px) {
	.step-content {
		max-width: calc(100% - 90px);
	}
}
.step-label {
	line-height: 1;
}
.step-number {
	font-size: 36px;
	line-height: 1;
}
@media (max-width: 768px) {
	.step-number {
		font-size: 30px;
		line-height: 1;
	}
}
.step-title {
	font-size: 20px;
	color: #009ea2;
	margin-bottom: 12px;
}
@media (max-width: 768px) {
	.step-title {
		font-size: 18px;
	}
}
.faq-section {
	margin-bottom: 120px;
}
@media (max-width: 768px) {
	.faq-section {
		margin-bottom: 80px;
	}
}
.faq-item {
	margin-bottom: 40px;
}
.faq-question {
	font-size: 22px;
	margin-bottom: 20px;
	display: flex;
	justify-content: flex-start;
	align-items: center;
}
@media (max-width: 768px) {
	.faq-question {
		font-size: 16px;
		justify-content: flex-start;
		align-items: flex-start;
	}
}
.faq-label {}
.color-question {
	font-size: 32px;
	margin-right: 15px;
}
@media (max-width: 768px) {
	.color-question {
		font-size: 24px;
		line-height: 1;
	}
}
.faq-answer {
	background: rgba(65, 170, 237, 0.08);
	border-radius: 12px;
	padding: 32px;
	display: flex;
}
@media (max-width: 768px) {
	.faq-answer {
		padding: 16px;
	}
}
.color-answer {
	color: #E00A63;
	font-size: 32px;
	margin-right: 15px;
	line-height: 1;
}
@media (max-width: 768px) {
	.color-answer {
		font-size: 24px;
		line-height: 1;
		margin-right: 15px;
	}
}
/*全画面*/
.g-wrapper {
	min-height: 100vh;
	min-height: 100svh;
	display: flex;
	flex-direction: column;
	background-color: var(--color-bg-base);
	overflow: hidden;
	position: relative;
}
@media (max-width: 1000px) {
	.g-wrapper {
		padding-top: var(--header-size);
	}
}
/*　ホバーアクション関連　*/
@media (hover: hover) and (pointer: fine) {
	.c-button:hover {
		text-decoration: none;
	}
	.c-button._theme1:hover {
		border-color: var(--color-primary);
		color: var(--color-light);
		background-color: var(--color-primary);
		--c-arrow-filter: invert(1) brightness(100);
	}
	.c-button._theme2:hover {
		border-color: var(--color-sub1);
		color: var(--color-light);
		background-color: var(--color-sub1);
		--c-arrow-filter: invert(1) brightness(100);
	}
	.c-button._theme2:hover:after {
		filter: invert(1) brightness(100);
	}
	.c-textlink:hover {
		text-decoration: none;
	}
	.c-textlink2:hover {
		text-decoration: none;
	}
	.p-categories__list a:hover {
		text-decoration: none;
		color: var(--color-light);
		background-color: var(--color-primary);
	}
	.p-pager__post:hover {
		text-decoration: none;
		--p-pager-img-scale: var(--zoom);
	}
	.p-pager__back:hover {
		text-decoration: none;
	}
	.p-post__item:hover {
		text-decoration: none;
		--q-post-img-scale: var(--zoom);
	}
	.wp-pagenavi a:hover {
		--svg-filter: invert(1) brightness(100);
		color: var(--color-light);
		background-color: var(--color-primary);
	}
	.post_text a:hover {
		text-decoration: none;
	}
	.g-footer .pagetop__button:hover {
		background: var(--color-primary);
		--svg-main-color: var(--color-light);
	}
	.g-footer .button__link:hover {
		text-decoration: none;
		color: var(--color-base);
		background-color: var(--color-light);
		--g-button-filter: none;
	}
	.g-footer .sns__item:hover {
		opacity: var(--opacity);
	}
	.q-policy a:hover {
		text-decoration: none;
	}
	.q-top-mv .navi__textlink:hover {
		text-decoration: none;
		border-block-end-color: transparent;
	}
	.q-top-recruit .recruit-link a:hover {
		text-decoration: none;
	}
}
@media (max-width: 768px) {
	.l-column {
		grid-template-columns: repeat(1, 1fr);
	}
	.l-column._subgrid > .l-column__item {
		grid-template-columns: repeat(1, 1fr);
	}
}
/*++++++
TOPページ
++++++*/
/* TOPメインビジュアル*/
.q-top-mv {
	position: relative;
}
.q-top-mv .mv {
	display: grid;
	/*margin-inline: 30px;*/
	min-height: 620px;
}
.q-top-mv .detail, .q-top-mv .slide {
	grid-column: 1/2;
	grid-row: 1/2;
}
.q-top-mv .detail {
	position: relative;
	z-index: 500;
	display: flex;
	max-width: 1200px;
	width: 100%;
	margin: 0 auto;
	/*justify-content: flex-end;*/
	row-gap: 20px;
	align-items: flex-end;
	/*	padding: var(--space-block) var(--space-inline);*/
}
.q-top-mv .logo {
	display: inline-flex;
	background: rgba(255, 255, 255, 0.8);
	line-height: 1.3;
	border-radius: 0px 40px 0px 0px;
	padding: 28px 34px 24px 34px;
	margin-inline-start: calc(50% - 50vw);
	padding-inline-start: calc(50vw - 55%);
	margin-inline-end: calc(50% - 50vw);
}
.q-top-mv .logo picture {
	flex-shrink: 0;
}
.q-top-mv .logo picture img {
	width: 108px;
	transform: translateY(15%);
}
.q-top-mv .logo .lead-txt {
	font-family: var(--ff-zen-maru);
	font-size: 36px;
	font-weight: 500;
	letter-spacing: 0.05em;
	text-shadow: 1px 1px 2px #fff;
	display: flex;
	align-items: flex-start;
	flex-direction: column;
	justify-content: flex-start;
	margin-inline-start: 10px;
}
.q-top-mv .logo .lead-txt span {
	font-size: 28px;
	display: block;
	margin-block-start: 10px;
}
.q-top-mv .open-img {
	position: absolute;
	right: 0;
	bottom: 0;
	transform: translateY(50%);
}
@media (max-width: 1000px) {
	.q-top-mv .logo {
		flex-direction: column;
		padding: 10px 20px;
		max-width: 65%;
	}
	.q-top-mv .logo picture {
		margin-block-end: 10px;
	}
	.q-top-mv .logo .lead-txt {
		font-size: 24px;
	}
	.q-top-mv .logo .lead-txt span {
		font-size: 16px;
	}
	.q-top-mv .open-img {
		width: 32%;
		height: auto;
		right: 20px;
	}
}
.q-top-mv .slide {
	position: relative;
}
.q-top-mv .slide__wrap {
	display: grid;
	height: 100%;
}
.q-top-mv .slide__item {
	opacity: 0;
	position: relative;
	grid-column: 1/2;
	grid-row: 1/2;
}
.q-top-mv .slide__img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}
.q-top-mv .slide__thumb {
	display: none;
	/*	position: absolute;
	z-index: 500;
	bottom: 30px;
	right: 30px;
	display: flex;
	flex-wrap: wrap;
	gap: 20px;*/
}
.q-top-mv .slide__button {
	position: relative;
	isolation: isolate;
	width: 40px;
	height: 3px;
	border: 1px solid var(--color-border);
}
.q-top-mv .slide__button.is-active {
	border-color: var(--color-light);
	background-color: var(--color-light);
}
.q-top-mv .slide__button::before {
	content: "";
	position: absolute;
	z-index: -10;
	inset: -25px -10px;
}
.q-top-mv__nav {
	/*background: #ffffff;*/
	background: rgba(255, 255, 255, 0.8);
	box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.25), 0 4px 8px 0 rgba(255, 255, 255, 0.25);
	padding: 28px 50px;
	margin: 2rem auto;
	width: 100%;
	max-width: 1000px;
	margin-top: 30px;
	font-weight: bold;
}
@media (max-width: 768px) {
	.q-top-mv__nav {
		display: none;
	}
	.q-top-mv .open-img img {
		width: 171px;
		height: auto;
	}
} /*
.q-top-mv__nav[data-sticky="true"] {
	position: fixed;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
}
.q-top-mv__nav--list {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}
.q-top-mv__nav--item.__border {
	border-left: 2px #005024 solid;
	padding-left: 10px;
}
.q-top-mv__nav--item.__no {
	font-weight: normal !important;
}*/
@media not all and (max-width: 768px) {
	.q-top-mv .navi__area {
		flex-basis: 290px;
	}
}
/* 診療案内 */
.q-top-guidance .guidance__wrap {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 30px 40px;
}
.q-top-guidance .guidance__item {
	/*	display: grid;
	grid-template-columns: 230px 1fr;*/
	/*	box-shadow: 0 3px 6px rgba(var(--color-dark-rgb), 0.16);*/
}
.q-top-guidance .info-address {
	margin-block-start: 24px;
}
.q-top-guidance .info-clinic-hours {}
@media (max-width: 768px) {
	.q-top-mv .mv {
		min-height: 375px;
		margin-inline: 0;
	}
	.q-top-mv .detail {
		/*padding-block-start: var(--space-block-small);*/
		padding-inline: calc(var(--space-inline) * 2);
	}
	.q-top-mv .navi {
		flex-direction: column-reverse;
		row-gap: 15px;
		width: 100%;
		max-width: 335px;
		margin-inline: auto;
	}
	.q-top-mv .navi__link {
		-webkit-margin-before: 5px;
		margin-block-start: 5px;
	}
	.q-top-mv .navi__textlink {
		margin-inline: -10px -20px;
	}
	.q-top-mv .slide__thumb {
		bottom: var(--space-block-xs);
		right: 0;
		width: 100%;
		justify-content: center;
		display: none;
	}
	.q-top-mv .button {
		min-height: 45px;
		font-size: 0.875rem;
	}
	.q-top-guidance .guidance__wrap {
		grid-template-columns: 1fr;
	}
	.guidance__wrap .guidance__item.info-txt {
		order: 2;
	}
	.guidance__wrap .guidance__item.info-clinic-hours {
		order: 1;
	}
}
/* ご挨拶 */
.q-top-greeting .c-bg {
	margin-inline-start: calc(50% - 50vw);
	padding-inline-start: calc(50vw - 50%);
	border-radius: 0 100px 0 0;
	padding-inline-end: 120px;
	margin-inline-end: -120px;
	position: relative;
	background: url("../img/top/greeting-bg.png") no-repeat left bottom var(--color-bg2-rgb);
}
@media (max-width: 1240px) {
	.q-top-greeting .c-bg {
		padding-inline-end: 15px;
		margin-inline-end: -15px;
		background-size: 50% auto;
	}
}
@media (max-width: 768px) {
	.q-top-greeting .c-bg {
		background-size: 187px auto;
	}
}
.q-top-greeting .message__wrap {
	display: grid;
	grid-template-columns: auto 264px;
	gap: 0px 70px;
}
.q-top-greeting .message__item {
	/*	display: grid;
	grid-template-columns: 230px 1fr;*/
	/*	box-shadow: 0 3px 6px rgba(var(--color-dark-rgb), 0.16);*/
}
.q-top-greeting .greeting-txt {
	margin-block-end: 22px;
	font-family: var(--ff-zen-maru);
	font-size: 17px;
}
.q-top-greeting .greeting-name {
	margin-block-end: 22px;
	text-align: right;
	font-size: 16px;
}
@media (max-width: 768px) {
	.q-top-greeting {
		margin-block-start: 30px;
	}
	.q-top-greeting .message__wrap {
		grid-template-columns: repeat(1, 1fr);
		margin-block-start: 80px;
	}
	.q-top-greeting .greeting-txt {
		position: relative;
		z-index: 2;
	}
	.q-top-greeting .greeting-img {
		position: absolute;
		top: 0;
		right: 0;
		z-index: 1;
		transform: translate(-10%, -70px);
		width: 44%;
		text-align: end;
	}
}
/* 診療メニュー */
.q-top-menu {
	background: var(--color-base-light3);
	margin-block: var(--space-block) 0;
}
.q-top-menu .l-inner {
	max-width: 1160px;
}
.q-top-menu .menu__heading img {
	max-width: 240px;
	height: auto;
}
.q-top-menu .q-top-menu__list {
	margin-block: 40px var(--space-block);
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 40px;
	max-width: 1000px;
	margin-inline: auto;
	font-family: var(--ff-zen-maru);
	font-weight: 500;
}
.q-top-menu .concerns__list-item a {
	display: flex;
	align-items: center;
	border-radius: 12px;
	background: var(--color-bg-base);
	border: 2px solid var(--color-primary);
	padding: 30px 24px 20px;
	position: relative;
	font-size: 20px;
	line-height: 1.4;
	height: 100%;
	text-decoration: none;
}
.q-top-menu .concerns__list-item .concerns__list-txt {}
.q-top-menu .concerns__list-item .concerns__list-txt span {
	display: inline-flex;
	align-items: center;
	margin-inline-start: 5px;
}
.q-top-menu .concerns__list-item a:hover {
	text-decoration: none;
	opacity: 1;
	background-color: var(--color-sub2);
	color: var(--color-base);
}
.q-top-menu .concerns__list-item .list-icon {}
.q-top-menu .concerns__list-item .list-icon img {
	position: absolute;
	transform: translate(-50%, -55%);
	top: 0;
	left: 50%;
}
.q-top-menu .q-top-menu__list.departments__list {
	gap: 20px 40px;
	margin-block: 20px var(--space-block);
}
.q-top-menu .departments__list-item a {
	display: flex;
	align-items: center;
	border-radius: 12px;
	background: url("../img/top/menu-arrow-departments.svg") no-repeat right 20px center var(--color-bg-base);
	border: 2px solid var(--color-sub3);
	padding: 20px 40px 20px 20px;
	position: relative;
	font-family: var(--ff-zen-maru);
	font-size: 20px;
	line-height: 1.4;
	height: 100%;
	text-decoration: none;
}
.q-top-menu .departments__list-item a:hover {
	text-decoration: none;
	opacity: 1;
	background-color: var(--color-sub4);
	color: var(--color-base);
}
@media (max-width: 768px) {
	.q-top-menu .menu__heading img {
		min-width: 141px;
		width: 45%;
		height: auto;
	}
	.q-top-menu .q-top-menu__list {
		grid-template-columns: repeat(2, 1fr);
		gap: 40px 20px;
	}
	.q-top-menu .concerns__list-item a {
		font-size: 15px;
		padding: 22px 12px 12px;
	}
	.q-top-menu .concerns__list-item .list-icon img {
		width: 48px;
		height: 48px;
	}
	.q-top-menu .concerns__list-item .concerns__list-txt span {
		transform: translateY(10%);
	}
	.q-top-menu .q-top-menu__list.departments__list {
		gap: 20px;
	}
	.q-top-menu .departments__list-item a {
		padding: 15px 40px 15px 12px;
		font-size: 16px;
	}
}
/* 採用情報 */
.q-top-recruit {}
.q-top-recruit .recruit-wrap {}
.q-top-recruit .recruit-item {
	border-radius: 12px;
	background: #f8f8f8;
	border: 1px solid #a7e2e3;
	padding: 32px;
}
.q-top-recruit .recruit-professions {
	font-size: 20px;
	font-weight: 700;
}
.q-top-recruit .recruit-job {
	margin-block: var(--space-block-xs);
}
.q-top-recruit .recruit-job dt {
	font-size: 18px;
	font-weight: 700;
}
.q-top-recruit .recruit-link {}
.q-top-recruit .recruit-link a {
	color: var(--color-primary);
	display: flex;
	justify-content: center;
	align-items: center;
}
.q-top-recruit .recruit-link a[target="_blank"]:after {
	content: "";
	display: inline-block;
	width: 16px;
	height: 16px;
	margin-left: 5px;
	background: url(../img/cmn/arrow-up-right-from-square-solid.svg) no-repeat left top;
	background-size: 100% 100%;
}
@media (max-width: 768px) {
	.q-top-recruit .recruit-item {
		padding: 16px;
	}
	.q-top-recruit .recruit-professions {
		font-size: 18px;
	}
	.q-top-recruit .recruit-job {
		margin-block: 10px;
	}
	.q-top-recruit .recruit-job dt {
		font-size: 16px;
	}
}
/* 概要 */
.q-top-outline {}
.q-top-outline .outline__heading {
	font-family: var(--ff-zen-maru);
	font-size: 24px;
	font-weight: 500;
	margin-block-end: 20px;
}
/*@media (max-width: 1100px) {
	.q-top-outline {
		margin-top: 60px;
	}
}
@media (max-width: 768px) {
	.q-top-outline {
		padding: 30px 0 0;
		margin-top: 30px;
	}
}*/
/*.outline__wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 160px; }*/
.q-top-outline .outline__wrap {
	display: grid;
	grid-template-columns: 2fr 1fr;
	gap: 0px 100px;
	margin-inline-start: calc(50% - 50vw);
	margin-inline-end: calc(50% - 50vw);
	padding-inline-end: calc(50vw - 50%);
}
.q-top-outline .outline__wrap .outline__img img {
	width: 100%;
	height: auto;
	object-fit: cover;
	border-radius: 0 100px 0 0;
}
.q-top-outline .outline__wrap .outline__txt {}
.q-top-outline .outline__wrap .outline__table {
	border-top: 1px solid var(--color-border);
	table-layout: auto;
	width: 100%;
}
.q-top-outline .outline__wrap .outline__table th, .outline__wrap .outline__table td {
	border-bottom: 1px solid var(--color-border);
	padding: 20px;
}
@media (max-width:1000px) {
	.q-top-outline .outline__wrap {
		grid-template-columns: repeat(1, 1fr);
		gap: 30px;
		margin-inline-start: 0;
		margin-inline-end: 0;
		padding-inline-end: 0;
	}
	.q-top-outline .outline__wrap .outline__img {
		margin-inline-start: calc(50% - 50vw);
		max-width: 87%;
	}
	.q-top-outline .outline__heading {
		font-size: 20px;
	}
}
/*++++++
ひとせ歯科の特長	
++++++*/
/* お約束 */
.q-about-promise {
	margin-block-end: 100px;
}
.q-about-promise .c-heading2__title {
	font-size: 28px;
	color: var(--color-primary);
}
.q-about-promise .c-bg {
	background: url("../img/top/greeting-bg.png") no-repeat right bottom, url("../img/about/promise-bg.png") no-repeat left top 20px;
	background-size: 380px 149px, cover;
	margin-inline: calc(50% - 50vw);
	padding-inline: calc(50vw - 50%);
}
.q-about-promise .message__wrap {
	display: grid;
	grid-template-columns: 2fr 1fr;
	gap: 0px 40px;
}
.q-about-promise .message__item {
	/*	display: grid;
	grid-template-columns: 230px 1fr;*/
	/*	box-shadow: 0 3px 6px rgba(var(--color-dark-rgb), 0.16);*/
}
.q-about-promise .promise-catch {
	font-family: var(--ff-zen-maru);
	font-weight: 500;
	font-size: 32px;
	line-height: 1.4;
	margin-block-end: 60px;
}
.q-about-promise .promise-txt {
	margin-block-end: 22px;
}
.q-about-promise .directors-name {
	text-align: right;
}
.q-about-promise .accordion__wrap {
	border-top: 1px solid var(--color-primary);
	border-bottom: 1px solid var(--color-primary);
	padding: 10px;
	margin-block: 20px;
}
.q-about-promise .message__wrap .toggle {
	display: none;
}
.q-about-promise .message__wrap .Label { /*タイトル*/
	display: block;
	cursor: pointer;
	font-family: var(--ff-zen-maru);
	font-weight: 500;
	font-size: 18px;
	color: var(--color-primary);
}
.q-about-promise .message__wrap .Label::after { /*タイトル横の矢印*/
	content: "";
	width: 10px;
	height: 10px;
	border-top: 2px solid var(--color-primary);
	border-right: 2px solid var(--color-primary);
	-webkit-transform: rotate(45deg);
	display: block;
	position: absolute;
	top: calc(50% - 3px);
	right: 20px;
	transform: rotate(135deg);
	margin-inline-start: auto;
}
.q-about-promise .message__wrap .accordion {
	flex-wrap: wrap;
	width: 100%;
}
.q-about-promise .message__wrap .Label, .q-about-promise .message__wrap .accordion-inner {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	transform: translateZ(0);
	transition: all 0.3s;
}
.q-about-promise .message__wrap .accordion-inner { /*本文*/
	height: 0;
	margin-bottom: 10px;
	overflow: hidden;
}
.q-about-promise .message__wrap .toggle:checked + .Label + .accordion-inner { /*開閉時*/
	height: auto;
	padding-block: 14px;
	transition: all .3s;
}
.q-about-promise .message__wrap .toggle:checked + .Label::after {
	transform: rotate(-45deg) !important;
}
@media (max-width: 1240px) {
	.q-about-promise .c-bg {
		padding-inline-end: 15px;
		margin-inline-end: -15px;
	}
}
@media (max-width: 768px) {
	.q-about-promise {
		margin-block-end: 0;
	}
	.q-about-promise .c-bg {
		background-size: 262px 103px, cover;
	}
	.q-about-promise .message__wrap {
		grid-template-columns: repeat(1, 1fr);
	}
	.q-about-promise .promise-txt {
		order: 2;
	}
	.q-about-promise .promise-catch {
		font-size: 24px;
		margin-block-end: 32px;
	}
	.q-about-promise .promise-img {
		width: 50%;
		margin: 0 auto 20px;
		order: 1;
	}
}
/* 特長 */
.q-about-features {
	position: relative;
	z-index: 1;
}
.q-about-features .features-number {
	font-family: var(--ff-zen-maru);
	font-size: 24px;
	display: flex;
	align-items: center;
	gap: 14px;
}
.q-about-features .features-number span {
	font-size: 60px;
	display: grid;
	transform: translateY(-0.75rem);
	line-height: 1.25;
}
.q-about-features .features-number span:after {
	content: "";
	display: block;
	width: 52px;
	height: 3px;
	border-radius: 2px;
	background: var(--color-primary);
}
.q-about-features .features__title {
	font-family: var(--ff-zen-maru);
	font-size: 32px;
	font-weight: 500;
	color: var(--color-primary);
	line-height: 1.5;
}
.q-about-features.sub-color .features-number span:after, .q-about-features.sub-color .c-heading3__title::before {
	background: var(--color-sub1);
}
.q-about-features.sub-color .features__title, .q-about-features.sub-color strong {
	color: var(--color-sub1);
}
/* 特長3 */
.equipment-list {
	margin-block-end: 40px;
}
.equipment-list h4 {
	font-family: var(--ff-zen-maru);
	color: var(--color-sub1);
	font-size: 18px;
	font-weight: 500;
	margin-block: 0 0.5rem;
}
.equipment-list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 24px var(--space-block);
}
.equipment-sublist {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 20px 24px;
}
@media (max-width: 768px) {
	.equipment-list {
		gap: 20px;
	}
	.equipment-sublist {
		grid-template-columns: repeat(1, 1fr);
		gap: 8px;
	}
}
#about-features01.q-about-features:before {
	content: "";
	display: block;
	min-width: 600px;
	width: 100%;
	height: 500px;
	border-radius: 0px 100px 0px 0px;
	background: rgba(var(--color-primary-rgb), 0.08);
	position: absolute;
	top: 0;
	right: calc(50% + 150px);
	z-index: -1;
}
#about-features02.q-about-features:before {
	content: "";
	display: block;
	min-width: 600px;
	width: 100%;
	height: 500px;
	border-radius: 100px 0px 0px 0px;
	background: rgba(var(--color-sub3-rgb), 0.08);
	position: absolute;
	top: 0;
	left: calc(50% + 150px);
	z-index: -1;
}
#about-features03.q-about-features:before {
	content: "";
	display: block;
	min-width: 600px;
	width: 100%;
	height: 500px;
	border-radius: 0px 100px 0px 0px;
	background: rgba(var(--color-sub3-rgb), 0.08);
	position: absolute;
	top: 0;
	right: calc(50% + 150px);
	z-index: -1;
}
#about-features04.q-about-features:before {
	content: "";
	display: block;
	min-width: 600px;
	width: 100%;
	height: 500px;
	border-radius: 100px 0px 0px 0px;
	background: rgba(var(--color-primary-rgb), 0.08);
	position: absolute;
	top: 0;
	left: calc(50% + 150px);
	z-index: -1;
}
@media (max-width: 768px) {
	.q-about-features .l-inner {
		/*		margin-block-start:-100px !important;*/
	}
	.q-about-features .features__title {
		font-family: var(--ff-zen-maru);
		font-size: 24px;
	}
	.q-about-features .features-number {
		font-size: 18px;
		gap: 14px;
	}
	.q-about-features .features-number span {
		font-size: 48px;
		transform: translateY(-0.5rem);
	}
	.q-about-features .features-number span:after {
		content: "";
		width: 46px;
	}
	#about-features01.q-about-features:before {
		content: "";
		display: block;
		width: 100%;
		height: calc(100% - 80px);
		top: 80px;
		right: 0;
		z-index: -1;
	}
	#about-features02.q-about-features:before {
		content: "";
		display: block;
		width: 100%;
		height: calc(100% - 80px);
		top: 80px;
		left: 0;
	}
	#about-features03.q-about-features:before {
		content: "";
		display: block;
		width: 100%;
		height: calc(100% - 80px);
		top: 80px;
		right: 0;
	}
	#about-features04.q-about-features {
		margin-block-end: 80px;
	}
	#about-features04.q-about-features:before {
		content: "";
		width: 100%;
		height: calc(100% - 80px);
		top: 80px;
		left: 0;
	}
}
/*++++++
来院案内・アクセス
++++++*/
.q-access-information {}
.q-access-information .outline__wrap {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0px 40px;
	margin-inline-start: calc(50% - 50vw);
	margin-inline-end: calc(50% - 50vw);
	padding-inline-end: calc(50vw - 50%);
	margin-block: 72px 80px;
}
.q-access-information .outline__wrap .outline__img img {
	width: 100%;
	height: auto;
	max-height: 423px;
	object-fit: cover;
	border-radius: 0px 24px 0px 0px;
}
.q-access-information .outline__wrap .outline__txt {
	display: grid;
	place-content: end;
}
.q-access-information .clinic-hours-table {
	margin-block-start: 20px;
}
@media (max-width:1000px) {
	.q-access-information .outline__wrap {
		grid-template-columns: repeat(1, 1fr);
		gap: 30px;
		margin-inline-start: 0;
		margin-inline-end: 0;
		padding-inline-end: 0;
		margin-block: 40px 20px;
	}
	.q-access-information .outline__wrap .outline__img {
		margin-inline-start: calc(50% - 50vw);
		max-width: 87%;
	}
}
.q-access-information .information-map figure {
	margin-block: 20px 40px;
}
.q-access-information .information-map__floor {
	display: grid;
	gap: 20px;
	margin-block: 60px 20px;
	grid-template-columns: repeat(2, 1fr);
}
.q-access-information .information-map__floor .floor__item {
	font-size: 14px;
	text-align: center;
}
@media (max-width: 768px) {
	.q-access-information .information-map__floor {
		margin-block: 20px;
		grid-template-columns: repeat(2, 1fr);
	}
}
.q-access-information .parking-detail {
	display: grid;
	grid-template-columns: repeat(2, max-content);
}
.q-access-information .parking-detail dt {
	font-weight: 500;
	color: var(--color-primary);
}
/* アクセス　詳細 */
.q-access-information .outline__wrap2 {
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: 0px 40px;
	margin-inline-end: calc(50% - 50vw);
	margin-inline-start: calc(50% - 50vw);
	padding-inline-start: calc(50vw - 50%);
	margin-block: 60px;
}
.q-access-information .outline__wrap2 .outline__img {
	order: 2;
}
.q-access-information .outline__wrap2 .outline__img img {
	width: 100%;
	height: auto;
	max-height: 423px;
	object-fit: cover;
	border-radius: 24px 0px 0px 0px;
}
.q-access-information .outline__wrap2 .outline__txt {
	order: 1;
}
.q-access-information .clinic-hours-table {
	margin-block-start: 20px;
}
.q-access-information .c-tel {
	border: 1px solid var(--color-border);
	border-radius: 40px;
	padding: 10px 30px;
	margin-block: 24px 16px;
	margin-inline: 0;
}
.q-access-information .c-tel__number {
	font-size: 32px;
}
.q-access-information .c-tel__number a {
	text-decoration: none;
}
.q-access-information .c-tel__icon {
	width: 28px;
	height: auto;
}
@media (max-width:1000px) {
	.q-access-information .outline__wrap2 {
		grid-template-columns: repeat(1, 1fr);
		gap: 30px;
		margin-inline: 0;
		padding-inline: 0;
	}
	.q-access-information .outline__wrap2 .outline__img {
		margin-inline: auto calc(50% - 50vw);
		order: 1;
		max-width: 87%;
	}
}
.q-access-details .parking__wrap {}
.q-access-details .parking__item.parking__txt {
	font-size: 18px;
}
.q-access-details .parking__item.parking-txt .parking-priority {
	/*	border-radius: 12px;
	background: rgba(var(--color-primary-rgb), 0.08);
	margin-block: 24px;
	padding: 30px;*/
}
.q-access-details .parking__item.parking-txt .parking-detail {
	display: grid;
	grid-template-columns: repeat(2, max-content);
}
.q-access-details .parking__item.parking-txt .parking-detail dt {
	font-weight: 500;
	color: var(--color-primary);
}
@media (max-width: 768px) {
	.q-access-details .parking__wrap {
		grid-template-columns: repeat(1, 1fr);
	}
	.access-googlemap {
		margin-block-start: var(--space-block);
	}
}
.q-access-details__map {
	max-width: 680px;
	width: 100%;
	margin: 0 auto 40px;
	display: block;
}
.c-accordion {
	margin-bottom: 60px;
}
@media (max-width: 768px) {
	.c-accordion {
		margin-bottom: 40px;
	}
}
.c-accordion-ttl {
	font-weight: 500;
	font-size: 24px;
	text-align: left;
	padding: 14px 60px 14px 20px;
	color: #fff;
	background: var(--color-primary);
	position: relative;
	margin: 0;
	/*border-radius: 12px;*/
	border-top-right-radius: 12px;
	border-top-left-radius: 12px;
	position: relative;
	cursor: pointer;
	padding-right: 30px; /* 矢印とテキストのためのスペースを確保 */
	padding-left: 65px;
}
.c-accordion-ttl:hover {
	background-color: rgba(0, 158, 162, 0.8);
}
@media (max-width: 768px) {
	.c-accordion-ttl {
		padding: 10px 60px 10px 30px;
		font-size: 16px;
		padding-right: 40px;
		padding-left: 44px;
	}
}
.number-box {
	position: absolute; /* 親要素に対して絶対配置 */
	left: 0; /* 左端から配置 */
	top: 0; /* 上端から配置 */
	width: 30px; /* 枠の幅 */
	height: auto; /* 親要素と同じ高さにする */
	display: flex; /* Flexboxで中央寄せ */
	align-items: center; /* 垂直方向の中央寄せ */
	justify-content: center; /* 水平方向の中央寄せ */
	border: 1px solid #E00A63; /* 赤い枠線 */
	font-size: 0.75em; /* 通常のテキストより小さく */
	color: #E00A63; /* 文字色 */
	box-sizing: border-box; /* 枠線を内側に含める */
	border-radius: 5px;
	background: #fff;
	top: 27%;
	left: 20px;
}
@media (max-width: 768px) {
	.number-box {
		width: 23px;
		top: 15px;
		left: 12px;
	}
}
.c-accordion-ttl:before {
	content: '開ける'; /* 初期状態のテキスト */
	position: absolute;
	right: 30px;
	top: 45%;
	transform: translateY(-50%);
	transition: all 0.3s ease;
	font-size: 12px;
}
@media (max-width: 768px) {
	.c-accordion-ttl:before {
		right: 9px;
		top: 35%;
		font-size: 10px;
	}
}
.c-accordion-ttl:after {
	content: '';
	background-image: url('../img/cmn/icon_arrow_open.svg'); /* 矢印画像 */
	background-size: cover;
	background-repeat: no-repeat;
	width: 20px; /* 矢印のサイズ */
	height: 20px; /* 矢印のサイズ */
	position: absolute;
	right: 38px;
	top: 70%;
	transform: translateY(-50%);
	transition: transform 0.3s ease;
}
@media (max-width: 768px) {
	.c-accordion-ttl:after {
		width: 15px;
		height: 15px;
		position: absolute;
		right: 16px;
		top: 57%;
	}
}
.c-accordion-ttl.active:before {
	content: '閉じる'; /* 開いている状態のテキストに変更 */
}
.c-accordion-ttl.active:after {
	transform: translateY(-50%) rotate(-180deg); /* アイコンを回転させる */
}
.c-accordion-box {
	display: none;
	padding: 48px;
	background: #F8F8F8;
	border-bottom-right-radius: 12px;
	border-bottom-left-radius: 12px;
}
@media (max-width: 768px) {
	.c-accordion-box {
		/*display: none;*/
		padding: 20px;
	}
}
.c-accordion__copy {
	margin-bottom: 25px;
}
.c-col2-wrap {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 24px var(--space-block);
}
@media (max-width: 768px) {
	.c-col2-wrap {
		grid-template-columns: repeat(1, 1fr);
	}
}
/*++++++
404
++++++*/
.q-404 {}
.q-404 .l-inner {
	height: 50vh;
	min-height: 400px;
	display: flex;
	align-items: center;
	justify-content: space-around;
	flex-direction: column;
}

/*++++++
追加
++++++*/
.c-glink a[target="_blank"]::after {
	content: "";
	display: inline-block;
	width: 16px;
	height: 16px;
	margin-left: 5px;
	background: url(../img/cmn/arrow-up-right-from-square-solid.svg) no-repeat left top;
	background-size: auto;
	background-size: 100% 100%;
}