@charset "utf-8";
/*
Theme Name: kawasaki-ichouka3
Theme URI: https://kawasaki-ichouka.com
Version: 3.0
*/

@font-face {
	font-family: 'HalisGR-SLight';
	src: url('webfonts/39699D_11_0.eot');
	src: url('webfonts/39699D_11_0.eot?#iefix') format('embedded-opentype'),
	url('webfonts/39699D_11_0.woff2') format('woff2'),
	url('webfonts/39699D_11_0.woff') format('woff'),
	url('webfonts/39699D_11_0.ttf') format('truetype');
}

@font-face {
	font-family: 'HalisGR-SBook';
	src: url('webfonts/39699D_1C_0.eot');
	src: url('webfonts/39699D_1C_0.eot?#iefix') format('embedded-opentype'),
	url('webfonts/39699D_1C_0.woff2') format('woff2'),
	url('webfonts/39699D_1C_0.woff') format('woff'),
	url('webfonts/39699D_1C_0.ttf') format('truetype');
}

@font-face {
	font-family: 'HalisGR-Book';
	src: url('webfonts/39699D_6_0.eot');
	src: url('webfonts/39699D_6_0.eot?#iefix') format('embedded-opentype'),
	url('webfonts/39699D_6_0.woff2') format('woff2'),
	url('webfonts/39699D_6_0.woff') format('woff'),
	url('webfonts/39699D_6_0.ttf') format('truetype');
}


/* common
---------------------------------------------------------------------------*/
:root {
	--color-navy: #1C4370;
	--color-navy-light: #4C637E;
	--color-line-navy: #D5DCE5;
	--color-line-navy-light: #E6EAEF;
	--color-bg-blue-light: #F1F8F9;
	--color-bg-navy-light: #F2F4FB;
	--font-sans-slight: 'HalisGR-SLight', sans-serif;
	--font-sans-sbook: 'HalisGR-SBook', sans-serif;
	--font-sans-book: 'HalisGR-Book', sans-serif;
	--font-serif: 'ACaslonPro-Regular', sans-serif;
	--font-min-m: 'FOT-筑紫明朝 Pr6 M', '游明朝体', '游明朝', YuMincho, 'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN', 'ＭＳ Ｐ明朝', 'MS PMincho', serif;
	--font-min-d: 'FOT-筑紫明朝 Pr6 D', '游明朝体', '游明朝', YuMincho, 'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN', 'ＭＳ Ｐ明朝', 'MS PMincho', serif;
}

html, body { height: calc(100vh + env(safe-area-inset-bottom)); }
@media all and (-webkit-min-device-pixel-ratio:0) and (min-resolution: .001dpcm) {
	html, body { height: 100%; }
}

body {
	background-color: #FFFFFF;
	color: var(--color-navy);
	font-size: 13px;
	font-family: var(--font-min-m);
	line-height: 1;
	font-feature-settings: 'palt' 1;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-text-size-adjust: 100%;
}

body.noscroll { overflow-y: scroll; position: fixed; width: 100%; }

::-moz-selection { background: var(--color-bg-blue-light); color: var(--color-navy); }
::selection { background: var(--color-bg-blue-light); color: var(--color-navy); }

p { font-size: 13px; line-height: 1.9; letter-spacing: 0.04em; margin-bottom: 10px; }
p:last-of-type { margin-bottom: 0 !important; }
address,i { font-style: normal; }
img { max-width: none; }

.clearfix:after { content: ''; display: block; clear:both; }

.block { display: inline-block !important; }
.wide { display: none !important; }
.narrow { display: inline-block !important; }

/* #loading
------------------------------------*/
#loading {
	display: block;
	opacity: 1;
	position: fixed;
	top: 50%;
	left: 50%;
	border: 1px solid var(--color-navy);
	border-top-color: transparent;
	border-radius: 50%;
	width: 20px;
	height: 20px;
	margin: -10px 0 0 -10px;
	z-index: 99999;
	animation: spin .5s infinite linear;
}

@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }

/* link
------------------------------------*/
a { color: var(--color-navy); text-decoration: none; -webkit-transform: translateZ(0); }

.txt-line {
	display: inline-block;
	position: relative;
	padding-bottom: 3px;
}

p .txt-line {
	padding-bottom: 0;
	line-height: 1.5;
}

.txt-line:after {
	display: block;
	content: '';
	background-color: var(--color-navy);
	position: absolute;
	bottom: 0px;
	left: 0;
	width: 100%;
	height: 1px;
	opacity: 0.3;
}

/* .btn
------------------------------------*/
.btn-link a {
	display: inline-block;
	position: relative;
	background: #FFFFFF;
	border: 1px solid var(--color-line-navy);
	border-radius: 30px;
	padding: 12px;
	font-size: 13px;
	letter-spacing: 0.1em;
	text-align: center;
}

.btn-link.left a {
	padding: 11px 38px 11px 16px;
}

.btn-color a {
	background-color: var(--color-navy);
	border-color: var(--color-navy);
	color: #FFFFFF;
	opacity: 1;
}

.btn-link a:after {
	display: block;
	content: '';
	position: absolute;
	top: 50%;
	right: 14px;
	transform: translateY(-50%);
	background: url(img/share/ico-arrow-navy.svg) no-repeat;
	background-size: 100% auto;
	width: 16px;
	height: 12px;
}

.btn-color a:after {
	background-image: url(img/share/ico-arrow-white.svg);
}

#informationContents .btn-back {
	margin: 20px 0 0 calc(3% + 8px);
}

#informationContents .btn-back a {
	display: inline-block;
	padding: 10px 10px 10px 0;
	font-size: 13px;
	letter-spacing: 0.16em;
	white-space: nowrap;
}

#informationContents .btn-back i {
	display: inline-block;
	box-sizing: border-box;
	background: url(img/share/ico-arrow-navy.svg) no-repeat center center;
	background-size: 14px auto;
	border-radius: 50%;
	border: 1px solid var(--color-line-navy);
	width: 28px;
	height: 28px;
	margin: -16px 12px 0 -8px;
	transform: translateY(9px) scaleX(-1);
}

/* .btn-nav
------------------------------------*/
.btn-nav {
	position: fixed;
	top: 11px;
	right: 6px;
	box-sizing: border-box;
	width: 60px;
	height: 60px;
	z-index: 10000;
}

.btn-nav div, .btn-nav span {
	display: inline-block;
	box-sizing: border-box;
	transition: all .2s;
}

.btn-nav div {
	position: relative;
	width: 24px;
	height: 15px;
	margin: 22px 0 0 18px;
}

.btn-nav span {
	position: absolute;
	left: 0;
	background-color: var(--color-navy);
	width: 100%;
	height: 1px;
}

.btn-nav span:nth-of-type(1) { top: 0; }
.btn-nav span:nth-of-type(2) { top: 7px; }
.btn-nav span:nth-of-type(3) { bottom: 0; }

/* .btn-nav.active
------------------------------------*/
.btn-nav.active span:nth-of-type(1) { transform: translateY(7px) rotate(-45deg); }
.btn-nav.active span:nth-of-type(2) { animation: active-menu-bar02 .4s forwards; opacity: 0; }
.btn-nav.active span:nth-of-type(3) { transform: translateY(-7px) rotate(45deg); }
@-webkit-keyframes active-menu-bar02 {100%{ height: 0; }}
@keyframes active-menu-bar02 {100%{ height: 0; }}

/* .nav-sp
------------------------------------*/
.nav-sp {
	position: fixed;
	top: 0;
	left: 0;
	background: #FFFFFF;
	box-sizing: border-box;
	width: 75%;
	height: 100%;
	z-index: 9999;
	display: none;
	opacity: 0;
}

.bg-nav-sp {
	position: fixed;
	top: 0;
	left: 0;
	background: rgba(241,248,249,0.9);
	box-sizing: border-box;
	width: 100%;
	height: 100%;
	z-index: 9998;
	display: none;
	opacity: 0;
}

.nav-sp .inner {
	position: relative;
	overflow-y: scroll;
	box-sizing: border-box;
	width: 100%;
	height: 100%;
	padding: 95px 9% 45px;
	-webkit-overflow-scrolling: touch;
}

.nav-sp .logo {
	position: absolute;
	top: 32px;
	left: 6.5%;
}

.nav-sp .logo img {
	width: 200px;
	height: auto;
}

.nav-sp .gnav {
	margin-bottom: 35px;
}

#gnav-top {
	display: none;
}

.nav-sp .gnav > ul > li {
	border-bottom: 1px solid var(--color-line-navy-light);
}

.nav-sp .gnav > ul > li > a,
.nav-sp .gnav > ul > li > b {
	display: block;
	padding: 19px 0 19px 8px;
	font-size: 16px;
	letter-spacing: 0.1em;
}

.nav-sp .gnav > ul > li > a,
.nav-sp .mnav a {
	background: url(img/share/ico-arrow-navy.svg) no-repeat right 12px center;
	background-size: 14px auto;
}

.nav-sp .mnav {
	margin-top: -2px;
	padding: 0 0 19px 28px;
}

.nav-sp .mnav a {
	display: block;
	background-position: right 12px top 13px;
	padding: 9px 0;
	font-size: 14px;
	letter-spacing: 0.1em;
}

.nav-sp .mnav a span {
	padding-left: 4px;
	font-size: 12px;
	letter-spacing: 0.08em;
}

.nav-sp .close,
.nav-sp .tel {
	margin-left: 8px;
}

.nav-sp .close {
	margin-bottom: 14px;
	font-size: 12px;
	letter-spacing: 0.08em;
}

.nav-sp .tel {
	margin-left: 9px;
/* 	font-family: var(--font-sans-sbook); 表示されない */
	font-family: var(--font-sans-sbook);
	font-size: 24px;
	letter-spacing: 0.04em;
	opacity: 0.8;
}

.nav-sp .tel span {
	padding-right: 2px;
	font-family: var(--font-sans-book);
	font-size: 14px;
	letter-spacing: 0.08em;
}

/* .bg-navy
------------------------------------*/
.bg-navy { background-color: var(--color-bg-navy-light); }

/* .btn-reserve
------------------------------------*/
header .btn-reserve {
	display: none;
}

.btn-reserve {
	margin: 20px 0 0 6px;
}

.btn-reserve a {
	display: inline-block;
	position: relative;
	border: 1px solid var(--color-navy-light);
	border-radius: 30px;
	padding: 8px 16px 8px;
}

.btn-reserve img {
	width: auto;
	height: 15px;
}

header .btn-reserve-sp {
	position: absolute;
	top: 31px;
	right: 60px;
}

header .btn-reserve-sp a {
	display: inline-block;
	position: relative;
	border: 1px solid var(--color-navy-light);
	border-radius: 30px;
	padding: 9px 6px 9px 7px;
	font-size: 10px;
	line-height: 0;
	letter-spacing: 0.04em;
	white-space: nowrap;
}


/* #wrap
---------------------------------------------------------------------------*/
#wrap {
	overflow: hidden;
	min-height: 100vh;
}


/* header
---------------------------------------------------------------------------*/
header {
	box-sizing: border-box;
	width: 100%;
	min-height: 80px;
	margin: 0;
	padding: 32px 6.5% 0;
	white-space: nowrap;
	opacity: 0;
}

header .logo { width: 100%; }
header .logo img { width: 200px; height: auto; }

header .tel,
header .gnav,
header h1.narrow { display: none !important; }

body.top header h1.narrow {
	display: block !important;
	margin: 0 0 13px -1px;
	font-size: 11px;
	letter-spacing: 0.1em;
}

body.top header h1.narrow strong {
	color: #FFFFFF;
	font-size: 0;
}


/* footer
---------------------------------------------------------------------------*/
footer {
	position: relative;
	box-sizing: border-box;
	width: 100%;
	margin: 100px auto 0;
	padding: 0 7.5% 60px;
	white-space: nowrap;
}

footer .inner .logo {
	margin: 0 0 24px -1px;
}

footer .inner .logo strong {
	display: block;
	margin-bottom: 12px;
	font-size: 12px;
	letter-spacing: 0.12em;
	line-height: 1.7;
}

footer .inner .logo img {
	width: 230px;
	height: auto;
}

footer .inner .en {
	display: none;
}

footer .copyright {
	position: absolute;
	bottom: 30px;
	left: 7.5%;
	margin-left: 0.5px;
}

footer .copyright img {
	width: auto;
	height: 10px;
}

footer .address .btn-link {
	margin: 0 0 12px -1px;
}

footer .address .btn-link a {
	padding: 8px 38px 8px 16px;
	font-size: 13px;
	letter-spacing: 0.1em;
}

footer .address .btn-link a:after {
	background-size: 100% auto;
	right: 12px;
	width: 16px;
	height: 12px;
	margin-top: -1px;
}

footer .address p {
	line-height: 1.8;
}

footer .address p span {
	display: inline-block;
	position: relative;
	line-height: 1;
	padding-bottom: 2px;
	letter-spacing: 0.12em;
}

footer .address p span:after {
	display: block;
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	background: var(--color-navy);
	width: 100%;
	height: 1px;
	opacity: 0.5;
}

footer address {
	margin: 32px 0 14px;
	font-size: 13px;
	letter-spacing: 0.08em;
}

footer address br.narrow {
	display: none !important;
}

footer address span {
	display: none;
}

footer .tel,
footer .fax {
	font-family: var(--font-sans-book);
}

footer .tel {
	display: block;
	margin: 0 8px 8px 1px;
	font-size: 22px;
	letter-spacing: 0.04em;
}

footer .tel span {
	font-size: 17px;
	letter-spacing: 0.06em;
}

footer .fax {
	display: inline-block;
	margin-right: 6px;
	margin-left: 1px;
	font-size: 14px;
	letter-spacing: 0.07em;
}

footer .close {
	display: inline-block;
	font-size: 12px;
	letter-spacing: 0.08em;
	transform: translateY(-0.5px);
}

footer .gnav {
	transform: translateY(6px);
}

.pagetop {
	position: absolute;
	bottom: 30px;
	right: 24px;
}

.pagetop a {
	display: block;
	margin: -20px;
	padding: 20px;
}

.pagetop a img {
	width: 18px;
	height: auto;
	-webkit-backface-visibility: hidden;
	image-rendering: -webkit-optimize-contrast;
}

/* .gnav-footer
------------------------------------*/
.gnav-footer {
	display: none;
}


/* contents
---------------------------------------------------------------------------*/
#mainContents {
	display: block;
	width: 100%;
	margin: 0 auto;
	padding: 0;
	text-align: left;
}

.contents {
	opacity: 0;
}


/* .img-main
---------------------------------------------------------------------------*/
.img-main {
	position: relative;
	width: 94vw;
	height: calc(94vw * 0.75);
	margin: 0 auto 60px;
}

.img-main .inner {
	border-radius: 4px;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

#informationContents .img-main .inner { background-image: url(img/information/img-main_sp.jpg); background-position: center bottom; }
#aboutContents .img-main .inner { background-image: url(img/about/img-main_sp.jpg); }
#gastroscopyContents .img-main .inner { background-image: url(img/gastroscopy/img-main_sp.jpg?220104); }
#colonoscopyContents .img-main .inner { background-image: url(img/colonoscopy/img-main_sp.jpg?220104); }
#internalContents .img-main .inner { background-image: url(img/internal/img-main_sp.jpg); }
#examinationContents .img-main .inner { background-image: url(img/examination/img-main_sp.jpg); }
#accessContents .img-main .inner { background-image: url(img/access/img-main_sp.jpg); }

.img-main h1 {
	position: absolute;
	bottom: -1px;
	left: -1px;
	box-sizing: border-box;
	background-color: #FFFFFF;
	border-radius: 0 8px 0 0;
	padding: 18px 20px 3px 12px;
	z-index: 2;
}

.img-main h1:before,
.img-main h1:after {
	display: block;
	content: '';
	position: absolute;
	background: url(img/share/bg-title.svg);
	background-size: 100% auto;
	width: 14px;
	height: 14px;
}

.img-main h1:before { top: -13.5px; left: 0px; }
.img-main h1:after { bottom: 0px; right: -14px; }

.img-main h1 a {
	display: block;
}

.img-main h1 em {
	display: block;
	margin: 0 0 -1px 1px;
	font-family: var(--font-sans-sbook);
	font-size: 9px;
	letter-spacing: 0.12em;
}

.img-main h1 strong {
	font-size: 14px;
	letter-spacing: 0.08em;
}

.img-main h1 strong span {
	display: inline-block;
	margin-right: -2px;
	margin-left: 4px;
	font-size: 13px;
	letter-spacing: 0.08em;
}

/* .title-sub
------------------------------------*/
.title-sub {
	position: relative;
	white-space: nowrap;
	margin-bottom: 32px;
	padding: 30px 0 0;
}

.title-sub.jp {
	padding-top: 22px;
}

.title-sub:before {
	display: block;
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	background-color: var(--color-navy);
	width: 24px;
	height: 1px;
	opacity: 0.3;
}

.title-sub strong {
	display: block;
	margin-bottom: 15px;
	font-size: 17px;
	letter-spacing: 0.12em;
}

.title-sub.jp strong {
	margin-bottom: 0;
	font-size: 15px;
}

.title-sub em {
	display: block;
	margin-left: 0.5px;
	font-family: var(--font-sans-book);
	font-size: 10px;
	letter-spacing: 0.2em;
}

/* .img-center
------------------------------------*/
.img-center {
	width: 86%;
	margin: 0 auto 60px;
	text-align: center;
}

.img-center img {
	width: 100%;
	height: auto;
	-webkit-backface-visibility: hidden;
	image-rendering: -webkit-optimize-contrast;
}

.img-center3 {
	overflow: hidden;
	box-sizing: border-box;
	padding: 0 3%;
}

.img-center3 figure {
	display: -webkit-box;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.img-center3 img {
	align-self: flex-start;
	width: 100%;
	height: auto;
	-webkit-backface-visibility: hidden;
	image-rendering: -webkit-optimize-contrast;
}

.img-center3 .img1 { order: 2; width: 48.5%; }
.img-center3 .img2 { order: 1; width: 100%; margin-bottom: 3.5%; }
.img-center3 .img3 { order: 3; width: 48.5%; }

/* .dot-list
------------------------------------*/
.dot-list li {
	position: relative;
	margin: 0 0 6px 3px;
	padding-left: 13px;
	font-size: 12px;
	line-height: 1.6;
	letter-spacing: 0.06em;
}

.dot-list li:last-of-type {
	margin-bottom: 0;
}

.dot-list li:before {
	display: block;
	content: '・';
	position: absolute;
	top: 0;
	left: 0;
}

.dot-list.even {
	display: -webkit-box;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.dot-list.even ul {
	margin-bottom: -6px;
}

.dot-list.even li {
	box-sizing: border-box;
	width: 50%;
	margin-left: 0;
	padding-left: 13px;
}

/* .tips
------------------------------------*/
.tips-wrap {
	display: inline-block;
	position: relative;
	z-index: 10;
}

.btn-tips {
	display: inline-block;
	transition: .15s ease-out;
	cursor: pointer;
}

.btn-tips b {
	padding-bottom: 0;
	font-weight: normal;
	line-height: 1.4;
}

.btn-tips i {
	display: inline-block;
	background: url(img/share/ico-q.svg) no-repeat;
	width: 18px;
	height: 18px;
	margin: -4px 4px 0 4px;
	transform: translateY(3px);
}

.tips {
	box-sizing: border-box;
	position: absolute;
	bottom: -10px;
	right: 0;
	margin-right: 25px;
	padding-bottom: 35px;
	white-space: normal;
	visibility: hidden;
	pointer-events: none;
	opacity: 0;
	transition: .3s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.tips span {
	display: block;
	position: relative;
	box-sizing: border-box;
	background-color: #8897CA;
	border-radius: 6px;
	padding: 11px 13px 12px 14px;
	color: #FFFFFF;
	font-size: 13px;
	line-height: 1.6;
	letter-spacing: 0.04em;
	text-align: justify;
	white-space: normal;
}

.tips-wrap:hover .tips {
	bottom: 0;
	visibility: visible;
	pointer-events: auto;
	opacity: 1;
}

.tips span:after {
	display: block;
	content: '';
	position: absolute;
	bottom: -12px;
	left: 21px;
	background: url(img/share/tips.svg) no-repeat;
	width: 8px;
	height: 12px;
}

#gastroscopyContents .sec-examination1 .txt .tips {
	right: -170px;
	width: 170px;
}

#colonoscopyContents .sec-examination1 .box-color li .tips {
	right: -210px;
	width: 210px;
}

/* .map
------------------------------------*/
.map {
	position: relative;
	overflow: hidden;
	width: 100%;
	height: 75vw;
	margin: 0 auto 45px;
}

.map iframe {
	position: absolute;
	top: -150px;
	left: 0;
	width: 100%;
	height: calc(100% + 300px);
	z-index: 1;
}

.map .btn-link {
	position: absolute;
	bottom: 15px;
	right: 15px;
	z-index: 2;
	background-color: var(--color-navy);
	border-radius: 30px;
}

.map .btn-link a {
	display: block;
	padding-top: 11px;
	padding-right: 40px;
	padding-left: 18px;
}

.map .btn-link a:after { right: 14px; }

/* #sec-service
------------------------------------*/
#sec-service {
	box-sizing: border-box;
	background-color: var(--color-bg-blue-light);
	margin: 90px auto 0;
	padding: 32px 5% 6.5%;
}

#topContents #sec-service {
	margin-bottom: 60px;
}

#sec-service > h2 {
	margin-bottom: 30px;
	padding-left: 5px;
	font-size: 13px;
	line-height: 1.9;
	letter-spacing: 0.13em;
	text-align: center;
}

.service-list {
	justify-content: space-between;
	box-sizing: border-box;
	background: #FFFFFF;
	border: 1px solid #D5DCE5;
	border-radius: 8px;
	padding: 15px 15px 0;
}

.service-list .inner {
	position: relative;
	box-sizing: border-box;
	background: url(img/share/line-dot.svg) repeat-x left bottom;
	height: 88px;
	margin-bottom: 14px;
	padding: 17px 20px 0 122px;
	white-space: nowrap;
	z-index: 1;
}

.service-list .inner:last-of-type {
	background: none;
	margin-bottom: 0;
	padding-bottom: 0;
}

.service-list .inner figure {
	width: 100px;
	position: absolute;
	top: 0;
	left: 0;
}

.service-list .inner figure img {
	width: 100%;
	height: auto;
	-webkit-backface-visibility: hidden;
	image-rendering: -webkit-optimize-contrast;
}

.service-list .inner h2 strong {
	display: block;
	margin-bottom: 12px;
	font-size: 15px;
	letter-spacing: 0.11em;
}

.service-list .inner h2 strong span {
	padding-left: 5px;
	font-size: 13px;
	letter-spacing: 0.1em;
}

.service-list .inner h2 em,
#sec-service .btn-txt h2 em {
	display: block;
	margin-left: 1px;
	font-family: var(--font-sans-sbook);
	font-size: 11px;
	letter-spacing: 0.14em;
	opacity: 0.6;
}

.service-list .inner .btn-link {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	text-indent: -999px;
	z-index: 1;
}

.service-list .inner .btn-link a {
	display: block;
	background: none;
	border: none;
	border-radius: 0;
	width: 100%;
	height: 100%;
	padding: 0;
}

.service-list .inner .btn-link a:after {
	display: none;
}

/* #sec-service .btn-txt
------------------------------------*/
#sec-service .btn-txt {
	box-sizing: border-box;
	background-color: #FFFFFF;
	border: 1px solid #D5DCE5;
	border-radius: 8px;
	width: 100%;
	margin-top: 15px;
}

#sec-service .btn-txt a {
	display: block;
	padding: 26px 22px 22px 24px;
}

#sec-service .btn-txt h2 {
	margin-bottom: 15px;
}

#sec-service .btn-txt h2 strong {
	display: block;
	margin-bottom: 12px;
	font-size: 15px;
	letter-spacing: 0.09em;
}

#sec-service .btn-txt p {
	font-size: 12px;
	line-height: 1.7;
	letter-spacing: 0.12em;
	text-align: justify;
}

#sec-service .btn-txt .arrow {
	display: block;
	position: absolute;
	top: 19px;
	right: 20px;
	box-sizing: border-box;
	background: url(img/share/ico-arrow-navy.svg) no-repeat center center;
	background-size: 14px auto;
	border-radius: 50%;
	border: 1px solid var(--color-line-navy);
	width: 30px;
	height: 30px;
}

/* .pic
------------------------------------*/
.pic {
	display: block;
	position: absolute;
	z-index: -999;
}

/* .box-color
------------------------------------*/
.box-color {
	box-sizing: border-box;
	background-color: var(--color-bg-navy-light);
	border-radius: 6px;
}

/* .figcaption
------------------------------------*/
figure {
	position: relative;
}

figure figcaption {
	display: inline-block;
	position: absolute;
	bottom: 6px;
	left: 6px;
	background-color: #FFFFFF;
	padding: 3px 5px 4px 5px;
	font-size: 11px;
	letter-spacing: 0.06em;
}


/* information
---------------------------------------------------------------------------*/
.information-wrap {
	position: relative;
	margin: 75px auto 0;
	padding: 0 3%;
}

#informationContents.single .information-wrap {
	margin-top: 25px;
}

.information-wrap > h2 {
	margin: 0 0 24px 12px;
	font-size: 14px;
	letter-spacing: 0.12em;
}

.information-wrap .btn-select {
	position: absolute;
	top: -8px;
	right: 20px;
	transform-origin: right top;
	transform: scale(0.8);
}

.information-wrap .btn-select select {
	cursor: pointer !important;
	width: 100% !important;
	height: 100% !important;
	z-index: 2;
}

.information-wrap .btn-select .customSelect {
	display: block;
	box-sizing: border-box;
	width: 100%;
	font-size: 16px;
	text-align: center;
	letter-spacing: 0.08em;
}

.information-wrap .btn-select .customSelect .customSelectInner {
	box-sizing: border-box;
  border: 1px solid var(--color-line-navy);
  border-radius: 3px;
	width: 100% !important;
	padding: 6px 9px 9px 10px;
}

/* .news-list
------------------------------------*/
.news-list {
	border-top: 1px solid var(--color-line-navy-light);
}

.news-list article {
	border-bottom: 1px solid var(--color-line-navy-light);
}

#informationContents.single .news-list { border-top: none; }
#informationContents.single .news-list article { border-bottom: none; }

/* .post-title
------------------------------------*/
.post-title {
	position: relative;
}

.post-title time {
	display: block;
	position: absolute;
	top: 22px;
	left: 12px;
	margin-bottom: 8px;
	font-family: var(--font-sans-sbook);
	font-size: 11px;
	letter-spacing: 0.12em;
}

.post-title h2 {
	position: relative;
	font-size: 14px;
	line-height: 1.6;
	letter-spacing: 0.08em;
}

.post-title h2 > span,
.post-title h2 > a {
	display: block;
	padding: 40px 40px 20px 12px;
}

.post-title h2 a i {
	text-decoration: underline;
}

#informationContents.single time {
	top: 18px;
	letter-spacing: 0.14em;
}

#informationContents.single .post-title h2 {
	font-size: 16px;
}

/* .btn-ac
------------------------------------*/
.btn-ac {
	position: relative;
	cursor: pointer;
}

i.plus {
	display: block;
	position: absolute;
	top: 44px;
	right: 13px;
	width: 13px;
	height: 13px;
	transition: .2s ease-out;
}

i.plus:before,
i.plus:after {
	display: block;
	content: '';
	position: absolute;
	background-color: var(--color-navy);
}

i.plus:before { top: 6px; left: 0; width: 100%; height: 1px; }
i.plus:after { top: 0; left: 6px; width: 1px; height: 100%; }

.btn-ac.active i.plus { transform: rotate(225deg); }
.btn-ac.active i.plus:before { left: -5%; width: 112%; transform: rotate(-15deg); top: 6px; }
.btn-ac.active i.plus:after { top: -5%; height: 112%; transform: rotate(15deg); left: 6px; }

#informationContents.single .btn-ac i.plus { display: none; }

/* .post-table
------------------------------------*/
.post-table {
	box-sizing: border-box;
	width: 100%;
	margin-bottom: 50px;
	font-size: 14px;
	line-height: 1.7;
	letter-spacing: 0.08em;
}

.post-table table { border-bottom: 1px solid rgba(0,0,0,0.15); }
.post-table tr { border-top: 1px solid rgba(0,0,0,0.15); }

.post-table th {
	position: relative;
	box-sizing: border-box;
	width: 20%;
	padding: 13px 15px 12px 0;
	font-weight: normal;
	text-align: left;
	vertical-align: top;
	letter-spacing: 0.06em;
}

.post-table td {
	box-sizing: border-box;
	width: 80%;
	padding: 13px 5px 12px 0;
}

/* .post-link
------------------------------------*/
.post-link {
	overflow: hidden;
	margin-bottom: -12px;
}

.post-link > div {
	float: left;
	margin: 0 10px 10px 0;
	line-height: 1;
}

/* .post-detail
------------------------------------*/
.post-detail,
.post-detail a {
	color: var(--color-navy-light);
}

.post-detail {
	display: none;
	position: relative;
	padding-bottom: 40px;
}

#informationContents.single .post-detail {
	display: block !important;
}

.post-detail .inner {
	box-sizing: border-box;
	border-radius: 0 0 8px 8px;
	width: 100%;
	padding: 0 12px;
}

.post-detail .inner,
.post-detail .inner p {
	font-size: 13px;
	line-height: 1.85;
	letter-spacing: 0.08em;
	text-align: justify;
}

.post-detail .inner p {
	margin-bottom: 12px;
}

.post-detail .inner-main strong { font-weight: bold; }
.post-detail .inner-main em { font-style: italic; }
.post-detail .inner-main del { text-decoration: line-through; }

.post-detail .inner-main img {
	display: block;
	width: 100%;
	height: auto;
	padding: 10px 0 10px;
}

.post-detail .inner-main img:last-of-type { padding-bottom: 0; }

.post-detail .inner-main .wp-caption {
	max-width: 100%;
	margin-bottom: 25px;
}

.post-detail .inner-main .wp-caption-text {
	margin-top: -5px;
}

.post-detail .inner-main ul,
.post-detail .inner-main ol {
	margin: 30px 0;
}

.post-detail .inner-main ul li {
	list-style: disc;
	margin: 0 0 6px 20px;
}

.post-detail .inner-main ol li {
	list-style: decimal;
	margin: 0 0 6px 25px;
}

.post-detail .inner-main ul li:last-of-type,
.post-detail .inner-main ol li:last-of-type {
	margin-bottom: 0;
}

.post-detail .inner-main blockquote {
	background: #F5F5F5;
	margin-top: 30px;
	padding: 22px 28px 20px;
}

.post-detail .post-table {
	margin: 50px 0 30px;
}

.post-detail .post-table h3 {
	margin: 40px 0 15px;
	font-size: 14px;
	letter-spacing: 0.06em;
}

.post-detail .post-table h3:first-of-type { margin-top: 0; }

.post-detail .post-table table {
	width: 100%;
	font-size: 14px;
}

.post-detail .post-link {
	margin: 22px 0 0 -2px;
}

/* .wp-pagenavi
------------------------------------*/
.wp-pagenavi {
	font-family: var(--font-sans-book);
	overflow: hidden;
	margin-top: 35px;
	margin-bottom: -10px;
	text-align: center;
	font-size: 14px;
}

.wp-pagenavi a,
.wp-pagenavi .extend {
	margin: 0 1px;
	padding: 10px;
}

.wp-pagenavi .current {
	display: inline-block;
	border-bottom: 1px solid #666666;
	margin: 0 12px;
	padding: 10px 1px 1px 0;
}

.wp-pagenavi .previouspostslink,
.wp-pagenavi .nextpostslink {
	display: inline-block;
	background: url(img/share/ico-arrow-navy.svg) no-repeat center center;
	background-size: 16px auto;
	text-indent: -9999px;
}

.wp-pagenavi .previouspostslink { margin-right: 12px; transform: translateY(-1px) scaleX(-1); }
.wp-pagenavi .nextpostslink { margin-left: 12px; transform: translateY(-1px); }


/* page top
---------------------------------------------------------------------------*/
#topContents {
	padding-top: 50px;
}

/* .img-main-top
------------------------------------*/
.img-main-top {
	position: relative;
	box-sizing: border-box;
	width: 100%;
	margin-bottom: 60px;
}

.img-main-top .inner {
	border-radius: 0 40px 0 0;
	background: url(img/top/img-main_sp@2x.jpg) no-repeat right 72% top;
	background-size: cover;
	position: relative;
	width: calc(100vw - 35px);
	height: calc((100vw - 35px)*0.798);
}

.img-main-top .inner .mask {
	position: absolute;
	top: 0;
	right: 0;
	background-color: #FFFFFF;
	width: 100%;
	height: 100%;
	z-index: 2;
}

.img-main-top h1 { display: none; }

.img-main-top h1 strong {
	color: #FFFFFF;
	pointer-events: none;
}

.img-main-top h2 {
	position: absolute;
	top: -30px;
	right: -9px;
	opacity: 0;
}

.img-main-top h2 img {
	width: 94px;
	height: auto;
}

/* .news-top
------------------------------------*/
.news-top {
	overflow: hidden;
	margin-top: 8px;
}

.news-top a {
	display: inline-block;
	box-sizing: border-box;
	padding: 10px 24px 10px 18px;
	font-size: 12px;
	letter-spacing: 0.1em;
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.news-top a time {
	padding-right: 14px;
	font-family: var(--font-sans-sbook);
	font-size: 12px;
	letter-spacing: 0.1em;
}

.news-top .slider-news,
.news-top .slick-list,
.news-top .slick-track,
.news-top article {
	float: none;
	width: auto !important;
}

/* .sec-lead-top
------------------------------------*/
.sec-lead-top {
	position: relative;
	margin-bottom: 80px;
	padding: 0 9%;
}

.sec-lead-top .pic1,
.sec-lead-top .pic2 {
	display: block;
	position: absolute;
	z-index: -1;
	height: auto;
}

.sec-lead-top .pic1 { bottom: -40px; left: 25px; width: 90px; }
.sec-lead-top .pic2 { top: -10px; right: 38px; width: 110px; }

.sec-lead-top h2 {
	margin-bottom: 35px;
	font-size: 24px;
	line-height: 1.6;
	letter-spacing: 0.16em;
}

.sec-lead-top h2 img { display: none; }

.sec-lead-top h2 strong {
	
}

.sec-lead-top p {
	margin-bottom: 14px;
	line-height: 2;
	white-space: nowrap;
}

.sec-lead-top .link {
	float: right;
	margin: 35px -9px 0 0;
}

.sec-lead-top .link a {
	position: relative;
	display: inline-block;
	padding: 10px 22px 10px 0;
	font-size: 13px;
	letter-spacing: 0.12em;
	text-decoration: underline;
}

.sec-lead-top .link a i {
	display: block;
	position: absolute;
	top: 9px;
	right: 0;
	background: url(img/share/ico-arrow-navy.svg) no-repeat center center;
	background-size: 100% auto;
	width: 16px;
	height: 16px;
}

/* .sec-news-top
------------------------------------*/
.sec-news-top {
	margin-bottom: 70px;
	padding: 0 3%;
}

/* .img-set4
------------------------------------*/
.img-set4 {
	width: 96%;
	margin: 0 auto 65px;
}

.img-set4 > figure {
	display: -webkit-box;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.img-set4 img {
	align-self: flex-start;
	width: 49%;
	height: auto;
	-webkit-backface-visibility: hidden;
	image-rendering: -webkit-optimize-contrast;
	margin-bottom: 2%;
}

/* .sec-service-title
------------------------------------*/
.sec-service-title {
	margin-bottom: 0;
	text-align: center;
}

.sec-service-title strong {
	display: block;
	margin-bottom: 7px;
	font-size: 17px;
	letter-spacing: 0.16em;
}

.sec-service-title em {
	font-family: var(--font-sans-sbook);
	font-size: 11px;
	letter-spacing: 0.12em;
}

.sec-service-title + #sec-service { margin-top: 32px; }

/* .img-center3
------------------------------------*/
#topContents .img-center3 { display: none; }

/* #sec-clinic
------------------------------------*/
#topContents #sec-clinic {
	margin-bottom: 75px;
}

#sec-clinic .pic {
	display: none !important;
	/*display: block;
	position: absolute;
	bottom: -45px;
	right: 25px;
	width: 85px;
	height: auto;*/
}

/* .sec-reserve-online
------------------------------------*/
.sec-reserve-online {
	display: -webkit-box;
	display: flex;
	flex-wrap: wrap;
	width: 88%;
	margin: 0 auto;
}

.sec-reserve-online .box-color {
	order: 2;
	padding: 34px 30px 30px;
}

.sec-reserve-online .box-color h2 {
	margin-bottom: 15px;
	font-size: 16px;
	letter-spacing: 0.1em;
}

.sec-reserve-online .box-color p { text-align: justify; }
.sec-reserve-online .box-color ul { margin: 16px 0 0 2px; }

.sec-reserve-online .map {
	order: 1;
	width: 100%;
	height: 260px;
	margin: 0 0 25px;
}

.sec-reserve-online .map iframe {
	position: absolute;
	top: -200px;
	left: -150px;
	width: calc(100% + 150px);
	height: calc(100% + 400px);
	z-index: 1;
}

.sec-reserve-online .map .btn-link { right: 12px; bottom: 12px; }
.sec-reserve-online .map .btn-link a { padding: 11px 44px 13px 22px; }
.sec-reserve-online .map .btn-link a:after { right: 14px; }


/* page about
---------------------------------------------------------------------------*/
#aboutContents {
	overflow: hidden;
}

/* #sec-lead-about
------------------------------------*/
#sec-lead-about {
	position: relative;
	box-sizing: border-box;
	margin: 78px auto 75px;
	padding: 0 10%;
}

#sec-lead-about h2 { margin: 0 0 25px -1px; }
#sec-lead-about h2 img { display: none; }

#sec-lead-about h2 strong {
	font-size: 23px;
	line-height: 1.7;
	letter-spacing: 0.16em;
}

#sec-lead-about h3 { display: none; }

#sec-lead-about p {
	margin-bottom: 14px;
	font-size: 14px;
	line-height: 2;
	letter-spacing: 0.08em;
	text-align: justify;
}

#sec-lead-about p br { display: none; }
/* #sec-lead-about .pic1 { bottom: 15px; left: -15px; width: 135px; height: auto; opacity: 0.9; } */
#sec-lead-about .pic1 { display: none;}
#sec-lead-about .pic2 { top: -15px; right: 34px; width: 105px; height: auto; opacity: 0.9; }



/* #sec-policy
------------------------------------*/
#sec-policy {
	margin-bottom: 100px;
}

#sec-policy figure {
	margin-bottom: 60px;
}

#sec-policy figure img {
	width: 100%;
	height: auto;
	-webkit-backface-visibility: hidden;
	image-rendering: -webkit-optimize-contrast;
}

#sec-policy .inner {
	position: relative;
	padding: 0 8% 0 9%;
}

#sec-policy h2 {
	margin-bottom: 38px;
}

#sec-policy dt,
#sec-policy dd {
	padding-left: 65px;
	text-align: justify;
}

#sec-policy dt {
	position: relative;
	margin-bottom: 20px;
	font-size: 14px;
	line-height: 1.75;
	letter-spacing: 0.1em;
}

#sec-policy dt i {
	display: block;
	position: absolute;
	top: 1px;
	left: 0;
	font-family: var(--font-sans-sbook);
	font-size: 14px;
	letter-spacing: 0.1em;
	white-space: nowrap;
}

#sec-policy dt i:after {
	display: block;
	content: '';
	position: absolute;
	top: 11px;
	left: 30px;
	background-color: var(--color-navy-light);
	width: 22px;
	height: 1px;
	opacity: 0.2;
}

#sec-policy dt br,
#sec-policy dd br { display: none; }

#sec-policy dd {
	margin-top: -15px;
	font-size: 12px;
	line-height: 1.85;
	letter-spacing: 0.1em;
}

#sec-policy .pic3 { top: -15px; right: 45px; width: 105px; height: auto; }
#sec-policy .pic4 { bottom: -45px; left: -5px; width: 70px; height: auto; }

/* #img-set-about
------------------------------------*/
#img-set-about {
	position: relative;
	margin: 0 auto 160px;
}

#img-set-about picture { display: block; }

#img-set-about img {
	display: block;
	width: 100%;
	height: auto;
	-webkit-backface-visibility: hidden;
	image-rendering: -webkit-optimize-contrast;
}

#img-set-about picture img { position: static; }
#img-set-about .img1 { display: none; }
#img-set-about .img2 { width: 76%; margin: 0 auto 12.5%; }
#img-set-about .img3 { width: 41%; margin-left: -1%; }
#img-set-about .img4 { display: none; }
#img-set-about .img5 { width: 48%; position: absolute; bottom: -14vw; right: 0; }
#img-set-about .pic5 { top: 60.5vw; right: 14vw; width: 25%; }

/* #sec-message
------------------------------------*/
#sec-message {
	position: relative;
	margin-bottom: 80px;
	padding: 0 9%;
}

#sec-message figure {
	width: calc(100% - 120px);
	margin-bottom: 30px;
}

#sec-message figure img {
	width: 100%;
	height: auto;
	-webkit-backface-visibility: hidden;
	image-rendering: -webkit-optimize-contrast;
}

#sec-message .txt h2 {
	margin-bottom: 32px;
}

#sec-message .txt h2 b {
	display: block;
	margin-bottom: 15px;
	font-size: 11px;
	font-weight: normal;
	letter-spacing: 0.12em;
}

#sec-message .txt h2 strong {
	margin-left: -1px;
	font-size: 20px;
	letter-spacing: 0.14em;
}

#sec-message .txt h2 em {
	margin-left: 4px;
	font-family: var(--font-sans-sbook);
	color: var(--color-navy-light);
	font-size: 10px;
	letter-spacing: 0.15em;
	text-transform: lowercase;
}

#sec-message .txt h3 {
	position: absolute;
	top: 0;
	right: calc(6% + 14px);
	font-size: 13px;
	line-height: 2;
	letter-spacing: 0.16em;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	white-space: nowrap;
}

#sec-message .txt ul {
	margin-bottom: 18px;
}

#sec-message .txt li,
#sec-message .txt p {
	font-size: 13px;
	line-height: 1.85;
	letter-spacing: 0.1em;
}

#sec-message .txt p { margin-bottom: 8px; text-align: justify; letter-spacing: 0.08em; }
#sec-message .txt p br { display: none; }

#sec-message .txt .pic6 {
	top: 69vw;
	right: calc(8% - 2px);
	width: 90px;
	height: auto;
}

/* .img-staff
------------------------------------*/
.img-staff {
	margin: 0 auto 60px;
}

.img-staff img {
	width: 122%;
	height: auto;
	margin-left: -11.5%;
	-webkit-backface-visibility: hidden;
	image-rendering: -webkit-optimize-contrast;
}

/* #sec-clinic
------------------------------------*/
#sec-clinic {
	position: relative;
	padding: 0 7.5%;
}

#sec-clinic > figure {
	display: -webkit-box;
	display: flex;
	justify-content: space-between;
	margin-bottom: 25px;
}

#sec-clinic > figure img {
	width: 100%;
	height: auto;
	-webkit-backface-visibility: hidden;
	image-rendering: -webkit-optimize-contrast;
}

#sec-clinic > figure .img1 { width: 66.5%; }
#sec-clinic > figure .img2 { width: 32.7%; }

#sec-clinic .info {
	margin-bottom: 60px;
}

#sec-clinic .info .logo {
	margin-bottom: 20px;
}

#sec-clinic .info .logo strong {
	display: block;
	margin-bottom: 14px !important;
	font-size: 12px;
	line-height: 1.6;
	letter-spacing: 0.12em;
}

#sec-clinic .info .logo img { width: 240px; height: auto; }

#sec-clinic .info address,
#sec-clinic .info .tel,
#sec-clinic .info .fax {
	font-size: 13px;
	line-height: 1.6;
	letter-spacing: 0.08em;
}

#sec-clinic .info address {
	margin-bottom: 4px;
}

#sec-clinic .info .tel,
#sec-clinic .info .fax {
	display: inline-block;
}

/* .schedule
------------------------------------*/
.schedule {
	margin: 28px -10px 10px;
}

.schedule table,
.schedule tr {
	width: 100%;
	white-space: nowrap;
}

.schedule table { border-top: 1px solid #E8ECF1; }
.schedule tr { border-bottom: 1px solid #E8ECF1; }

.schedule th {
	padding: 11px 8px 11px;
	font-size: 13px;
	font-weight: normal;
	text-align: center;
	vertical-align: middle;
}

.schedule th:first-of-type {
	font-size: 12px;
	letter-spacing: 0.1em;
}

.schedule th span,
.schedule td span {
	display: block;
	padding-top: 6px;
	font-size: 10px;
	letter-spacing: 0.08em;
}

.schedule td span {
	color: var(--color-navy-light);
}

.schedule td {
	position: relative;
	padding: 10px 6px 9px;
	font-size: 21px;
	text-align: center;
	vertical-align: middle;
}

.schedule th:first-of-type,
.schedule td:first-of-type {
	padding-left: 0;
}

.schedule th:last-of-type { padding-right: 16px; }
.schedule td:last-of-type {	padding-right: 13px; }

.schedule td:first-of-type {
	font-family: var(--font-sans-book);
	font-size: 14px;
	letter-spacing: 0.02em;
}

.schedule tr.line1 td {
	padding-top: 12px;
	padding-bottom: 13px;
}

.schedule tr.line1 td:first-of-type { transform: translateY(2px); }

.schedule td i {
	display: inline-block;
	border-radius: 50%;
	border: 1px solid var(--color-navy);
	width: 8px;
	height: 8px;
}

.schedule td i {
	transform: translateY(-4px);
}

.schedule td i.close {
	border-radius: 0;
	background-color: var(--color-navy);
	border: none;
	width: 8px;
	height: 1px;
	vertical-align: middle;
	transform: translateY(-3px);
}

.schedule td b {
	display: inline-block;
	position: absolute;
	top: 5px;
	left: 0;
	background: #F1F4FB;
	border-radius: 4px;
	padding: 5px 6px 5px 5px;
	font-size: 11px;
	font-weight: normal;
	line-height: 1.2;
	letter-spacing: 0.02em;
}

/* .important-info
------------------------------------*/
.important-info {
	margin-top: -15px;
	display: -webkit-box;
	display: flex;
	white-space: nowrap;
}

p + .important-info {
	margin-top: 16px;
}

.important-info h2 {
	position: relative;
	padding: 10px 10px 10px 0;
	font-size: 13px;
	letter-spacing: 0.06em;
}

.important-info h2:after {
	display: block;
	content: '';
	position: absolute;
	top: 10px;
	right: 0;
	background: var(--color-navy);
	width: 1px;
	height: 26px;
	transform-origin: center top;
	transform: scale(0.5);
	opacity: 0.5;
}

.important-info a {
	position: relative;
	max-width: 100%;
	padding: 10px 0 10px 10px;
	font-size: 13px;
	letter-spacing: 0.08em;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.important-info a:after {
	display: block;
	content: '';
	position: absolute;
	bottom: 7px;
	left: 10px;
	background-color: var(--color-navy);
	width: calc(100% - 10px);
	height: 1px;
	opacity: 0.5;
}

/* .attention-list
------------------------------------*/
.attention-list li {
	position: relative;
	margin: 0 0 3px;
	padding-left: 16px;
	font-size: 12px;
	line-height: 1.75;
	letter-spacing: 0.07em;
	text-align: justify;
}

.attention-list li:last-of-type { margin-bottom: 0 !important; }

.attention-list li:before {
	display: block;
	content: '※';
	position: absolute;
	top: 0;
	left: 0;
}

/* #sec-clinic .alliance
------------------------------------*/
#sec-clinic .alliance {
	position: relative;
	margin-top: 60px;
}

#sec-clinic .alliance h2 {
	margin-bottom: 15px;
	font-size: 15px;
	letter-spacing: 0.14em;
}

#sec-clinic .alliance h2:not(:first-child) {
	margin-top: 30px;
}

#sec-clinic .alliance h2 + p {
	line-height: 1.8;
	letter-spacing: 0.035em;
	margin-bottom: 24px !important;
	text-align: justify;
}

#sec-clinic .alliance h2 + p br { display: none; }

#sec-clinic .alliance .inner {
	position: relative;
	display: -webkit-box;
	display: flex;
	-webkit-box-align: start;
	align-items: flex-start;
	margin-left: 3px;
}

#sec-clinic .alliance .inner ul {
	position: relative;
	margin-right: 24px;
	padding-left: 14px;
	vertical-align: middle;
	white-space: nowrap;
}

#sec-clinic .alliance .inner ul:last-of-type { margin-right: 0; }

#sec-clinic .alliance .inner ul:before {
	display: block;
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	background-color: var(--color-line-navy);
	width: 1px;
	height: 100%;
}

#sec-clinic .alliance .inner li {
	margin-bottom: 8px;
	font-size: 13px;
	line-height: 1.6;
	letter-spacing: 0.06em;
}

#sec-clinic .alliance .inner li:last-of-type { margin-bottom: 0; }

#sec-clinic .alliance p.sup {
	font-size: 12px;
	display: inline;
}

#sec-clinic .alliance > ul { margin-top: 14px; }
#sec-clinic .alliance > ul li:nth-of-type(1) { display: none; }


/* page gastroscopy / colonoscopy
---------------------------------------------------------------------------*/
#gastroscopyContents .img-center3,
#colonoscopyContents .img-center3 {
	margin-bottom: 55px;
}

/* .sec-examination1
------------------------------------*/
.sec-examination1 {
	margin-bottom: 70px;
	padding: 0 9%;
}

.sec-examination1 .txt {
	margin-bottom: 55px;
}

.sec-examination1 .txt h2,
.sec-examination2 .txt h2 {
	margin-bottom: 17px;
	font-family: var(--font-min-d);
	font-size: 18px;
	line-height: 1.8;
	letter-spacing: 0.12em;
	white-space: nowrap;
}

#colonoscopyContents .sec-examination1 .txt h2 {
	margin-bottom: 19px;
	font-size: 16px;
	letter-spacing: 0.14em;
}

.sec-examination1 .txt p { text-align: justify; }
.sec-examination1 .txt p br { display: none; }

.sec-examination1 .box-wrap h3 {
	margin-bottom: 24px;
	text-align: center;
}

.sec-examination1 .box-wrap h3 em {
	margin-bottom: 13px;
	font-size: 13px;
	letter-spacing: 0.12em;
}

.sec-examination1 .box-wrap h3 strong {
	font-family: var(--font-min-d);
	font-size: 17px;
	letter-spacing: 0.14em;
}

.sec-examination1 .box-color {
	margin: 0 -2px;
	padding: 24px 26px 22px;
}

#colonoscopyContents .sec-examination1 .box-color {
	padding-bottom: 16px;
}

.sec-examination1 .box-color .even li:nth-child(odd) { width: 60%; }
.sec-examination1 .box-color .even li:nth-child(even) { width: 40%; }

.sec-examination1 .box-wrap h4 {
	margin: 30px 0 11px;
	font-family: var(--font-min-d);
	font-size: 14px;
	letter-spacing: 0.13em;
}

.sec-examination1 .box-wrap h4:first-of-type { margin-top: 35px; }
.sec-examination1 .box-wrap p {
	line-height: 1.85;
	text-align: justify;
}

/* .sec-examination2
------------------------------------*/
.sec-examination2 {
	margin-bottom: 75px;
	padding: 0 9%;
}

.sec-examination2 .img {
	margin-bottom: 35px;
}

.sec-examination2 .img figure {
	margin-bottom: 25px;
}

.sec-examination2 .img figure img {
	width: 100%;
}

.sec-examination2 .img h3 {
	margin-bottom: 14px;
	font-size: 12px;
	letter-spacing: 0.06em;
}

.sec-examination2 .img h4 {
	margin-bottom: 13px;
}

.sec-examination2 .img h4 strong {
	font-family: var(--font-sans-sbook);
	font-size: 17px;
	letter-spacing: 0.03em;
}

.sec-examination2 .img h4 span {
	display: block;
	margin-top: 5px;
	font-size: 11px;
	line-height: 1.5;
	letter-spacing: 0.04em;
	white-space: nowrap;
}

.sec-examination2 .txt h2 {
	margin-bottom: 14px;
}

.sec-examination2 p { text-align: justify; }
.sec-examination2 p br { display: none; }

.sec-examination2 p.attention {
	margin-top: -2px;
	font-size: 12px;
	letter-spacing: 0.11em;
}

.sec-examination2 .box-color {
	margin: 30px 0 0;
	padding: 32px 30px 28px;
}

.sec-examination2 .box-color figure {
	align-self: flex-start;
	width: 80px;
	min-width: 80px;
}

.sec-examination2 .box-color figure img { border-radius: 3px; }
.sec-examination2 .box-color figure.side img { border-radius: 3px 0 0 3px; }

.sec-examination2 .box-color h3 {
	margin-bottom: 14px;
	font-family: var(--font-min-d);
	font-size: 16px;
	letter-spacing: 0.1em;
}

.sec-examination2 .box-color .img-s {
	position: relative;
	display: flex;
	justify-content: space-between;
	margin-top: 26px;
}

.sec-examination2 .box-color .img-s figure {
	width: 48%;
}

.sec-examination2 .box-color .img-s figure img {
	width: 100%;
}

.sec-examination2 .box-color .img-s figure.side img {
	width: 50%;
}

.sec-examination2 .box-color .img-s figure:not(.zoom) figcaption {
	position: static;
	background-color: inherit;
	margin-top: 14px;
	padding: 0;
	font-family: var(--font-sans-sbook);
	font-size: 15px;
	letter-spacing: 0.05em;
}

.sec-examination2 .box-color .img-s figure:not(.zoom) figcaption span {
	display: block;
	margin-bottom: 9px;
	font-size: 10px;
	letter-spacing: 0.04em;
}

.sec-examination2 .box-color .img-s figure.side figcaption span {
	letter-spacing: 0.02em;
}

.sec-examination2 .box-color .img-s figure.side {
	display: flex;
	align-items: center;
	background-color: #E2E6F5;
	border-radius: 0 3px 3px 0;
	width: 100%;
}

.sec-examination2 .box-color .img-s figure.side figcaption {
	width: 100%;
	margin: 0;
	padding: 0 0 0 17px;
	white-space: nowrap;
}

.sec-examination2 .box-color .img-s .zoom {
	position: absolute;
	top: -20px;
	right: -20px;
	width: 60px;
	min-width: auto;
	width: auto;
	text-align: center;
}

.sec-examination2 .box-color .img-s .zoom figcaption {
	display: block;
	background-color: inherit;
	position: static;
	margin-top: -6px;
	padding: 0;
	font-size: 11px;
	letter-spacing: 0.03em;
	text-align: center;
}

.sec-examination2 .box-color .img-s .zoom figcaption span {
	display: inline-block;
	background-color: #FFFFFF;
	margin-bottom: 3px;
	padding: 0px 3px 2px 3px;
}

/* .sec-examination3
------------------------------------*/
.sec-examination3 {
	margin: -30px auto 80px;
	padding: 0 9%;
}

.sec-examination3 dl > div { margin-bottom: 40px; }
.sec-examination3 dl > div:last-of-type { margin-bottom: 0; }
.sec-examination3 dt.title-sub.jp { margin-bottom: 18px; }
.sec-examination3 dt.title-sub.jp:before { width: 22px; }
.sec-examination3 dt.title-sub.jp strong { letter-spacing: 0.1em; }
.sec-examination3 dd p { margin-bottom: 6px; text-align: justify; }
.sec-examination3 dd p br { display: none; }

/* .sec-method
------------------------------------*/
.sec-method {
	position: relative;
	margin: 130px auto 100px;
}

.sec-method:before {
	display: block;
	content: '';
	position: absolute;
	top: -88px;
	left: 50%;
	background: var(--color-line-navy);
	width: 1px;
	height: 65px;
}

.sec-method h2 {
	margin-bottom: 40px;
	text-align: center;
}

.sec-method h2 strong {
	display: block;
	margin-bottom: 4px;
	font-size: 16px;
	line-height: 1.7;
	letter-spacing: 0.14em;
}

.sec-method h2 em {
	color: var(--color-navy-light);
	font-family: var(--font-sans-sbook);
	font-size: 11px;
	letter-spacing: 0.14em;
}

.method {
	border-top: 1px solid var(--color-line-navy);
	border-bottom: 1px solid var(--color-line-navy);
	width: 90%;
	margin: 0 auto;
}

.method > div {
	box-sizing: border-box;
	padding: 32px 14px 28px;
}

.method > div:nth-child(odd) { background: url(img/share/line-dot.svg) repeat-x left bottom; }

.method h3 {
	position: relative;
	margin-bottom: 18px;
	padding-left: 37px;
	font-family: var(--font-min-d);
	font-size: 15px;
	letter-spacing: 0.1em;
	white-space: nowrap;
}

.method h3 i {
	display: block;
	position: absolute;
	top: 2px;
	left: 2px;
	font-family: var(--font-sans-sbook);
	font-size: 16px;
}

.method h3 i:after {
	display: block;
	content: '';
	position: absolute;
	top: 8px;
	right: -18px;
	background: var(--color-line-navy);
	width: 10px;
	height: 1px;
}

.method p {
	color: var(--color-navy-light);
	line-height: 1.9;
	text-align: justify;
}

/* .sec-price
------------------------------------*/
.sec-price {
	margin-bottom: 75px;
	padding: 0 7%;
}

.sec-price h2 {
	margin-bottom: 22px;
}

.sec-price > p { text-align: justify; }

.sec-price > p.attention {
	margin-top: -2px;
	font-size: 12px;
}

/* .sec-flow
------------------------------------*/
.sec-flow {
	margin-bottom: 75px;
	padding: 40px 5.5% 30px;
}

.sec-flow-inner h2 {
	margin: 0 0 24px 6px;
	font-family: var(--font-min-d);
	font-size: 15px;
	letter-spacing: 0.14em;
}

.sec-flow-inner .attention-list li {
	margin-bottom: 14px;
	line-height: 1.8;
	text-align: justify;
}

.sec-flow-inner .attention-list li br { display: none; }

.flow-list {
	margin-bottom: 26px;
}

.flow-list .inner {
	position: relative;
	background-color: #FFFFFF;
	border-radius: 5px;
	margin-bottom: 15px;
	padding: 26px 22px 22px 22px;
}

.flow-list .inner:last-of-type { margin-bottom: 0; }

.flow-list h3 {
	position: relative;
	box-sizing: border-box;
	margin-bottom: 18px;
	padding-left: 20px;
	font-size: 15px;
	letter-spacing: 0.12em;
}

#colonoscopyContents .flow-list .inner:nth-of-type(1),
#colonoscopyContents .flow-list .inner:nth-of-type(2) {
	padding-top: 32px;
}

#colonoscopyContents .flow-list .inner:nth-of-type(1) h3,
#colonoscopyContents .flow-list .inner:nth-of-type(2) h3 {
	margin-bottom: 24px;
}

.flow-list h3 i {
	display: block;
	position: absolute;
	top: 4px;
	left: 1px;
	font-family: var(--font-serif);
	font-size: 15px;
}

.flow-list .txt p {
	text-align: justify;
	line-height: 1.8;
	letter-spacing: 0.04em;
	font-size: 12px;
}

.flow-list .txt p br { display: none; }

.flow-list .txt .attention-list {
	margin-top: 2px;
}

.flow-list .attention-list li {
	margin-top: 4px;
	margin-bottom: 3px;
	font-size: 12px !important;
}

.flow-list .ico {
	position: absolute;
	top: 19px;
	right: 21px;
}

.flow-list .inner:nth-of-type(1) .ico { right: 28px; }
.flow-list .ico a,
.flow-list .ico span { display: block; }
.flow-list .ico img { width: auto; height: 40px; }

.flow-list + .attention-list {
	padding: 0 6px;
}

/* .sec-reserve
------------------------------------*/
.sec-reserve {
	padding: 0 9%;
}

.sec-reserve > figure {
	margin: 0 -5% 45px;
}

.sec-reserve > figure img {
	width: 100%;
	height: auto;
	-webkit-backface-visibility: hidden;
	image-rendering: -webkit-optimize-contrast;
}

.sec-reserve .txt {
	margin-bottom: 45px;
}

.sec-reserve h2 {
	margin-bottom: 28px;
}

.sec-reserve h2 strong {
	font-size: 14px !important;
}

.sec-reserve h3 {
	margin: 34px 0 12px;
	font-size: 15px;
	line-height: 1.7;
	letter-spacing: 0.08em;
	white-space: nowrap;
}

.sec-reserve .tel {
	margin: 0 0 30px 1px;
}

.sec-reserve .tel span {
	padding-bottom: 1px;
	font-size: 13px;
	letter-spacing: 0.1em;
}

.sec-reserve .tel strong {
	padding-left: 8px;
	font-family: var(--font-sans-sbook);
	font-size: 23px;
	letter-spacing: 0.06em;
}

.sec-reserve .tel .txt-line:after { bottom: 0; }

.sec-reserve .box-color {
	margin: 28px -3px 0;
	padding: 26px 14px 22px 22px;
}

.sec-reserve .box-color h4 {
	margin-bottom: 18px;
	font-family: var(--font-min-d);
	font-size: 14px;
	letter-spacing: 0.1em;
}

.sec-reserve .attention-list {
	margin-top: 16px;
}

.sec-reserve .inner .img { position: relative; }

.sec-reserve .inner .img img {
	width: 100%;
	height: auto;
	-webkit-backface-visibility: hidden;
	image-rendering: -webkit-optimize-contrast;
}

.sec-reserve .inner .img figure {
	margin-bottom: 14px;
}

.sec-reserve .inner .img p {
	font-size: 12px;
	letter-spacing: 0.08em;
	text-align: justify;
}


/* page internal
---------------------------------------------------------------------------*/

/* .sec-internal
------------------------------------*/
.sec-internal {
	margin-bottom: 45px;
	padding: 0 9%;
}

.sec-internal .txt {
	margin-bottom: 60px;
}

.sec-internal .txt h2 {
	margin-bottom: 15px;
	font-size: 17px;
	line-height: 1.8;
	letter-spacing: 0.14em;
	white-space: nowrap;
}

.sec-internal .txt p {
	font-size: 14px;
	text-align: justify;
}

.sec-internal .txt p br { display: none; }

.sec-internal .box-wrap {
	text-align: center;
}

.sec-internal .box-wrap h3 {
	display: inline-block;
	margin-bottom: 22px;
	font-size: 15px;
	letter-spacing: 0.13em;
}

.sec-internal .box-color {
	margin: 0 -6px;
	padding: 22px 14px 22px 22px;
	text-align: left;
}

.sec-internal .box-color h4 {
	margin: 24px 0 11px;
	font-size: 13px;
	letter-spacing: 0.1em;
}

.sec-internal .box-color li span {
	font-size: 12px;
	letter-spacing: 0.06em;
}


/* page examination
---------------------------------------------------------------------------*/

/* .sec-examination
------------------------------------*/
.sec-examination {
	padding: 0 9%;
}

.sec-examination h2 {
	margin-bottom: 17px;
	font-size: 16px;
	line-height: 1.8;
	letter-spacing: 0.14em;
}

.sec-examination h2 + p {
	text-align: justify;
}

/* .price-list
------------------------------------*/
.price-list {
	border-top: 1px solid var(--color-line-navy);
	margin: 30px 0% 0;
}

.price-list .inner {
	position: relative;
	border-bottom: 1px solid var(--color-line-navy);
	padding: 19px 8px 21px;
}

.price-list .inner > div {
	display: -webkit-box;
	display: flex;
	justify-content: space-between;
	position: relative;
}

.price-list .inner > div + div.sub {
	margin-top: 20px;
}

.price-list .inner > div + div.sub.mt0 {
	margin-top: 0;
	margin-bottom: 0;
	padding-top: 8px;
	padding-bottom: 8px;
}

.price-list .inner > div + div.sub.mt0.sub-top { padding-top: 3px; margin-top: 26px; }
.price-list .inner > div + div.sub.mt0.sub-btm { padding-bottom: 0; margin-bottom: 18px; }

.price-list .inner > div + div.sub.mt0 .price { top: 4px; }
.price-list .inner > div + div.sub.mt0.sub-top .price { top: -2px; }

.price-list .txt h3 {
	margin-bottom: 12px;
	font-size: 15px;
	line-height: 1.6;
	letter-spacing: 0.1em;
}

.price-list .txt h3:last-child { margin-bottom: 0; }

.price-list .txt h3 span {
	display: block;
	margin-top: 3px;
	font-size: 11px;
	letter-spacing: 0.08em;
	opacity: 0.6;
}

.price-list .txt h3 span.inb {
	display: inline-block;
	margin: 0 0 0 4px;
}

.price-list .txt p {
	text-align: justify;
	line-height: 1.8;
}

.price-list .txt p br {
	display: none;
}

.price-list .txt.font-s h3 {
	margin-bottom: 14px;
}

.price-list .txt.font-s p {
	padding-left: 2px;
	font-size: 13px;
	line-height: 1.9;
}

.price-list .txt p.attention {
	margin-top: -6px;
	font-size: 12px;
}

.price-list .price {
	text-align: right;
	white-space: nowrap;
	position: absolute;
	top: 0;
	right: 0;
}

.price-list .price p {
	font-size: 13px;
}

.price-list .price p strong {
	padding: 0 1.5px 0 2px;
	font-family: var(--font-serif);
	font-size: 17px;
	line-height: 1;
	letter-spacing: 0.03em;
}

.price-list .price p i {
	margin-right: 3px;
	font-size: 11px;
}

.price-list .price p i:last-child { margin-right: 0; }

.price-list .price p.attention {
	margin-top: -6px;
	font-size: 13px;
}

.price-list .inner .sub {
	border-left: 1px solid #E5E5E5;
	margin: 15px 0 5px 3px;
	padding: 3px 0 0 11px;
}

.price-list .inner .sub h4 {
	margin-bottom: 10px;
	font-family: var(--font-min-d);
	font-size: 13px;
	letter-spacing: 0.12em;
}

.price-list .inner .sub h4:last-of-type { margin-bottom: 0; }

.price-list .inner .sub h4 span {
	padding-left: 12px;
	font-size: 12px;
	letter-spacing: 0.1em;
}


/* page access
---------------------------------------------------------------------------*/
#accessContents .img-main {
	margin-bottom: 50px;
}

/* .sec-access
------------------------------------*/
.sec-access {
	margin: 0 auto 75px;
}

.sec-access h2 {
	margin-bottom: 50px;
	font-size: 16px;
	line-height: 1.9;
	letter-spacing: 0.16em;
	text-align: center;
}

.route { padding: 0 9%; }
.route > div { margin-bottom: 45px; }
.route > div:last-of-type { margin-bottom: 0; }

.route figure {
	position: relative;
	margin-bottom: 20px;
}

.route figure img { width: 100%; height: auto; -webkit-backface-visibility: hidden; image-rendering: -webkit-optimize-contrast; }

.route figure span {
	display: block;
	position: absolute;
}

.route1 .zoom1-1 { top: 22%; left: 36%; z-index: 1; width: 16%; }
.route1 .zoom1-2 { top: 12%; left: 9%; z-index: 2; width: 39.5%; }
.route1 .zoom1-3 { top: 12.1%; left: -8%; z-index: 3; width: 35%; }

.route1 .zoom2-1 { bottom: 22.7%; right: 31.4%; z-index: 1; width: 9%; }
.route1 .zoom2-2 { bottom: 4.8%; right: 5.5%; z-index: 2; width: 33.2%; }
.route1 .zoom2-3 { bottom: 3.2%; right: -9%; z-index: 3; width: 23%; }

.route2 .zoom3-1 { top: 48.2%; right: 44.8%; z-index: 1; width: 10%; }
.route2 .zoom3-2 { top: -6.8%; right: -4%; z-index: 2; width: 57%; }
.route2 .zoom3-3 { top: -4.8%; right: -9%; z-index: 3; width: 33.6%; }

@media all and (-webkit-min-device-pixel-ratio:0) and (min-resolution: .001dpcm) {
	.route1 .zoom2-2 { bottom: 4.6%; }
	.route2 .zoom3-2 { top: -6.6%; }
}

.route p { letter-spacing: 0.08em; text-align: justify; }
.route p strong { padding-right: 0.5em; font-family: var(--font-min-d); }

/* .parking
------------------------------------*/
.parking .title-sub {
	margin-bottom: 26px;
}

.parking figure {
	display: -webkit-box;
	display: flex;
	justify-content: space-between;
	margin-bottom: 16px;
}

.parking figure img {
	align-self: flex-start;
	height: auto;
	-webkit-backface-visibility: hidden;
	image-rendering: -webkit-optimize-contrast;
}

.parking figure img:nth-of-type(1) { width: 60%; }
.parking figure img:nth-of-type(2) { width: 37.2%; }


/* .modal
---------------------------------------------------------------------------*/
.modal-wrap {
	position: fixed;
	top: 0;
	left: 0;
	background: var(--color-bg-navy-light);
	width: 100%;
	height: 100%;
	z-index: 10001;
	display: none;
	opacity: 0;
}

.modal-close {
	position: absolute;
	top: 20px;
	right: 20px;
	text-align: center;
	z-index: 2;
}

.modal-close img {
	width: 45px;
	height: auto;
}

.modal-close strong {
	display: block;
	margin-top: 12px;
	padding-left: 0.16em;
	font-size: 12px;
	letter-spacing: 0.16em;
	text-align: center;
}

.modal {
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%) !important;
	width: 100%;
	z-index: 1;
	opacity: 0;
}

.modal figure {
	display: -webkit-box;
	display: flex;
	justify-content: space-between;
}

.modal figure img {
	align-self: flex-start;
	width: 49.8%;
	height: auto;
	-webkit-backface-visibility: hidden;
	image-rendering: -webkit-optimize-contrast;
}


/* error
---------------------------------------------------------------------------*/
.sec-error {
	margin: 75px auto 0;
	padding: 0 9%;
}

.sec-error h1 {
	margin-bottom: 24px;
	font-size: 17px;
	letter-spacing: 0.08em;
}

.sec-error p {
	text-align: justify;
}

.sec-error p br {
	display: none;
}