/* common
---------------------------------------------------------------------------*/
@font-face {
    font-family: 'HalisGR';
    src: url("../fonts/AhmetAltunHalisGRLight.woff") format("woff");
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'HalisGR';
    src: url("../fonts/AhmetAltunHalisGRBook.woff") format("woff");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

/* common
---------------------------------------------------------------------------*/
:root {
	--color-navy: #861F30;
	--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', sans-serif;
	--font-sans-sbook: 'HalisGR', sans-serif;
	--font-sans-book: 'HalisGR', 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;
}

body {
	background-color: #FFFFFF;
	color: var(--color-navy);
	font-size: 14px;
	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: 14px; line-height: 1.8; letter-spacing: 0.1em; 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: inline-block !important; }
.narrow { display: none !important; }
.nav-sp { display: none; opacity: 0; }

/* #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 .7s infinite linear;
}

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

/* link
------------------------------------*/
a { color: var(--color-navy); text-decoration: none; transition: .15s ease-out; -webkit-transform: translateZ(0); }
a:hover { text-decoration: none; opacity: 0.5; }

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

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

.txt-line:after {
	display: block;
	content: '';
	background-color: var(--color-navy);
	position: absolute;
	bottom: 0;
	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: 14px 12px 17px 14px;
	font-size: 16px;
	letter-spacing: 0.16em;
	text-align: center;
}

.btn-link.left a {
	padding-right: 48px;
	padding-left: 22px;
	font-size: 14px;
}

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

.btn-color a:hover {
	opacity: 0.7;
}

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

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

#informationContents .btn-back {
	margin: 40px 0 0 140px;
}

#informationContents .btn-back a {
	display: inline-block;
	padding: 10px 10px 10px 0;
	font-size: 15px;
	letter-spacing: 0.15em;
	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: 18px auto;
	border-radius: 50%;
	border: 1px solid var(--color-line-navy);
	width: 34px;
	height: 34px;
	margin: -20px 16px 0 -9px;
	transform: translateY(11px) scaleX(-1);
}

/* .btn-nav
------------------------------------*/
.btn-nav,
.nav-sp {
	display: none !important;
}

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

/* .btn-reserve
------------------------------------*/
.btn-reserve {
	width: 127px;
	min-width: 127px;
	margin: -1px 0 0 20px;
}

header .btn-reserve-sp {
	display: none;
}

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

.btn-reserve a img.white {
	position: absolute;
	top: 7px;
	left: 12px;
	opacity: 0;
	transition: .15s ease-out;
}

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

.btn-reserve a:hover img.white {
	opacity: 1;
}


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


/* header
---------------------------------------------------------------------------*/
header {
	display: -webkit-box;
	display: flex;
	justify-content: space-between;
	box-sizing: border-box;
	width: 100%;
	min-height: 130px;
	margin: 0 auto;
	padding: 55px 40px 0 65px;
	white-space: nowrap;
	opacity: 0;
}

header .logo {
	width: 100%;
	margin-top: -25px;
}

header .logo img {
	width: 317px;
	height: auto;
}

header .tel {
	margin-top: 2px;
	font-family: var(--font-sans-slight);
	font-size: 29px;
	letter-spacing: 0.02em;
	font-weight: 300;
}

header .tel span {
	padding-right: 4px;
	font-family: var(--font-sans-book);
	font-size: 15px;
	letter-spacing: 0.08em;
	font-weight: 400;
}

/* .gnav
------------------------------------*/
header .gnav {
	margin: 0 45px 0 0;
}

header .gnav > ul {
	display: -webkit-box;
	display: flex;
}

header .gnav > ul > li > a,
header .gnav > ul > li > b {
	display: block;
	padding: 12px 11px;
	font-size: 16px;
}

header .gnav > ul > li > b {
	cursor: default;
}

header .gnav > ul > li > a span,
header .gnav > ul > li > b span,
header .gnav > ul > li > a span i,
header .gnav > ul > li > b span i {
	display: block;
	position: relative;
}

header .gnav > ul > li > a span i,
header .gnav > ul > li > b span i {
	opacity: 0;
}

header .gnav > ul > li > a span i:after,
header .gnav > ul > li > b span i:after {
	display: block;
	content: '';
	position: absolute;
	bottom: -44px;
	right: 0;
	background-color: var(--color-navy);
	width: 0;
	height: 2px;
	transition: .2s cubic-bezier(0.165, 0.84, 0.44, 1); /* easeOutQuart */
}

header .gnav.active > ul > li > a span i:after,
header .gnav.active > ul > li > b span i:after {
	left: 0;
	width: 100%;
	transition: .3s cubic-bezier(0.165, 0.84, 0.44, 1); /* easeOutQuart */
}

body.information #gnav-information > a i,
body.about #gnav-about > a i,
body.gastroscopy #gnav-service > b i,
body.colonoscopy #gnav-service > b i,
body.internal #gnav-service > b i,
body.examination #gnav-service > b i,
body.access #gnav-access > a i {
	opacity: 1;
}

/* .mnav
------------------------------------*/
.btn-mnav { position: relative; z-index: 1; padding: 12px 11px; }
/* .btn-mnav:hover { z-index: 1; } */

.mnav-wrap {
	position: absolute;
	top: 20px;
	left: 50%;
	transform: translateX(-50%) !important;
	width: 266px;
	padding-top: 55px;
	transition: .3s cubic-bezier(0.165, 0.84, 0.44, 1);
	visibility: hidden;
	pointer-events: none;
	opacity: 0;
	z-index: 0;
}

/*#wrap.tablet .mnav-wrap {
	display: none;
	visibility: inherit;
	transition: inherit;
}*/

#wrap.mnav-on:not(.tablet) .btn-mnav:hover .mnav-wrap,
#wrap.mnav-on .btn-mnav.active .mnav-wrap {
	top: 30px;
	visibility: visible;
	pointer-events: auto;
	opacity: 1;
}

body.top .mnav-wrap {
	position: absolute;
	top: 15px;
	padding-top: 35px;
}

body.top #wrap.mnav-on:not(.tablet) .btn-mnav:hover .mnav-wrap,
body.top #wrap.mnav-on .btn-mnav.active .mnav-wrap { top: 25px; }
#wrap.tablet .btn-mnav > a { pointer-events: none; }

.mnav {
	background-color: #FFFFFF;
	box-shadow: 3px 3px 8px 0 rgba(94,96,102,0.3);
	border-radius: 6px;
	padding: 6px 12px;	
}

.mnav li { border-bottom: 1px solid var(--color-line-navy); }
.mnav li:last-of-type { border-bottom: none; }

.mnav a {
	display: block;
	background: url(../img/share/ico-arrow-navy.svg) no-repeat right 8px center;
	padding: 16px 10px 16px;
	font-size: 16px;
	letter-spacing: 0.1em;
	white-space: nowrap;
}

/* media query
-----------------------------------*/
@media (max-width: 1400px) {
	header {
		padding-right: 35px;
		padding-left: 60px;
	}
	header .gnav {
		margin-right: 35px;
	}
	header .gnav > ul > li a,
	header .gnav > ul > li > span {
		padding-right: 9px;
		padding-left: 9px;
	}
}

@media (max-width: 1340px) {
	header {
		padding-left: 40px;
	}
	header .logo img {
		width: 310px;
	}
	header .gnav {
		margin-right: 20px;
	}
	header .gnav > ul > li a,
	header .gnav > ul > li > span {
		padding-right: 7px;
		padding-left: 7px;
	}
	header .tel {
		margin-top: 4px;
		font-size: 26px;
	}
	.btn-reserve {
		margin-left: 18px;
	}
}


/* footer
---------------------------------------------------------------------------*/
footer {
	display: -webkit-box;
	display: flex;
	-webkit-box-align: end;
	align-items: flex-end;
	position: relative;
	box-sizing: border-box;
	width: 100%;
	margin: 180px auto 0;
	padding: 0 0 50px 55px;
	white-space: nowrap;
}

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

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

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

footer .inner .en {
	margin-bottom: 12px;
	font-family: var(--font-sans-sbook);
	font-size: 18px;
	line-height: 1.75;
	letter-spacing: 0.14em;
}

footer .address {
	margin: 0 60px 0 0;
}

footer .address .btn-link {
	margin: 0 0 16px -4px;
}

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

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

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

footer .address p span {
	display: inline-block;
	position: relative;
	line-height: 1;
	padding-bottom: 5px;
}

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: 22px 0 12px;
	font-size: 15px;
	letter-spacing: 0.06em;
}

footer address span {
	display: none;
}

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

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

footer .tel a {
	pointer-events: none;
}

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

footer .fax {
	font-size: 14px;
	letter-spacing: 0.1em;
}

footer .close {
	margin: 8px 0 4px;
	font-size: 14px;
	letter-spacing: 0.06em;
}

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

footer .gnav a {
	display: inline-block;
	position: relative;
	padding: 5px 10px 10px 13px;
	font-size: 15px;
	letter-spacing: 0.1em;
}

footer .gnav a:before {
	display: block;
	content: '';
	position: absolute;
	top: 13px;
	left: 0;
	background-color: var(--color-navy);
	width: 5px;
	height: 1px;
	opacity: 0.4;
}

footer #gnav-top {
	display: none;
}

.pagetop {
	position: absolute;
	bottom: 52px;
	right: 50px;
}

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

/* .gnav-footer
------------------------------------*/
.gnav-footer {
	display: -webkit-box;
	display: flex;
	transform: translateY(4px);
}

.gnav-footer ul { margin-right: 12px; }
.gnav-footer ul:last-of-type { margin-right: 0; }

.gnav-footer li { position: relative; }

.gnav-footer li:before {
	display: block;
	content: '';
	position: absolute;
	top: 17px;
	left: 0;
	background: var(--color-navy);
	width: 5px;
	height: 1px;
	opacity: 0.4;
}

.gnav-footer a {
	display: inline-block;
	padding: 8px 10px 8px 14px;
	font-size: 15px;
	letter-spacing: 0.1em;
	white-space: nowrap;
}

/* media query
-----------------------------------*/
@media (max-width: 1340px) {
	footer { padding-left: 50px; }
	footer .inner { margin-right: 55px; }
	footer .address { margin-right: 50px; }
	.pagetop { 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: calc(100% - 70px);
	height: calc(100vh - 165px);
	min-height: 700px;
	max-height: 900px;
	margin: 0 auto 180px;
}

.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.jpg); background-position: center bottom; }
#aboutContents .img-main .inner { background-image: url(../img/about/img-main.jpg); } */
/* #gastroscopyContents .img-main .inner { background-image: url(../img/gastroscopy/img-main.jpg?220104); } */
#gastroscopyContents .img-main .inner { background-image: url(../img/dummy.png); }
/* #colonoscopyContents .img-main .inner { background-image: url(../img/colonoscopy/img-main.jpg); }
#internalContents .img-main .inner { background-image: url(../img/internal/img-main.jpg); }
#examinationContents .img-main .inner { background-image: url(../img/examination/img-main.jpg); }
#accessContents .img-main .inner { background-image: url(../img/access/img-main.jpg); } */

.img-main h1 {
	position: absolute;
	bottom: 0;
	left: 0;
	box-sizing: border-box;
	background-color: #FFFFFF;
	border-radius: 0 9px 0 0;
	padding: 30px 50px 10px 25px;
	z-index: 2;
}

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

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

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

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

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

.img-main h1 strong span {
	padding-left: 6px;
}

/* .title-sub
------------------------------------*/
.title-sub {
	position: relative;
	white-space: nowrap;
	padding: 52px 0 0;
}

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

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

.title-sub.jp:before {
	width: 32px;
}

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

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

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

/* .img-center
------------------------------------*/
.img-center {
	text-align: center;
	display: block;
	margin-bottom: 100px;
}

.img-center3 {
	overflow: hidden;
	box-sizing: border-box;
	max-width: 1800px;
	margin: 0 auto;
	padding: 0 40px;
}

.img-center3 figure {
	display: -webkit-box;
	display: flex;
	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 img {
	height: 250px;
	object-fit: cover;
}

.img-center3 .img1 { width: 21.4%; }
.img-center3 .img2 { width: 52.3%; }
.img-center3 .img3 { width: 21.4%; }

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

.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 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:hover { opacity: 0.7; }

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

.btn-tips i {
	display: inline-block;
	background: url(../img/share/ico-q.svg) no-repeat;
	width: 18px;
	height: 18px;
	margin: 0 4px 0 3px;
	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: 8px 14px 12px 14px;
	color: #FFFFFF;
	font-size: 14px;
	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: 1100px;
	height: 620px;
	margin: 0 auto 60px;
}

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

.map .btn-link {
	position: absolute;
	bottom: 25px;
	right: 25px;
	z-index: 2;
}

.map .btn-link {
	background-color: var(--color-navy);
	border-radius: 30px;
}

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

/* #sec-service
------------------------------------*/
#sec-service {
	box-sizing: border-box;
	background-color: var(--color-bg-blue-light);
	border-radius: 14px;
	width: 1240px;
	margin: 150px auto 0;
	padding: 48px 44px 60px;
}

#sec-service > h2 {
	margin-bottom: 40px;
	font-size: 22px;
	line-height: 1.9;
	letter-spacing: 0.12em;
	text-align: center;
}

.service-list {
	display: -webkit-box;
	display: flex;
	justify-content: space-between;
	box-sizing: border-box;
	background: #FFFFFF;
	border: 1px solid #D5DCE5;
	border-radius: 11px;
	padding: 37px 0 37px;
}

.service-list .inner {
	position: relative;
	box-sizing: border-box;
	background: url(../img/share/line-dot-v.svg) repeat-y right top;
	width: calc(100% / 3);
	padding: 7px 37px;
	z-index: 1;
}

.service-list .inner:last-of-type { background: none; }

.service-list .inner figure {
	margin-bottom: 26px;
}

.service-list .inner figure img {
	width: 100%;
}

.service-list .inner h2 {
	text-align: center;
}

.service-list .inner h2 strong {
	display: block;
	margin-bottom: 16px;
	font-size: 18px;
	letter-spacing: 0.12em;
}

.service-list .inner h2 em {
	display: block;
	font-family: var(--font-sans-sbook);
	font-size: 12px;
	letter-spacing: 0.2em;
	opacity: 0.6;
}

.service-list .inner .btn-link {
	margin-top: 28px;
	width: 100%;
}

.service-list .inner .btn-link a {
	display: block;
	font-size: 15px;
	letter-spacing: 0.1em;
}

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

#sec-service .btn-txt a {
	display: -webkit-box;
	display: flex;
	justify-content: space-between;
	white-space: nowrap;
	padding: 30px 43px 29px 46px;
}

#sec-service .btn-txt h2 {
	text-align: center;
}

#sec-service .btn-txt h2 strong {
	display: inline-block;
	margin-right: 18px;
	font-size: 20px;
	letter-spacing: 0.09em;
	transform: translateY(2px);
}

#sec-service .btn-txt h2 em {
	display: inline-block;
	font-family: var(--font-sans-sbook);
	font-size: 12px;
	letter-spacing: 0.18em;
}

#sec-service .btn-txt p {
	font-size: 15px;
	letter-spacing: 0.11em;
}

#sec-service .btn-txt .arrow {
	box-sizing: border-box;
	background: url(../img/share/ico-arrow-navy.svg) no-repeat center center;
	border-radius: 50%;
	border: 1px solid var(--color-line-navy);
	width: 46px;
	height: 46px;
	margin: -8px 0 -7px;
}

/* .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: 8px;
	left: 8px;
	background-color: #FFFFFF;
	padding: 4px 7px 6px 7px;
	font-size: 14px;
	letter-spacing: 0.12em;
}


/* information
---------------------------------------------------------------------------*/
.information-wrap {
	position: relative;
	width: 860px;
	margin: 140px auto 0;
}

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

.information-wrap > h2 {
	margin: 0 0 40px 15px;
	font-size: 16px;
	letter-spacing: 0.15em;
}

.information-wrap .btn-select {
	position: absolute;
	top: -8px;
	right: 0;
	transition: .15s ease-out;
}

.information-wrap .btn-select:hover {
	opacity: 0.5;
}

.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: 15px;
	text-align: center;
	letter-spacing: 0.1em;
}

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

/* .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);
	margin-left: -5px;
}

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

/* .post-title
------------------------------------*/
.post-title {
	position: relative;
	transition: .15s ease-out;
}

.post-title time {
	display: block;
	position: absolute;
	top: 30px;
	left: 20px;
	font-family: var(--font-sans-sbook);
	font-size: 14px;
	letter-spacing: 0.14em;
	z-index: 2;
}

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

.post-title h2 > span,
.post-title h2 > a {
	display: block;
	padding: 21px 80px 21px 140px;
}

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

#informationContents.single time {
	position: static;
	margin-left: 140px;
	margin-bottom: -10px;
}

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

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

#informationContents.single .btn-ac { cursor: default; }
.btn-ac:not(.active):hover { opacity: 0.5; }

i.plus {
	display: block;
	position: absolute;
	top: 25px;
	right: 30px;
	width: 21px;
	height: 21px;
	transition: .25s ease-out;
}

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

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

.btn-ac.active i.plus { transform: rotate(225deg); }
.btn-ac.active i.plus:before { left: -10%; width: 120%; transform: rotate(-20deg); }
.btn-ac.active i.plus:after { top: -10%; height: 120%; transform: rotate(20deg); }

#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 12px 12px 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 30px 0 140px;
}

.post-detail .inner,
.post-detail .inner p {
	font-size: 14px;
	line-height: 1.9;
	letter-spacing: 0.1em;
	text-align: justify;
}

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

.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: 30px 0 0 -4px;
}

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

.wp-pagenavi a,
.wp-pagenavi .extend {
	margin: 0 2px;
	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;
	text-indent: -9999px;
}

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