@charset "utf-8";
/*------------------------------------------------------------
	デフォルトスタイル
------------------------------------------------------------*/
html {
	font-size: 62.5%;
}
body, table, input, textarea, select, option {
	font-family: source-han-sans-japanese, sans-serif;
}
img {
	vertical-align: top;
	max-width: 100%;
	height: auto;
}
a, a:link {
	color: #03004C;
	text-decoration: none;
	transition: .3s;
}
a:visited {
	color: #03004C;
}
a:hover {
	color: #03004C;
}
a:active {
	color: #03004C;
}
/*------------------------------------------------------------
	汎用スタイル
------------------------------------------------------------*/
/* clearfix */
.clearfix:after {
	content: "";
	display: block;
	clear: both;
}
/* flex */
.flex, .flexA, .flexB, .flexC {
	display: flex;
	flex-wrap: wrap;
}
.flexA {
	justify-content: space-around;
}
.flexB {
	justify-content: space-between;
}
.flexC {
	justify-content: center;
}

.flexbox{ width: calc(100%/2 - 15px); }
/*------------------------------------------------------------
	レイアウト
------------------------------------------------------------*/
body {
	color: #03004C;
	font-size: 1.5rem;
	line-height: 1.5;
	font-weight: 300;
	text-size-adjust: none;
	-webkit-text-size-adjust: none;
	background-color: #F7F7F7;
}
body.fixed {
	position: fixed;
	width: 100%;
	height: 100%;
	overflow-y: scroll !important;
}
#container {
	text-align: left;
	position: relative;
	overflow: hidden;
}
a[href^="tel:"] {
	cursor: default;
	pointer-events: none;
}
a:hover {
	opacity: 0.7;
}
img {
	image-rendering: -webkit-optimize-contrast;
}
@media all and (min-width: 897px) {
	.sp {
		display: none !important;
	}
}
@media all and (max-width: 896px) {
	a:hover, a:hover img {
		opacity: 1 !important;
	}
	a[href^="tel:"] {
		cursor: pointer;
		pointer-events: auto;
	}
	.pc {
		display: none !important;
	}
	body {
		min-width: 320px;
	}
	body.fixed {
		position: fixed;
		width: 100%;
		height: 100%;
	}
}
@media all and (max-width: 897px) {}
/*------------------------------------------------------------
	ヘッダー
------------------------------------------------------------*/
#gHeader {
	position: absolute;
	width: 100%;
	z-index: 100;
}
#gHeader .hBox {
	padding-right: 94px;
	display: flex;
	justify-content: flex-end;
	align-items: center
}
#gHeader .logo {
	width: 154px;
	position: fixed;
	top: 0;
	left: 0;
}
#gHeader .logo a:hover {
	opacity: 1;
}
#gHeader h1 {
	margin-top: 32px;
	font-size: 1.1rem;
	text-align: right;
	font-weight: 300;
}


#gHeader .hTxt a {
	margin-left: 2px;
	color: #03004C;
	letter-spacing: 0.1em;
}
#gHeader .hTxt p {
	font-size: 1.1rem;
	text-align: right;
	font-weight: 300;
}


#gHeader .hTxt p.h1{
	margin-top: 32px;
	font-size: 1.1rem;
	text-align: right;
	font-weight: 300;
}

.menu {
	width: 60px;
	height: 60px;
	position: fixed;
	right: 20px;
	top: 19px;
	background: url("../images/common/webp/menu_img01.webp") no-repeat right top / 60px;
	z-index: 102;
	cursor: pointer;
}
.no-webp .menu {
	background-image: url("../images/common/menu_img01.png");
}
.menu.active {
	background-image: url("../images/common/webp/menu_img02.webp");
}
.no-webp .menu.active {
	background-image: url("../images/common/menu_img02.png");
}
.menuBox {
	box-sizing: border-box;
	width: 300px;
	height: 100%;
	position: fixed;
	top: 0;
	right: 0;
	z-index: 100;
	overflow-y: auto;
	transform: translateX(100%);
	transition: transform 0.5s ease;
	background-color: #03004D;
}
.menuBox.on {
	transform: translateX(0);
}
.menuBox .menuList {
	padding: 95px 60px 50px;
}
.menuBox .menuList li {
	margin-top: 21px;
}
.menuBox .menuList li a {
	color: #fff;
	font-size: 1.5rem;
	letter-spacing: 0;
	position: relative;
}
.menuBox .mBinn{
	padding: 0 26px;
}
.menuBox .mBtxt{
	color: #fff;
	font-size: 1.1rem;
}
.menuBox address{
	margin: 10px 0; 
}
.menuBox address a{
	color: #fff;
	font-size: 1.1rem;
}
.menuBox .mBtxt span{
	font-size: 1.2rem;
}

@media all and (min-width: 897px) {
	.menuBox .menuList li a:hover {
		opacity: 1;
	}
	.menuBox .menuList li a:hover::after {
		position: absolute;
		bottom: -3px;
		left: 0;
		width: 100%;
		height: 2px;
		background-color: #8280A7;
		content: '';
	}
}
.menuBox .insUl {
	position: absolute;
	top: 515px;
	right: 37px;
}
.menuBox .insUl li {
	margin-bottom: 15px;
	width: 26px;
}
@media all and (min-width: 897px) {
	.menuBox .insUl li a .on {
		display: none;
	}
	.menuBox .insUl li a:hover .on {
		display: block;
	}
	.menuBox .insUl li a:hover .img {
		display: none;
	}
}
.visit {
	position: fixed;
	top: 99px;
	right: 20px;
	width: 61px;
	z-index: 100;
}
.visit a:hover {
	opacity: 1;
}
@media all and (min-width: 897px) {
	.visit a .on {
		opacity: 0;
        position: absolute;
        top: 0;
        left: 0;
        width: 61px;
        height: 181px;
        transition: .3s;
	}
    .visit a .img {
        transition: .3s;
    }
	.visit a {
        display: block;
        position: relative;
	}
	.visit a:hover .img {
		opacity: 0;
	}
	.visit a:hover .on {
		opacity: 1;
	}
	.menu:hover {
		opacity: 0.7;
	}
}
@media all and (max-width: 896px) {
	.menu {
		width: 55px;
		height: 55px;
		right: 10px;
		top: 10px;
		background: url("../images/common/webp/menu_img01.webp") no-repeat right top / 55px;
	}
	.no-webp .menu {
		background-image: url("../images/common/menu_img01.png");
	}
	#gHeader .logo {
		width: 108px;
		margin-right: 9px;
		position: inherit;
	}
	#gHeader h1 {
		margin-top: 0;
		font-size: 1rem;
		text-align: left;
		font-weight: 300;
	}
	
	#gHeader .hTxt p.h1{
		margin-top: 0;
		font-size: 1rem;
		text-align: left;
		font-weight: 300;
	}
	
	#gHeader .hBox {
		padding-right: 65px;
		justify-content: flex-start;
	}
	.menuBox {
		width: 100%;
		z-index: 99;
	}
	.menuBox .menuList {
		margin-bottom: 32px;
		padding: 86px 38px 0 42px;
	}
	.menuBox .menuList li {
		margin-top: 0;
	}
	.menuBox .menuList > li {
		margin-top: 0;
		border-bottom: 2px solid #110F56;
	}
	.menuBox .menuList > li a {
		display: block;
		padding: 9px 8px 10px;
		letter-spacing: 0.05em;
	}
	.menuBox .insUl {
		margin-bottom: 30px;
		position: initial;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	.menuBox .insUl li {
		margin: 0 6px;
		width: 36px;
	}
	.menuBox .insUl li .on {
		display: none;
	}
	.menuBox .menuList li p::before, .menuBox .menuList li p::after {
		margin-top: 0px;
		position: absolute;
		right: 23px;
		width: 12px;
		height: 1px;
		top: 50%;
		background-color: #fff;
		transition: all .3s ease;
		content: "";
	}
	.menuBox .menuList li p {
		position: relative;
		color: #fff;
		font-size: 1.6rem;
		display: block;
		padding: 9px 8px 10px;
		letter-spacing: 0.05em;
		cursor: pointer;
	}
	.menuBox .menuList li p::after {
		background-color: #fff;
		transform: rotate(90deg);
	}
	.menuBox .menuList li p.on::after {
		transform: rotate(180deg);
		opacity: 0;
	}
	.menuBox .menuList li .navUl {
		display: none;
		padding: 0 0 20px 30px;
		margin-top: -5px;
	}
	.menuBox .menuList li .navUl li {
		display: inline-block;
		margin: 9px 25px 0 0;
		min-width: 100px;
	}
	.menuBox .menuList li .navUl li:nth-child(2n) {
		margin-right: 0;
	}
	.menuBox .menuList li .navUl a {
		font-size: 1.4rem;
		padding: 0;
		letter-spacing: 0.12em;
	}
}
@media all and (max-width: 374px) {
	#gHeader .logo {
		width: 80px;
		margin-right: 5px;
	}
	#gHeader h1 {
		font-size: 0.9rem;
	}
}
/*------------------------------------------------------------
	フッター
------------------------------------------------------------*/
#gFooter {
	padding: 49px 0 90px;
	background-color: #03004D;
	position: relative;
	color: #fff;
}
#gFooter::after {
	width: 100%;
	height: 148px;
	position: absolute;
	top: -148px;
	left: 0;
	content: '';
	background: url("../images/common/webp/bg_img01.webp") no-repeat top center / 100% 100%;
}
.no-webp #gFooter::after {
	background: url("../images/common/bg_img01.png") no-repeat top center / 100% 100%;
}
#gFooter .smTxt,
main .smTxt{
	display: block;
	font-size: 1.2rem;
}
#gFooter .comInnBox .map p.smTxt a{ 
	background: inherit;
	color: #fff;
}
#gFooter .comInnBox .map p.smTxt a::after{
	content: none;
}
#gFooter .smTxt.center,
main .smTxt.center{
	text-align: center;
}
#gFooter .fLogo {
	margin: 0 auto;
	width: 216px;
}
#gFooter .fLogo a:hover {
	opacity: 1;
}
#gFooter h2 {
	color: #fff;
	font-size: 2rem;
	text-align: center;
	letter-spacing: 0.1em;
	font-weight: normal;
}
#gFooter h2 a{
	color: #fff;
}
#gFooter .centerTxt {
	margin-bottom: 50px;
	color: #fff;
	font-size: 1.2rem;
	line-height: 1.66;
	letter-spacing: 0.1em;
	text-align: center;
}
#gFooter .comInnBox table td {
	color: #fff;
}
#gFooter .comInnBox .textBox {
	margin-top: -5px;
}
#gFooter .comInnBox table thead th {
	border-bottom-color: #8181A7;
}
#gFooter .comInnBox .node {
	border-top-color: #8181A7;
}
#gFooter .comInnBox .node .innTxt span {
	background-color: #fff;
	color: #03004C;
}
#gFooter .comInnBox .tel a {
	color: #fff;
	letter-spacing: 0.115em;
}
#gFooter .comInnBox .map p a {
	color: #03004C;
	background-color: #fff;
}
@media all and (min-width: 897px) {
	#gFooter .comInnBox .map p a:hover {
		background-color: #8FD3F5;
		opacity: 1;
	}
}
#gFooter .comInnBox .map .mapTxt,
main .comInnBox .map .mapTxt{
	background-image: url("../images/common/webp/icon04.webp");
	margin-bottom: 10px;
}
#gFooter .comInnBox .map .mapTxt a,
main .comInnBox .map .mapTxt a{
	color: #fff;
}
.no-webp #gFooter .comInnBox .map .mapTxt {
	background-image: url("../images/common/icon04.png");
}
#gFooter .comInnBox {
	padding-bottom: 49px;
	border-bottom: 2px solid #100C56;
	margin-bottom: 93px;
}
#gFooter .fBox {
	padding: 0 40px 100px;
	position: relative;
}
#gFooter .fNavi {
	display: flex;
}
#gFooter .fNavi a {
	color: #fff;
	letter-spacing: 0.115em;
}
#gFooter .fNavi > li {
	min-width: 84px;
	margin-right: 47px;
}
#gFooter .fNavi > li a {
	font-size: 1.3rem;
}
@media all and (min-width: 897px) {
	#gFooter .fNavi a:hover {
		text-decoration: underline;
		opacity: 1;
	}
}
#gFooter .fNavi .fUl > li {
	margin-bottom: 2px;
}
#gFooter .fNavi .innUl {
	margin-top: -1px;
}
#gFooter .fNavi .innUl li {
	margin-top: 1px;
}
#gFooter .fNavi .innUl a {
	padding-left: 18px;
	font-size: 1.1rem;
}
#gFooter .fNavi .naviUl {
	padding-left: 17px;
	display: flex;
}
#gFooter .fNavi .naviUl a {
	font-size: 1.1rem;
}
#gFooter .fNavi .naviUl > li {
	min-width: 70px;
}
#gFooter .fNavi .naviUl ul li {
	margin-bottom: 2px;
}
#gFooter .linkUl {
	width: 105px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: absolute;
	top: 5px;
	right: 0;
}
#gFooter .linkUl li {
	width: 25px;
}
#gFooter .linkUl li a:hover {
	opacity: 1;
}
#gFooter .fBox small a{
	color: #4E4C82;
	font-size: 1.1rem;
	letter-spacing: 0.1em;
	position: absolute;
	right: 41px;
    display: contents;
    margin-top: 50px;
}
@media all and (min-width: 897px) {
	#gFooter .linkUl li a .on {
		display: none;
	}
	#gFooter .linkUl li a:hover .on {
		display: block;
	}
	#gFooter .linkUl li a:hover .img {
		display: none;
	}
}
@media all and (max-width: 896px) {
	#gFooter {
		padding: 38px 0 120px;
	}
	#gFooter::after {
		height: 47px;
		top: -47px;
		background-image: url("../images/common/webp/sp_bg_img01.webp");
	}
	.no-webp #gFooter::after {
		background-image: url("../images/common/sp_bg_img01.png");
	}
	#gFooter h2 {
		margin: 0 -15px 15px;
		font-size: 1.8rem;
		letter-spacing: 0.05em;
	}
	#gFooter .comInnBox .tel a {
		letter-spacing: 0.05em;
	}
	#gFooter .comInnBox {
		padding-bottom: 50px;
		margin-bottom: 48px;
	}
	#gFooter .fBox {
		padding: 0 10px;
	}
	#gFooter .fNavi {
		margin: 0 -50px 85px 0;
		flex-wrap: wrap;
	}
	#gFooter .fNavi > li {
		margin: 0 20px 0 0;
		min-width: inherit !important;
	}
	#gFooter .fNavi .fUl > li {
		margin-bottom: 6px;
	}
	#gFooter .fNavi > li a {
		font-size: 1.4rem;
	}
	#gFooter .fNavi .innUl a {
		font-size: 1.2rem;
	}
	#gFooter .fNavi .innUl {
		margin-top: 4px;
	}
	#gFooter .fNavi .innUl li {
		margin-bottom: 5px;
	}
	#gFooter .fNavi .naviUl a {
		font-size: 1.2rem;
		letter-spacing: 0.1em;
	}
	#gFooter .fNavi .naviUl {
		padding-top: 5px;
	}
	#gFooter .fNavi .naviUl ul li {
		margin-bottom: 5px;
	}
	#gFooter .fNavi > .liStyle {
		width: 100%;
		margin-top: 0px;
	}
	#gFooter .fBox small a{
		display: block;
		position: relative;
		right: auto;
		bottom: auto;
		text-align: center;
		letter-spacing: 0.05em;
		margin: 0 -20px 10px;
	}
	#gFooter .linkUl {
		margin: -45px -10px 51px 0;
		position: relative;
		top: auto;
		justify-content: flex-end;
		right: auto;
		width: auto;
	}
	#gFooter .linkUl li {
		width: auto;
		margin-left: 13px;
	}
	#gFooter .linkUl li img {
		width: auto;
		height: 33px;
	}
	.fixdBox {
		position: fixed;
		bottom: 0;
		left: 0;
		width: 100%;
		z-index: 98;
		box-sizing: border-box;
		padding: 5px 10px;
		background-color: #03004D;
	}
	.fixdBox .fexdUl {
		margin-bottom: 3px;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.fixdBox .fexdUl li {
		width: 48.5%;
	}
	.fixdBox .fexdUl a {
		padding: 7px 5px 9px;
		font-size: 1.6rem;
		text-align: center;
		letter-spacing: 0.05em;
		color: #03004C;
		background-color: white;
		border-radius: 50px;
		display: block;
	}
	.fixdBox .fexdUl span {
		padding-left: 30px;
		display: inline-block;
		background: url("../images/common/webp/icon01.webp") no-repeat left center;
		background-size: 18px auto;
	}
	.no-webp .fixdBox .fexdUl span {
		background: url("../images/common/icon01.png") no-repeat left center;
		background-size: 18px auto;
	}
	.fixdBox .fexdUl a{
		font-size: 1.2rem;
	}
	.fixdBox .fexdUl .tel a {
		padding-bottom: 7px;
	}
	.fixdBox .fexdUl .tel span {
		padding: 0 0 2px 15px;
		background-image: url("../images/common/webp/icon05.webp");
		background-size: 12px auto;
	}
	.no-webp .fixdBox .fexdUl .tel span {
		background-image: url("../images/common/icon05.png");
	}
	.fixdBox p {
		text-align: center;
		font-size: 1.1rem;
		font-weight: bold;
		letter-spacing: 0.05em;
	}
	#gFooter .linkUl li .on {
		display: none;
	}
	
	.flexbox{ width: 100%; }
}
@media all and (max-width: 374px) {
	#gFooter h2 {
		font-size: 1.6rem;
	}
	#gFooter .fNavi {
		margin-left: -20px;
	}
	#gFooter .fNavi > li {
		margin-right: 5px;
	}
	#gFooter .fNavi > li a {
		font-size: 1.2rem;
	}
	#gFooter .fNavi .naviUl a {
		font-size: 1.1rem;
	}
	.fixdBox .fexdUl a {
		font-size: 1.3rem;
	}
}
/*------------------------------------------------------------
	common
------------------------------------------------------------*/
.content {
	margin: 0 auto;
	max-width: 800px;
}
.comBtn a {
	padding: 15px 10px 17px;
	max-width: 300px;
	display: flex;
	justify-content: center;
	align-items: center;
	color: #03004C;
	font-size: 1.8rem;
	letter-spacing: 0.1em;
	background-color: #fff;
	border-radius: 50px;
	box-sizing: border-box;
	border: 1px solid #03004C;
	position: relative;
	transition: all .3s;
}
.comBtn a::after {
	width: 32px;
	height: 6px;
	top: 50%;
	transform: translateY(-50%);
	right: 13px;
	content: '';
	position: absolute;
	transition: all .3s;
	background: url("../images/common/webp/arrow01.webp") no-repeat right center / 32px;
}

.comBtn2 a{
	margin: auto;
	margin-top: 45px;
}

.no-webp .comBtn a::after {
	background: url("../images/common/arrow01.png") no-repeat right center / 32px;
}
.comBtn a img {
	width: 18px;
	margin-right: 12px;
	margin-top: 7px;
}
@media all and (min-width: 897px) {
	.comBtn a:hover::after {
		right: -27px;
	}
	.comBtn a:hover {
		background-color: #8FD3F5;
		opacity: 1;
	}
}
.headLine01 {
	margin-bottom: 69px;
	font-size: 1.3rem;
	letter-spacing: 0.05em;
	line-height: 1;
	font-weight: 300;
}
.headLine01 span {
	margin-bottom: 21px;
	display: block;
	font-size: 4rem;
	font-weight: 300;
	font-family: urw-din, sans-serif;
	letter-spacing: 0.1em;
	position: relative;
}
.headLine01 span::before {
	position: absolute;
	width: 150px;
	height: 1px;
	top: 50%;
	left: -175px;
	transform: translateY(-50%);
	background-color: #03004C;
	content: '';
}
.comTxt {
	margin-bottom: 45px;
	font-size: 2.4rem;
	letter-spacing: 0.1em;
}
.comTxt span {
	color: #35A1E2;
	font-weight: bold;
}
/*-----------------------------------
-----------------------------------*/
	h3.comTxt {
		font-weight: 300;
	}
/*-----------------------------------
-----------------------------------*/

.comText {
	margin-bottom: 89px;
	font-size: 1.8rem;
	letter-spacing: 0.1em;
}
/*-----------------------------------
-----------------------------------*/
	.innerBox .content .comText {
		margin-bottom: 42px;
	}
/*-----------------------------------
-----------------------------------*/

.comInnBox {
	display: flex;
	justify-content: space-between;
}
.comInnBox .textBox {
	width: 370px;
}
.comInnBox .textBox .ttl {
	padding: 6px 5px 8px;
	color: #fff;
	font-size: 1.7rem;
	letter-spacing: 0;
	text-align: center;
	background-color: #03004C;
	border-radius: 45px;
	box-sizing: border-box;
	margin-bottom: 10px;
}
.comInnBox .textBox .ttl a{
	color: #fff;
}
.comInnBox table {
	margin-bottom: 19px;
	width: 100%;
	border-collapse: collapse;
}
.comInnBox table th {
	padding-right: 15px;
}
.comInnBox table thead th {
	padding: 0 0 7px;
	text-align: center;
	border-bottom: 2px solid #03004C;
}
.comInnBox table th, .contact table td {
	padding-top: 5px;
	font-weight: normal;
	text-align: center;
	letter-spacing: 0.05em;
}
.comInnBox table tbody tr:first-of-type th, .contact table tbody tr:first-of-type td {
	padding-top: 14px;
}
.comInnBox table tbody th {
	width: 35.8%;
}
.time span {
	font-size: 12px;
}
.comInnBox table td {
	text-align: center;
	color: #35A1E2;
	font-size: 1.5rem;
  vertical-align: middle;
  padding-top: 18px;
	
}
.comInnBox .node {
	margin-bottom: 11px;
	padding-top: 11px;
	display: flex;
	justify-content: space-between;
	line-height: 1.5;
	border-top: 2px solid #03004C;
}
.comInnBox .node .innTxt {
	font-size: 1.8rem;
	letter-spacing: 0.05em;
}
.comInnBox .node .innTxt span {
	padding: 1px 5px 2px;
	width: 80px;
	display: inline-block;
	color: #fff;
	font-size: 1.5rem;
	letter-spacing: 0;
	text-align: center;
	background-color: #03004C;
	border-radius: 45px;
	box-sizing: border-box;
	margin-right: 9px;
}
.comInnBox .node small {
	margin-top: 2px;
	font-size: 1.5rem;
	letter-spacing: 0.05em;
}
.comInnBox .tel {
	margin-bottom: 10px;
	text-align: center;
}
.comInnBox .tel a {
	color: #03004C;
	font-size: 2.8rem;
	font-family: urw-din, sans-serif;
	letter-spacing: 0.05em;
}
.comInnBox .comBtn {
	margin-bottom: 14px;
}
.comInnBox .comBtn a {
	padding: 15px 47px 17px 10px;
	max-width: inherit;
}
.comInnBox .comBtn a img {
	margin-right: 40px;
}
.comInnBox .comBtn a:hover {
	opacity: 1;
}
.comInnBox .comBtn02 a img {
	width: 24px;
	margin-right: 23px;
}
.comInnBox .map {
	width: 370px;
}
.comInnBox .map .img {
	margin-bottom: 10px;
}
.comInnBox .map .img img {
	width: 100%;
}
.comInnBox .map p {
	margin-bottom: 10px;
	font-size: 1.5rem;
	letter-spacing: 0.1em;
	display: flex;
	justify-content: space-between;
	align-items: center
}
.comInnBox .map p a {
	padding: 0 11px 1px 2px;
	width: 100px;
	color: #03004C;
	font-size: 1.2rem;
	text-align: center;
	letter-spacing: 0.05em;
	border-radius: 45px;
	border: 1px solid #03004C;
	box-sizing: border-box;
	margin-top: 3px;
	position: relative;
}
.comInnBox .map p.smTxt{
	display: block;
    font-size: 1.2rem;
}
@media all and (min-width: 897px) {
	.comInnBox .map p a:hover {
		background-color: #8FD3F5;
		opacity: 1;
	}
}
.comInnBox .map p a::after {
	width: 6px;
	height: 6px;
	position: absolute;
	right: 6px;
	top: 50%;
	transform: translateY(-50%);
	content: '';
	background: url("../images/common/webp/arrow02.webp") no-repeat right center / 6px;
}
.no-webp .comInnBox .map p a::after {
	background: url("../images/common/arrow02.png") no-repeat right center / 6px;
}
.comInnBox .map .mapTxt {
	margin-bottom: 0;
	padding-left: 18px;
	font-size: 1.2rem;
	letter-spacing: 0.05em;
	background: url("../images/common/webp/icon03.webp") no-repeat left center / 12px;
}
.no-webp .comInnBox .map .mapTxt {
	background: url("../images/common/icon03.png") no-repeat left center / 12px;
}
.slickBox .arrow {
	margin: 0 auto 33px;
	max-width: 800px;
}
.slickBox .arrow li {
	margin-right: 30px;
	width: 31px;
	display: inline-block;
	cursor: pointer;
}
@media all and (min-width: 897px) {
	.slickBox .arrow li:hover {
		opacity: 0.7;
	}
}
.slickBox .arrow .prev {
	float: left;
}
.slickBox .slickUl li a:hover {
	opacity: 0.7;
}
.slickBox .slick-slide > div {
	margin: 0 38px;
	width: 400px;
}
.wave {
	width: 100%;
	height: 1234px;
	position: absolute;
	bottom: 60px;
	left: 0;
}
.wave::after {
	position: absolute;
	left: 50%;
	bottom: 0;
	width: 3000px;
	height: 1234px;
	content: '';
	transform: translateX(-50%);
	background: url("../images/common/webp/line02.webp") no-repeat center bottom / 100%;
}
.no-webp .wave::after {
	background: url("../images/common/line01.png") no-repeat center bottom / 100%;
}
.wave01 {
	animation: wave01 8s ease-in-out infinite reverse forwards;
}
.wave02 {
	bottom: 23px;
	animation: wave02 9s ease-in-out infinite reverse forwards;
}
.wave02::after {
	background-image: url("../images/common/webp/line02.webp");
}
.no-webp .wave02::after {
	background-image: url("../images/common/line02.png");
}

main section h2.entry-title a{
	color: #fff;
}


@keyframes wave01 {
	0% {
		transform: translateY(50px);
	}
	50% {
		transform: translateY(-50px);
	}
	100% {
		transform: translateY(50px)
	}
}
@keyframes wave02 {
	0% {
		transform: translateY(11px);
	}
	50% {
		transform: translateY(-74px);
	}
	100% {
		transform: translateY(11px)
	}
}
@media all and (max-width: 896px) {
    @keyframes wave01 {
        0% {
            transform: translateY(0);
        }
        50% {
            transform: translateY(-20px);
        }
        100% {
            transform: translateY(0)
        }
    }
    @keyframes wave02 {
        0% {
            transform: translateY(0);
        }
        50% {
            transform: translateY(-30px);
        }
        100% {
            transform: translateY(0)
        }
    }
}
@media all and (max-width: 896px) {
	.wave::after {
		position: absolute;
		left: 0;
		right: auto;
		width: 100%;
        height: 100%;
		transform: none;
	}
    .wave::after {
        background-size: 140%;
        background-image: url("../images/common/webp/sp_line01.webp");
}
    .no-webp .wave::after {
    background-image: url("../images/common/sp_line01.png");
  }
    .wave02::after {
    background-image: url("../images/common/webp/sp_line02.webp");
}
    .no-webp .wave02::after {
    background-image: url("../images/common/sp_line02.png");
  }
	.content {
		padding: 0 20px;
		max-width: inherit;
	}
	.comBtn a {
		max-width: inherit;
	}
	.headLine01 {
		margin-bottom: 46px;
	}
	.headLine01 span {
		letter-spacing: 0.07em;
	}
	.headLine01 span::before {
		display: none;
	}
	.comTxt {
		margin-bottom: 40px;
		letter-spacing: 0.05em;
	}
	.comText {
		margin-bottom: 46px;
		letter-spacing: 0.05em;
		-webkit-font-smoothing: antialiased;
		font-feature-settings: "palt";
	}
	.comInnBox {
		display: block;
		justify-content: space-between;
	}
	.comInnBox .textBox {
		margin-bottom: 50px;
		width: auto;
	}
	.comInnBox .textBox .ttl {
		padding: 7px 5px 8px;
	}
	.comInnBox .node {
		padding-top: 12px;
		margin-bottom: 14px;
	}
	.comInnBox .tel {
		margin-bottom: 15px;
		padding-left: 20px;
	}
	.comInnBox .map {
		width: auto;
	}
	.comInnBox .map .img {
		margin-bottom: 12px;
	}
	.comInnBox .map p {
		margin-bottom: 11px;
	}
	.comInnBox .map .mapTxt {
		letter-spacing: 0;
	}
	.slickBox .arrow {
		margin: 0 auto 33px;
		max-width: inherit;
		padding: 0 20px;
	}
	.slickBox .slick-slide > div {
		width: 336px;
	}
	.comInnBox table tbody th {
		width: 40%;
	}
	.comInnBox table th {
		padding: 6px 10px 0 2px;
		text-align: left;
	}
	.comInnBox table thead th {
		padding: 0 0 6px;
	}
	.comInnBox table tbody tr:first-of-type th, .contact table tbody tr:first-of-type td {
		padding-top: 15px;
	}
	.comInnBox table {
		margin-bottom: 18px;
	}
    
.media {
    width: 100% !important;
    }
	
.media-pic {
    width: 33.0%;
}

.media-pic img {
    width: 100%;
    height: auto;
}
    
.media-pic .last img {
    height: 135px !important;
}
    
    
}
@media all and (max-width: 374px) {
	.headLine01 span {
		font-size: 3.5rem;
		letter-spacing: 0.05em;
	}
	.comTxt {
		font-size: 2rem;
	}
	.comInnBox .textBox .ttl {
		font-size: 1.4rem;
	}
	.comInnBox table th, .contact table td {
		font-size: 1.3rem;
	}
	.comInnBox table th {
		padding: 0 4px 0 2px;
	}
	.comInnBox .node .innTxt span {
		width: 70px;
	}
	.comInnBox .map p {
		font-size: 1.6rem;
		letter-spacing: 0;
	}
	.comInnBox .map .mapTxt {
		font-size: 1rem;
	}
	.comBtn a::after {
		right: 2px;
	}
	.slickBox .slick-slide > div {
		width: 300px;
	}
}


/*20220316*/
.oyashirazu-banner .textBox {
    padding: 7px 20px 22px 40px;
    width: 850px;
    margin: 80px auto 20px!important;
    position: relative;
    border-radius: 5px;
    box-sizing: border-box;
    background-color: #fff;
    z-index: 2;
}
.oyashirazu-banner .textBox .comBtn a{
    margin: 0 auto!important;
}
.oyashirazu-banner.sub-page .textBox {
    width: 800px;
    background-color: #f4f4f4;
}
.oyashirazu-banner .textBox h3 {
    margin-top: 20px;
    margin-bottom: 19px;
    font-size: 2rem;
    line-height: 1.21;
    letter-spacing: 0.05em;
    font-feature-settings: 'palt';
}

.textBox p {
    font-weight: 500;
    line-height: 1.87;
    letter-spacing: 0.086em;
    margin-bottom: 20px;
}

.oyashirazu-banner .textImg01 {
    width: 250px;
    position: absolute;
    top: -65px;
    left: -32px;
}
.oyashirazu-banner .textImg02 {
    width: 250px;
    position: absolute;
    top: -15px;
    right: 0;
}
.menuBox .menuList li a.eng_text{ letter-spacing: 0; font-size:12px; line-height: 1.6; display:inline-block; margin-top: 10px;}
#gFooter .fNavi a.eng_text{ letter-spacing: 0; line-height: 1.3; display: inline-block; margin-top: 5px;}
#gFooter .fBox small {
	color: #4E4C82;
	font-size: 1.1rem;
	letter-spacing: 0.1em;
	position: absolute;
	right: 41px;
	bottom: 9px;
}

@media all and (max-width: 768px) {
    .menuBox .menuList li a.eng_text{ margin-top: 0; padding-top: 0;}
    .menuBox .mBinn{text-align: center; padding-bottom: 30px;}
    #gFooter .fBox small {
		display: block;
		position: relative;
		right: auto;
		bottom: auto;
		text-align: center;
		letter-spacing: 0.05em;
		margin: 0 -20px 10px;
	}
    .oyashirazu-banner.sub-page{
    margin: 0 calc(50% - 50vw);
    width:100vw;
    }
    .oyashirazu-banner.sub-page .textImg02 {
    width: 120px;
    top: 180px;
    }
    
.oyashirazu-banner .textBox {
    padding: 5px 20px 15px 25px;
    width:100%;
    border-radius: 5px;
}
.oyashirazu-banner.sub-page .textBox {
    padding: 5px 20px 15px 25px;
    width:100%;
    border-radius: 5px;
}
.oyashirazu-banner .textBox {
    padding: 5px 20px 15px 25px;
    width:100%;
    border-radius: 5px;
}
.oyashirazu-banner .textBox h3 {
    margin-bottom: 30px;
    }
.oyashirazu-banner .textBox .textImg01 {
    width: 150px;
    left: 20px;
    top: -31px;
}
.oyashirazu-banner .textImg02{
    width: 28vw;
    top: 30vw;
    right: 0px;
}
.oyashirazu-banner.sub-page .textImg02{
    width: 28vw!important;
    top: 30vw!important;
    right: 0px;
}
}
/*//20231020*/

.menuBox .menuList {
    padding: 95px 30px 50px;
}

.visit-rp {
	position: fixed;
	top: 289px;
	right: 20px;
	width: 61px;
	z-index: 100;
}
.visit-rp a:hover {
	opacity: 1;
}
@media all and (min-width: 897px) {
	.visit-rp a .on {
		opacity: 0;
        position: absolute;
        top: 0;
        left: 0;
        width: 61px;
        transition: .3s;
	}
    .visit-rp a .img {
        transition: .3s;
    }
	.visit-rp a {
        display: block;
        position: relative;
	}
	.visit-rp a:hover .img {
		opacity: 0;
	}
	.visit-rp a:hover .on {
		opacity: 1;
	}
}
	.fixdBox2 {
		position: fixed;
		bottom: 6.2rem;
		left: 0;
		width: 100%;
		z-index: 98;
		box-sizing: border-box;
		padding-top: 5px;
		background-color: #35A1E2;
	}
	.fixdBox2 .fexdUl {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.fixdBox2 .fexdUl li {
		width: 100%;
	}
	.fixdBox2 .fexdUl a {
		padding: 3px 5px 9px;
		font-size: 1.6rem;
		text-align: center;
		letter-spacing: 0.05em;
		color: #FFFFFF;
		display: block;
	}
	.fixdBox2 .fexdUl span {
		padding-left: 30px;
		display: inline-block;
		background: url(../../images/common/webp/icon06.webp) no-repeat left center;
		background-size: 18px auto;
	}
	.no-webp .fixdBox2 .fexdUl span {
		background: url(../../images/common/icon06.png) no-repeat left center;
		background-size: 18px auto;
	}
	.fixdBox2 .fexdUl a{
		font-size: 1.2rem;
	}
@media all and (max-width: 374px) {
	.fixdBox2 .fexdUl a {
		font-size: 1.3rem;
	}
}

/*//20231020*/