﻿.clearfix::after {
	content: "";
	clear: both;
	display: table
}
p {
	margin: 0;
	padding: 0
}
ol, ul {
	list-style: none;
	margin: 0;
	padding: 0
}
input, textarea {
	margin: 0;
	font-size: 100%;
	resize: none
}
input[type="text"], input[type="date"], input[type="email"], input[type="number"], input[type="url"] {
	word-break: normal;
	white-space: nowrap;
	-webkit-appearance: none;
	-moz-appearance: none;
	-ms-appearance: none;
	-o-appearance: none;
	appearance: none
}
table {
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0;
	font-size: 100%
}
dl, dt, dd, th, td {
	margin: 0;
	padding: 0
}
h1, h2, h3, h4, h5, h6 {
	font-weight: normal;
	margin: 0;
	padding: 0
}
h5 {
	font-weight: 500;
}

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video, dialog {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent
}
img {
	margin: 0;
	padding: 0;
	vertical-align: middle;
	border: 0;
	max-width: 100%;
	height: auto
}
table img {
	margin: 0;
	padding: 0;
	vertical-align: middle;
	border: 0
}
article, aside, dialog, figure, footer, header, hgroup, nav, section {
	display: block
}
nav ul {
	list-style: none
}
*, *:before, *:after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-ms-box-sizing: border-box;
	-o-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale
}
*:focus {
	outline: none !important
}
label, select, button {
	cursor: pointer
}
input, textarea, select, button {
	font-family: inherit
}
a {
	color: #454545;
	outline: none;
	text-decoration: none;
	transition: opacity 0.3s;
	cursor: pointer
}
@media only screen and (min-width: 1025px) {
	a:hover {
		opacity: 0.5
	}
}
.ffN {
	font-family: "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "ヒラギノ角ゴ W3", "メイリオ", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif
}
.ffM {
	font-family: "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "HGS明朝E", "ＭＳ Ｐ明朝", serif
}
.ffYG {
	font-family: "游ゴシック体", "游ゴシック", "YuGothic", "Yu Gothic", "Noto Sans JP", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif
}
.ffYM {
	font-family: "游明朝体", "游明朝", "YuMincho", "Yu Mincho", "Noto Serif JP", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif
}
.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute !important;
	white-space: nowrap;
	height: 1px;
	width: 1px;
	overflow: hidden
}
.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	color: #21759b;
	display: block;
	font-size: 14px;
	font-size: 0.875rem;
	font-weight: bold;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000
}
html {
	font-size: 62.5%;
	-webkit-text-size-adjust: 100%;
	-moz-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	-o-text-size-adjust: 100%;
	text-size-adjust: 100%;
	overflow-x: hidden
}
html.is-ipad * {
	-webkit-text-size-adjust: none;
	-moz-text-size-adjust: none;
	-ms-text-size-adjust: none;
	-o-text-size-adjust: none;
	text-size-adjust: none
}
body {
	height: 100%;
	width: 100%;
	margin: 0;
	padding: 0;
	color: #454545;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 2.26667em;
	letter-spacing: .08em;
	font-weight: 500;
	font-family: "kozuka-gothic-pro", sans-serif;
	word-break: break-word;
	overflow-x: hidden
}
@media (max-width: 767px) {
	body {
		font-size: 16px;
		font-size: 1.6rem;
		line-height: 2em
	}
}
#wrap {
	display: block;
	background: #f7f7f7;
}

.recruit #wrap {
	background: none;
}

.inner {
	max-width: 1050px;
	padding: 0 25px;
	margin: 0 auto
}
.inner--large {
	max-width: 1170px
}
@media (min-width: 768px) {
	.sp, .SP {
		display: none !important
	}
}
@media (max-width: 767px) {
	.pc, .PC {
		display: none !important
	}
}
.alignnone {
	margin: 5px 0 20px
}
.aligncenter, div.aligncenter {
	display: block;
	margin: 5px auto 5px auto
}
.alignright {
	float: right;
	margin: 5px 0 20px auto
}
.alignleft {
	float: left;
	margin: 5px auto 20px 0
}
a img.alignright {
	float: right;
	margin: 5px 0 20px auto
}
a img.alignnone {
	margin: 5px 0 20px
}
a img.alignleft {
	float: left;
	margin: 5px auto 20px 0
}
a img.aligncenter {
	display: block;
	margin-left: auto;
	margin-right: auto
}
.wp-caption {
	background: #fff;
	border: 1px solid #f0f0f0;
	max-width: 96%;
	padding: 5px 3px 10px;
	text-align: center
}
.wp-caption.alignnone {
	margin: 5px 0 20px
}
.wp-caption.alignleft {
	margin: 5px auto 20px 0
}
.wp-caption.alignright {
	margin: 5px 0 20px auto
}
.wp-caption img {
	border: 0 none;
	height: auto;
	margin: 0;
	max-width: 98.5%;
	padding: 0;
	width: auto
}
.wp-caption p.wp-caption-text {
	font-size: 11px;
	line-height: 17px;
	margin: 0;
	padding: 0 4px 5px
}
.wp-video {
	max-width: 100%;
	margin-bottom: 40px
}
.wp-video video {
	max-width: 100%;
	height: auto
}
.cms-content {
	margin-top: 52px;
	font-size: 15px;
	font-size: 1.5rem;
	line-height: 2.26667em;
	-webkit-text-size-adjust: none;
	-ms-text-size-adjust: none;
	word-wrap: break-word
}
.cms-content::after {
	content: "";
	clear: both;
	display: table
}
@media (max-width: 767px) {
	.cms-content {
		margin-top: 34px;
		font-size: 15px;
		font-size: 1.5rem;
		line-height: 2em
	}
}
.cms-content ul, .cms-content ol {
	padding-left: 20px;
	margin-bottom: 20px
}
.cms-content ul[style*="list-style-type: circle;"] li {
	list-style-type: circle
}
.cms-content ul[style*="list-style-type: square;"] li {
	list-style-type: square
}
.cms-content ul li {
	list-style: disc
}
.cms-content ol[style*="list-style-type: lower-roman;"] li {
	list-style-type: lower-roman
}
.cms-content ol[style*="list-style-type: lower-alpha;"] li {
	list-style-type: lower-alpha
}
.cms-content ol[style*="list-style-type: lower-greek;"] li {
	list-style-type: lower-greek
}
.cms-content ol[style*="list-style-type: upper-alpha;"] li {
	list-style-type: upper-alpha
}
.cms-content ol[style*="list-style-type: upper-roman;"] li {
	list-style-type: upper-roman
}
.cms-content ol li {
	list-style-type: decimal
}
.cms-content p {
	margin-bottom: 26px
}
.cms-content p:last-child {
	margin-bottom: 0
}
@media (max-width: 767px) {
	.cms-content p {
		margin-bottom: 23px
	}
}
.cms-content iframe {
	max-width: 100% !important
}
.cms-content img {
	max-width: 100%;
	height: auto;
	max-height: 100%;
	width: auto;
	border-radius: 15px
}
.cms-content table {
	table-layout: fixed;
	border: 1px solid #454545;
	margin-bottom: 40px
}
.cms-content table td, .cms-content table th {
	border: 1px solid #454545
}
.cms-content a {
	text-decoration: underline;
	color: #008bea
}
.cms-content h3 {
	margin: 82px 0 30px;
	background: #d3ebf5;
	border-radius: 12px;
	padding: 18px 25px 16px;
	color: #32a2e7;
	font-size: 26px;
	font-size: 2.6rem;
	line-height: 1.30769em;
	letter-spacing: .1em;
	font-weight: 700
}
@media (max-width: 767px) {
	.cms-content h3 {
		margin: 70px 0 23px;
		padding: 15px 18px 14px;
		font-size: 22px;
		font-size: 2.2rem;
		line-height: 1.36364em
	}
}
.cms-content h4 {
	position: relative;
	margin: 65px 0 26px;
	border-bottom: #32a2e7 2px solid;
	padding-bottom: 15px;
	font-size: 20px;
	font-size: 2rem;
	line-height: 1.5em;
	letter-spacing: .1em;
	font-weight: 700
}
.cms-content h4:before {
	content: "";
	position: absolute;
	bottom: -2px;
	width: 60px;
	height: 2px;
	background: #008bea
}
@media (max-width: 767px) {
	.cms-content h4 {
		margin: 60px 0 24px;
		padding-bottom: 15px;
		font-size: 18px;
		font-size: 1.8rem;
		line-height: 1.44444em
	}
}
.cms-content h5 {
	margin: 57px 0 16px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cg id='Ellipse_71' data-name='Ellipse 71' fill='none' stroke='%2335b488' stroke-width='2'%3E%3Ccircle cx='5' cy='5' r='5' stroke='none'/%3E%3Ccircle cx='5' cy='5' r='4' fill='none'/%3E%3C/g%3E%3C/svg%3E%0A");
	background-repeat: no-repeat;
	background-position: left 2px top 6px;
	padding-left: 20px;
	font-size: 18px;
	font-size: 1.8rem;
	line-height: 1.44444em;
	letter-spacing: .1em;
	font-weight: 700
}
@media (max-width: 767px) {
	.cms-content h5 {
		margin: 49px 0 13px;
		padding-left: 20px;
		background-position: left 2px top 6px;
		font-size: 16px;
		font-size: 1.6rem;
		line-height: 1.5em
	}
}
.cms-content blockquote {
	margin: 30px 0 30px;
	background: #f7f7f7;
	border-radius: 10px;
	padding: 35px 50px 33px;
	font-size: 15px;
	font-size: 1.5rem;
	line-height: 1.86667em
}
@media (max-width: 767px) {
	.cms-content blockquote {
		margin: 30px 0 35px;
		padding: 26px 30px
	}
}
.cms-content blockquote a {
	font-weight: 500;
	text-decoration: underline
}
.cms-content span[style*="text-decoration: underline;"] {
	text-decoration: none !important;
	box-shadow: inset 0px -8px 0 0px #fff39b
}
@media (max-width: 767px) {
	.cms-content span[style*="text-decoration: underline;"] {
		box-shadow: inset 0px -6px 0 0px #fff39b
	}
}
.c-pagingDt {
	position: relative;
	margin: 78px auto 0;
	max-width: 438px;
	text-align: center
}
@media (max-width: 767px) {
	.c-pagingDt {
		margin: 55px auto 0;
		max-width: 325px
	}
}
.c-pagingDt .list {
	display: block;
	margin: 0 auto;
	max-width: 250px;
	border-bottom: #d9d9d9 2px solid;
	padding-bottom: 10px;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.25em;
	letter-spacing: .08em;
	font-weight: 500
}
@media (max-width: 767px) {
	.c-pagingDt .list {
		width: calc(100% - 144px)
	}
}
.c-pagingDt .prev, .c-pagingDt .next {
	position: absolute;
	top: 50%;
	transform: translate(0, -50%);
	width: 64px;
	height: 64px;
	margin-top: 3px;
	background-color: #f0f0f0;
	background-position: center;
	background-repeat: no-repeat;
	border-radius: 50%;
	transition: 0.3s
}
@media (max-width: 767px) {
	.c-pagingDt .prev, .c-pagingDt .next {
		width: 52px;
		height: 52px;
		margin-top: 3px
	}
}
.c-pagingDt .prev {
	left: 0;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4.691' height='8.143' viewBox='0 0 4.691 8.143'%3E%3Cg id='arw' transform='translate(-295 -1737.09)'%3E%3Cpath id='Path_15' data-name='Path 15' d='M0,0,2.661,2.281,5.323,0' transform='translate(298.281 1738.5) rotate(90)' fill='none' stroke='%23454545' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'/%3E%3C/g%3E%3C/svg%3E%0A")
}
.c-pagingDt .next {
	right: 0;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4.691' height='8.143' viewBox='0 0 4.691 8.143'%3E%3Cg id='arw' transform='translate(-640.309 -1737.09)'%3E%3Cpath id='Path_97' data-name='Path 97' d='M0,2.281,2.661,0,5.323,2.281' transform='translate(644 1738.5) rotate(90)' fill='none' stroke='%23454545' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'/%3E%3C/g%3E%3C/svg%3E%0A")
}
.c-img {
	display: block;
	position: relative
}
.c-img img {
	display: block;
	object-fit: cover;
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%
}
.c-img--contain img {
	object-fit: contain
}
.c-img--top img {
	object-position: top
}
.c-fw {
	width: 100%
}
[rel~="js-lazy"] {
	opacity: 0
}
[rel~="js-lazy"]:not(.initial) {
	transition: opacity 0.15s
}
[rel~="js-lazy"].initial, [rel~="js-lazy"].loaded, [rel~="js-lazy"].error {
	opacity: 1
}
.c-lazybg {
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat
}
.c-lazybg--top {
	background-position: center top
}
.c-lazybg--contain {
	background-size: contain
}
[data-aos="fade-up"] {
	transform: translate3d(0, 50px, 0)
}
.clGreen {
	color: #32a2e7
}
.clOrange {
	color: #008bea
}
.c-circle {
	position: absolute !important;
	display: block;
	width: 588px;
	position: relative;
	border: #FFFFFF 60px solid;
	border-radius: 50%;
	opacity: 0.5;
}
.c-circle:before {
	display: block;
	content: " ";
	width: 100%;
	padding-top: 100%
}
.c-circle>.content {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0
}
.c-circle.gray {
	border-color: #f7f7f7
}
@media (max-width: 767px) {
	.c-circle {
		border-width: 50px
	}
}
.c-writetext {
	opacity: 1;
	transform: translateZ(0)
}
.c-writetext .character {
	position: relative;
	top: 20px;
	opacity: 0;
	transition: opacity 0.3s, top 0.3s
}
.c-writetext.aos-animate .character {
	top: 0;
	opacity: 1
}
.c-titlegroup {
	position: relative;
	background: #d3ebf5;
	/*min-height: 426px;*/
	padding: 156px 0 100px;
	padding: 156px 0 70px;
	overflow: hidden
}
.c-titlegroup:before {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 90px;
	height: 100%;
	background-color: rgba(255,255,255,0.7);
	/*
	background: url(../img/common/other/bg_titlepage.png) no-repeat top center;
	background-size: 100% 100%;
	*/
	z-index: 2
}

.c-titlegroup,
.hikari .c-titlegroup,
.about .c-titlegroup {
	background: url(../img/bg-hikari.jpg) no-repeat center center;
	background-position: center center;
}

.gairai .c-titlegroup {
	background: url(../img/bg-gairai.jpg) no-repeat center center;
	background-position: center center;
}

.houmon .c-titlegroup {
	background: url(../img/bg-houmon.jpg) no-repeat center center;
	background-position: center center;
}

.nyuin .c-titlegroup {
	background: url(../img/bg-nyuin.jpg) no-repeat center center;
	background-position: center center;
}

.hikarinosato .c-titlegroup {
	background: url(../img/bg-hikarinosato.jpg) no-repeat center center;
	background-position: center center;
}

.recruit .c-titlegroup {
	background: url(../img/bg-recruit.jpg) no-repeat center center;
	background-position: center center;
}

.access .c-titlegroup {
	background: url(../img/bg-access.jpg) no-repeat center center;
	background-position: center center;
}

.file .c-titlegroup {
	background: url(../img/bg-file.jpg) no-repeat center center;
	background-position: center center;
}

.privacy .c-titlegroup {
	background: url(../img/bg-privacy.jpg) no-repeat center center;
	background-position: center center;
}

@media (max-width: 767px) {
	.c-titlegroup {
		padding: 115px 0 74px;
		padding: 115px 0 54px;
		min-height: auto
	}
	.c-titlegroup:before {
		background-color: rgba(255, 255, 255, 0.7);
	}
}
.c-titlegroup .widthdiv {
	position: relative;
	z-index: 3
}
.c-titlegroup .circle01 {
	top: 100px;
	left: -70px;
	width: 588px
}
@media (max-width: 767px) {
	.c-titlegroup .circle01 {
		top: 125px;
		left: -73px;
		width: 333px
	}
}
.c-titlegroup .circle02 {
	top: -98px;
	right: -48px;
	width: 360px
}
@media (max-width: 767px) {
	.c-titlegroup .circle02 {
		top: -78px;
		right: -83px;
		width: 203px
	}
}
.c-titlepage .text_en {
	display: inline-block;
	vertical-align: middle;
	/*color: #32a2e7;*/
	font-size: 72px;
	font-size: 7.2rem;
	font-size: 62px;
	font-size: 6.2rem;
	line-height: 1.11111em;
	/*letter-spacing: .15em;*/
	font-weight: 500;
	font-family: "Jost", sans-serif
}
@media (max-width: 767px) {
	.c-titlepage .text_en {
		display: block;
		font-size: 44px;
		font-size: 4.4rem;
		font-size: 34px;
		font-size: 3.4rem;
		line-height: 1.13636em;
		letter-spacing: .12em
	}
}
.c-titlepage .text_jp {
	position: relative;
	top: 2px;
	display: inline-block;
	vertical-align: middle;
	padding-left: 24px;
	font-size: 18px;
	font-size: 1.8rem;
	line-height: 1.55555em;
	letter-spacing: .08em;
	font-weight: 700
}
@media (max-width: 767px) {
	.c-titlepage .text_jp {
		display: block;
		top: 0;
		padding: 13px 0 0;
		font-size: 16px;
		font-size: 1.6rem;
		line-height: 1.25em
	}
}
.c-breadcrumb {
	position: relative;
	margin-top: 28px;
	color: #92c9b6;
	font-size: 12px;
	font-size: 1.2rem;
	line-height: 2.33333em;
	letter-spacing: .08em;
	font-weight: 500
}
@media (max-width: 767px) {
	.c-breadcrumb {
		margin-top: 30px;
		font-size: 12px;
		font-size: 1.2rem;
		line-height: 1.66667em
	}
}
.c-breadcrumb li {
	display: inline;
	color: #666666;
}
.c-breadcrumb li:not(:last-child) {
	margin-right: 17px;
	padding-right: 26px;
	background: url(../img/icon_breadcrumb.svg) right top no-repeat
}
.c-breadcrumb li a, .c-breadcrumb li .link {
	color: #666666;
	transition: 0.3s;
	cursor: pointer;
	text-decoration: underline;
}
.c-breadcrumb li a:hover, .c-breadcrumb li .link:hover {
	text-decoration: none;
}

@media only screen and (min-width: 1025px) {
	.c-breadcrumb li a:hover, .c-breadcrumb li .link:hover {
		opacity: 0.7
	}
}
@media (max-width: 767px) {
	.c-breadcrumb li:not(:last-child) {
		margin-right: 9px;
		padding-right: 18px
	}
}
.c-ttl01 .text_en {
	display: block;
	/*color: #32a2e7;*/
	font-size: 60px;
	font-size: 6rem;
	font-size: 50px;
	font-size: 5rem;
	line-height: 1.14286em;
	/*letter-spacing: .15em;*/
	font-weight: 500;
	font-family: "Jost", sans-serif
}
/*
.c-ttl01 .text_en:first-letter {
	color: #008bea
}
*/
@media (max-width: 767px) {
	.c-ttl01 .text_en {
		font-size: 48px;
		font-size: 4.8rem;
		font-size: 38px;
		font-size: 3.8rem;
		line-height: 1.08333em
	}
}
.c-ttl01 .text_jp {
	position: relative;
	margin-top: 11px;
	display: inline-block;
	padding-left: 20px;
	font-size: 17px;
	font-size: 1.7rem;
	line-height: 1.17647em;
	letter-spacing: .08em;
	font-weight: 500
}
.c-ttl01 .text_jp:before {
	content: "";
	position: absolute;
	top: 6px;
	left: 3px;
	width: 6px;
	height: 6px;
	background: #008bea;
	border-radius: 50%
}
@media (max-width: 767px) {
	.c-ttl01 .text_jp {
		margin-top: 10px;
		padding-left: 19px
	}
}
.c-ttl01.oneline .text_en, .c-ttl01.oneline .text_jp {
	margin-top: 0;
	display: inline-block;
	vertical-align: middle
}
.c-ttl01.oneline .text_jp {
	margin-left: 10px
}
.c-ttl01.small .text_en {
	font-size: 34px;
	font-size: 3.4rem;
	line-height: 1.47059em
}
.c-ttl01.small .text_jp {
	font-size: 15px;
	font-size: 1.5rem;
	line-height: 1.33333em
}
.c-ttl01.white {
	color: #fff
}
.c-ttl01.white .text_en {
	color: #fff
}
.c-ttl01.white .text_en:first-letter {
	color: #fff
}
.c-ttl01.white .text_jp:before {
	background: #fff
}
@media (min-width: 768px) {
	.c-ttl01.write_vertical {
		writing-mode: tb
	}
	.c-ttl01.write_vertical .text_en {
		letter-spacing: 0.12em
	}
	.c-ttl01.write_vertical .text_jp {
		margin-top: 0;
		margin-right: 24px;
		padding-left: 0;
		padding-top: 24px;
		letter-spacing: 0.18em
	}
	.c-ttl01.write_vertical .text_jp:before {
		content: "";
		position: absolute;
		top: 3px;
		left: 50%;
		margin-left: -3px
	}
}
.c-btn01 {
	position: relative;
	display: flex;
	align-items: center;
	max-width: 315px;
	width: 100%;
	height: 56px;
	overflow: hidden;
	border: #32a2e7 2px solid;
	background: #32a2e7;
	border-radius: 80px;
	padding: 13px 38px 10px;
	text-align: left;
	color: #fff;
	font-size: 15px;
	font-size: 1.5rem;
	line-height: 1.33333em;
	letter-spacing: .08em;
	font-weight: 700;
	cursor: pointer
}
.c-btn01:before {
	content: "";
	position: absolute;
	bottom: 0;
	left: -10px;
	right: -10px;
	height: 0;
	background: #fff;
	border-radius: 80px;
	transition: 0.3s
}
.c-btn01:after {
	content: "";
	position: absolute;
	top: 50%;
	right: 37px;
	margin-top: -8px;
	width: 18px;
	height: 16px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='17.732' height='14.743' viewBox='0 0 17.732 14.743'%3E%3Cg id='arw_r' transform='translate(-395.97 -1753.086)'%3E%3Cpath id='Path_9' data-name='Path 9' d='M3569.772,1773.414l5.957,5.958-5.957,5.958' transform='translate(-3163.027 -18.914)' fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'/%3E%3Cpath id='Path_10' data-name='Path 10' d='M3572.736,1781h-15.2' transform='translate(-3160.564 -20.909)' fill='none' stroke='%23fff' stroke-linecap='round' stroke-width='2'/%3E%3C/g%3E%3C/svg%3E%0A");
	background-position: right center;
	background-repeat: no-repeat;
	transition: 0.3s
}

.c-btn01.btnsml {
	height: 36px;
	/*font-size: 11px;*/
	max-width: 450px;
}
 
@media (max-width: 767px) {
	.c-btn01 {
		max-width: 325px;
		padding: 13px 33px 10px
	}
	.c-btn01:after {
		right: 33px;
		background-size: 14px auto
	}
	.c-btn01.btnsml {
		font-size: 10px;
	}
	.c-btn01.btnsml:after {
		right: 23px;
	}

}
.c-btn01 .label {
	position: relative
}
.c-btn01.small {
	max-width: 140px;
	height: 33px;
	padding: 6px 18px 5px;
	font-size: 13px;
	font-size: 1.3rem
}
.c-btn01.small:after {
	right: 12px;
	background-size: 10px auto
}
@media (max-width: 767px) {
	.c-btn01.small:after {
		right: 15px
	}
}
@media only screen and (min-width: 1025px) {
	.c-btn01:hover {
		opacity: 1;
		color: #32a2e7
	}
	.c-btn01:hover:before {
		height: 100%
	}
	.c-btn01:hover:after {
		background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='17.732' height='14.743' viewBox='0 0 17.732 14.743'%3E%3Cg id='arw_r' transform='translate(-395.97 -1753.086)'%3E%3Cpath id='Path_9' data-name='Path 9' d='M3569.772,1773.414l5.957,5.958-5.957,5.958' transform='translate(-3163.027 -18.914)' fill='none' stroke='%2335b488' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'/%3E%3Cpath id='Path_10' data-name='Path 10' d='M3572.736,1781h-15.2' transform='translate(-3160.564 -20.909)' fill='none' stroke='%2335b488' stroke-linecap='round' stroke-width='2'/%3E%3C/g%3E%3C/svg%3E%0A")
	}
}
.c-btn01.orange {
	background: #008bea;
	border-color: #008bea;
	cursor: pointer
}
@media only screen and (min-width: 1025px) {
	.c-btn01.orange:hover {
		color: #008bea
	}
	.c-btn01.orange:hover:after {
		background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='17.732' height='14.743' viewBox='0 0 17.732 14.743'%3E%3Cg id='arw_r' transform='translate(-395.97 -1753.086)'%3E%3Cpath id='Path_9' data-name='Path 9' d='M3569.772,1773.414l5.957,5.958-5.957,5.958' transform='translate(-3163.027 -18.914)' fill='none' stroke='%23ed705a' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'/%3E%3Cpath id='Path_10' data-name='Path 10' d='M3572.736,1781h-15.2' transform='translate(-3160.564 -20.909)' fill='none' stroke='%23ed705a' stroke-linecap='round' stroke-width='2'/%3E%3C/g%3E%3C/svg%3E%0A")
	}
}
.c-btn01.nobg {
	background: transparent;
	color: #32a2e7;
	cursor: pointer
}
.c-btn01.nobg:before {
	background: #32a2e7
}
.c-btn01.nobg:after {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='17.732' height='14.743' viewBox='0 0 17.732 14.743'%3E%3Cg id='arw_r' transform='translate(-395.97 -1753.086)'%3E%3Cpath id='Path_9' data-name='Path 9' d='M3569.772,1773.414l5.957,5.958-5.957,5.958' transform='translate(-3163.027 -18.914)' fill='none' stroke='%2335b488' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'/%3E%3Cpath id='Path_10' data-name='Path 10' d='M3572.736,1781h-15.2' transform='translate(-3160.564 -20.909)' fill='none' stroke='%2335b488' stroke-linecap='round' stroke-width='2'/%3E%3C/g%3E%3C/svg%3E%0A")
}
@media only screen and (min-width: 1025px) {
	.c-btn01.nobg:hover {
		color: #fff
	}
	.c-btn01.nobg:hover:before {
		height: 100%
	}
	.c-btn01.nobg:hover:after {
		background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='17.732' height='14.743' viewBox='0 0 17.732 14.743'%3E%3Cg id='arw_r' transform='translate(-395.97 -1753.086)'%3E%3Cpath id='Path_9' data-name='Path 9' d='M3569.772,1773.414l5.957,5.958-5.957,5.958' transform='translate(-3163.027 -18.914)' fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'/%3E%3Cpath id='Path_10' data-name='Path 10' d='M3572.736,1781h-15.2' transform='translate(-3160.564 -20.909)' fill='none' stroke='%23fff' stroke-linecap='round' stroke-width='2'/%3E%3C/g%3E%3C/svg%3E%0A")
	}
}
.c-shadowhover {
	cursor: pointer
}
.c-shadowhover .text_normal, .c-shadowhover .text_hover {
	position: relative;
	display: block;
	transition: 0.5s
}
.c-shadowhover .text_normal {
	opacity: 1;
	top: 0
}
.c-shadowhover .text_hover {
	position: absolute;
	top: 20px;
	opacity: 0;
	color: #32a2e7
}
@media only screen and (min-width: 1025px) {
	.c-shadowhover:hover {
		opacity: 1
	}
	.c-shadowhover:hover:after {
		width: 100%
	}
	.c-shadowhover:hover .text_normal {
		opacity: 0;
		top: -20px
	}
	.c-shadowhover:hover .text_hover {
		opacity: 1;
		top: 0
	}
}
.footerslide {
	display: flex;
	overflow: hidden;
	margin-top: 150px
}
@media (max-width: 767px) {
	.footerslide {
		margin-top: 100px
	}
}
.footerslide .imgslide {
	white-space: nowrap;
	color: #f0f0f0;
	font-size: 82px;
	font-size: 8.2rem;
	line-height: 1.09756em;
	letter-spacing: .2em;
	font-weight: 500;
	animation: footer_slide 70s infinite linear 0.5s both
}
@media (max-width: 767px) {
	.footerslide .imgslide {
		font-size: 50px;
		font-size: 5rem
	}
}
@keyframes footer_slide {
	from {
		transform: translateX(0)
	}
	to {
		transform: translateX(-100%)
	}
}
.footerInner {
	margin-top: 50px;
	position: relative
}
.footerInner:before {
	content: "";
	position: absolute;
	top: 0;
	left: calc(50% + 125px);
	right: 0;
	height: 100%;
	background: #d3ebf5;
	border-radius: 60px 0 0 0
}
@media only screen and (max-width: 1050px) {
	.footerInner:before {
		left: calc(100% - 400px)
	}
}
@media (max-width: 767px) {
	.footerInner {
		margin-top: 34px
	}
	.footerInner:before {
		display: none
	}
}
.footerInner .cntdiv {
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: center
}
@media (max-width: 767px) {
	.footerInner .cntdiv {
		display: block
	}
}
.footerInner .cntdiv .contactdiv {
	width: calc(50% - 40px);
	max-width: 335px;
	padding: 75px 0 70px;
	order: 2
}
@media (max-width: 767px) {
	.footerInner .cntdiv .contactdiv {
		margin: 0 -25px;
		width: calc(100% + 50px);
		max-width: calc(100% + 50px);
		background: #d3ebf5;
		padding: 47px 25px 60px
	}
}
@media (min-width: 768px) {
	.footerInner .cntdiv .contactdiv .c-ttl01 .text_en {
		font-size: 50px;
		font-size: 5rem
	}
}
@media (max-width: 767px) {
	.footerInner .cntdiv .contactdiv .c-ttl01 {
		text-align: center
	}
	.footerInner .cntdiv .contactdiv .c-ttl01 .text_en {
		font-size: 42px;
		font-size: 4.2rem;
		letter-spacing: 0.12em
	}
}
.footerInner .cntdiv .contactdiv .txt_notice {
	margin-top: 35px;
	font-size: 15px;
	font-size: 1.5rem;
	line-height: 2em
}
@media (max-width: 767px) {
	.footerInner .cntdiv .contactdiv .txt_notice {
		margin-top: 14px;
		text-align: center;
		font-size: 15px;
		font-size: 1.5rem;
		line-height: 1.6em
	}
}
.footerInner .cntdiv .contactdiv .teldiv {
	margin-top: 25px;
	color: #008bea;
	font-size: 20px;
	font-size: 2.2rem;
	line-height: 1.36364em;
	letter-spacing: .03em;
	font-weight: 500;
	font-family: "Jost", sans-serif;
	white-space: nowrap;
}
@media (max-width: 767px) {
	.footerInner .cntdiv .contactdiv .teldiv {
		margin-top: 23px;
		text-align: center;
		font-size: 18px;
		font-size: 1.8rem;
		line-height: 1.44444em
	}
}
.footerInner .cntdiv .contactdiv .teldiv .call {
	margin-left: -2px;
	color: #008bea;
	font-size: 34px;
	font-size: 3.4rem;
	line-height: 1.11111em;
	letter-spacing: .05em;
	font-weight: 500
}
@media (max-width: 767px) {
	.footerInner .cntdiv .contactdiv .teldiv .call {
		margin-left: 0;
		font-size: 34px;
		font-size: 3.4rem;
		line-height: 1.17647em
	}
}
.footerInner .cntdiv .contactdiv .btncontact {
	margin-top: 35px
}
@media (max-width: 767px) {
	.footerInner .cntdiv .contactdiv .btncontact {
		margin-top: 19px
	}
}
.footerInner .cntdiv .leftdiv {
	width: calc(50% + 40px);
	margin-top: -10px
}
@media only screen and (min-width: 768px) and (max-width: 900px) {
	.footerInner .cntdiv .leftdiv {
		padding-right: 70px
	}
}
@media (max-width: 767px) {
	.footerInner .cntdiv .leftdiv {
		width: 100%;
		margin-top: 58px
	}
}
.footerInner .cntdiv .infordiv {
	display: flex;
	flex-wrap: wrap;
	align-items: center
}
@media (max-width: 767px) {
	.footerInner .cntdiv .infordiv {
		display: block
	}
}
.footerInner .cntdiv .infordiv .logo {
	margin-right: 40px
}
@media only screen and (max-width: 1100px) {
	.footerInner .cntdiv .infordiv .logo img {
		width: 250px
	}
}
@media (max-width: 767px) {
	.footerInner .cntdiv .infordiv .logo {
		margin-right: 0
	}
	.footerInner .cntdiv .infordiv .logo img {
		width: 260px
	}
}
.footerInner .cntdiv .infordiv .txt_address {
	font-size: 15px;
	font-size: 1.5rem;
	line-height: 1.46667em;
	letter-spacing: .08em;
	font-weight: 500
}
@media (max-width: 767px) {
	.footerInner .cntdiv .infordiv .txt_address {
		margin-top: 17px
	}
}
.footerInner .cntdiv .ftnavi {
	margin: 9px -20px 0;
	display: flex;
	flex-wrap: wrap
}
@media (max-width: 767px) {
	.footerInner .cntdiv .ftnavi {
		margin: 13px -10px 0
	}
}
.footerInner .cntdiv .ftnavi a {
	position: relative;
	display: block;
	margin: 0 20px;
	width: calc(50% - 40px);
	border-bottom: #d9d9d9 2px solid;
	padding: 35px 10px 5px;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.875em;
	letter-spacing: .08em;
	font-weight: 500;
	cursor: pointer
}
.footerInner .cntdiv .ftnavi a:after {
	content: "";
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 0;
	height: 2px;
	background: #32a2e7;
	transition: 0.3s
}
@media only screen and (min-width: 768px) and (max-width: 900px) {
	.footerInner .cntdiv .ftnavi a {
		margin: 0 15px;
		width: calc(50% - 30px);
		font-size: 15px;
		font-size: 1.5rem;
		line-height: 2em;
		letter-spacing: 0em;
		white-space: nowrap
	}
}
@media only screen and (min-width: 1025px) {
	.footerInner .cntdiv .ftnavi a:hover:after {
		width: 100%
	}
}
@media (max-width: 767px) {
	.footerInner .cntdiv .ftnavi a {
		margin: 0 10px;
		width: calc(50% - 20px);
		padding: 20px 5px 7px;
		font-size: 13px;
		font-size: 1.3rem;
		line-height: 1.53846em
	}
}
.footerInner .cntdiv .ftnavi a .label {
	position: relative;
	display: block
}
.footerInner02 {
	background: #32a2e7;
	padding: 37px 0 35px;
	color: #fff
}
@media (max-width: 767px) {
	.footerInner02 {
		margin-top: 60px;
		padding: 37px 0 35px
	}
}
.footerInner02 .seodiv {
	padding: 0 0 25px;
	color: #b0e3d2;
	font-size: 10px;
	font-size: 1rem;
	line-height: 2em;
	letter-spacing: .05em;
	font-weight: 500
}
@media (max-width: 767px) {
	.footerInner02 .seodiv {
		padding: 0 0 27px;
		font-size: 10px;
		font-size: 1rem;
		line-height: 1.8em
	}
}
.footerInner02 .cntdiv {
	display: flex;
	justify-content: center;
	font-size: 12px;
	font-size: 1.2rem;
	line-height: 1.33333em;
	letter-spacing: .08em;
	font-weight: 400;
	font-family: "Jost", sans-serif
}
@media (max-width: 767px) {
	.footerInner02 .cntdiv {
		display: block
	}
}
.footerInner02 .linkdiv a {
	padding-right: 25px;
	color: #fff;
	font-size: 1.4rem;
}
@media (max-width: 767px) {
	.footerInner02 .linkdiv a {
		margin-right: 10px
	}
}
@media (max-width: 767px) {
	.footerInner02 .linkdiv {
		margin-bottom: 10px
	}
}
.btn_gototop {
	position: fixed;
	right: 30px;
	bottom: 70px;
	width: 60px;
	height: 60px;
	border-radius: 50%;
	z-index: 999;
	background-color: #fff;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14.743' height='17.732' viewBox='0 0 14.743 17.732'%3E%3Cg id='arw' transform='translate(-1753.086 413.702) rotate(-90)'%3E%3Cpath id='Path_9' data-name='Path 9' d='M3569.772,1773.414l5.957,5.958-5.957,5.958' transform='translate(-3163.027 -18.914)' fill='none' stroke='%2335b488' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'/%3E%3Cpath id='Path_10' data-name='Path 10' d='M3572.736,1781h-15.2' transform='translate(-3160.564 -20.543)' fill='none' stroke='%2335b488' stroke-linecap='round' stroke-width='2'/%3E%3C/g%3E%3C/svg%3E%0A");
	background-position: center top 14px;
	background-repeat: no-repeat;
	border: #32a2e7 2px solid;
	padding: 34px 0 0 2px;
	text-align: center;
	color: #32a2e7;
	font-size: 11px;
	font-size: 1.1rem;
	line-height: 1.36364em;
	letter-spacing: .03em;
	font-weight: 600;
	font-family: "Jost", sans-serif;
	transition: 0.3s;
	cursor: pointer
}
@media only screen and (min-width: 1025px) {
	.btn_gototop:hover {
		background-color: #32a2e7;
		background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14.743' height='17.732' viewBox='0 0 14.743 17.732'%3E%3Cg id='arw' transform='translate(-1753.086 413.702) rotate(-90)'%3E%3Cpath id='Path_9' data-name='Path 9' d='M3569.772,1773.414l5.957,5.958-5.957,5.958' transform='translate(-3163.027 -18.914)' fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'/%3E%3Cpath id='Path_10' data-name='Path 10' d='M3572.736,1781h-15.2' transform='translate(-3160.564 -20.543)' fill='none' stroke='%23fff' stroke-linecap='round' stroke-width='2'/%3E%3C/g%3E%3C/svg%3E%0A");
		border-color: #fff;
		color: #fff
	}
}
@media (max-width: 767px) {
	.btn_gototop {
		right: 25px;
		bottom: 75px
	}
}
.btn_gototop img {
	box-shadow: 0px 3px 15px rgba(205, 38, 80, 0.08);
	border-radius: 50%
}
.header {
	position: fixed;
	left: auto;
	top: auto;
	z-index: 1000;
	width: 100%;
	padding: 21px 30px 0 40px;
	transition: 0.3s
}
@media (max-width: 767px) {
	.header {
		height: 100px;
		padding: 38px 30px 0 20px
	}
}
.header .inHeader {
	position: relative;
	height: 100%;
	display: flex;
	justify-content: space-between
}
.header .txth1 {
	position: absolute;
	width: calc(100% - 400px);
	top: 7px;
	font-size: 10px;
	font-size: 1rem;
	line-height: 1.6em;
	letter-spacing: .05em;
	font-weight: 400
}
@media (max-width: 767px) {
	.header .txth1 {
		display: none
	}
}
.header .logo {
	padding: 45px 0 0 4px;
	padding: 10px 0 0 4px;
}
@media only screen and (min-width: 768px) and (max-width: 900px) {
	.header .logo img {
		width: 200px
	}
}
@media (max-width: 767px) {
	.header .logo {
		margin-top: -2px;
		padding: 0
	}
	.header .logo img {
		width: 231px
	}
}
.layerMenu {
	position: relative;
	text-align: right
}
@media (min-width: 768px) {
	.layerMenu {
		display: block !important
	}
}
@media (max-width: 767px) {
	.layerMenu {
		position: fixed;
		top: 0;
		bottom: 0;
		left: 0;
		width: 100%;
		text-align: left;
		background: #32a2e7;
		z-index: 999;
		overflow-y: auto;
		color: #fff;
		display: none
	}
	.layerMenu .inLayer {
		position: relative;
		display: flex;
		flex-wrap: wrap;
		height: auto;
		padding: 100px 25px 81px;
		overflow: hidden
	}
}
.layerMenu .circle01 {
	top: -40px;
	left: -65px;
	width: 359px;
	border-color: #ffffff;
	opacity: 0.3;
}
.layerMenu .circle02 {
	bottom: -40px;
	right: -120px;
	width: 258px;
	border-color: #ffffff;
	opacity: 0.3;
}
.layerMenu .logo02 {
	position: absolute;
	top: 35px;
	left: 20px
}
.layerMenu .hNavi {
	position: relative;
	margin-top: 10px;
	display: flex;
	justify-content: flex-end;
	align-items: center
}
@media (max-width: 767px) {
	.layerMenu .hNavi {
		display: block;
		width: 100%;
		order: 2;
		text-align: center
	}
}
.layerMenu .hNavi .btntel {
	display: inline-block;
	color: #008bea;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.25em;
	letter-spacing: .03em;
	font-weight: 500;
	font-family: "Jost", sans-serif
}

.btntel + .btntel {
	margin-left: 10px;
}

.layerMenu .hNavi .btntel .num {
	margin-left: -4px;
	color: #008bea;
	font-size: 22px;
	font-size: 2.2rem;
	line-height: 1.25em;
	letter-spacing: .03em;
	font-weight: 500
}
@media (max-width: 767px) {
	.layerMenu .hNavi .btntel {
		margin-top: 36px;
		padding-right: 5px;
		color: #fff;
		font-size: 18px;
		font-size: 1.8rem;
		line-height: 1.11111em
	}
	.layerMenu .hNavi .btntel .num {
		margin-left: 0;
		color: #fff;
		font-size: 34px;
		font-size: 3.4rem;
		line-height: 1.17647em;
		letter-spacing: .05em
	}
	.btntel + .btntel {
		margin-left: 0px;
		margin-top: 16px !important;
	}

}
.layerMenu .hNavi .btncontact {
	margin-left: 20px;
	max-width: 163px;
	height: 34px;
	padding-top: 8px;
	text-align: center;
	justify-content: center
}
@media (min-width: 768px) {
	.layerMenu .hNavi .btncontact:after {
		display: none
	}
}
@media (max-width: 767px) {
	.layerMenu .hNavi .btncontact {
		margin: 23px 0 0;
		max-width: 100%;
		height: 74px;
		justify-content: flex-start;
		padding-left: 33px;
		font-size: 15px;
		font-size: 1.5rem;
		line-height: 1.33333em
	}
	.layerMenu .hNavi .btncontact:after {
		right: 32px;
		background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14.344' height='12.177' viewBox='0 0 14.344 12.177'%3E%3Cg id='arw_r' transform='translate(1 1.414)'%3E%3Cpath id='Path_9' data-name='Path 9' d='M3569.772,1773.414l4.674,4.674-4.674,4.674' transform='translate(-3562.102 -1773.414)' fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'/%3E%3Cpath id='Path_10' data-name='Path 10' d='M3569.462,1781h-11.929' transform='translate(-3557.534 -1776.613)' fill='none' stroke='%23fff' stroke-linecap='round' stroke-width='2'/%3E%3C/g%3E%3C/svg%3E%0A");
		background-size: 14px auto
	}
}
.layerMenu .gNavi {
	position: relative;
	margin-top: 13px
}
@media (max-width: 767px) {
	.layerMenu .gNavi {
		margin-top: 6px;
		width: 100%
	}
}
.layerMenu .gNavi>li {
	display: inline-block;
	vertical-align: top;
	width: auto;
	margin-left: 39px;
	font-weight: bold;
	letter-spacing: 1px;
	position: relative
}
@media only screen and (min-width: 768px) and (max-width: 900px) {
	.layerMenu .gNavi>li {
		margin-left: 8px
	}
}
@media (max-width: 767px) {
	.layerMenu .gNavi>li {
		display: block;
		width: 100%;
		margin-left: 0
	}
}
.layerMenu .gNavi>li>a, .layerMenu .gNavi>li .itempa {
	position: relative;
	display: block;
	padding: 3px 0;
	font-size: 15px;
	font-size: 1.5rem;
	line-height: 1.33333em;
	letter-spacing: .08em;
	font-weight: 700;
	opacity: 1 !important
}
.layerMenu .gNavi>li>a .label, .layerMenu .gNavi>li .itempa .label {
	position: relative;
	display: block
}
@media (max-width: 767px) {
	.layerMenu .gNavi>li>a, .layerMenu .gNavi>li .itempa {
		border-bottom: #75d6b4 2px solid;
		padding: 35px 5px 19px;
		color: #fff;
		font-size: 18px;
		font-size: 1.8rem;
		line-height: 1.11111em;
		letter-spacing: .08em;
		font-weight: 700
	}
	.layerMenu .gNavi>li>a:after, .layerMenu .gNavi>li .itempa:after {
		content: "";
		position: absolute;
		top: 50%;
		right: 10px;
		margin-top: -2px;
		width: 14px;
		height: 14px;
		background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14.344' height='12.177' viewBox='0 0 14.344 12.177'%3E%3Cg id='arw_r' transform='translate(1 1.414)'%3E%3Cpath id='Path_9' data-name='Path 9' d='M3569.772,1773.414l4.674,4.674-4.674,4.674' transform='translate(-3562.102 -1773.414)' fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'/%3E%3Cpath id='Path_10' data-name='Path 10' d='M3569.462,1781h-11.929' transform='translate(-3557.534 -1776.613)' fill='none' stroke='%23fff' stroke-linecap='round' stroke-width='2'/%3E%3C/g%3E%3C/svg%3E%0A");
		background-repeat: no-repeat;
		background-position: right center
	}
}
.layerMenu .gNavi>li.hasSub>a, .layerMenu .gNavi>li.hasSub .itempa {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='9.82' height='5.41' viewBox='0 0 9.82 5.41'%3E%3Cpath id='Path_16' data-name='Path 16' d='M2113.391,87.736l3.5,3,3.5-3' transform='translate(-2111.981 -86.326)' fill='none' stroke='%2335b488' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'/%3E%3C/svg%3E%0A");
	background-position: right 3px top 10px;
	background-repeat: no-repeat;
	padding-right: 18px
}
@media (max-width: 767px) {
	.layerMenu .gNavi>li.hasSub>a, .layerMenu .gNavi>li.hasSub .itempa {
		background: none
	}
	.layerMenu .gNavi>li.hasSub>a:after, .layerMenu .gNavi>li.hasSub .itempa:after {
		background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13.929' height='13.929' viewBox='0 0 13.929 13.929'%3E%3Cg id='Group_167' data-name='Group 167' transform='translate(-326.655 -5100.748)'%3E%3Cpath id='Path_10' data-name='Path 10' d='M3569.462,1781h-11.929' transform='translate(-3229.879 3326.713)' fill='none' stroke='%23fff' stroke-linecap='round' stroke-width='2'/%3E%3Cpath id='Path_7301' data-name='Path 7301' d='M3569.462,1781h-11.929' transform='translate(2114.619 1544.215) rotate(90)' fill='none' stroke='%23fff' stroke-linecap='round' stroke-width='2'/%3E%3C/g%3E%3C/svg%3E%0A")
	}
}
.layerMenu .gNavi>li.hasSub.hover>a, .layerMenu .gNavi>li.hasSub.hover .itempa {
	opacity: 1;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='9.82' height='5.41' viewBox='0 0 9.82 5.41'%3E%3Cpath id='Path_15' data-name='Path 15' d='M2113.391,90.736l3.5-3,3.5,3' transform='translate(-2111.981 -86.736)' fill='none' stroke='%2335b488' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'/%3E%3C/svg%3E%0A");
	color: #32a2e7
}
@media (max-width: 767px) {
	.layerMenu .gNavi>li.hasSub.active>a:after, .layerMenu .gNavi>li.hasSub.active .itempa:after {
		background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13.929' height='2' viewBox='0 0 13.929 2'%3E%3Cg id='Group_167' data-name='Group 167' transform='translate(-326.655 -5106.713)'%3E%3Cpath id='Path_10' data-name='Path 10' d='M3569.462,1781h-11.929' transform='translate(-3229.879 3326.713)' fill='none' stroke='%23fff' stroke-linecap='round' stroke-width='2'/%3E%3Cpath id='Path_7301' data-name='Path 7301' d='M3569.462,1781h-11.929' transform='translate(-3229.879 3326.713)' fill='none' stroke='%23fff' stroke-linecap='round' stroke-width='2'/%3E%3C/g%3E%3C/svg%3E%0A")
	}
}
@media (min-width: 768px) {
	.layerMenu .gNavi .navSub {
		position: absolute;
		left: 50%;
		top: 100%;
		width: 282px;
		margin-left: 25px;
		padding-top: 15px;
		transform: translateX(-50%);
		display: none
	}
}
@media (max-width: 767px) {
	.layerMenu .gNavi .navSub {
		display: none
	}
}
@media (min-width: 768px) {
	.layerMenu .gNavi .navSub ul {
		background: #fff;
		border-radius: 10px;
		box-shadow: 0px 0px 20px rgba(206, 206, 206, 0.2);
		padding: 10px 30px 30px
	}
}
@media (max-width: 767px) {
	.layerMenu .gNavi .navSub ul {
		margin-bottom: -5px;
		padding: 20px 0 0
	}
}
.layerMenu .gNavi .navSub ul li a {
	position: relative;
	display: block;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13.882' height='11.8' viewBox='0 0 13.882 11.8'%3E%3Cg id='arw' transform='translate(-395.97 -1753.099)'%3E%3Cpath id='Path_9' data-name='Path 9' d='M3569.772,1773.414l5.957,4.5-5.957,4.5' transform='translate(-3166.878 -18.914)' fill='none' stroke='%2335b488' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'/%3E%3Cpath id='Path_10' data-name='Path 10' d='M3568.886,1781h-11.352' transform='translate(-3160.564 -22.277)' fill='none' stroke='%2335b488' stroke-linecap='round' stroke-width='2'/%3E%3C/g%3E%3C/svg%3E%0A");
	background-position: right 10px center;
	background-repeat: no-repeat;
	border-bottom: #d9d9d9 2px solid;
	padding: 16px 4px 13px;
	text-align: left;
	font-size: 14px;
	font-size: 1.4rem;
	line-height: 1.42857em;
	letter-spacing: .08em;
	font-weight: 700;
	transition: 0.3s;
	cursor: pointer
}
.layerMenu .gNavi .navSub ul li a:after {
	content: "";
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 0;
	height: 2px;
	background: #32a2e7;
	transition: 0.3s
}
@media only screen and (min-width: 1025px) {
	.layerMenu .gNavi .navSub ul li a:hover {
		opacity: 1;
		background-position: right 0 center;
		color: #32a2e7
	}
	.layerMenu .gNavi .navSub ul li a:hover:after {
		width: 100%
	}
}
@media (max-width: 767px) {
	.layerMenu .gNavi .navSub ul li a {
		background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14.344' height='12.177' viewBox='0 0 14.344 12.177'%3E%3Cg id='arw_r' transform='translate(1 1.414)'%3E%3Cpath id='Path_9' data-name='Path 9' d='M3569.772,1773.414l4.674,4.674-4.674,4.674' transform='translate(-3562.102 -1773.414)' fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'/%3E%3Cpath id='Path_10' data-name='Path 10' d='M3569.462,1781h-11.929' transform='translate(-3557.534 -1776.613)' fill='none' stroke='%23fff' stroke-linecap='round' stroke-width='2'/%3E%3C/g%3E%3C/svg%3E%0A");
		background-position: right 10px center;
		border: none;
		padding: 10px 15px;
		color: #fff;
		font-size: 16px;
		font-size: 1.6rem;
		line-height: 1.25em
	}
}
@media (min-width: 768px) {
	.layerMenu .gNavi .gRecruit .navSub {
		left: auto;
		right: -15px;
		transform: translateX(0)
	}
}
@media (min-width: 768px) {
	.fixHeader .header {
		height: 117px;
		background: rgba(255, 255, 255, 0.95);
		border-radius: 0px 0px 30px 30px;
		box-shadow: 0px 3px 18px rgba(195, 195, 195, 0.1);
		padding-top: 0
	}
	.fixHeader .header .logo {
		padding-top: 40px
	}
	.fixHeader .header .txth1 {
		display: none
	}
	.fixHeader .layerMenu .hNavi {
		margin-top: 20px
	}
}
@media (max-width: 767px) {
	.layerOn .header {
		background: #32a2e7
	}
}

.rightdiv {
	flex: 1;
}

.hamberger {
	position: fixed;
	right: 20px;
	top: 20px;
	z-index: 1000;
	width: 60px;
	height: 60px;
	background: #32a2e7;
	border: #32a2e7 1px solid;
	border-radius: 50%;
	padding: 18px 5px 0 5px;
	line-height: 1;
	font-size: 0;
	text-align: center;
	cursor: pointer;
	display: none
}
.hamberger .line {
	margin: 0 auto 6px;
	display: block;
	width: 26px;
	height: 2px;
	background: #fff;
	-webkit-transition: 0.3s ease all;
	-moz-transition: 0.3s ease all;
	-ms-transition: 0.3s ease all;
	-o-transition: 0.3s ease all;
	transition: 0.3s ease all
}
.hamberger .txt {
	text-align: center;
	color: #fff;
	font-size: 8px;
	font-size: .8rem;
	line-height: 1.25em;
	letter-spacing: .15em;
	font-weight: 800;
	font-family: "Jost", sans-serif
}
.hamberger .txt.close {
	display: none
}
.hamberger.active {
	border-color: #fff
}
.hamberger.active .line {
	width: 28px
}
.hamberger.active .ham {
	transform: rotate(18deg) translateY(4px) translateX(1px)
}
.hamberger.active .ber {
	transform: rotate(-18deg) translateY(-4px) translateX(1px)
}
.hamberger.active .txt.menu {
	display: none
}
.hamberger.active .txt.close {
	display: block
}
@media only screen and (max-width: 767px) {
	.hamberger {
		display: block
	}
}
.wp-pagenavi {
	margin-top: 60px;
	text-align: center;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.25em;
	letter-spacing: .08em;
	font-weight: 800;
	font-family: "Jost", sans-serif
}
.wp-pagenavi::after {
	content: "";
	clear: both;
	display: table
}
@media (max-width: 767px) {
	.wp-pagenavi {
		margin-top: 52px;
		font-size: 15px;
		font-size: 1.5rem;
		line-height: 1.33333em
	}
}
.wp-pagenavi span, .wp-pagenavi a {
	display: inline-block;
	vertical-align: middle;
	margin: 0 3px;
	width: 64px;
	height: 64px;
	background-color: #f0f0f0;
	border-radius: 50%;
	padding-top: 22px;
	text-align: center
}
@media (max-width: 767px) {
	.wp-pagenavi span, .wp-pagenavi a {
		margin: 0 2px;
		width: 51px;
		height: 51px;
		padding-top: 15px
	}
}
.wp-pagenavi span.current {
	background-color: #32a2e7;
	color: #fff
}
.wp-pagenavi .previouspostslink, .wp-pagenavi .first, .wp-pagenavi .nextpostslink, .wp-pagenavi .last {
	margin: 0 0 0 20px;
	text-indent: -99999px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='9.254' height='8.143' viewBox='0 0 9.254 8.143'%3E%3Cg id='arw' transform='translate(-635.746 -1737.09)'%3E%3Cpath id='Path_97' data-name='Path 97' d='M0,2.281,2.661,0,5.323,2.281' transform='translate(644 1738.5) rotate(90)' fill='none' stroke='%23454545' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'/%3E%3Cpath id='Path_98' data-name='Path 98' d='M0,2.281,2.661,0,5.323,2.281' transform='translate(639.438 1738.5) rotate(90)' fill='none' stroke='%23454545' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'/%3E%3C/g%3E%3C/svg%3E%0A");
	background-repeat: no-repeat;
	background-position: center
}
@media (max-width: 767px) {
	.wp-pagenavi .previouspostslink, .wp-pagenavi .first, .wp-pagenavi .nextpostslink, .wp-pagenavi .last {
		margin-left: 17px
	}
}
@media only screen and (max-width: 374px) {
	.wp-pagenavi .previouspostslink, .wp-pagenavi .first, .wp-pagenavi .nextpostslink, .wp-pagenavi .last {
		margin-left: 10px
	}
}
.wp-pagenavi .previouspostslink, .wp-pagenavi .first {
	margin: 0 20px 0 0;
	transform: rotate(180deg)
}
@media (max-width: 767px) {
	.wp-pagenavi .previouspostslink, .wp-pagenavi .first {
		margin-right: 17px
	}
}
@media only screen and (max-width: 374px) {
	.wp-pagenavi .previouspostslink, .wp-pagenavi .first {
		margin-right: 10px
	}
}
.wp-pagenavi .previouspostslink, .wp-pagenavi .nextpostslink, .wp-pagenavi .extend {
	display: none
}

.list-9box {
	margin-top: 20px;
}

.list-9 {
    list-style-type: disc;
    list-style-position: inside;
    padding: 1em;
    border: 2px solid #2589d0;
}

.list-9 li {
    padding: .5em;
}

.list-9 li:not(:last-child) {
    border-bottom: 1px dashed #2589d0;
}

.list-9 li::marker {
    color: #2589d0;
    font-size: 1.1em;
}

.table-price {
	margin-top: -40px;
}

.sample2 {
    border-collapse: collapse;
    table-layout: fixed;
    width: 100%;
    background: #fff;
    border: none;
}
.sample2 th,
.sample2 td {
    background: #fff;
    border: 1px solid #ccc;
    padding: 8px;
    vertical-align: middle;
    box-sizing: border-box;
}
.sample2 th {
    font-weight: 700;
    text-align: center;
}
.sample2 thead th {
    color: #fff;
    background: #32A2E7;
}
.sample2 tbody td:last-child {
  text-align: right;
}
.sample2 thead th:first-child,
.sample2 thead th:last-child {
  width: 20%;
}
@media screen and (max-width: 768px) {
  .sample2 thead {
    display:none;
  }
  .sample2 tr {
    background-color: unset;
  }
  .sample2 th, .ex_sample2 td {
    display: block;
    width: 100%;
    border: 0;
    border-bottom: 1px solid #ccc;
  }
  .sample2 tbody th{
    background: #32A2E7;
    color:#fff;
    text-align: center;
  }
  .sample2 tbody tr td:not(:last-child) {
    display: flex;
    flex-direction: column;
    gap: 5px;
  }
  .sample2 tbody tr td:not(:last-child)::before{
    content: attr(data-label);
    width: fit-content;
    padding: 0.2em 1em;
    border-radius: 100vw;
    font-size: 12px;
    background: #eee;
  }
  .sample2 tbody td:last-child::before{
    content: attr(data-label);
    display: inline-block;
    margin-right: 10px;
  }
  .sample2 tbody td:last-child{
    display: flex;
    justify-content: space-between;
  }
}

.dli-caret-down {
  display: block;
  vertical-align: middle;
  color: #32A2E7;
  line-height: 1;
  width: 0;
  height: 0;
  border-style: solid;
  border-color: transparent;
  border-width: 0.64952em 0.375em;
  border-top-color: currentColor;
  border-bottom: 0;
  margin:15px auto;
}

.houmon-lead {
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px solid #ccc;
}

.text_red {
	color: #F00;
}

.table_design03 {
border-collapse: collapse;
width: 100%;
background: #fff;
}
.table_design03 th, .table_design03 td {
border-bottom: 2px solid #c1c7c6;
padding: 1em;
}
.table_design03 th {
border-bottom: 2px solid #4d9bc1;;
font-weight: bold;
text-align: center;
width: 20%;
min-width: 4em;
}

.wardwrap {
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
}

.wardwrap div:nth-child(2n) {
	margin: 0 20px;
}

.heading-21 {
    position: relative;
    padding: .5em .7em .4em;
    border-bottom: 3px solid #2589d0;
    color: #333333;
	font-size: 24px;
	font-size: 2.4rem;
	font-weight: bold;
	margin-bottom: 40px;
}

.heading-21::before,
.heading-21::after {
    position: absolute;
    left: 30px;
    bottom: -15px;
    width: 30px;
    height: 15px;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    content: '';
}

.heading-21::before {
    background-color: #2589d0;
}

.heading-21::after {
    bottom: -11px;
    background-color: #fff;
}

/* 横スクロール（スマホ対応） */
.price-table-wrap{
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 6px; /* スクロールバーが被らないように */
}

/* テーブル本体 */
.price-table{
  width: 100%;
  min-width: 680px;             /* 画像っぽい見た目を保つ */
  border-collapse: separate;
  border-spacing: 0;
  font-weight: 700;
  text-align: center;
}

/* 共通セル */
.price-table th,
.price-table td{
  padding: 14px 18px;
  border-right: 2px solid #ffffff;
  border-bottom: 2px solid #ffffff;
  white-space: nowrap;
  font-size: 16px;
  line-height: 1.2;
}

/* ヘッダー */
.price-table thead th{
  background: #5ea0d3;
  color: #ffffff;
  text-align: center;
}
.price-table thead th.price-table__corner{
  width: 140px;                 /* 左の「要介護」列幅 */
}

/* 左列（行見出し） */
.price-table tbody th{
  background: #d7e3f0;
  color: #000;
	text-align: center;
}



/* データ部分（交互の行色） */
.price-table tbody tr:nth-child(odd) td{
  background: #eef4fb;
}
.price-table tbody tr:nth-child(even) td{
  background: #e2edf8;
}

/* 外枠をキレイに（右・下の白線を消す） */
.price-table tr > *:last-child{ border-right: 0; }
.price-table tbody tr:last-child > *{ border-bottom: 0; }

/* 角丸（雰囲気を画像に寄せる） */
.price-table thead tr th:first-child{ border-top-left-radius: 6px; }
.price-table thead tr th:last-child{ border-top-right-radius: 6px; }
.price-table tbody tr:last-child th:first-child{ border-bottom-left-radius: 6px; }
.price-table tbody tr:last-child td:last-child{ border-bottom-right-radius: 6px; }

/* 小さめ画面で文字を少し縮める */
@media (max-width: 480px){
  .price-table th,
  .price-table td{
    padding: 12px 14px;
    font-size: 14px;
  }
}

/* ==========================
   オレンジ配色バージョン
   ========================== */
.price-table.tableor thead th{
  background: #ffc400;   /* 濃いオレンジ（ヘッダー） */
  color: #ffffff;
}

/* 左列（要介護） */
.price-table.tableor tbody th{
  background: #ffe7c2;   /* 薄いオレンジ */
  color: #000;
}

/* データ部分（交互の行色） */
.price-table.tableor tbody tr:nth-child(odd) td{
  background: #fff3df;
}

.price-table.tableor tbody tr:nth-child(even) td{
  background: #ffe8cc;
}

/* 枠線（白のままでOK） */
.price-table.tableor th,
.price-table.tableor td{
  border-right: 2px solid #ffffff;
  border-bottom: 2px solid #ffffff;
}

/* PCは最大960px・中央寄せ */
.map-wrap{
  max-width: 960px;
  width: 100%;
  margin: 0 auto;
}

/* アスペクト比を保つ（16:9） */
.map-inner{
  position: relative;
  width: 100%;
  padding-top: 56.25%; /* 16:9 */
  overflow: hidden;
}

/* iframeを全面フィット */
.map-inner iframe{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.txt-r {
	text-align: right;
}

.list-1 {
    list-style-type: disc;
    padding: 1em 1em 1em 2.5em;
}

.list-1 li {
    padding: .3em .3em .3em 0;
    border-bottom: 1px dotted #2589d0;

}

.list-1 li::marker {
    color: #2589d0;
}

/* =========================================
   スマホ下部 固定電話バー
   ========================================= */
.sp-callbar {
  display: none;
}

@media only screen and (max-width: 768px) {

  .sp-callbar {
    position: fixed;
    left: 0;
    bottom: 0;
    width: 100%;
    display: flex;
    z-index: 9998;
    box-shadow: 0 -4px 14px rgba(0, 0, 0, 0.12);
  }

  .sp-callbar__btn {
    width: 50%;
    background: #2f6fa5;
    color: #fff;
    text-decoration: none;
    text-align: center;

    /* ▼ここが重要 */
    display: flex;
    align-items: center;
    justify-content: center;
    height: 60px;

    border-right: 1px solid rgba(255, 255, 255, 0.2);
    box-sizing: border-box;
  }

  .sp-callbar__btn:last-child {
    border-right: none;
  }

  .sp-callbar__label {
    font-size: 14px;
    font-weight: 700;
    line-height: 1.4;
  }

  /* 下に隠れない余白も高さに合わせて調整 */
  body:not(#top):not(.top) {
    padding-bottom: 60px;
  }
}

.sp-callbar__icon {
  display: block;
  font-size: 16px;
  margin-right: 5px;
}
@media only screen and (max-width: 768px) {
  .pagetop,
  .page-top,
  .to-top,
  #pageTop,
  #top_btn {
    bottom: 75px !important;
  }
}

/* =========================
   診療のご案内 下 安心ポイント
   ========================= */
.hospital-points{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
  margin-top: 42px;
}

.hospital-points__item{
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 20px 22px;
  background: #fff;
  border: 1px solid #d9e8f3;
  border-radius: 16px;
  box-shadow: 0 8px 24px rgba(20, 64, 98, 0.08);
}

.hospital-points__icon{
  position: relative;
  flex: 0 0 56px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, #32a2e7 0%, #6fc3f3 100%);
}

.hospital-points__title{
  margin: 0 0 6px;
  font-size: 18px;
  line-height: 1.5;
  font-weight: 700;
  color: #1f3b53;
}

.hospital-points__text{
  margin: 0;
  font-size: 14px;
  line-height: 1.8;
  color: #5a6b78;
}

/* 女性医師アイコン */
.hospital-points__icon--doctor::before{
  content: "";
  position: absolute;
  top: 11px;
  left: 50%;
  width: 18px;
  height: 18px;
  margin-left: -9px;
  background: #fff;
  border-radius: 50%;
}

.hospital-points__icon--doctor::after{
  content: "";
  position: absolute;
  top: 28px;
  left: 50%;
  width: 28px;
  height: 16px;
  margin-left: -14px;
  background: #fff;
  border-radius: 16px 16px 10px 10px;
}

.hospital-points__icon--doctor span::before{
  content: "";
  position: absolute;
  top: 32px;
  left: 50%;
  width: 4px;
  height: 14px;
  margin-left: -2px;
  background: #32a2e7;
  border-radius: 999px;
  z-index: 2;
}

.hospital-points__icon--doctor span::after{
  content: "";
  position: absolute;
  top: 37px;
  left: 50%;
  width: 14px;
  height: 4px;
  margin-left: -7px;
  background: #32a2e7;
  border-radius: 999px;
  z-index: 2;
}

/* 駐車場アイコン */
.hospital-points__icon--parking::before{
  content: "P";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -58%);
  color: #fff;
  font-size: 24px;
  line-height: 1;
  font-weight: 700;
}

.hospital-points__icon--parking::after{
  content: "";
  position: absolute;
  left: 50%;
  bottom: 10px;
  width: 26px;
  height: 3px;
  margin-left: -13px;
  background: rgba(255,255,255,0.9);
  border-radius: 999px;
}

/* タブレット以下 */
@media (max-width: 900px){
  .hospital-points{
    grid-template-columns: 1fr;
  }
}

/* スマホ */
@media (max-width: 767px){
  .hospital-points{
    gap: 14px;
    margin-top: 24px;
  }

  .hospital-points__item{
    padding: 16px;
    border-radius: 12px;
    gap: 12px;
  }

  .hospital-points__icon{
    flex: 0 0 48px;
    width: 48px;
    height: 48px;
  }

  .hospital-points__title{
    font-size: 16px;
    line-height: 1.4;
  }

  .hospital-points__text{
    font-size: 13px;
    line-height: 1.7;
  }

  .hospital-points__icon--doctor::before{
    width: 15px;
    height: 15px;
    margin-left: -7.5px;
    top: 10px;
  }

  .hospital-points__icon--doctor::after{
    width: 24px;
    height: 14px;
    margin-left: -12px;
    top: 24px;
  }

  .hospital-points__icon--doctor span::before{
    top: 28px;
    height: 12px;
  }

  .hospital-points__icon--doctor span::after{
    top: 32px;
    width: 12px;
    margin-left: -6px;
  }

  .hospital-points__icon--parking::before{
    font-size: 21px;
  }

  .hospital-points__icon--parking::after{
    width: 22px;
    margin-left: -11px;
  }
}

/* =========================
   GoogleMapセクション
   ========================= */
.hospital-map{
  margin-top: 60px;
}

.hospital-map__title{
  font-size: 22px;
  font-weight: 700;
  color: #1f3b53;
  margin-bottom: 16px;
  position: relative;
  padding-left: 12px;
}

.hospital-map__title::before{
  content: "";
  position: absolute;
  left: 0;
  top: 6px;
  width: 4px;
  height: 20px;
  background: #32a2e7;
  border-radius: 2px;
}

/* 枠デザイン */
.hospital-map__inner{
  position: relative;
  width: 100%;
  padding-top: 40%; /* 16:9 */
  border-radius: 16px;
  overflow: hidden;
  /*box-shadow: 0 8px 24px rgba(20, 64, 98, 0.08);*/
  border: 1px solid #d9e8f3;
}

/* iframeを完全フィット */
.hospital-map__inner iframe{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

/* スマホ微調整 */
@media (max-width: 767px){
  .hospital-map{
    margin-top: 28px;
  }

  .hospital-map__title{
    font-size: 18px;
  }

  .hospital-map__inner{
    border-radius: 12px;
  }
}

.button01, .sitemap .main-link, .sitemap .sitemap-sub a, .thumbnail-wrap .prev-arrow, .thumbnail-wrap .next-arrow, .checkup-info .info-box a, .l-main .ui.form.inputForm button.button02, .l-main .ui.form.inputForm a.button02, .backnumber-btn-list>li>a, .btn-list>li>a, .button02 {
  display: inline-block;
  width: 100%;
  max-width: 240px;
  font-weight: bold;
  color: #fff;
  background: rgb(50, 162, 231);
  border: 1px solid rgb(50, 162, 231);
  text-decoration: none;
  position: relative;
  padding: 15px 60px 15px 20px;
  border-radius: 6px;
  transition: .3s;
}

.button01::after, .sitemap .main-link::after, .sitemap .sitemap-sub a::after, .thumbnail-wrap .prev-arrow::after, .thumbnail-wrap .next-arrow::after, .checkup-info .info-box a::after, .l-main .ui.form.inputForm button.button02::after, .l-main .ui.form.inputForm a.button02::after, .backnumber-btn-list > li > a::after, .btn-list > li > a::after, .button02::after {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
  right: 20px;
  width: 29px;
  height: 20px;
  color: rgb(40, 175, 96);
  display: grid;
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  font-size: 12px;
  border-radius: 999px;
  background: rgb(255, 255, 255);
  place-content: center;
  transition: 0.3s;
}

.meal-charge {
  padding: 40px 0px;
}

.meal-charge__inner {
  max-width: 1100px;
  margin: 0 auto;
}

.meal-charge__table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  font-family: "Yu Gothic", "Hiragino Kaku Gothic ProN", sans-serif;
  color: #333;
  background: #fff;
}

.meal-charge__table th,
.meal-charge__table td {
  border: 1px solid #666;
  padding: 18px 14px;
  vertical-align: middle;
  text-align: center;
  line-height: 1.8;
}

.meal-charge__table .table-title {
  font-weight: 700;
  padding: 18px 10px;
}

.meal-charge__table .income-heading {
  font-weight: 500;
}

.meal-charge__table .old-price,
.meal-charge__table .new-price {
  font-weight: 500;
}

.meal-charge__table .new-price {
  color: #e53935;
  font-weight: 700;
}

.left-lines div {
  padding: 6px 0;
}

.category-cell {
  font-weight: 500;
}

.note-cell {
  text-align: left !important;
  font-size: 16px;
  line-height: 2;
}

.price-cell {
  font-size: 0;
  white-space: nowrap;
}

.price-unit,
.price-num {
  display: inline-block;
  font-size: 18px;
  vertical-align: middle;
}

.price-unit {
  margin-right: 18px;
}

.price-num {
  font-weight: 500;
}

.price-num.is-red {
  color: #e53935;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.arrow-cell .arrow {
  display: inline-block;
  margin-right: 18px;
  font-size: 34px;
  font-weight: 700;
  color: #e53935;
  vertical-align: middle;
  line-height: 1;
}

.blank-diagonal {
  position: relative;
  background: #fff;
}

.blank-diagonal::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top right, transparent 49.3%, #666 49.5%, #666 50.5%, transparent 50.7%);
  pointer-events: none;
}

.meal-charge__notes {
  margin-top: 28px;
  font-size: 14px;
  line-height: 2;
  color: #333;
  font-weight: normal;
}

.meal-charge__notes p {
  margin: 0 0 8px;
}

.arrow-cell .arrow {
  color: #e53935;
  font-size: 0;
  width: 34px;
  height: 18px;
  background: #e53935;
  display: inline-block;
  position: relative;
  margin-left: -78px;
  vertical-align: middle;
}

.arrow-cell .arrow::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -14px;
  transform: translateY(-50%);
  border-top: 13px solid transparent;
  border-bottom: 13px solid transparent;
  border-left: 14px solid #e53935;
}

/* スマホ対応 */
@media (max-width: 767px) {
  .meal-charge {
    padding: 24px 12px;
  }

  .meal-charge__table {
    display: block;
    overflow-x: auto;
    white-space: nowrap;
  }

  .meal-charge__table th,
  .meal-charge__table td {
    font-size: 14px;
    padding: 12px 10px;
  }

  .arrow-cell .arrow {
    margin-right: 10px;
	display: none;
  }

  .meal-charge__notes {
    font-size: 13px;
  }
  .price-unit, .price-num {
  display: inline-block;
  font-size: 16px;
  }
}

.slider-fade {
  position: relative;
  overflow: hidden;
  border-radius: 10px;
  width: 100%;
  height: 200px;
}

.slider-fade img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 3s ease;
}

.slider-fade img.active {
  opacity: 1;
  z-index: 2;
}

.news-archive-list {
  border-top: 1px solid #ddd;
}

.news-archive-list li {
  border-bottom: 1px solid #ddd;
}

.news-archive-list li a {
  display: block;
  padding: 15px 0;
  text-decoration: none;
  color: inherit;
}

.news-archive-list li a {
  display: block;
  padding: 20px 0;
}

.news-archive-list li a:hover {
  color: #32a2e7;
}

.entry-content a {
  color: #0000EE;          /* デフォルトの青 */
  text-decoration: underline;
}

.entry-content a:visited {
  color: #551A8B;          /* 訪問済み（紫） */
}

.entry-content a:hover {
  text-decoration: underline;
  opacity: 0.8;
}

.news-back {
  margin-top: 40px !important;
  text-align: center;
}

.btn-back {
  display: inline-block;
  padding: 12px 24px;
  border: 1px solid rgb(50, 162, 231);
  color: rgb(50, 162, 231);
  text-decoration: none;
  transition: 0.3s;
}

.btn-back:hover {
  background: rgb(50, 162, 231);
  color: #fff;
}