@charset "UTF-8";

/* Scss Document */
/* Scss Document */
/*-----------------------------------------------------------
Reset
-----------------------------------------------------------*/
html {
	font-size: 100%;
}

body {
	margin: 0;
	padding: 0;
	line-height: 1;
}

div,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
img,
ins,
kbd,
q,
samp,
sub,
sup,
var,
b,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
caption,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
mark,
audio,
video,
a {
	margin: 0;
	padding: 0;
	border: 0;
	vertical-align: baseline;
	background: transparent;
	font-size: 100%;

}

span,
small,
em,
time,
i {
	font-style: normal;
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	vertical-align: baseline;
	background: transparent;
}

a {
	color: inherit;
	text-decoration: none;
	border: medium;
}

a:-webkit-any-link:focus-visible {
	outline-offset: 1px;
}

:focus-visible {
	outline: -webkit-focus-ring-color auto 1px;
}

sup {
	vertical-align: text-top;
}

sub {
	vertical-align: text-bottom;
}

legend {
	color: #000;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	line-height: 1.8em;
}

main,
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
	display: block;
}

li {
	list-style: none;
}

blockquote,
q {
	quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: '';
	content: none;
}

input,
textarea,
select {
	font-family: inherit;
	font-size: inherit;
	font-weight: inherit;
}

input,
select {
	vertical-align: middle;
}

abbr[title],
dfn[title] {
	cursor: help;
}

del {
	text-decoration: line-through;
}

ins {
	font-style: oblique;
	text-decoration: none;
}

mark {
	background: transparent;
	font-style: normal;
}

img {
	vertical-align: top;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
	width: 100%;
}

th {
	font-weight: normal;
	text-align: left;
}

button {
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
	font-size: inherit;
}

/*=============================================
 * RESPONSIVE
 *=============================================*/
.clearfix:after {
	content: "." !important;
	clear: both !important;
	display: block !important;
	height: 0 !important;
	visibility: hidden !important;
}

img.responsive {
	max-width: 100%;
	width: auto;
	height: auto;
}

html:not(.responsive) {
	/*	min-width: 1000px;*/
	/* viewport */
}


@font-face {
	font-family: 'Anaheim';
	src: url("./font/Anaheim.woff2") format("woff2");
	font-weight: normal;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: 'Quentin';
	src: url('./font/Quentin.eot');
	src: url('./font/Quentin.eot?#iefix') format('embedded-opentype'),
		url('./font/Quentin.woff2') format('woff2'),
		url('./font/Quentin.woff') format('woff');
	font-weight: normal;
	font-style: normal;
	font-display: swap;
}

h1,
h2,
h3,
h4,
h5 {
	font-family: 'FOT-セザンヌ ProN DB';
}

.link {
	text-decoration: underline;
}

.link:hover {
	text-decoration: none;
}

/*=============================================
 * body
 *=============================================*/


body {
	color: #4E4E4E;
	font-size: 17px;
	line-height: 2;
	background: #fff;
	min-width: inherit;
	min-height: inherit;
	letter-spacing: 0.05em;
	max-height: 100%;
	font-family: 'FOT-セザンヌ ProN M';
	font-weight: 500;
	font-style: normal;
}

/*=============================================
 * fonts - DON'T EDIT
 *=============================================*/
.fnt-anaheim {
	font-family: "Anaheim", sans-serif;
	font-weight: 400;
	font-style: normal;
}

.font-wix {
	font-family: "Wix Madefor Display", sans-serif;
	font-weight: 800;
	font-style: normal;
}

@media screen and (min-width: 768px) {
	.dis-flex-pc {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
}

/*=============================================
 * <header>
 *=============================================*/
.main-box {
	position: relative;
	overflow: hidden;
}

.main-box img {
	max-width: 100%;
	width: 100%;
	height: auto;
}

.main-box a img {
	transition: all 0.35s ease;
}

.main-box a:hover img {
	opacity: 0.8;
}

.header {
	position: fixed;
	width: 100%;
	top: 0;
	left: 0;
	height: 100px;
	display: flex;
	justify-content: space-between;
	z-index: 9;
}

.header::before {
	content: "";
	background: #fff;
	height: 80px;
	position: fixed;
	top: 0;
	right: 0;
	left: 0;
	opacity: 0;
	visibility: hidden;
}

.header .h-logo,
.header .logo {
	max-width: 281px;
	padding: 0;
	position: relative;
	z-index: 2;
	background: url(../images/share/logo_fix.jpg) no-repeat top center;
	-webkit-background-size: 100% auto;
	background-size: 100% auto;

}

.header .h-logo a,
.header .logo a {
	display: block;
}




.header .h-logo a:hover img,
.header .logo a:hover img {
	opacity: 1;
}

.has-nav .header {
	height: 80px;
}

.header .h-logo img,
.header .logo img {
	opacity: 1;
}

.has-nav .header .h-logo,
.has-nav .header .logo {
	max-width: 238px;
	height: 100px;
}

.has-nav .header .h-logo img,
.has-nav .header .logo img {
	opacity: 0;
	visibility: hidden;
}

.icon-deco {
	position: relative;
}

.icon-deco::before {

	background-size: 100% auto;
	width: 100px;
	height: 70px;
	position: absolute;
	content: "";
}

.has-nav .header::before {
	opacity: 1;
	visibility: visible;
}

#keyvisual-page,
#keyvisual {
	padding-left: 100px;
	position: relative;
}

.navi-box {
	display: flex;
	flex-wrap: wrap;
	padding-right: 128px;
	background-color: #fff;
	padding-left: 14px;
}

.has-nav .navi-box {
	padding-right: 115px;
}

.navi-box .navi-info {
	display: flex;
	justify-content: flex-end;
	width: 100%;
	line-height: 48px;
	padding-top: 20px;
}

.navi-box .navi-info ul {
	display: flex;
}

.navi-box .navi-info ul li {
	margin-left: 10px;
}

.navi-box .g-navi {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	width: 100%;
	height: 52px;
	position: relative;
}

.has-nav .navi-box .g-navi {
	height: 40px;
}

.navi-box .g-navi-list {
	display: flex;
	justify-content: flex-end;
}

.navi-box .g-navi-list li {
	position: relative;
	margin-left: 19px;
	font-size: 16px;
}

.navi-box .g-navi-list li span {
	position: relative;
	cursor: default;
	padding-right: 20px;
}

.navi-box .g-navi-list li span::after {
	content: "";
	background: url(../images/share/plus.svg) no-repeat center;
	width: 9px;
	height: 9px;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
}

.navi-box .g-navi-list li span::before {
	content: "";
	background: #80B0E8;
	width: 100%;
	height: 2px;
	position: absolute;
	left: 0;
	bottom: -19px;
	transition: all 0.4s ease;
	opacity: 0;
}

.has-nav .navi-box .g-navi-list li span::before {
	bottom: -35px;
}

.navi-box .g-navi-list li:hover span::before {
	opacity: 1;
}

.navi-box .g-navi-list li a::before {
	content: "";
	background: #80B0E8;
	width: 100%;
	height: 2px;
	position: absolute;
	left: 0;
	bottom: -11px;
	transition: all 0.4s ease;
	opacity: 0;
}

.has-nav .navi-box .g-navi-list li a::before {
	bottom: -23px;
}

.navi-box .g-navi-list li a:hover::before {
	opacity: 1;
}

.navi-box .g-navi-list .show-sub:hover nav {
	z-index: 99;
	opacity: 1;
	visibility: visible;
}

.navi-box .g-navi-list nav {
	position: absolute;
	top: 45px;
	right: -100%;
	min-width: 345px;
	background: #454C55;
	opacity: 0;
	visibility: hidden;
	z-index: -1;
	transition: all 0.35s ease;
	box-sizing: border-box;
	padding: 30px;
}

.has-nav .navi-box .g-navi-list nav {

	top: 57px;
}

.navi-box .g-navi-list nav a {
	display: block;
	position: relative;
	letter-spacing: 0.05em;
	line-height: 32px;
	font-size: 15px;
	color: #fff;
	padding-left: 14px;
	transition: all 0.35s ease;
}



.navi-box .g-navi-list nav a::before {
	content: "";
	background: url(../images/share/arrow_s.svg) no-repeat center;
	width: 4px;
	height: 7px;
	margin-top: -5px;
	position: absolute;
	top: 50%;
	opacity: 1;
}

.navi-box .g-navi-list nav a:hover {
	opacity: 0.7;
}

a.link-ext {
	background: #D8CD56;
	border-radius: 0 0 5px 5px;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 160px;
	height: 48px;
	color: #FFF;
	font-size: 18px;
	transition: all 0.35s ease;
}

a.link-ext.btn-web span {

	padding-left: 25px;
}

a.link-ext.btn-eng span {


	padding-left: 35px;
}

a.link-ext:hover {
	opacity: 0.75;
}

.tel-common {
	font-size: 26px;
	font-family: "Wix Madefor Display";
	font-weight: 800;
	letter-spacing: 0em;
	padding-right: 0;
	line-height: 1;
}

.tel-common .telhref {
	background: none;
}


.tel-common .telhref::before {
	content: "";
	background: url(../images/share/icon_tel.svg) no-repeat;
	-webkit-background-size: 100% auto;
	background-size: 100% auto;
	width: 20px;
	height: 20px;
	position: absolute;
	top: 50%;
	margin-top: -10px;
	left: 11px;
}

.map-common {
	width: 100px;
	height: 100px;
	background-color: #3157A0;
	text-align: center;
	font-size: 15px;
	position: absolute;
	top: 0;
	right: 0;
	/* transition: all .4s ease; */
}

.map-common a {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 2;
	font-size: 0px;
}

.map-common span {
	display: block;
	position: relative;
	font-size: 15px;
	line-height: 1;
	color: #fff;
	padding-top: 60px;
}

.map-common::before {
	content: "";
	background: url(../images/share/location.svg) no-repeat;
	width: 24px;
	height: 29px;
	position: absolute;
	top: 18px;
	left: 50%;
	margin-left: -12px;
}

.has-nav .header .tel-common {
	opacity: 0;
	visibility: hidden;
	display: none;
}

.has-nav .map-common {
	width: 80px;
	height: 80px;
}

.has-nav .map-common span {
	display: none;
}

.has-nav .map-common::before {
	top: 26px;
}

.map-common:hover {
	opacity: .6;
}

.sp {
	display: none;
}

.telhref {

	position: relative;
	background: url(../images/share/icon_tel.svg) no-repeat center left;
	padding: 0 0 2px 35px;
	letter-spacing: 0.04em;


}

.telhref.none {
	background: none;
	padding: 0 0 2px 0px !important;
}

.inner,
.page-inner {
	max-width: 1024px;
	margin: auto;
	position: relative;
	box-sizing: border-box;
}

.inner.is-inner,
.page-inner.is-inner {
	max-width: 1200px;
}

.title-h2 .title-jp {
	font-size: 24px;
	line-height: 30px;
}

.title-h2 .title-eng {
	font-size: 98px;
	font-family: "Wix Madefor Display";
	color: #80B0E8;
}

.btn-common {
	position: relative;
}

.btn-common a {
	width: 140px;
	height: 38px;
	background: #85CD63;
	color: #FFF;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	border-radius: 3px;
	overflow: hidden;
	transition: all 0.35s ease;
	font-size: 16px;
}

.btn-common a.big {
	width: 240px;
	height: 48px;
}

.btn-common a::before {
	background: #FBF9E4;
	position: absolute;
	top: 50%;
	right: 0;
	height: 1px;
	width: 20px;
	content: "";
}

.btn-common a:hover {
	opacity: 0.75;
}

.color-g {
	color: #80B0E8;
}

table.time-box {
	background: #FFF;
	margin-bottom: 12px;
	font-size: 15px;
}

table.time-box thead {
	background: #454C55;
	color: #FFF;
}

table.time-box thead th {
	width: 145px;
	box-sizing: border-box;
}

table.time-box thead th,
table.time-box thead td {
	text-align: center;
}

table.time-box tbody th,
table.time-box tbody td {
	padding: 20px 8px 0;
	text-align: center;
	line-height: 25px;
}

table.time-box tbody tr th,
table.time-box tbody tr td {
	border-top: 1px solid #99A1AA;
	padding-bottom: 10px;
}

table.time-box tbody tr:last-child th,
table.time-box tbody tr:last-child td {
	padding: 18px 8px 5px;
}

table.tbox-white {
	background: transparent !important;
}

table.tbox-white thead {
	background: #99A1AA !important;
	color: #454C55 !important;
}

table.tbox-white tbody tr th,
table.tbox-white tbody tr td {
	border-top: 1px solid #99A1AA;
	color: #fff;
}

table.tbox-white thead th,
table.tbox-white thead td {}

dl.time-note {
	display: flex;
	align-items: center;
	line-height: 27px;
	margin-bottom: 20px;
}

dl.time-note dt {
	color: #6FB24F;
	width: 87px;
	line-height: 27px;
	border: 1px solid;
	border-radius: 3px;
	position: relative;
	text-align: center;
	box-sizing: border-box;
}

dl.time-note dd {
	width: calc(100% - 87px);
	box-sizing: border-box;
	padding: 0 10px;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 500;
	font-style: normal;
}

.time-table-txt {
	font-size: 14px;
	letter-spacing: 0;
}

.time-table-txt .time-t {
	padding-left: 26px;
}





@media only screen and (min-width: 801px) and (max-width: 1099px) {

	.has-nav .header .h-logo,
	.has-nav .header .logo,
	.header .h-logo,
	.header .logo {
		max-width: 176px;
	}

	.has-nav .header,
	.header,
	.header::before {
		height: 59px;
	}

	.map-common,
	.has-nav .map-common {
		width: 59px;
		height: 59px;
	}

	.map-common::before {
		background: url(../images/share/location.svg) no-repeat;
		width: 16px;
		height: 24px;
		top: 10px;
		margin-left: -8px;
		background-size: 100% auto;
	}

	.tel-common .telhref::before {
		width: 16px;
		height: 16px;
	}

	.map-common span {
		font-size: 11px;
		padding-top: 40px;
	}

	.has-nav .navi-box,
	.navi-box {
		padding-right: 70px;
	}

	.has-nav .map-common::before {
		top: 19px;
	}

	.tel-common {
		font-size: 18px;
	}

	.navi-box .navi-info {
		padding-top: 10px;
	}

	.navi-box .g-navi-list li {
		margin-left: 13px;
		font-size: 14px;
	}

	.navi-box .g-navi {
		height: 28px;
	}

	.navi-box .g-navi-list li span::before {
		bottom: -12px;
	}

	.navi-box .g-navi-list li a::before {
		bottom: -2px;
	}

	.navi-box .g-navi-list nav {
		top: 30px;
	}

	.has-nav .navi-box .g-navi-list li span::before {
		bottom: -25px;
	}

	.has-nav .navi-box .g-navi-list li a::before {
		bottom: -15px;
	}

	.navi-box .g-navi-list li span::after {
		right: 4px;
	}

	.has-nav .navi-box .g-navi-list nav {
		top: 43px;
	}
}

@media only screen and (max-width: 800px) {


	.time-table-txt .time-t {
		padding-left: 0;
		display: block;
	}


	body {
		font-size: 14px;
		line-height: 28px;
	}

	.sp {
		display: block;
	}

	.pc {
		display: none;
	}

	.header::before,
	.has-nav .header::before {
		display: none;
	}

	.hamberger-btn {
		position: relative;
		background: #3157A0;
		transition: all 0.35s ease;
		cursor: pointer;
		z-index: 99;
		max-width: 35px;
		margin: 0 auto;
	}

	.hamberger-btn::before {
		position: absolute;
		top: 8px;
		left: 0;
		width: 35px;
		height: 1px;
		background: #FFF;
		content: "";
		opacity: 0.9;
		/* transition: top 300ms 350ms ease, transform 300ms 50ms ease; */
	}

	.hamberger-btn span {
		position: relative;
		width: 35px;
		height: 21px;
		display: block;
		margin: 0;
	}

	.hamberger-btn span::before {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 1px;
		background: #FFF;
		content: "";
		opacity: 0.9;
		transition: top 300ms 350ms ease, transform 300ms 50ms ease;
	}

	.hamberger-btn span::after {
		position: absolute;
		top: 17px;
		left: 0;
		width: 100%;
		height: 1px;
		background: #FFF;
		content: "";
		opacity: 0.9;
		transition: top 300ms 350ms ease, transform 300ms 50ms ease;
	}

	.menu-open .hamberger-btn span::before {
		top: 10px;
		transform: rotate(35deg);
		transition: top 300ms 50ms ease, transform 300ms 350ms ease;
	}

	.menu-open .hamberger-btn::before {
		opacity: 0;
	}

	.menu-open .hamberger-btn span::after {
		top: 10px;
		transform: rotate(-35deg);
		width: 100%;
		left: 0;
		transition: top 300ms 50ms ease, transform 300ms 350ms ease;
	}

	.main-box {
		padding-top: 0;
	}

	.header {
		width: 100%;
		top: 0;
		left: 0;
		position: relative;
		z-index: 99;
		height: 0;
	}

	.header .h-logo,
	.header .logo {
		max-width: 130px;
		padding: 0;
		position: absolute;
		top: 0;
		left: 0;
		background: none;
	}



	.icon-deco {
		position: relative;
	}

	.icon-deco::before {

		background-size: 100% auto;
		width: 52px;
		height: 36px;
		position: absolute;
		content: "";
	}

	#keyvisual {
		padding-left: 5%;
	}

	#keyvisual::before {}

	#keyvisual ul {
		position: relative;
		overflow: hidden;
	}

	#keyvisual ul li {
		width: 100%;
		height: 400px;
	}

	#keyvisual ul li img {
		height: 100%;
		position: absolute;
		top: 50%;
		left: 40%;
		transform: translate3d(-50%, -50%, 0);
		object-fit: cover;
		width: 120%;
		max-width: 120%;
	}

	#keyvisual .title-key {
		font-size: 24px;
		line-height: 40px;
		letter-spacing: 0.05em;
		position: absolute;
		top: 260px;
		left: 5%;
		z-index: 2;
	}

	#keyvisual .title-key::before {
		top: -46px;
		left: -14px;
	}

	#keyvisual .title-key span {
		display: inline-block;
		line-height: 40px;
		padding: 0 10px;
		background: #FBF9E4;
		margin-bottom: 5px;
	}

	#keyvisual.page-child::before {
		width: 100%;
		height: 310px;
		position: absolute;
		bottom: -65px;
		left: 0;
		content: "";
		background: #E9F4E4;
		z-index: -1;
	}

	#keyvisual.page-child ul li {
		height: 220px;
	}

	#keyvisual.page-child .title-key {
		top: 165px;
	}

	.navi-box {
		display: block;
		padding-right: 0;
		width: 100%;
		height: 100%;
		background: #3157A0;
		position: fixed;
		top: 0;
		left: 0;
		box-sizing: border-box;
		overflow-y: auto;
		opacity: 0;
		visibility: hidden;
		z-index: -1;
		padding-left: 0;
		transition: all 0.45s ease;
	}

	.navi-box .navi-box-scroll {
		display: block;
		padding-bottom: 100px;
	}

	.navi-box .navi-info {
		width: 100%;
		line-height: 38px;
		padding-bottom: 125px;
		text-align: center;
		display: none;
	}

	.navi-box .navi-info p {
		margin-right: 0;
	}

	.navi-box .navi-info ul {
		display: flex;
		flex-wrap: wrap;
		margin: 0 15%;
	}

	.navi-box .navi-info ul li {
		margin-left: 0;
		margin-top: 20px;
		width: 100%;
	}

	.navi-box .navi-info ul li a.link-ext {
		width: 100%;
		border-radius: 5px;
	}

	.navi-box .g-navi {
		display: block;
		padding-top: 85px;
		height: auto;
	}

	.navi-box .g-navi-list {
		display: block;
	}

	.navi-box .g-navi-list li {
		position: relative;
		margin: 0 35px 10px;
	}

	.navi-box .g-navi-list li span {
		position: relative;
		cursor: pointer;
		padding-right: 20px;
		font-size: 16px;
		color: #fff;
	}

	.navi-box .g-navi-list li span::before {
		display: none;
	}

	.navi-box .g-navi-list li.show span::after {
		content: "";
		background: url(../images/share/hyphen.svg) no-repeat center;
		width: 9px;
		height: 1px;
		position: absolute;
		top: 40%;
		right: 0;
		transform: translateY(-50%);
	}

	.navi-box .g-navi-list li a {
		font-size: 16px;
		color: #fff;
	}

	.navi-box .g-navi-list li a:hover,
	.navi-box .g-navi-list li a.active {
		opacity: .6;
	}

	.navi-box .g-navi-list li a::before {
		display: none;
	}

	.navi-box .g-navi-list .show-sub:hover nav {
		opacity: 0;
		visibility: hidden;
		z-index: -1;
	}

	.navi-box .g-navi-list .show-sub.show nav {
		opacity: 1;
		visibility: visible;
		z-index: 98;
		display: block;
		margin-left: 20px;
		top: 0 !important;
	}

	.navi-box .g-navi-list nav {
		position: relative;
		top: 0;
		right: 0px;
		background: none;
		width: 100%;
		opacity: 0;
		visibility: hidden;
		z-index: -1;
		transition: all 0.35s ease;
		box-sizing: border-box;
		padding: 10px 0 0;
		display: none;
		min-width: 0;
	}

	.navi-box .g-navi-list nav a {
		display: block;
		position: relative;
		letter-spacing: 0.05em;
		line-height: 26px;
		padding-left: 14px;
		font-size: 15px;
		margin-bottom: 5px;
	}

	.navi-box .g-navi-list nav a::before {
		content: "";
		background: url(../images/share/arrow_s.svg) no-repeat center;
		width: 4px;
		height: 7px;
		margin-top: -5px;
		position: absolute;
		top: 50%;
		opacity: 1;
		display: block !important;
	}

	.navi-box {
		padding-right: 0;
	}

	.menu-open .navi-box {
		opacity: 1;
		visibility: visible;
		z-index: 98;
	}

	.has-nav .navi-box {
		padding-right: 0;
	}

	.has-nav .navi-box .g-navi {
		height: auto;
	}

	body.menu-open,
	body.menu-open *,
	body.menu-open *:hover,
	body.menu-open *:focus,
	body.menu-open *:active {
		/*    cursor: none !important;*/
		touch-action: none !important;
		pointer-events: none !important;
	}

	body.menu-open .footer-fixed,
	body.menu-open .footer-fixed *,
	body.menu-open .navi-box,
	body.menu-open #navi-toggle,
	body.menu-open #navi-toggle * {
		touch-action: auto !important;
		pointer-events: visible !important;
	}

	.menu-open {
		overflow: hidden !important;
		-webkit-overflow-scrolling: touch !important;
		touch-action: none !important;
		pointer-events: none !important;
	}

	.menu-open #navi-toggle {
		opacity: 1;
		visibility: visible;
		pointer-events: visible;
	}


	a.link-ext {
		border-radius: 5px;
		width: 160px;
		height: 46px;
		font-size: 16px;
	}

	.tel-common {
		font-size: 22px;
		margin-right: 5px;
	}

	.telhref {
		position: relative;
		pointer-events: visible;
		background: url(../images/share/icon_tel.svg) no-repeat center left;
		background-size: 18px auto;
		padding: 0 0 2px 35px;
	}

	.inner,
	.page-inner {
		max-width: 1024px;
		margin: auto;
		position: relative;
		box-sizing: border-box;
	}

	.inner.is-inner,
	.page-inner.is-inner {
		max-width: 1200px;
	}

	.title-h2 {
		font-family: "秀英丸ゴシック L";
		font-family: "dnp-shuei-mgothic-std", sans-serif;
		font-weight: 400;
		font-style: normal;
	}

	.title-h2 .title-jp {
		font-size: 26px;
		line-height: 30px;
	}

	.title-h2 .title-eng {
		font-size: 22px;
		font-family: "EB Garamond", serif;
		font-optical-sizing: auto;
		font-weight: 500;
		font-style: normal;
		color: #85CD63;
	}

	.btn-common {
		position: relative;
	}

	.btn-common a {
		width: 140px;
		height: 38px;
		background: #85CD63;
		color: #FFF;
		display: flex;
		justify-content: center;
		align-items: center;
		position: relative;
		border-radius: 3px;
		overflow: hidden;
		transition: all 0.35s ease;
		font-size: 16px;
	}

	.btn-common a.big {
		width: 240px;
		height: 48px;
	}

	.btn-common a::before {
		background: #FBF9E4;
		position: absolute;
		top: 50%;
		right: 0;
		height: 1px;
		width: 20px;
		content: "";
	}

	.btn-common a:hover {
		opacity: 0.75;
	}

	table.time-box {
		font-size: 13px;
		margin-bottom: 15px;
	}

	table.time-box thead th {
		width: 105px;
		box-sizing: border-box;
	}

	table.time-box thead th,
	table.time-box thead td {
		padding: 5px;
		text-align: center;
	}

	table.time-box tbody th,
	table.time-box tbody td {
		padding: 10px 5px 0;
		line-height: 24px;
	}

	table.time-box tbody tr:last-child th,
	table.time-box tbody tr:last-child td {
		padding: 10px 5px 10px;
	}

	dl.time-note {
		font-size: 14px;
	}
}

/*=============================================
 * <footer>
 *=============================================*/
footer {
	position: relative;
}

footer::before {
	content: "";
	background: #80B0E8;
	position: absolute;
	bottom: 0;
	right: 0;
	left: 0;
	height: 555px;
}

footer .footer-info {}

footer .inner {
	display: flex;
	justify-content: space-between;
}

footer .footer-navi {
	max-width: 740px;
	margin: auto;
	padding: 64px 0 59px 50px;
	box-sizing: border-box;
	display: flex;
	position: relative;
	z-index: 2;
	font-size: 16px;
	justify-content: space-between;
}

footer .footer-navi li {
	line-height: 1;
}

footer .footer-navi li+li {
	margin-top: 24px;
}

footer .footer-navi ul ul li {
	margin-top: 12px;
	margin-bottom: 0;
}

footer .footer-navi ul ul li+li {
	margin-top: 9px;
}

footer .footer-navi .sub-nav .box ul li {
	margin-bottom: 8px;
}

footer .footer-navi .sub-nav .box ul li+li {
	margin-top: 0;
}

footer .footer-navi span,
footer .footer-navi a {
	color: #fff;
}

footer .footer-navi a:hover {
	text-decoration: underline;
}

footer .footer-navi .sub-nav {}

footer .footer-navi .sub-nav .box {
	width: 410px;
	margin-left: 97px;
	color: #fff;
}

footer .footer-navi .sub-nav .box-s {
	display: flex;
	flex-wrap: wrap;
}

footer .footer-navi .sub-nav .box .title {
	width: 100%;
	padding-bottom: 2px;
	margin-bottom: 12px;
	line-height: 1;
}

footer .footer-navi .sub-nav .box ul {
	width: 55%;
}

footer .footer-navi .sub-nav .box ul+ul {
	width: 45%;
}

footer .footer-navi .sub-nav .box.sort {
	width: 200px;
	display: block;
}

footer .footer-navi .sub-nav .box.sort ul {
	width: 100%;
}

.footer .footer-navi .sub-nav ul li a,
footer .footer-navi ul ul li a {
	position: relative;
	letter-spacing: 0.05em;
	line-height: 32px;
	color: #fff;
	padding-left: 14px;
	font-size: 15px;
}


.footer .footer-navi .sub-nav ul li a::before,
footer .footer-navi ul ul li a::before {
	content: "";
	background: url(../images/share/arrow_s.svg) no-repeat;
	width: 4px;
	height: 7px;
	position: absolute;
	top: 50%;
	left: 4px;
	margin-top: -4px;
}

address {
	background: #DCE2E8;
	color: #99A1AA;
	font-size: 13px;
	line-height: 26px;
	text-align: center;
	position: relative;
	z-index: 2;
	padding: 22px 0;
	letter-spacing: 2px;
}

.footer-fixed {
	display: none;
}


@media only screen and (min-width: 801px) and (max-width: 1099px) {
	.footer-info .inner {
		padding: 0 20px;
	}
}

@media only screen and (max-width: 800px) {
	footer {
		padding-bottom: 55px;
	}

	footer::before {

		height: 80%;
	}

	footer .footer-info {
		padding: 15vw 5%;
	}

	footer .inner {
		display: block;
	}

	footer .col-left {
		max-width: 100%;
		width: 100%;
		margin-bottom: 40px;
	}

	footer .col-left .sns-box {
		display: flex;
		align-items: center;
	}

	footer .col-left .sns-box .logo {
		width: 200px;
		margin-right: 25px;
	}

	footer .col-left ul a.link-ext {
		width: 160px;
	}

	footer .col-right {
		max-width: 100%;
		width: 100%;
	}

	footer .col-right .gg-map {
		height: 480px;
	}

	footer .footer-navi {
		max-width: 1024px;
		padding: 50px 5% 40px;
		display: block;
	}

	footer .footer-navi .sub-nav {
		display: block;
	}

	footer .footer-navi .sub-nav .box {
		width: 100%;
		display: block;
		margin-left: 0;
	}

	footer .footer-navi .sub-nav .box .title {
		margin-top: 10vw;
	}

	footer .footer-navi .sub-nav .box ul {}

	footer .footer-navi .sub-nav .box.sort {
		width: 100%;
		display: block;
	}

	footer .footer-navi .sub-nav .box.sort ul {
		width: 100%;
	}

	address {}

	.footer-fixed {
		position: fixed;
		bottom: 0;
		left: 0;
		display: block;
		width: 100%;
		z-index: 101;
		background: #3157A0;
	}

	.footer-fixed ul {
		display: flex;
	}

	.footer-fixed ul li {
		width: 25%;
		position: relative;
		cursor: pointer;
	}

	.footer-fixed ul li:nth-child(1) img {
		width: 18px;
		height: 16px;
	}

	.footer-fixed ul li:nth-child(2) img {
		width: 16px;
		height: 16px;
	}

	.footer-fixed ul li:nth-child(3) img {
		width: 13px;
		height: 16px;
	}

	.footer-fixed ul li a {
		display: block;
		font-size: 12px;
		color: #fff;
		text-align: center;
		position: relative;

	}

	.footer-fixed ul li a img {
		width: 16px;
		position: absolute;
		top: 13px;
		left: 50%;
		margin-left: -8px;
	}

	.footer-fixed ul li span {
		padding-top: 30px;
		display: block;
	}

	.footer-fixed ul li.ham-btn {
		padding-top: 20px;
	}

	.footer-fixed ul li.ham-btn span {
		padding-top: 0;
	}

	.footer-fixed ul li::before {
		content: "";
		background: #fff;
		width: 1px;
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
	}
}

/*=============================================
 * animated
 *=============================================*/
.animated {
	-webkit-animation-duration: 2s;
	animation-duration: 2s;
	-webkit-animation-fill-mode: both;
	animation-fill-mode: both;
}

.animated.infinite {
	-webkit-animation-iteration-count: infinite;
	animation-iteration-count: infinite;
}

@-webkit-keyframes fadeInUp {
	0% {
		opacity: 0;
		-webkit-transform: translateY(20px);
		transform: translateY(20px);
	}

	100% {
		opacity: 1;
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
}

@keyframes fadeInUp {
	0% {
		opacity: 0;
		-webkit-transform: translateY(20px);
		-ms-transform: translateY(20px);
		transform: translateY(20px);
	}

	100% {
		opacity: 1;
		-webkit-transform: translateY(0);
		-ms-transform: translateY(0);
		transform: translateY(0);
	}
}

.fadeInUp {
	-webkit-animation-name: fadeInUp;
	animation-name: fadeInUp;
}

/*=============================================
 * content
 *=============================================*/
.contents {
	padding-top: 0px;
}

.page-inner {
	padding: 100px 20px 100px;
	max-width: 1064px;
	box-sizing: border-box;
}

.page-inner img {
	width: 100%;
	height: auto;
}

.breadcrumb {
	padding: 40px 50px 20px 100px;
}

.breadcrumb ul {
	display: flex;
	flex-wrap: wrap;
}

.breadcrumb ul li {
	position: relative;
}

.breadcrumb ul li span {
	overflow: hidden;
	max-height: 4rem;
	word-break: break-all;
}

.breadcrumb ul li a {
	text-decoration: underline;
}

.breadcrumb ul li a:hover {
	text-decoration: none;
}

.breadcrumb ul li.taxonomy {
	display: none;
}

.breadcrumb ul li+li {
	margin-left: 10px;
	padding-left: 20px;
}

.breadcrumb ul li+li::before {

	width: 4px;
	height: 7px;
	position: absolute;
	top: 10px;
	left: 0;
	content: "";
	background: url(../images/share/arrow_s.svg) no-repeat;
	filter: brightness(0) saturate(100%);

}

.mb10 {
	margin-bottom: 10px;
}

.mb20 {
	margin-bottom: 20px;
}

.mt20 {
	margin-top: 20px;
}

.mb30 {
	margin-bottom: 30px;
}

.mb40 {
	margin-bottom: 40px;
}

.mb50 {
	margin-bottom: 50px;
}

.mb60 {
	margin-bottom: 60px;
}

.mb70 {
	margin-bottom: 70px;
}

.mb80 {
	margin-bottom: 80px;
}

.mb90 {
	margin-bottom: 90px;
}

.mb100 {
	margin-bottom: 100px;
}

.mb120 {
	margin-bottom: 120px !important;
}

.mb-style {
	margin-bottom: 150px;
}

.page-h2 {
	font-size: 34px;
	font-weight: 400;
	text-align: center;
	letter-spacing: 0.05em;
	position: relative;
	margin-bottom: 60px;
	font-family: 'FOT-セザンヌ ProN DB';
}

.page-h2::before {
	border: 3px solid #80B0E8;
	width: 50px;
	position: absolute;
	bottom: -10px;
	left: 50%;
	margin-left: -25px;
	content: "";
}

.page-h3 {
	font-size: 30px;
	font-weight: 400;
	letter-spacing: 0.05em;
	position: relative;
	margin-bottom: 35px;
	border-bottom: 1px solid #80B0E8;
	padding-bottom: 4px;
	color: #3157A0;
}

.page-h4,
.title-under {
	font-size: 24px;
	font-weight: 400;
	font-style: normal;
	letter-spacing: 0.05em;
	position: relative;
	margin-bottom: 25px;
	padding-left: 12px;
	border-left: 3px solid #80B0E8;
}

.title-under {
	display: block;
	margin-bottom: 15px;
}

@media only screen and (max-width: 800px) {

	.mb120 {
		margin-bottom: 90px !important;
	}


	.contents {
		padding-top: 0px;
	}

	.page-inner {
		padding: 60px 5% 80px;
	}

	.breadcrumb {
		padding: 20px 5% 0;
	}

	.breadcrumb ul {
		display: flex;
		flex-wrap: wrap;
	}

	.breadcrumb ul li {
		position: relative;
		font-size: 12px;
	}

	.breadcrumb ul li+li {
		margin-left: 6px;
		padding-left: 14px;
	}

	.mb-style {
		margin-bottom: 150px;
	}

	.page-h2 {
		font-size: 28px;
		margin-bottom: 52px;
		line-height: 1.5;
		padding-bottom: 5px;
	}

	.page-h2:before {
		border-width: 2px;
	}

	.page-h3 {
		font-size: 22px;
		margin-bottom: 30px;
		padding-bottom: 4px;
		line-height: 1.5;
	}

	.page-h4,
	.title-under {
		margin-bottom: 20px;
	}

	.title-under {
		display: block;
		margin-bottom: 15px;
	}
}


.txt-underline {
	display: inline;
	background: url("../images/under/under_line.png") repeat left bottom;
}

.tall {
	margin-bottom: 70px;
}



.page-scroll,
.hero-scroll {
	position: absolute;
	left: 45px;
	bottom: 0;
	transform: translateX(-50%);
}

.page-scroll .txt,
.hero-scroll .txt {
	display: block;
	width: 20px;
	font-size: 13px;
	line-height: 1;
	letter-spacing: 0.05em;
	writing-mode: vertical-rl;
	position: relative;
	padding-bottom: 71px;
	font-family: "Wix Madefor Display", sans-serif;
	font-weight: 600;
}

.page-scroll .txt::before,
.hero-scroll .txt::before {
	content: "";
	width: 1px;
	height: 50px;
	position: absolute;
	left: 14px;
	bottom: 0;
	transform: translateX(-50%);
	background: #333;
}

.page-scroll .txt::after,
.hero-scroll .txt::after {
	content: "";
	background: #333;
	border-radius: 50%;
	position: absolute;
	bottom: 0;
	left: 14px;
	transform: translateX(-50%);
	height: 5px;
	width: 5px;
	animation: iconScroll 2s ease-in-out infinite;
	will-change: animation;
}

.page-scroll {
	position: fixed;
	right: 2%;
	bottom: 40px;
	left: auto;
	z-index: 10;
}

.page-scroll .txt {
	padding-top: 60px;
	padding-bottom: 0;
}

.page-scroll .txt::before {
	top: 0;
	bottom: auto;
}

.page-scroll .txt::after {
	top: 16px;
	animation: iconScroll-ext 2s ease-in-out infinite;
	will-change: animation;
}

@keyframes iconScroll {
	0% {
		transform: scale(0) translateX(-50%);
		bottom: 55px;
	}

	1%,
	22% {
		transform: scale(1) translateX(-50%);
	}

	60% {
		transform: scale(1) translateX(-50%);
		bottom: -1px;
	}

	100% {
		transform: scale(0) translateX(-50%);
		bottom: -1px;
	}
}

@keyframes iconScroll-ext {
	0% {
		transform: scale(0) translateX(-50%);
		top: 50px;
	}

	1%,
	22% {
		transform: scale(1) translateX(-50%);
	}

	60% {
		transform: scale(1) translateX(-50%);
		top: -1px;
	}

	100% {
		transform: scale(0) translateX(-50%);
		top: -1px;
	}
}

@media screen and (max-width: 800px) {

	.page-scroll .txt,
	.hero-scroll .txt {
		font-size: 10px;
		line-height: 10px;
	}

	.hero-scroll {
		left: -3px;
		bottom: 0;
		transform: none;
		display: none;
	}

	.page-scroll {
		bottom: 90px;
		transform: none;
		right: 5vw;
		opacity: 0;
		visibility: hidden;
	}

	.page-scroll.visible {
		opacity: 1;
		visibility: visible;
	}

	.page-scroll .txt {
		line-height: 16px;
	}
}


.footer-info {
	max-width: 1200px;
	margin: 0 auto;
	background-color: #454C55;
	color: #fff;
	padding-top: 55px;
	padding-bottom: 52px;
	position: relative;
	z-index: 2;
}

.footer-info .inner {
	max-width: 1026px;
	margin: 0 auto;
}

.footer-info .inner .col-left {
	width: 48%;
	max-width: 420px;
	padding-top: 7px;
}

.footer-info .inner .col-left .logo {
	max-width: 247px;
	margin-bottom: 23px;
}

.footer-info .inner .col-left .note {
	line-height: 32px;
	margin-bottom: 21px;
	font-size: 16px;
	letter-spacing: 0px;
}

.footer-info .inner .col-right {
	position: relative;
	width: 48%;
}

.footer-info .inner .col-right dl.tel-top {
	margin-bottom: 35px;
}

.footer-info .inner .col-right dl.tel-top dt {
	position: relative;
	line-height: 1;
	display: inline-block;
	margin-bottom: 14px;
	font-size: 16px;
}

.footer-info .inner .col-right dl.tel-top dt::before {
	content: "";
	background-color: #fff;
	width: 52px;
	height: 1px;
	position: absolute;
	top: 50%;
	right: -60px;
	margin-top: -1px;
}

.footer-info .inner .col-right dl.tel-top dd {
	font-size: 34px;
	opacity: 1;
	visibility: visible;
	display: block;
}

.footer-info .inner .col-right dl.tel-top .tel-common .telhref::before {
	width: 30px;
	height: 30px;
	left: 0;
}

.footer-info .inner .col-right .link-fb {
	position: absolute;
	top: 39px;
	right: 128px;
	width: 30px;
}

.footer-info .inner .col-right .link-ins {
	position: absolute;
	top: 39px;
	right: 87px;
	width: 30px;
}

.footer-info .time-table-txt {
	font-size: 14px;
	letter-spacing: 1px;
}

.footer-info .time-table-txt .time {
	padding-left: 20px;
}


@media only screen and (min-width: 801px) and (max-width: 1099px) {
	.footer-info .inner .col-right {
		width: 53%;
	}

	.footer-info .inner .col-right .link-fb {
		right: 40px;
	}

	.footer-info .inner .col-right .link-ins {
		right: 0;
	}
}

@media only screen and (max-width: 800px) {
	.footer-info {
		color: #fff;
		padding-top: 55px;
		padding-bottom: 52px;
		position: relative;
		z-index: 2;
	}

	.footer-info .inner {
		max-width: 1026px;
		margin: 0 auto;
		display: flex;
	}

	.footer-info .inner .col-left {
		max-width: 420px;
		padding-top: 0;
	}

	.footer-info .inner .col-left .logo {
		max-width: 210px;
		margin: 0 auto 20px;
	}

	.footer-info .inner .col-left .note {
		line-height: 28px;
		margin-bottom: 21px;
		font-size: 14px;
		letter-spacing: 0;
	}


	.footer-info .inner .col-right dl.tel-top {
		padding-bottom: 30px;
		max-width: 290px;
		margin: 0 auto 45px;
	}

	.footer-info .inner .col-right dl.tel-top dt {
		margin-bottom: 13px;
	}

	.footer-info .inner .col-right dl.tel-top dt::before {
		width: 52px;
		height: 1px;
		position: absolute;
		top: 50%;
		right: -60px;
		margin-top: -1px;
	}

	.footer-info .inner .col-right dl.tel-top dd {
		font-size: 30px;
		opacity: 1;
		visibility: visible;
		display: block;
	}

	.footer-info .inner .col-right dl.tel-top .tel-common .telhref::before {
		width: 26px;
		height: 26px;
		left: 0;
		margin-top: -14px;
	}

	.footer-info .inner .col-right .link-fb {
		top: 80px;
		right: calc(50% + 25px);
		width: 30px;
	}

	.footer-info .inner .col-right .link-ins {
		position: absolute;
		top: 80px;
		right: calc(50% - 29px);
		width: 30px;
	}

	.footer-info .time-table-txt {
		font-size: 14px;
		letter-spacing: 1px;
	}

	.footer-info .time-table-txt .time {
		padding-left: 0;
		display: block;
	}
}


@media only screen and (max-width: 767px) {
	.footer-info .inner {
		display: block;
	}

	.footer-info .inner .col-left {
		width: auto;
		padding-top: 0;
	}

	.footer-info .inner .col-left .logo {
		max-width: 210px;
		margin: 0 auto 6vw;
	}

	.footer-info .inner .col-left .note {
		font-size: 14px;
		text-align: center;
	}

	.footer-info .inner .col-right {
		width: auto;
	}
}

.btn-s {
	width: 160px;
	border: 1px solid #fff;
	text-align: center;
	display: block;
	padding: 5px 0;
	font-size: 16px;
}

.btn-s:hover {
	opacity: .7;
}

.btn-s span {
	padding-left: 27px;
	position: relative;
}

.btn-s span::before {
	content: "";
	background: url(../images/share/location_on.svg) no-repeat;
	width: 16px;
	height: 19px;
	position: absolute;
	top: calc(50% - 10px);
	left: 0px;
}


@media only screen and (max-width: 800px) {
	.btn-s {
		width: 200px;
		padding: 10px 0 10px;
		margin: 0 auto;
	}

	.btn-s span {
		padding-left: 27px;
		position: relative;
	}

	.btn-s span::before {
		width: 16px;
		height: 19px;
		position: absolute;
		top: 50%;
		margin-top: -8px;
		padding-left: 0px;
		left: 0px;
	}

}



.fade-in {
	will-change: transform;
	transition: opacity 0.8s cubic-bezier(0.19, 1, 0.435, 0.99), -webkit-transform 1.8s cubic-bezier(0.19, 1, 0.435, 0.99);
	transition: transform 1.8s cubic-bezier(0.19, 1, 0.435, 0.99), opacity 0.8s cubic-bezier(0.19, 1, 0.435, 0.99);
	transition: transform 1.8s cubic-bezier(0.19, 1, 0.435, 0.99), opacity 0.8s cubic-bezier(0.19, 1, 0.435, 0.99), -webkit-transform 1.8s cubic-bezier(0.19, 1, 0.435, 0.99);
	-webkit-transform: translateY(100px);
	transform: translateY(100px);
	opacity: 0;
}

.fade-in.is-action {
	-webkit-transform: translateY(0);
	transform: translateY(0);
	opacity: 1;
}


.keymain,
#keyvisual-page {
	height: 650px;
	position: relative;
}

#keyvisual-page .ttl {
    font-weight: 400;
    font-family: 'FOT-セザンヌ ProN DB';
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: 150px;
	font-size: 46px;
	z-index: 2;
	color: #fff;
}

.keymain img {
	position: absolute;
	top: 0px;
	left: 0px;
	right: 0px;
	bottom: 0px;
	object-fit: cover;
	width: 100% !important;
	height: 100% !important;
}


@media only screen and (max-width: 800px) {

	.keymain,
	#keyvisual-page {
		height: 360px;
	}

	#keyvisual-page .ttl {
		font-size: 30px;
		bottom: 42%;
		left: 5%;
		letter-spacing: 0.02em;
		line-height: 1.5;
		right: 0;
		text-align: center;
		top: auto;
		transform: translateY(0px);
	}
}





.business-calendar-box-wrap .business-calendar-box {
	display: grid;
	grid-gap: 32px;

	margin-bottom: 15px;
	font-family: "Wix Madefor Display", sans-serif;
	font-style: normal;
}


.business-calendar-box-wrap .business-calendar-box>div {}

.business-calendar-box-wrap .business-calendar {
	text-align: center;
	border-collapse: collapse;
	border-spacing: 0;
	width: 100%;
}

.business-calendar-box-wrap .business-calendar caption {
	background: #3157A0;
	color: #fff;
	font-size: 18px;
	font-family: "Wix Madefor Display", sans-serif;
	font-style: normal;
	text-align: center;
	margin: 0 0 10px;
	padding: 10px 0;
}

.business-calendar-box-wrap .business-calendar caption span {
	line-height: 1;
	font-size: 25px;
	vertical-align: -1px;
}

.business-calendar-box-wrap .business-calendar-past a,
.business-calendar-box-wrap .business-calendar-future a {
	display: inline-block;
	cursor: pointer;
	text-indent: 100%;
	white-space: nowrap;
	overflow: hidden;
	position: relative;
	width: 25px;
	height: 25px;
}

.business-calendar-box-wrap .business-calendar-past a::before,
.business-calendar-box-wrap .business-calendar-future a::before {
	display: inline-block;
	content: "";
	border-style: solid;
	border-width: 7px 6px 7px 0;
	border-color: transparent #fff transparent transparent;
	position: absolute;
	top: 10px;
	left: 10px;
}

.business-calendar-box-wrap .business-calendar-future a::before {
	transform: rotate(180deg);
}

.business-calendar-box-wrap .business-calendar th {
	text-align: center;
	font-size: 13px;

	padding: 5px;
	width: 14%;
	font-weight: bold;
}

.business-calendar-box-wrap .business-calendar td {
	position: relative;
	padding: 10px 5px;
	z-index: 0;
	font-size: 12px;
	font-weight: normal;
}

.business-calendar-box-wrap .business-calendar td::before {
	content: "";
	background: #ccc;
	border-radius: 50px;
	width: 29px;
	height: 29px;
	position: absolute;
	top: 47%;
	left: 49%;
	transform: translate(-50%, -50%);
	z-index: -1;
	opacity: 0;
}

.business-calendar-box-wrap.large .business-calendar th,
.business-calendar-box-wrap.large .business-calendar td {
	padding: 10px;
	font-size: 15px;
}

.business-calendar-box-wrap.col2 {}

.business-calendar-box-wrap.col2 .business-calendar-box {
	display: grid;
	grid-gap: 3%;
}

.business-calendar-box-wrap .business-calendar .today {
	text-decoration: none;
	color: #fff;
}

.business-calendar-box-wrap .business-calendar tbody {
	border-bottom: 1px solid #99A1AA;
}

.business-calendar-box-wrap .business-calendar tbody tr {
	border-top: 1px solid #99A1AA;
}

.business-calendar-box-wrap .business-calendar td.today::before {}

.business-calendar-box-wrap .business-calendar .attr0,
.business-calendar-box-wrap .business-calendar .attr1,
.business-calendar-box-wrap .business-calendar .attr2,
.business-calendar-box-wrap .business-calendar .attr3 {
	color: #fff;
}

.business-calendar-box-wrap .business-calendar .attr0::before,
.business-calendar-box-wrap .business-calendar .attr1::before,
.business-calendar-box-wrap .business-calendar .attr2::before,
.business-calendar-box-wrap .business-calendar .attr3::before {
	opacity: 1;
}

.business-calendar-box-wrap .business-calendar .attr0::before {
	background: #454C55;
}

.business-calendar-box-wrap .business-calendar .attr1 {
	color: #333;
}

.business-calendar-box-wrap .business-calendar .attr1::before {
	background: #DCE2E8;
}

.business-calendar-box-wrap .business-calendar .attr2::before {
	background: #80B0E8;
}

.business-calendar-box-wrap .business-calendar .attr3 {
	color: #333;
}

.business-calendar-box-wrap .business-calendar .attr3::before {
	background: #fff;
	border: 1px solid #333;
}

.list-event {
	display: flex;
	justify-content: start;
	flex-wrap: wrap;
	gap: 10px 20px;
	margin-top: 25px;
}

.list-event li {
	font-size: 13px;
	line-height: 1;
}

.list-event i {
	margin: 0 5px 0 0;
	width: 15px;
	height: 15px;
	border-radius: 50%;
	display: inline-block;
}

.list-event .event01 {
	color: #454C55;
}

.list-event .event02 {
	color: #DCE2E8;
}

.list-event .event03 {
	color: #80B0E8;
}

.list-event .event04 {
	color: #454C55;
}

@media (max-width: 800px) {
	.business-calendar-box-wrap .business-calendar-box {
		grid-gap: 25px;
	}

	.business-calendar-box-wrap .business-calendar-box>div {
		padding: 0px;
	}

	.list-event {
		justify-content: flex-start;
	}

	.business-calendar-box-wrap .business-calendar td::before {
		top: 50%;

	}

}


/*TOP*/

.d-flex {
	display: flex;
	justify-content: space-between;
}

.btn-more {
	height: 46px;
	padding: 12px 95px 0 0;
	display: inline-block;
	font-size: 20px;
	line-height: 1.5;
	position: relative;
	font-family: 'FOT-セザンヌ ProN DB';
	letter-spacing: 0.2em;
	font-weight: 600;
}

.btn-more::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 50px;
	height: 50px;
	border-radius: 50%;
	transition: 0.3s;
	background-color: #80B0E8;
}

.btn-more::after {
	content: "";
	width: 44px;
	height: 11px;
	position: absolute;
	top: 20px;
	right: 18px;
	background: url(../images/share/btn_arrow.svg) center/contain no-repeat;
	transition: 0.3s;
}

.btn-more:hover::before {
	scale: 1.2;
}

.btn-more:hover::after {
	right: 15px;
}

.btn-more.white {
	color: #fff;
}

.btn-more.white::before {
	background-color: #fff;
}

.btn-more.white::after {
	background: url(../images/share/btn_arrow_b.svg) center/contain no-repeat;
}

#news-box {
	position: relative;
	background: #E9F4E4;
	padding: 0 20px;
}

#news-box .inner {
	top: -100px;
	margin-bottom: -20px;
	background: rgba(251, 249, 228, 0.9);
	box-sizing: border-box;
	padding: 60px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

#news-box .title-h2 {
	width: 205px;
}

#news-box .news-list {
	width: calc(100% - 205px);
	border-top: 1px solid #DDDDDD;
}

#news-box .news-list dl {
	padding: 22px 0;
	border-bottom: 1px solid #DDDDDD;
	display: flex;
	font-size: 15px;
	line-height: 30px;
}

#news-box .news-list dl dt {
	width: 120px;
	color: #B7AD9E;
}

#news-box .news-list dl dd {
	width: calc(100% - 120px);
}

#news-box .news-list dl dd a {
	text-decoration: none;
	max-height: 30px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: initial;
	display: -webkit-box;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
	transition: all 0.35s ease;
}

#news-box .news-list dl dd a:hover {
	opacity: 0.7;
}

#news-box .more {
	position: absolute;
	left: 60px;
	bottom: 60px;
}

@media only screen and (max-width: 800px) {
	#news-box {
		padding: 80px 5% 65px;
	}

	#news-box .inner {
		top: 0;
		margin-bottom: 0;
		padding: 30px;
		display: block;
	}

	#news-box .title-h2 {
		width: 100%;
		margin-bottom: 6%;
	}

	#news-box .news-list {
		width: 100%;
	}

	#news-box .news-list dl {
		padding: 12px 0;
		display: block;
	}

	#news-box .news-list dl dt {
		width: 100%;
	}

	#news-box .news-list dl dd {
		width: 100%;
	}

	#news-box .news-list dl dd a {
		max-height: 60px;
		-webkit-line-clamp: 2;
	}

	#news-box .more {
		position: relative;
		left: 0;
		bottom: 0;
		display: flex;
		justify-content: center;
		padding-top: 10%;
	}
}

#keyvisual {
	position: relative;
	height: 880px;
}

#keyvisual h2 {
	font-size: 46px;
	position: absolute;
	bottom: 191px;
	left: 237px;
	z-index: 3;
	color: #fff;
	letter-spacing: 0.04em;
	line-height: 82px;
	top: auto;
	transform: translateY(0px);
}

#keyvisual .kv {
	height: 880px;
	background-size: cover;
	background-position: center center;
	position: relative;
}

#keyvisual .kv img {
	object-fit: cover;
	width: 100% !important;
	height: 100% !important;
	position: absolute;
	top: 0px;
	left: 0px;
	right: 0px;
	bottom: 0px;
}

@media only screen and (max-width: 1099px) {

	#keyvisual,
	#keyvisual .kv {
		height: 650px;
	}

	#keyvisual h2 {
		font-size: 40px;
		bottom: 30px;
		left: 150px;
		line-height: 1.5;
	}
}


@media only screen and (max-width: 800px) {

	#keyvisual-page,
	#keyvisual {
		height: 360px;
		padding-left: 5%;
	}

	#keyvisual h2 {
		font-size: 20px;
		bottom: 20px;
		left: 5%;
		letter-spacing: 0.02em;
		line-height: 1.5;
		right: 0;
		text-align: center;
	}

	#keyvisual .kv {
		height: 360px;
	}


}

.container {
	max-width: 1024px;
	margin: 0 auto;
	position: relative;
}

.en {
	font-family: "Wix Madefor Display", sans-serif;
	font-weight: 800;
	font-style: normal;
	display: block;
	line-height: 1;
}

.ttl-c {

	text-align: center;
}

.ttl-c .en {
	font-size: 80px;
	margin-bottom: 22px;
	color: #80B0E8;
	letter-spacing: 0.1em;
}

.ttl-c .jp {
	line-height: 1;
	font-size: 24px;
	font-weight: 600;
}

@media only screen and (min-width: 801px) and (max-width: 1099px) {
	.ttl-c .en {
		font-size: 60px;
	}

	.ttl-c .jp {
		font-size: 18px;
	}
}

@media only screen and (max-width: 800px) {
	.ttl-c .en {
		font-size: 35px;
		margin-bottom: 4vw;
		letter-spacing: 0.1em;
	}

	.ttl-c .jp {
		line-height: 1;
		font-size: 1rem;
	}
}

#sec01 {
	padding: 100px 0 119px 0;
}

#sec01 .title {
	position: absolute;
	top: 10px;
	left: 0;
}

#sec01 .ttl-c {
	text-align: left;
}

#sec01 .ttl-c span.en {
	font-size: 44px;
	margin-bottom: 12px;
}

#sec01 .ttl-c span.jp {
	font-size: 16px;
}

#sec01 .r-item {
	max-width: 780px;
	width: 80%;
	margin-left: auto;
}

@media only screen and (min-width: 801px) and (max-width: 1099px) {
	#sec01 {
		padding: 100px 20px 119px 20px;
	}

	#sec01 .r-item {
		width: calc(50% + 180px);
	}
}

@media only screen and (max-width: 800px) {
	#sec01 {
		padding: 10vw 0 15vw;
	}

	#sec01 .title {
		position: relative;
		top: 0;
		left: 0;
		text-align: center;
		margin-bottom: 6vw;
	}

	#sec01 .ttl-c {
		text-align: center;
	}

	#sec01 .ttl-c span.en {
		font-size: 2.25rem;
		margin-bottom: 4vw;
	}

	#sec01 .ttl-c span.jp {
		font-size: 1rem;
	}

	#sec01 .r-item {
		max-width: 780px;
		width: auto;
		margin: 0 5%;
	}

}

.list-top-news li.list-item {
	border-bottom: 1px solid #DCE2E8;
	padding: 34px 0;
	position: relative;
	display: flex;
	justify-content: space-between;
	border-top: 1px solid #DCE2E8;
	margin-bottom: -1px;
}

.list-top-news li.list-item time {
	color: #99A1AA;
	font-weight: bold;
	font-size: 13px;
	font-family: "Wix Madefor Display", sans-serif;
	letter-spacing: 0;
	width: 15%;
	min-width: 117px;
	display: block;
}

.list-top-news li.list-item a {
	position: relative;
	display: block;
	width: 85%;
	overflow: hidden;
	max-height: 4rem;
	-webkit-line-clamp: 1;
	display: box;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	text-overflow: ellipsis;
	white-space: normal;
	padding-right: 30px;
	word-wrap: break-word;
}

.list-top-news li.list-item a:hover {
	text-decoration: underline;
}

.list-top-news li.list-item a::before {
	content: "";
	background: url(../images/share/arrow.svg) no-repeat;
	width: 22px;
	height: 22px;
	position: absolute;
	top: 50%;
	right: 0;
	margin-top: -11px;
}

@media only screen and (min-width: 801px) and (max-width: 1099px) {
	.list-top-news li.list-item a {
		padding-right: 5%;
	}
}


@media only screen and (max-width: 800px) {
	.list-top-news li.list-item {
		padding: 3vw 0;
	}

	.list-top-news li.list-item time {
		width: 10%;
		min-width: 100px;
	}

	.list-top-news li.list-item a {
		width: 80%;
		padding-right: 10%;
	}
}


#sec02 {
	position: relative;
	padding-top: 135px;
}

#sec02::before {
	content: "";
	background: url(../images/sec05_bg.jpg) no-repeat center;
	background-size: cover;
	height: 854px;
	width: calc(50% + 400px);
	position: absolute;
	top: 0;
	left: 0;
}

.sec02-layout {
	justify-content: flex-start;
	align-items: flex-start;
	position: relative;
}

#sec02 .l-img {
	position: relative;
	width: 610px;
	padding-left: 5.5vw;
	padding-top: 81px;
}

#sec02 .l-img figure {
	width: 310px;
	position: absolute;
	top: -66px;
	right: -89px;
	z-index: 2;
}

#sec02 .l-img figure+figure {
	position: relative;
	width: 610px;
	z-index: 1;
	right: 0;
	top: 0;
}

#sec02 .r-desc {
	width: 600px;
	position: relative;
	z-index: 1;
	padding-left: 12.1vw;
}

#sec02 .r-desc .ttl-c {
	margin-bottom: 65px;
	text-align: left;
}

#sec02 .r-desc .ttl-c .en {
	font-size: 98px;
}

#sec02 .r-desc .r-txt {
	margin-bottom: 49px;
}

#sec02 .r-desc .r-txt p {
	margin-bottom: 34px;
}

#sec02 .r-desc .r-txt p:last-child {
	margin-bottom: 0;
}


@media only screen and (min-width: 801px) and (max-width: 1499px) {
	#sec02 {
		padding-bottom: 40px;
	}

	#sec02::before {
		height: 100%;
	}

	#sec02 .r-desc .ttl-c {
		margin-bottom: 30px;
	}

	#sec02 .r-desc {
		width: 45%;
		padding-left: 8%;
	}

	#sec02 .l-img {
		width: 40%;
		padding-left: 2%;
	}

	#sec02 .l-img figure {
		width: 45%;
		top: -4%;
		right: -15%;
	}

	#sec02 .l-img figure+figure {
		width: 100%;
	}

	#sec02 .r-desc .r-txt p {
		margin-bottom: 20px;
	}
}

@media only screen and (min-width: 1100px) and (max-width: 1299px) {
	#sec02 .r-desc .ttl-c .en {
		font-size: 82px;
	}
}

@media only screen and (min-width: 801px) and (max-width: 1099px) {
	#sec02 .r-desc .ttl-c .en {
		font-size: 68px;
	}
}



@media only screen and (max-width: 800px) {
	#sec02 {
		padding-top: 24vw;
		padding-bottom: 10vw;
	}

	#sec02::before {
		height: 100%;
		width: calc(50% + 74px);
		position: absolute;
		top: 0;
		left: 0;
	}

	.sec02-layout {
		display: block;
	}

	#sec02 .l-img {
		position: relative;
		width: 90%;
		padding-left: 0;
		padding-top: 8vw;
		margin: 0 5%;
	}

	#sec02 .l-img figure {
		width: 50%;
		position: absolute;
		top: -12vw;
		right: -5vw;
		z-index: 2;
	}

	#sec02 .l-img figure+figure {
		position: relative;
		width: 100%;
		z-index: 1;
		right: 0;
		top: 0;
	}

	#sec02 .r-desc {
		width: auto;
		position: relative;
		z-index: 1;
		padding-left: 5vw;
		padding-top: 10vw;
		padding: 10vw 5vw 0;
	}

	#sec02 .r-desc .ttl-c {
		margin-bottom: 7vw;
		text-align: left;
	}

	#sec02 .r-desc .ttl-c .en {
		font-size: 40px;
	}

	#sec02 .r-desc .r-txt {
		margin-bottom: 10vw;
	}

	#sec02 .r-desc .r-txt p {
		margin-bottom: 25px;
	}

	#sec02 .r-desc .r-txt p:last-child {
		margin-bottom: 0;
	}
}


#sec03 {
	position: relative;
	padding-top: 201px;
	padding-bottom: 111px;
}

#sec03::before {
	content: "";
	background: url(../images/sec05_bg.jpg) no-repeat center;
	background-size: cover;
	height: 731px;
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
}

#sec03 .container {
	max-width: 1200px;
}

#sec03 .ttl-c {
	margin-bottom: 46px;
}

#sec03 .sec03-list {
	position: relative;
	display: flex;
	justify-content: space-between;
	margin-bottom: 59px;
	align-items: flex-start;
}

#sec03 .sec03-list li {
	width: 376px;
	background-color: #fff;
	position: relative;
}

#sec03 .sec03-list li .num {
	font-size: 96px;
	width: 85px;
	position: absolute;
	top: -49px;
	line-height: 1;
	left: 15px;
	height: 90px;
	z-index: 2;
	font-family: "Anaheim";
	font-weight: 400;
	font-style: normal;
	color: #3E64AD;
}

#sec03 .sec03-list li .num::before {
	content: "";
	background: url(../images/line.svg) no-repeat;
	-webkit-background-size: 100% auto;
	background-size: 100% auto;
	width: 36px;
	height: 36px;
	position: absolute;
	bottom: 0px;
	right: -16px;
}

#sec03 .sec03-list li figure {
	background-size: cover;
	background-position: center center;
	position: relative;
	height: 270px;
	width: 100%;
	margin-bottom: -26px;
}

#sec03 .sec03-list li figure img {
	position: absolute;
	top: 0px;
	left: 0px;
	right: 0px;
	bottom: 0px;
	object-fit: cover;
	width: 100% !important;
	height: 100% !important;
}

#sec03 .sec03-list li dl {
	padding-bottom: 26px;
	position: relative;
	z-index: 2;
}

#sec03 .sec03-list li dl dt {
	margin-bottom: 20px;
}

#sec03 .sec03-list li dl dt span {
	display: inline-block;
	line-height: 1;
	font-size: 22px;
	color: #fff;
	margin-bottom: 10px;
	background-color: #3157A0;
	padding: 10px 14px;
}

#sec03 .sec03-list li dl dd {
	padding: 0 29px;
	font-size: 15px;
	min-height: 240px;
}

#sec03 .sec03-list li:nth-child(2) {
	margin-top: 30px;
}

#sec03 .sec03-list li:nth-child(3) {
	margin-top: 60px;
}

#sec03 .btn-more {
	display: block;
	max-width: 105px;
	margin: 0 auto;
}

@media only screen and (min-width: 801px) and (max-width: 1199px) {
	#sec03 {
		padding: 201px 20px 111px;
	}

	#sec03 .sec03-list li {
		max-width: 376px;
		width: 32%;
	}

	#sec03 .sec03-list li figure {
		height: 205px;
	}
}


@media only screen and (max-width: 800px) {
	#sec03 {
		padding-top: 20vw;
		padding-bottom: 15vw;
	}

	#sec03::before {
		height: 82%;
		position: absolute;
		left: 0;
		right: 0;
		bottom: 0;
	}

	#sec03 .ttl-c {
		margin-bottom: 15vw;
	}

	#sec03 .sec03-list {
		position: relative;
		display: block;
		margin-bottom: 10vw;
		padding: 0 5vw;
	}

	#sec03 .sec03-list li {
		width: 100%;
		background-color: #fff;
		position: relative;
	}

	#sec03 .sec03-list li .num {
		font-size: 96px;
		width: 85px;
		top: -49px;
		left: 15px;
		height: 90px;
	}

	#sec03 .sec03-list li .num::before {
		width: 36px;
		height: 36px;
		bottom: 0px;
		right: -16px;
	}

	#sec03 .sec03-list li figure {
		height: 270px;
		width: 100%;
		margin-bottom: -26px;
	}

	#sec03 .sec03-list li figure img {}

	#sec03 .sec03-list li dl {
		padding-bottom: 9vw;
	}

	#sec03 .sec03-list li dl dt {
		margin-bottom: 20px;
	}

	#sec03 .sec03-list li dl dt span {
		line-height: 1;
		font-size: 22px;
		margin-bottom: 10px;
		padding: 8px 14px;
	}

	#sec03 .sec03-list li dl dd {
		padding: 0 25px;
		font-size: 15px;
		min-height: 100%;
	}

	#sec03 .sec03-list li:nth-child(2) {
		margin-top: 20vw;
	}

	#sec03 .sec03-list li:nth-child(3) {
		margin-top: 60px;
	}

	#sec03 .btn-more {

		margin: 0 auto;
	}
}


#sec04 {
	padding-top: 199px;
	padding-bottom: 265px;
}

#sec04 .container {
	max-width: 1200px;
}

#sec04 .ttl-c {
	margin-bottom: 51px;
}

#sec04 .sec04-layout {
	position: relative;
	margin-bottom: 116px;
}

#sec04 .sec04-layout .item {
	position: relative;
	display: flex;
	flex-direction: row-reverse;
	justify-content: space-around;
}

#sec04 .sec04-layout .item figure {
	width: 770px;
	position: relative;
	margin-right: 4%;
}

#sec04 .sec04-layout .item figure::before {
	content: "";
	position: absolute;
	top: 20px;
	right: -20px;
	bottom: -20px;
	left: 20px;
	border: 1px solid #3157A0;
}

#sec04 .sec04-layout .item figure img {
	position: relative;
	z-index: 2;
}

#sec04 .sec04-layout .item figure figcaption {
	font-size: 129px;
	line-height: 1;
	font-family: 'Quentin';
	transform: rotate(-11deg);
	position: absolute;
	top: -41px;
	left: -88px;
	color: #3157A0;
	z-index: 3;
	letter-spacing: 6px;
}

#sec04 .sec04-layout .item .l-desc {
	max-width: 572px;
	width: 38%;
	padding-top: 92px;
	padding-left: 15%;
}

#sec04 .sec04-layout .item .l-desc h3 {
	font-size: 32px;
	color: #3157A0;
	line-height: 56px;
	position: relative;
	padding-left: 35px;
	margin-bottom: 32px;
	font-weight: 800;
	font-style: normal;
}

#sec04 .sec04-layout .item .l-desc h3::before {
	content: "";
	background-color: #3157A0;
	width: 2px;
	position: absolute;
	top: 8px;
	bottom: 12px;
	left: 0;
}

#sec04 .sec04-layout .item .l-desc .txt {
	margin-bottom: 30px;
	padding-right: 22px;
}

#sec04 .sec04-layout .item:nth-child(2n) {
	margin: 116px 0;
	flex-direction: row;
}

#sec04 .sec04-layout .item:nth-child(2n) figure {
	margin-right: 0;
	margin-left: 3%;
}

#sec04 .sec04-layout .item:nth-child(2n) figure::before {
	top: 20px;
	right: 20px;
	bottom: -20px;
	left: -20px;
}

#sec04 .sec04-layout .item:nth-child(2n) figure figcaption {
	left: auto;
	right: -208px;
}

#sec04 .sec04-layout .item:nth-child(2n) .l-desc {
	margin-left: 0;
	padding-left: 0;
	margin-right: 0;
}

#sec04 .sec04-layout .item:nth-child(3) .l-desc {
	padding-top: 32px;
}

@media only screen and (min-width: 801px) and (max-width: 1599px) {
	#sec04 .sec04-layout .item figure {
		width: 55%;
	}

	#sec04 .sec04-layout .item .l-desc {
		width: 37%;
		padding-right: 2%;
		padding-left: 5%;
	}


	#sec04 .sec04-layout .item figure {
		background-size: cover;
		background-position: center center;
	}

	#sec04 .sec04-layout .item figure img {
		position: absolute;
		z-index: 2;
		object-fit: cover;
		width: 100%;
		height: 100%;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
	}

	#sec04 .sec04-layout .item:nth-child(2n) .l-desc {
		margin-left: 0;
		padding-left: 5%;
		margin-right: 0%;
	}

	#sec04 .sec04-layout .item:nth-child(3) .l-desc {
		padding-top: 70px;
	}

	#sec04 .sec04-layout .item:nth-child(2n) {}
}

@media only screen and (min-width: 801px) and (max-width: 1099px) {
	#sec04 .sec04-layout .item .l-desc h3 {
		font-size: 28px;
		line-height: 45px;
	}

	#sec04 .sec04-layout .item figure figcaption {
		font-size: 80px;
	}
}



@media only screen and (max-width: 800px) {
	#sec04 {
		padding-top: 22vw;
		padding-bottom: 20vw;
	}

	#sec04 .ttl-c {
		margin-bottom: 15vw;
	}

	#sec04 .sec04-layout {
		margin-bottom: 15vw;
		padding-left: 5vw;
		padding-right: 5vw;
	}

	#sec04 .sec04-layout .item {
		display: block;
	}

	#sec04 .sec04-layout .item figure {
		position: relative;
		margin-right: 4%;
		width: 100%;
	}

	#sec04 .sec04-layout .item figure::before {
		position: absolute;
		top: 20px;
		right: -10px;
		bottom: -10px;
		left: 10px;
		border: 1px solid #3157A0;
	}

	#sec04 .sec04-layout .item figure img {
		position: relative;
		z-index: 2;
	}

	#sec04 .sec04-layout .item figure figcaption {
		font-size: 60px;
		line-height: 1;
		transform: rotate(-11deg);
		position: absolute;
		top: -42px;
		left: -23px;
		color: #3157A0;
		z-index: 3;
		letter-spacing: 6px;
	}

	#sec04 .sec04-layout .item .l-desc {
		max-width: 572px;
		width: auto;
		padding-top: 10vw;
		padding-left: 0;
	}

	#sec04 .sec04-layout .item .l-desc h3 {
		font-size: 1.6rem;
		line-height: 1.5;
		padding-left: 30px;
		margin-bottom: 5vw;
	}

	#sec04 .sec04-layout .item .l-desc h3::before {
		width: 2px;
		top: 8px;
		bottom: 7px;
		left: 0;
	}

	#sec04 .sec04-layout .item .l-desc .txt {
		margin-bottom: 10vw;
		padding-right: 0;
	}

	#sec04 .sec04-layout .item:nth-child(2n) {
		margin: 15vw 0 20vw;
		flex-direction: row;
	}

	#sec04 .sec04-layout .item:nth-child(2n) figure {
		margin-right: 0;
		margin-left: 3%;
	}

	#sec04 .sec04-layout .item:nth-child(2n) figure::before {
		top: 10px;
		right: 10px;
		bottom: -10px;
		left: -10px;
	}

	#sec04 .sec04-layout .item:nth-child(2n) figure figcaption {
		left: auto;
		right: -14px;
		top: -18px;
	}

	#sec04 .sec04-layout .item:nth-child(2n) .l-desc {
		margin-left: 0;
		padding-left: 0;
	}

	#sec04 .sec04-layout .item:nth-child(3) .l-desc {
		padding-top: 10vw;
	}
}


.sec04-card {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.sec04-card li {
	width: 48%;
	max-width: 578px;
	position: relative;
	border-bottom: 1px solid #DCE2E8;
	box-sizing: border-box;
	padding: 30px 0 30px 166px;
	min-height: 166px;
}

.sec04-card li a {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	font-size: 0;
	z-index: 2;
}

.sec04-card li a::after {
	content: "";
	background: url(../images/share/arrow.svg) no-repeat;
	width: 22px;
	height: 22px;
	position: absolute;
	top: 50%;
	right: 0;
	margin-top: -11px;
	transition: all .4s ease;
}

.sec04-card li figure {
	width: 120px;
	height: 120px;
	border-radius: 50%;
	background-color: #fff;
	position: absolute;
	top: 50%;
	left: 20px;
	transform: translateY(-50%);
}

.sec04-card li figure img {
	display: block;
	width: 76px;
	margin: 0 auto;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	filter: brightness(0) saturate(100%) invert(70%) sepia(13%) saturate(1277%) hue-rotate(175deg) brightness(95%) contrast(92%);
}

.sec04-card li h3 {
	font-size: 21px;
	font-family: 'FOT-セザンヌ ProN DB';
}

.sec04-card li .list li {
	width: 100%;
	max-width: 578px;
	position: relative;
	border-bottom: none;
	padding-bottom: 0;
	padding-left: 20px;
	padding-top: 0;
	min-height: 30px;
}

.sec04-card li .list li::before {
	content: "";
	background: url(../images/share/icon_check.svg) no-repeat;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: 0;
	width: 15px;
	height: 13px;
	padding-left: 30px;
	border-bottom: none;
	max-width: 15px;
	padding-bottom: 0;
}

.sec04-card li .list li+li {
	margin-top: 0;
}

.sec04-card li:hover figure {
	background-color: #80B0E8;
}

.sec04-card li:hover figure img {
	filter: brightness(0) saturate(100%) invert(100%) sepia(100%) saturate(38%) hue-rotate(321deg) brightness(110%) contrast(110%);
}

.sec04-card li:hover a::after {
	scale: 1.2;
}

.sec04-card li.icon01 figure img {
	width: 54px;
	height: 67px;
}

.sec04-card li.icon02 figure img {
	width: 78px;
	height: 40px;
}

.sec04-card li.icon03 figure img {
	width: 32px;
	height: 57px;
}

.sec04-card li.icon04 figure img {
	width: 68px;
	height: 49px;
}

.sec04-card li.icon05 figure img {
	width: 64px;
	height: 59px;
}

.sec04-card li.icon06 figure img {
	width: 64px;
	height: 56px;
}


@media only screen and (max-width: 800px) {


	.sec04-card {
		display: block;
		padding: 0 5vw;
	}

	.sec04-card li {
		width: 100%;
		max-width: 578px;
		position: relative;
		box-sizing: border-box;
		padding: 5vw 0 5vw 80px;
		min-height: 100%;
	}

	.sec04-card li a {
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		font-size: 0;
		z-index: 2;
	}

	.sec04-card li a::after {
		position: absolute;
		top: 50%;
		right: 0;
		margin-top: -11px;
		transition: all .4s ease;
	}

	.sec04-card li figure {
		width: 70px;
		height: 70px;
		background-color: #fff;
		position: absolute;
		top: 50%;
		left: 0;
	}

	.sec04-card li figure img {
		display: block;
		width: 76px;
		margin: 0 auto;
		position: absolute;
		top: 50%;
		left: 50%;
	}

	.sec04-card li h3 {
		font-size: 1rem;
		letter-spacing: 0.01em;
	}

	.sec04-card li .list li {
		width: 100%;
		max-width: 578px;
		border-bottom: none;
		padding-bottom: 0;
		padding-left: 23px;
		padding-top: 0;
		min-height: 25px;
	}

	.sec04-card li .list li::before {
		left: 0;
		padding-left: 0;
		border-bottom: none;
		max-width: 15px;
		padding-bottom: 0;
	}

	.sec04-card li .list li+li {
		margin-top: 0;
	}

	.sec04-card li figure {
		background-color: #80B0E8;
	}

	.sec04-card li figure img {
		filter: brightness(0) saturate(100%) invert(100%) sepia(100%) saturate(38%) hue-rotate(321deg) brightness(110%) contrast(110%);
	}

	.sec04-card li:hover a::after {
		scale: 1;
	}

	.sec04-card li.icon01 figure img {
		width: 33px;
		height: 56px;
	}

	.sec04-card li.icon02 figure img {
		width: 50px;
		height: 35px;
	}

	.sec04-card li.icon03 figure img {
		width: 20px;
		height: 50px;
	}

	.sec04-card li.icon04 figure img {
		width: 42px;
		height: 49px;
	}

	.sec04-card li.icon05 figure img {
		width: 38px;
		height: 50px;
	}

	.sec04-card li.icon06 figure img {
		width: 37px;
		height: 56px;
	}



}

@media only screen and (min-width: 801px) and (max-width: 1299px) {
	.sec04-card {
		padding: 0 20px;
	}

	.sec04-card li {
		padding: 30px 0 30px 120px;
		min-height: 140px;
	}

	.sec04-card li .list li {
		width: auto;
		padding-right: 25px;
		line-height: 25px;

	}

	.sec04-card li .list li::before {
		top: 10px;
	}

	.sec04-card li figure {
		width: 80px;
		height: 80px;
	}

	.sec04-card li.icon01 figure img {
		width: 36px;
	}

	.sec04-card li.icon02 figure img {
		width: 56px;
	}

	.sec04-card li.icon03 figure img {
		width: 24px;
	}

	.sec04-card li.icon04 figure img {
		width: 50px;
	}

	.sec04-card li.icon05 figure img {
		width: 47px;
	}

	.sec04-card li.icon06 figure img {
		width: 44px;
	}
}


#sec05 {
	position: relative;
	padding-bottom: 120px;
}

#sec05::before {
	content: "";
	background: url(../images/sec05_bg.jpg) no-repeat center;
	background-size: cover;
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 861px;
}

#sec05 .container {
	max-width: 1200px;
}

#sec05 .ttl-c {
	margin-bottom: 207px;
	text-align: left;
	position: relative;
	z-index: 2;
}

#sec05 figure {
	position: absolute;
	top: -58px;
	right: -200px;
	max-width: 980px;
	width: 100%;
}

#sec05 .l-box {
	background-color: #80B0E8;
	max-width: 920px;
	width: 80%;
	position: relative;
	z-index: 2;
}

#sec05 .l-box .l-info {
	padding: 65px 88px;
	color: #fff;
}

#sec05 .l-box .l-info p {
	margin-bottom: 35px;
}


@media only screen and (max-width: 1599px) {
	#sec05 figure {
		right: 0;
	}
}

@media only screen and (min-width: 801px) and (max-width: 1199px) {
	#sec05 .ttl-c {
		padding-left: 20px;
	}

	#sec05 .l-box .l-info {
		padding: 40px;
	}

	#sec05 figure {
		right: 0;
		width: 88%;
		top: -6px;
	}
}


@media only screen and (max-width: 800px) {
	#sec05 {
		padding-bottom: 15vw;
	}

	#sec05::before {
		background: url(../images/sec05_bg.jpg) no-repeat center;
		background-size: cover;
		position: absolute;

		bottom: 0;
		left: 0;
		right: 0;
		height: 81%;
	}

	#sec05 .ttl-c {
		margin-bottom: -15vw;
		text-align: left;
		padding-left: 5vw;
	}

	#sec05 figure {
		position: relative;
		top: 0;
		right: 0;
		max-width: 980px;
		width: 80%;
		margin-left: 20%;
		margin-bottom: -10vw;
	}

	#sec05 .l-box {
		width: 90%;
	}

	#sec05 .l-box .l-info {
		padding: 30px;
	}

	#sec05 .l-box .l-info p {
		margin-bottom: 20px;
	}
}


#sec06 .ttl-c {
	margin-bottom: 50px;
}

#sec06 .container {
	margin-bottom: 87px;
	padding-top: 133px;
}

#sec06 .l-left {
	max-width: 490px;
	width: 49%;
}

#sec06 .r-right {
	width: 49%;
	max-width: 490px;
}

#sec06 .r-right .list-dl {
	margin-bottom: 24px;
	font-size: 16px;
}

#sec06 .r-right .list-dl dl {
	display: flex;
	justify-content: space-between;
	line-height: 32px;
}

#sec06 .r-right .list-dl dl dt {
	max-width: 80px;
	width: 20%;
}

#sec06 .r-right .list-dl dl dd {
	max-width: 400px;
	width: 80%;
	letter-spacing: 0;
}

#sec06 .r-right .list-dl dl dd a.telhref {
	background: none;
	padding-left: 0;
}

#sec06 .r-right .list-dl dl+dl {
	margin-bottom: 0px;
}

#sec06 .mmap {
	max-width: 1600px;
	margin: 0 auto;
	height: 450px;
}

@media only screen and (min-width: 801px) and (max-width: 1099px) {
	#sec06 {
		padding: 0 20px;
	}

	#sec06 .l-left {
		width: 38%;
	}

	#sec06 .r-right {
		width: 60%;
	}

	#sec06 .r-right .list-dl {
		font-size: 15px;

	}
}

@media only screen and (max-width: 800px) {
	#sec06 .ttl-c {
		margin-bottom: 10vw;
	}

	#sec06 .container {
		margin-bottom: 15vw;
		padding-top: 20vw;
	}

	.sec06-layout {
		display: block;
		padding: 0 5vw;
	}

	#sec06 .l-left {
		max-width: 100%;
		width: auto;
	}

	#sec06 .r-right {
		width: auto;
		max-width: 100%;
		padding-top: 7vw;
	}

	#sec06 .r-right .list-dl {
		margin-bottom: 24px;
	}

	#sec06 .r-right .list-dl dl {
		display: flex;
		justify-content: start;
		line-height: 32px;
	}

	#sec06 .r-right .list-dl dl dt {
		max-width: 92px;
		width: 30%;
	}

	#sec06 .r-right .list-dl dl dd {
		max-width: 400px;
		width: 70%;
		letter-spacing: 0;
	}

	#sec06 .r-right .list-dl dl dd a.telhref {
		background: none;
		padding-left: 0;
	}

	#sec06 .r-right .list-dl dl+dl {
		margin-bottom: 0px;
	}

	#sec06 .mmap {
		max-width: 1600px;
		margin: 0 auto;
		height: 450px;
	}

}


#sec07 {

	padding-top: 100px;

	padding-bottom: 91px;
}

#sec07 .title {
	position: absolute;
	top: 4px;
	left: 0;
}

#sec07 .ttl-c {
	text-align: left;
}

#sec07 .ttl-c span.en {
	font-size: 44px;
}

#sec07 .ttl-c span.jp {
	font-size: 16px;
}

#sec07 .r-item {
	max-width: 763px;
	width: 80%;
	margin-left: auto;
}

#sec07 .btn-more {
	position: absolute;
	top: 161px;
	left: 0;
}


@media only screen and (min-width: 801px) and (max-width: 1099px) {
	#sec07 {
		padding: 100px 20px 91px;
	}

	#sec07 .r-item {
		width: 75%;
	}

	.list-top-news-img li.list-item {
		width: 31%;
	}
}

@media only screen and (max-width: 800px) {
	#sec07 {

		padding-top: 15vw;

		padding-bottom: 18vw;
	}

	#sec07 .title {
		position: relative;
		top: 0;
		left: 0;
		text-align: center;
	}

	#sec07 .ttl-c {
		text-align: center;
		margin-bottom: 7vw;
	}

	#sec07 .ttl-c span.en {
		font-size: 44px;
	}

	#sec07 .ttl-c span.jp {
		font-size: 16px;
	}

	#sec07 .r-item {
		max-width: 763px;
		width: auto;
		margin-left: auto;
		padding: 0 5vw;
	}

	#sec07 .btn-more {
		position: relative;
		top: 0;
		left: 0;
		margin: 0 auto;
		display: block;
		max-width: 75px;
	}
}


.list-top-news-img li.list-item {
	padding: 0;
	position: relative;
	width: 32%;
	max-width: 241px;
}

.list-top-news-img li.list-item figure {
	background-color: #fff;
	border: 1px solid #DCE2E8;
	width: 100%;
	margin-bottom: 10px;
	height: 160px;
	position: relative;
}

.list-top-news-img li.list-item figure img {
	object-fit: cover;
	width: 100%;
	height: 100%;
}

.list-top-news-img li.list-item time {
	color: #99A1AA;
	font-size: 13px;
	font-weight: bold;
	display: block;
}

.list-top-news-img li.list-item a.list-txt {
	position: relative;
	text-decoration: none;
	max-height: 30px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: initial;
	display: -webkit-box;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
	margin-bottom: 8px;
	font-size: 16px;
	word-break: break-all;
}

.list-top-news-img li.list-item a.list-txt:hover {
	text-decoration: underline;
}

.list-top-news-img li.list-item .list-cate {
	display: inline-block;
	font-size: 12px;
	color: #3157A0;
	border: 1px solid #3157A0;
	line-height: 19px;
	padding: 2px 5px;
}

.list-top-news-img li.list-item .list-cate i {
	position: relative;
}

.list-top-news-img li.list-item .list-cate i+i {
	padding-left: 10px;
	margin-left: 10px;
}

.list-top-news-img li.list-item .list-cate i+i::before {
	content: "";
	background: #3157A0;
	width: 1px;
	height: 12px;
	top: -5px;
	transform: rotate(40deg);
	position: absolute;
	left: 0;
}

@media only screen and (max-width: 800px) {
	.list-top-news-img {
		display: block;
	}

	.list-top-news-img li.list-item {
		padding: 0;
		width: 100%;
		max-width: 100%;
		margin-bottom: 7vw;
	}

	.list-top-news-img li.list-item figure {
		background-color: #fff;
		width: 100%;
		margin-bottom: 10px;
	}

	.list-top-news-img li.list-item time {
		color: #99A1AA;
		font-size: 13px;
		font-weight: bold;
		display: block;
	}

	.list-top-news-img li.list-item a.list-txt {
		margin-bottom: 8px;
	}

	.list-top-news-img li.list-item .list-cate {
		font-size: 12px;
		line-height: 19px;
		padding: 3px 6px 3px;
	}
}




/*ENDTOP*/

/*Style layout*/
.txt-center {
	text-align: center;
}

.txt-right {
	text-align: right;
}

.dis-flex {
	display: flex;
}

.dis-block {
	display: block !important;
}

.x-short p+p {
	margin-top: 20px;
}

iframe {
	width: 100%;
	height: 100%;
}

.clearfix {
	zoom: 1 !important;
}

.clearfix:after {
	content: "." !important;
	clear: both !important;
	display: block !important;
	height: 0 !important;
	visibility: hidden !important;
}

.btn-global {
	display: inline-block;
	margin: 20px auto !important;
}

.btn-global a {
	display: flex;
	justify-content: center;
	align-items: center;
	color: #fff;
	background: #80B0E8;
	min-width: 210px;
	padding: 20px 30px;
	position: relative;
	transition: ease 0.3s;
	line-height: 1;
	text-decoration: none !important;
	color: #fff !important;
	font-style: normal;
}

.btn-global a:before {
	content: "";
	left: 15px;
	width: 5px;
	height: 5px;
	border-bottom: 1px solid #fff;
	border-right: 1px solid #fff;
	position: absolute;
	transform: translateX(-50%) rotate(-45deg);
	z-index: 2;
	top: 45%;
}

.btn-global a:hover {
	opacity: 0.8;
}

.btn-global.btn-right {
	float: right;
}

.btn-global+.btn-global {
	margin-left: 20px !important;
}

@media screen and (max-width: 800px) {
	.btn-global {
		display: block;
		width: 100%;
	}

	.btn-global+.btn-global {
		margin-left: 0 !important;
	}

	.btn-global a {
		padding: 18px 0px 18px;
	}
}

@media screen and (min-width: 801px) {
	.btn-multicol {
		justify-content: center;
	}

	.btn-multicol p {
		margin: 20px 0 !important;
	}
}

.style3-disc {
	display: inline-block;
}

.style3-disc li {
	position: relative;
	padding: 0 0 0 15px;
	letter-spacing: 0;
}

.style3-disc li+li {
	margin-top: 3px;
}

.style3-disc li:before {
	background: #3157A0;
	border-radius: 50%;
	content: "";
	display: block;
	position: absolute;
	left: 0;
	top: 16px;
	width: 5px;
	height: 5px;
}

@media screen and (max-width: 800px) {
	.style3-disc li:before {
		top: 12px;
	}
}

.style3-check1 li {
	position: relative;
	padding: 4px 0 2px 32px;
}

.style3-check1 li:before {
	content: "";
	display: block;
	border: 1px solid #3157A0;
	height: 17px;
	width: 17px;
	position: absolute;
	left: 0;
	top: 6px;
	box-sizing: border-box;
}

.style3-check1 li:after {
	content: "";
	display: block;
	width: 5px;
	height: 9px;
	border: solid #3157A0;
	border-width: 0 1px 1px 0;
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	transform: rotate(45deg);
	box-sizing: border-box;
	position: absolute;
	top: 9px;
	left: 6px;
}

.style3-check2 li {
	position: relative;
	padding: 4px 0 2px 32px;
}

.style3-check2 li:after {
	content: "";
	display: block;
	width: 7px;
	height: 14px;
	border: solid #3157A0;
	border-width: 0 2px 2px 0;
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	transform: rotate(45deg);
	box-sizing: border-box;
	position: absolute;
	top: 9px;
	left: 6px;
}

.style3-num li {
	margin-bottom: 2px;
	align-items: flex-start;
	justify-content: space-between;
}

.style3-num li .num {
	background: #4E4E4E;
	color: #fff;
	border-radius: 50%;
	width: 25px;
	height: 25px;
	display: flex;
	justify-content: center;
	align-items: center;
	font-family: 'Anaheim';
	font-size: 120%;
}

.style3-num li .txt {
	width: calc(100% - 35px);
}

.style3-num2 {
	margin-left: 27px;
}

.style3-num2 li {
	list-style: decimal;
}

.list-dot dl {
	border-bottom: 1px dotted #80B0E8;
	padding: 5px 0;
	justify-content: space-between;
}

.list-dot dl dt {
	width: 100px;
}

.list-dot dl dd {
	width: calc(100% - 110px);
}

.style4 {
	color: #fff;
	background: #80B0E8;
	padding: 55px 60px;
	font-size: 17px;
}

.style4 .page-h2:before {
	border-color: #fff;
}

.style4 p+p {
	margin-top: 34px;
}

@media screen and (max-width: 800px) {
	.style4 {
		padding: 30px 25px;
		margin-bottom: 50px;
	}
}

.style5 {
	margin: 0 -88px;
}

@media screen and (min-width: 801px) and (max-width: 1250px) {
	.style5 {
		margin: 0 -30px;
	}
}

@media screen and (min-width: 801px) and (max-width: 1100px) {
	.style5 {
		margin: 0;
	}
}

@media screen and (max-width: 800px) {
	.style5 {
		margin: 0;
	}
}

.style5-item {
	margin-bottom: 70px;
	align-items: flex-start;
}

.style5-item .style5-img {
	width: 64%;
	position: relative;
	z-index: 0;
}

.style5-item .style5-img:before {
	content: "";
	position: absolute;
	z-index: -1;
	box-sizing: border-box;
	border: 1px solid #3157A0;
	width: 100%;
	height: 100%;
	top: 20px;
}

.style5-item .style5-info {
	width: 45.8%;
	box-sizing: border-box;
}

.style5-item:nth-child(odd) .style5-img {
	margin-left: -16.6%;
}

.style5-item:nth-child(odd) .style5-img:before {
	left: -20px;
}

.style5-item:nth-child(even) .style5-img {
	order: 2;
	margin-right: -15.8%;
}

.style5-item:nth-child(even) .style5-img:before {
	left: 20px;
}

.style5-item .style5-num {
	color: #80B0E8;
	font-size: 30px;
	line-height: 1.8;
}

.style5-item .style5-ttl {
	color: #3157A0;
	font-size: 30px;
	line-height: 1.8;
	margin-bottom: 45px;
}

@media screen and (min-width: 801px) and (max-width: 1100px) {
	.style5-item:nth-child(odd) .style5-img {
		margin-left: -13%;
	}

	.style5-item:nth-child(even) .style5-img {
		margin-right: -13%;
	}
}

@media screen and (max-width: 800px) {
	.style5-item {
		margin-bottom: 50px;
	}

	.style5-item .style5-img {
		width: 100%;
		margin: 0 auto !important;
	}

	.style5-item .style5-img:before {
		top: 10px;
	}

	.style5-item:nth-child(odd) .style5-img:before {
		left: -10px;
	}

	.style5-item:nth-child(even) .style5-img:before {
		left: 10px;
	}

	.style5-item .style5-info {
		width: 100%;
		margin-top: 30px;
	}

	.style5-item .style5-num,
	.style5-item .style5-ttl {
		font-size: 25px;
	}

	.style5-item .style5-ttl {
		margin-bottom: 15px;
	}
}

.style6 .style6-item {
	display: flex;
	justify-content: space-between;
	position: relative;
}

.style6 .style6-item ul {
	display: flex;
	align-items: center;
	margin: 20px 0 10px;
}

.style6 .style6-item ul li {
	margin-bottom: 15px;
}

.style6 .style6-item ul li .btn-web {
	border-radius: 3px;
	margin-left: 10px;
}

.style6 .style6-item+.style6-item {
	border-top: 1px solid #80B0E8;
	padding-top: 55px;
	margin-top: 50px;
}

.style6 .style6-item+.style6-item::before {
	content: "";
	width: 22px;
	height: 22px;
	border-bottom: 2px solid #80B0E8;
	border-right: 2px solid #80B0E8;
	position: absolute;
	top: -18px;
	left: 50%;
	-webkit-transform: translateX(-50%) rotate(45deg);
	transform: translateX(-50%) rotate(45deg);
	z-index: 2;
}

.style6 .style6-item+.style6-item::after {
	content: "";
	background: #fff;
	width: 75px;
	height: 22px;
	position: absolute;
	top: -18px;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	z-index: 1;
}

.style6 .photo {
	width: 35%;
	float: right;
	margin-top: -80px;
	/*
	width: 39%;
	order: 2;
*/
}

.style6 .box {
	width: 100%;
	/*
	width: 56%;
	order: 1;
*/
}

.style6 .box .style6-txts {
	margin-top: 28px;
	width: 60%;
}

.style6 .full .box {
	/*
	width: 100%;
	order: 1;
*/
}

.style6 .page-inner-h3 {
	display: flex;
	align-items: center;
	font-size: 30px;
	line-height: 1.5;
	margin: 0 0 25px;
	padding-bottom: 0;
	border-bottom: 1px solid #80B0E8;
	width: 60%;
}

.style6 .num-s,
.style6 .num {
	background: url(../images/share/style_06_tt.png) no-repeat right center;
	color: #fff;
	display: inline-block;
	font-size: 18px;
	line-height: 30px;
	padding: 11px 45px 6px 20px;
	height: 50px;
	margin: 0 10px 0 0;
	position: relative;
	box-sizing: border-box;
	min-width: 140px;
	text-align: center;
}

.style6 .num-s {
	min-width: 95px;
}

/*
.style6 .num::after {
    content: "";
    border-style: solid;
    border-width: 47px 0px 0px 46px;
    border-color: transparent transparent transparent #3157A0;
    position: absolute;
    right: -44px;
    top: 0px;
}
*/

@media screen and (max-width: 800px) {
	.style6 .tel-common {
		font-size: 20px;
	}

	.style6 .telhref {
		background-size: 16px auto;
		padding: 0 0 2px 41px;
	}

	.style6 a.link-ext {
		width: 140px;
		height: 40px;
	}

	.style6 .style6-item {
		flex-wrap: wrap;
	}

	.style6 .style6-item ul {
		display: flex;
		margin: 20px 0 10px;
	}

	.style6 .style6-item ul li {
		margin-bottom: 15px;
	}

	.style6 .style6-item ul li .btn-web {
		border-radius: 3px;
		margin-left: 10px;
	}

	.style6 .style6-item+.style6-item {
		padding-top: 35px;
		margin-top: 30px;
	}

	.style6 .photo {
		width: 100%;
		order: 1;
		margin-bottom: 8%;
		float: none;
		margin-top: 0;
	}

	.style6 .box {
		width: 100%;
		order: 2;
	}

	.style6 .box .style6-txts {
		width: 100%;
	}

	.style6 .full .box {
		width: 100%;
		order: 1;
	}

	.style6 .page-inner-h3 {
		display: flex;
		align-items: flex-start;
		font-size: 20px;
		line-height: 45px;
		margin: 0 0 20px;
		width: 100%;
	}

	.style6 .num {}

	/*
	.style6 .num::after {

		border-width: 47px 0px 0px 46px;
		right: -45px;
	}
*/

}

.style7 {
	border: 1px solid #3157A0;
	box-sizing: border-box;
	padding: 20px;
}

.style7:not(:first-child) {
	margin-left: 20px;
}

.style7 .border-ttl {
	border-bottom: 1px solid #80B0E8;
	font-weight: 700;
	padding: 15px 0 5px;
	margin-bottom: 10px;
}

.style7 .btn-global {
	display: block;
	max-width: 250px;
}

.style7 .border-img02,
.style7 .border-img {
	height: 310px;
	background-size: cover;
	background-position: center center;
	position: relative;
	margin-bottom: 0 !important;
}

.style7 .border-img02 {
	height: 195px;
}



.style7 .border-img02 img,
.style7 .border-img img {
	object-fit: cover;
	width: 100% !important;
	height: 100% !important;
	position: absolute;
	top: 0px;
	left: 0px;
	right: 0px;
	bottom: 0px;
}

.style7-imgs {
	width: 60%;
	margin: 0 auto;
}


@media screen and (max-width: 800px) {
	.style7 {
		width: 100% !important;
		margin: 0 0 20px !important;
	}

	.style7 .border-img {
		height: 220px;
	}

	.style7 .border-img02 {
		height: 100%;
		padding-top: 50vw;
	}

}

.style-3col {
	justify-content: flex-start;
	flex-wrap: wrap;
}

.style-3col .style7 {
	width: calc((100% - 40px) / 3);
	margin-bottom: 20px;
}



.style-3col .style7:nth-child(3n + 1) {
	margin-left: 0;
}

.style-2col {}

.style-2col .style7,
.style-2col>.x-short {
	margin-bottom: 0px;
}

.style-2col .style7:nth-child(2n + 1),
.style-2col>.x-short:nth-child(2n + 1) {
	margin-left: 0;
	margin-bottom: 20px;
}

.style-2col-2 {}

.style-2col-2>.x-short {}

.pic_img {
	width: 40%;
}

.style-pic-info {
	width: calc(60% - 30px);
}

.style-pic-info p+p {
	margin-top: 1.5em;
}

.style-pic-right .pic_img {
	order: 2;
	margin-left: 30px;
}

.style-pic-left .pic_img {
	margin-right: 30px;
}

@media screen and (min-width: 801px) {
	.style-2col {
		flex-wrap: wrap;
		justify-content: space-between;
	}

	.style-2col .style7,
	.style-2col>.x-short {
		width: calc((100% - 20px) / 2);
		margin-bottom: 20px;
	}

	.style-2col-2 {
		flex-wrap: wrap;
		justify-content: space-between;
	}

	.style-2col-2>.x-short {
		width: calc((100% - 50px) / 2);
	}

	.style-2col .style7:nth-child(2n + 1),
	.style-2col>.x-short:nth-child(2n + 1) {
		margin-left: 0;
	}
}


@media screen and (min-width: 801px) {
	.style-box .pic_img {
		float: right;
		border-left: 30px solid #fff;
		position: relative;
		z-index: 1;
	}

	.style-box.pic-left .pic_img {
		float: left;
		border-right: 30px solid #fff;
		border-left: none;
	}

	.style-box.dis-flex-pc .style-box-txt {
		width: calc(70% - 30px);
	}
}

@media screen and (max-width: 800px) {
	.pic_img {
		margin: 0 0 30px !important;
	}

	.pic_img,
	.style-pic-info {
		width: 100%;
	}

	.style-2col-2>.x-short {
		margin-bottom: 30px;
		width: 100%;
	}
}

.style8 {
	background: #4E4E4E;
	box-sizing: border-box;
	padding: 50px 30px;
	color: #fff;
	text-align: center;
	max-width: 800px;
	margin: 0 auto;
}

.style8 .style8-ttl {
	font-weight: 700;
	font-size: 18px;
	border-bottom: 1px solid #fff;
	text-align: center;
	display: inline-flex;
	justify-content: center;
	padding-bottom: 10px;
	margin-bottom: 40px;
}

.style8 .style8-txt {
	text-align: left;
	margin-top: 40px;
	display: inline-flex;
	justify-content: center;
}

.style8 .style8-txt p {
	margin: 10px 0;
}

.style8 .style8-txt dl {
	align-items: flex-start;
}

.style8 .style8-txt dl dt {
	border: 1px solid #80B0E8;
	text-align: center;
	margin-right: 20px;
	width: 120px;
	line-height: 1;
	padding: 8px 0;
}

.style8 .style8-txt dl dd span {
	display: inline-block;
}

@media screen and (max-width: 800px) {
	.style8 {
		padding: 40px 20px;
	}

	.style8 .style8-ttl {
		margin-bottom: 30px;
	}

	.style8 .style8-txt {
		margin-top: 25px;
	}

	.style8 .style8-txt dl dt {
		width: 80px;
		margin-right: 10px;
		padding: 10px 0;
	}
}

.style10 {
	color: #4E4E4E;
}

.style10 .style10-ttl {
	font-family: 'FOT-セザンヌ ProN DB';
	font-size: 24px;
	border-bottom: 2px solid #80B0E8;
	color: #4E4E4E;
	position: relative;
	margin-bottom: 20px;
	padding-bottom: 5px;
}

.style10 .style10-ttl:before {
	content: "";
	position: absolute;
	left: 0;
	bottom: -2px;
	width: 50px;
	height: 2px;
	background: #3157A0;
}

@media screen and (max-width: 800px) {
	.style10 .style10-ttl {
		font-size: 18px;
	}
}

.style15 {
	width: 0px;
	height: 0px;
	border-style: solid;
	border-width: 100px 190px 0 190px;
	border-color: #3157A0 transparent transparent transparent;
	transform: rotate(0deg);
	margin: 40px auto;
}

@media screen and (max-width: 800px) {
	.style15 {
		border-width: 50px 95px 0 95px;
	}
}

.style16 {
	color: #454c55;
}

.style16 .style16-img {
	width: calc((100% - 40px) / 2);
	text-align: center;
	margin-bottom: 30px;
}

@media screen and (max-width: 800px) {
	.style16 .style16-img {
		width: 100%;
	}
}

.style18 {
	border: 1px solid #3157A0;
	box-sizing: border-box;
	padding: 20px;
}

.style18 .first-ttl {
	text-align: center;
	font-family: "FOT-セザンヌ ProN DB";
	font-size: 28px;
	margin-bottom: 20px;
}

.style18 dl {
	margin-bottom: 20px;
}

.style18 dl dt {
	display: flex;
	border-bottom: 1px dotted #80B0E8;
	margin-bottom: 5px;
	padding-bottom: 5px;
	justify-content: space-between;
	color: #454c55;
	font-family: "FOT-セザンヌ ProN DB";
	line-height: 1.3;
}

.style18 dl dt .style18-ttl {
	width: calc(100% - 300px);
}

.style18 dl dt .style18-price {
	text-align: right;
	width: 300px;
}

.style18 dl dd {
	font-size: 90%;
	padding: 10px 0 0;
	margin: 0;
}

@media screen and (max-width: 800px) {
	.style18 .first-ttl {
		font-size: 23px;
	}

	.style18 dl dt {
		display: block;
	}

	.style18 dl dt .style18-ttl,
	.style18 dl dt .style18-price {
		width: 100%;
	}
}

.box-bg2 {
	background: #F4F5F7;
	padding: 17px 20px;
}

.box-bg3 {
	background: #F4F5F7;
	padding: 45px 40px;
}

@media screen and (max-width: 800px) {
	.box-bg3 {
		padding: 30px 25px;
	}
}

.slide-box .slick-list {
	overflow: visible;
}

.slide-box .slick-slide {
	margin: 0 30px;
	width: 800px !important;
}

.slide-box .slick-prev,
.slide-box .slick-next {
	display: block;
	position: absolute;
	top: 230px;
	width: 40px;
	height: 40px;
	-webkit-transition: .5s;
	transition: .5s;
	z-index: 10;
	font-size: 0;
	opacity: 0.7;
	background: #4E4E4E;
	border-radius: 50%;
}

.slide-box .slick-prev:before,
.slide-box .slick-next:before {
	content: "";
	position: absolute;
	width: 10px;
	height: 10px;
	top: 18px;
}

.slide-box .slick-prev:hover,
.slide-box .slick-next:hover {
	opacity: 1;
}

.slide-box .slick-prev {
	left: 93px;
}

.slide-box .slick-prev:before {
	border-top: 3px solid #fff;
	border-left: 3px solid #fff;
	-webkit-transform: rotate(-45deg) translateY(-50%);
	transform: rotate(-45deg) translateY(-50%);
}

.slide-box .slick-next {
	right: 91px;
}

.slide-box .slick-next:before {
	border-top: 3px solid #fff;
	border-right: 3px solid #fff;
	-webkit-transform: rotate(45deg) translateY(-50%);
	transform: rotate(45deg) translateY(-50%);
	right: 19px;
}

.slide-box .slick-dots {
	display: flex;
	justify-content: center;
	padding-top: 25px;
}

.slide-box .slick-dots li {
	margin: 0 7px;
}

.slide-box .slick-dots li button {
	display: block;
	background: none;
	border-radius: 50%;
	cursor: pointer;
	color: transparent;
	width: 11px;
	height: 11px;
	outline: none;
	border: 1px solid #999;
}

.slide-box .slick-dots li.slick-active button {
	background: #999;
}

.slide-box .slide-common-img {
	width: 800px;
}

.slide-box .slide-common-img img {
	opacity: 0.2;
}

.slide-box .slick-current .slide-common-img img {
	opacity: 1;
}

.slide-box .slide-common-ttl {
	font-weight: 700;
	font-size: 120%;
	margin-top: 10px;

}

.slide-box .slide-common-ttl,
.slide-box .slide-common-txt {
	opacity: 0;
	visibility: hidden;
}


.slide-box .slick-current .slide-common-ttl,
.slide-box .slick-current .slide-common-txt {
	opacity: 1;
	visibility: visible;
}

@media screen and (min-width: 850px) and (max-width: 1080px) {

	.slide-box .slick-prev,
	.slide-box .slick-next {
		top: 240px;
		left: 50%;
		right: auto;
	}

	.slide-box .slick-prev {
		margin-left: -420px;
	}

	.slide-box .slick-next {
		margin-left: 382px;
	}
}

@media screen and (max-width: 850px) {
	.slide-box .slick-prev {
		margin-left: -267px;
	}

	.slide-box .slick-next {
		margin-left: 227px;
	}

	.slide-box .slick-prev,
	.slide-box .slick-next {
		top: 138px;
		left: 50%;
		right: auto;
	}

	.slide-box .slick-slide {
		margin: 0 20px;
		width: 500px !important;
	}

	.slide-box .slide-common-img {
		width: 500px;
	}
}


@media screen and (max-width: 600px) {
	.slide-box .slick-prev {
		margin-left: -200px;
	}

	.slide-box .slick-next {
		margin-left: 172px;
	}

	.slide-box .slick-next:before {
		right: 15px;
	}

	.slide-box .slick-prev,
	.slide-box .slick-next {
		top: 105px;
		left: 50%;
		right: auto;
		width: 30px;
		height: 30px;
	}

	.slide-box .slick-prev:before,
	.slide-box .slick-next:before {
		width: 7px;
		height: 7px;
		top: 13px;
	}

	.slide-box .slick-slide {
		margin: 0 20px;
		width: 375px !important;
	}

	.slide-box .slide-common-img {
		width: 375px;
	}
}

@media screen and (max-width: 480px) {
	.slide-box .slick-prev {
		margin-left: -164px;
	}

	.slide-box .slick-next {
		margin-left: 135px;
	}

	.slide-box .slick-next:before {
		right: 15px;
	}

	.slide-box .slick-prev,
	.slide-box .slick-next {
		top: 80px;
	}

	.slide-box .slick-slide {
		margin: 0 10px;
		width: 300px !important;
	}

	.slide-box .slide-common-img {
		width: 300px;
	}
}

.gmap {
	width: 100%;
	height: 480px;
}

.style2 {
	position: relative;
	color: #454c55;
}

.style2 table {
	background: #FFF;
}

.style2 table th,
.style2 table td {
	border: 1px solid #ddd;
	padding: 10px 20px;
	box-sizing: border-box;
	word-break: break-all;
}

.style2 table th p+p,
.style2 table td p+p {
	margin-top: 10px;
}

.style2 table th {
	width: 25%;
	background: #80B0E8;
	color: #fff;
}

.style2 tbody tr:first-child th {}

@media screen and (max-width: 800px) {

	.style2 table th,
	.style2 table td {
		width: 100%;
		display: block;
	}

	.style2 table th {
		border: 1px solid #80B0E8;
	}

	.style2.table-sp table th,
	.style2.table-sp table td {
		width: 100%;
		display: table-cell;
		font-size: 13px;
		letter-spacing: 0;
		padding: 10px 16px;
	}

	.style2.table-sp table th {
		border: 1px solid #ddd;
		width: 50%;
	}
}

.txt-color {
	color: #80B0E8;
}

table.time-box {
	background: #FFF;
	margin-bottom: 12px;
	font-size: 15px;
	border: none;
}

table.time-box thead {
	background: #4E4E4E;
	font-family: 'FOT-セザンヌ ProN DB';
	color: #FFF;
}

table.time-box thead th {
	width: 145px;
	box-sizing: border-box;
}

table.time-box thead th,
table.time-box thead td {
	padding: 8px;
	text-align: center;
}

table.time-box tbody th {
	font-family: 'FOT-セザンヌ ProN DB';
}

table.time-box tbody th,
table.time-box tbody td {
	padding: 14px 8px 0;
	text-align: center;
	line-height: 25px;
}

table.time-box tbody tr {
	border-bottom: 1px solid #4E4E4E;
}

table.time-box tbody tr:last-child {
	border: none;
}

table.time-box tbody tr:last-child th,
table.time-box tbody tr:last-child td {
	padding: 14px 8px 14px;
}

@media screen and (max-width: 800px) {
	table.time-box {
		font-size: 13px;
		margin-bottom: 15px;
	}

	table.time-box thead th {
		width: 105px;
		box-sizing: border-box;
	}

	table.time-box thead th,
	table.time-box thead td {
		padding: 5px;
		text-align: center;
	}

	table.time-box tbody th,
	table.time-box tbody td {
		padding: 10px 5px 0;
		line-height: 24px;
	}

	table.time-box tbody tr:last-child th,
	table.time-box tbody tr:last-child td {
		padding: 10px 5px 10px;
	}
}

.calendar-txt span {
	display: inline-block;
}

.staff-h2 {
	font-size: 28px;
	margin-bottom: 30px;
	font-family: 'FOT-セザンヌ ProN DB';
}

@media screen and (max-width: 800px) {
	.staff-h2 {
		font-size: 24px;
		margin-bottom: 20px;
	}
}

.staff-name {
	text-align: right;
}

.staff-name span {
	display: inline-block;
}

.staff-name span.name-jp {
	margin: 0 10px;
	font-family: 'FOT-セザンヌ ProN DB';
	font-size: 150%;
}

.staff-name span.name-en {
	font-size: 110%;
}

.staff-box {
	box-sizing: border-box;
	border: 1px solid #3157A0;
	padding: 30px;
	margin-bottom: 30px;
	background: #eee;
}

.staff-box .staff-row2 li {
	border-bottom: 1px dotted #80B0E8;
	padding: 5px 0;
}

.staff-box .staff-item dt {
	font-family: 'FOT-セザンヌ ProN DB';
	margin-top: 10px;
}

.style10-ttl .staff-name-en {
	color: #ccc;
	font-size: 80%;
	display: inline-block;
	margin-left: 20px;
}

@media screen and (min-width: 801px) {
	.pb115 {
		padding-bottom: 115px;
	}

	.pb100 {
		padding-bottom: 100px;
	}
}


.txt-right {
	text-align: right;
}

.mt10 {
	margin-top: 10px;
}

.mt20 {
	margin-top: 20px;
}

.mt30 {
	margin-top: 30px;
}

.mt40 {
	margin-top: 40px;
}

.mt50 {
	margin-top: 50px;
}

.text-link {
	color: #9a76ad;
	text-decoration: underline;
}

.text-link:hover {
	text-decoration: none;
}

@media screen and (max-width: 800px) {
	.heightLine-auto {
		height: auto !important;
	}
}

.style11 {
	align-items: flex-start;
}

.style11 .style11-img {
	position: relative;
	z-index: 0;
}

.style11 .style11-img:before {
	content: "";
	position: absolute;
	z-index: -1;
	box-sizing: border-box;
	border: 1px solid #3157A0;
	width: 100%;
	height: 100%;
	top: 10px;
	left: -10px;
}

.style11 .style11-info {
	margin-top: 30px;
	box-sizing: border-box;
}

.style11 .style11-ttl {
	color: #3157A0;
	font-size: 25px;
	line-height: 1.8;
	margin-bottom: 15px;
	font-family: 'FOT-セザンヌ ProN DB';
}

.style11 .style11-ttls {
	font-size: 16px;
	line-height: 1.8;
	margin-bottom: 15px;
	font-family: 'FOT-セザンヌ ProN DB';
}

@media screen and (min-width: 801px) {
	.style11 {
		margin-left: -88px;
		margin-right: -88px;
	}

	.style11 .style11-img {
		width: 64%;
		margin-left: -16.6%;
	}

	.style11 .style11-img:before {
		top: 20px;
		left: -20px;
	}

	.style11 .style11-info {
		width: 45.8%;
		margin-top: 0px;
	}

	.style11 .style11-ttl {
		font-size: 30px;
		margin-bottom: 20px;
	}

	.style11 .style11-ttls {
		font-size: 20px;
		margin-bottom: 20px;
	}

	.style11.style11-img-right {
		flex-direction: row-reverse;
	}

	.style11.style11-img-right .style11-img {
		margin-left: auto;
		margin-right: -16.6%;
	}

	.style11.style11-img-right .style11-img:before {
		top: 20px;
		left: 20px;
	}

	.style11.style-pic-right .style11-img {
		margin-left: auto;
		margin-right: -16.6%;
		order: 2;
	}

	.style11.style-pic-right .style11-img:before {
		top: 20px;
		left: 20px;
	}
}

@media screen and (min-width: 801px) and (max-width: 1250px) {
	.style11 {
		margin-left: -30px;
		margin-right: -30px;
	}
}

@media screen and (min-width: 801px) and (max-width: 1100px) {
	.style11 {
		margin-left: 0px;
		margin-right: 0px;
	}

	.style11 .style11-img {
		margin-left: -13%;
	}

	.style11.style11-img-right .style11-img {
		margin-right: -13%;
	}

	.style11.style-pic-right .style11-img {
		margin-right: -13%;
	}
}

.style12 {
	position: relative;
	box-sizing: border-box;
	padding: 0px 20px 20px 20px;
}

.style12:before {
	content: "";
	position: absolute;
	top: 15px;
	left: 0px;
	right: 0px;
	bottom: 0px;
	background: #F4F5F7;
	z-index: -1;
}

.style12 .style12-point {
	color: #80B0E8;
	font-family: "Wix Madefor Display";
	font-weight: 800;
	letter-spacing: 0.05em;
	line-height: 1;
	font-size: 35px;
	margin-bottom: 20px;
}

@media screen and (min-width: 801px) {
	.style12 {
		padding: 0px 40px 40px 40px;
	}

	.style12:before {
		top: 25px;
	}

	.style12 .style12-point {
		font-size: 50px;
	}
}

.style13.page-h3 {
	line-height: 1.4;
	position: relative;
	padding-left: 55px;
}

.style13.page-h3 .page-h3-num {
	font-size: 40px;
	line-height: 0.54;
	letter-spacing: 0.05em;
	font-family: 'Anaheim';
	position: absolute;
	display: inline-block;
	padding: 0px 5px 5px 0px;
	top: 0px;
	left: 0px;
	box-sizing: border-box;
}

.style13.page-h3 .page-h3-num:before {
	content: "";
	position: absolute;
	right: 0px;
	bottom: 0px;
	transform: skewX(-45deg);
	width: 1px;
	height: 20px;
	background: #3e64ad;
}

@media screen and (min-width: 801px) {
	.style13.page-h3 {
		padding-left: 90px;
	}

	.style13.page-h3 .page-h3-num {
		font-size: 77px;
		padding: 0px 5px 10px 0px;
		top: -30px;
		left: 0px;
	}

	.style13.page-h3 .page-h3-num:before {
		height: 30px;
	}
}

.style-img-col {
	margin: 0px 0px 20px 0px;
}

@media screen and (min-width: 801px) {
	.style-img-col {
		width: 35%;
	}

	.style-txt-info {
		width: 60%;
	}

	.style-img-right .style-img-col {
		order: 2;
		margin: 0px 0px 0px 30px;
	}

	.style-img-left .style-img-col {
		margin: 0px 30px 0px 0px;
	}
}

.style14 {

	background: #F4F5F7;
	padding: 20px;
}

@media screen and (min-width: 801px) {
	.style14 {
		padding: 30px;
	}
}

@media screen and (min-width: 801px) {
	.style14-2col .style3-disc {
		width: calc(100% / 2);
	}
}

.style14-3col .style3-disc {
	padding-right: 5%;
}

@media screen and (min-width: 801px) {
	.style14-3col .style3-disc {
		width: calc(100% / 3);
		padding-right: 0;
	}
}

@media screen and (min-width: 801px) {
	.style14.style-2col .x-short {
		width: calc((100% - 30px) / 2);
	}
}

.style15-for-parent {
	position: relative;
}

.style15-for-parent:after {
	content: "";
	position: relative;
	display: block;
	margin: 20px auto;
	width: 0px;
	height: 0px;
	border-style: solid;
	border-width: 50px 95px 0 95px;
	border-color: #3157A0 transparent transparent transparent;
}

@media screen and (min-width: 801px) {
	.style15-for-parent:after {
		border-width: 98px 189.5px 0 189.5px;
	}
}

.style17 .style7 {
	background: #F4F5F7;
	border: none;
}

.style17 .style17-ttl {
	text-align: center;
}

.style17 .style17-ttl .style17-num {
	display: inline-block;
	background: #3157A0;
	color: #fff;
	line-height: 1;
	padding: 5px 25px 4px;
	border-radius: 25px;
	font-size: 12px;
}

.style17 .style17-ttl .style17-tit {
	display: block;
	color: #454c55;
	font-weight: 700;
}



@media screen and (max-width: 801px) {
	.style17 .style17-ttl .style17-num {
		font-size: 15px;
		padding: 5px 25px 5px;
	}
}

.style19 {
	display: flex;
	align-items: flex-start;
}

.style19 .style19-tit {
	background: #3157A0;
	color: #fff;
	border-radius: 3px;
	width: 180px;
	text-align: center;
	box-sizing: border-box;
	padding: 14px 0;
	line-height: 1;
}

.style19 .style19-txt {
	padding: 6px 15px 0;
	width: calc(100% - 180px);
	box-sizing: border-box;
}

.style19+.style19 {
	margin-top: 10px;
}

.style20 .x-short {
	background: #F4F5F7;
	border-top: 2px solid #80B0E8;
	box-sizing: border-box;
	padding: 20px;

}

.style20 .style20-merit {
	border-top: 2px solid #80B0E8;
}

.style20 .style20-demerit {
	border-top: 2px solid #454c55;
}

.style20 .style20-ttl {
	margin-bottom: 20px;
}

.style20 .style20-ttl-en {
	font-size: 22px;
	margin-right: 20px;
}

.style20 .style20-ttl-jp {
	font-size: 14px;
}

@media screen and (max-width: 800px) {
	.style20 .x-short {
		width: 100%;
		margin-bottom: 20px !important;
	}

	.style19 .style19-tit {
		padding: 11px 0 11px;
	}
}

@media screen and (min-width: 801px) {
	.style20 .x-short {
		padding: 30px 35px;
	}

	.style20 .style20-ttl-en {
		font-size: 25px;
	}
}

.qa-item span {
	border-radius: 18px;
	color: #fff;
	font-size: 20px;
	font-family: "Wix Madefor Display", sans-serif;
	font-weight: bold;
	text-align: center;
	width: 35px;
	height: 35px;
	line-height: 34px;
	position: absolute;
	top: 0;
	left: 0;
}

.qa-item .qa-title {
	cursor: pointer;
	display: flex;
	border-bottom: 1px solid #ddd;
	padding: 0 35px 15px 50px;
	margin: 0 0 20px;
	position: relative;
	font-size: 20px;
}

.qa-item .qa-title::before {
	content: "";
	background: url(../images/share/ico_open.svg) no-repeat center/contain;
	width: 25px;
	height: 25px;
	position: absolute;
	top: 5px;
	right: 0;
	transition: all 0.3s ease;
}

.qa-item .qa-title.active::before {
	background: url(../images/share/ico_close.svg) no-repeat center/contain;
}

.qa-item .qa-title span {
	background: #000;
}

.qa-item .qa-desc {
	position: relative;
	padding: 0 35px 35px 50px;
}

.qa-item .qa-desc span {
	background: #bbb;
}

@media screen and (max-width: 801px) {
	.qa-item span {
		line-height: 35px;
	}

}

.blog-main {
	position: relative;
}

.blog-main .date-detail span {
	display: inline-block;
	background: #3157A0;
	color: #FFF;
	margin-left: 15px;
	font-size: 12px;
	line-height: 26px;
	padding: 5px 10px 0;
}

.blog-main .date-detail span i {
	display: inline-block;
	position: relative;
}

.blog-main .date-detail span i+i {
	margin-left: 5px;
	padding-left: 15px;
}

.blog-main .date-detail span i+i::before {
	content: "/";
	position: absolute;
	top: 0;
	left: 0;
}

.blog-main .blog-list {
	position: relative;
}




.blog-main .blog-list .item+.item {
	margin-top: 70px;
	padding-top: 70px;
	border-top: 1px solid #80B0E8;
}

.blog-main .blog-list .item .page-h3 {
	border-bottom-style: dashed;
	overflow: hidden;
	max-height: 4rem;
	-webkit-line-clamp: 1;
	display: box;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	text-overflow: ellipsis;
	white-space: normal;
	line-height: 2;

}

.blog-main .blog-list .item .date {
	margin-bottom: 15px;
}

.blog-main .blog-list .item .date time,
.blog-main .blog-list .item .date p {
	display: inline-block;
}

.blog-main .blog-list .item .date span {
	display: inline-block;
	background: #3157A0;
	color: #FFF;
	margin-left: 15px;
	font-size: 12px;
	line-height: 26px;
	padding: 2px 10px;
}

.blog-main .blog-list .item .date span i {
	display: inline-block;
	position: relative;
}

.blog-main .blog-list .item .date span i+i {
	margin-left: 5px;
	padding-left: 15px;
}

.blog-main .blog-list .item .date span i+i::before {
	content: "/";
	position: absolute;
	top: 0;
	left: 0;
}

.blog-main .blog-list .item .box {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.blog-main .blog-list .item .box .photo {
	width: 25%;
}

.blog-main .blog-list .item .box .photo a {
	display: block;
	width: 100%;
	padding-top: 70%;
	position: relative;
	overflow: hidden;
}

.blog-main .blog-list .item .box .photo a::before {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	content: "";
	box-sizing: border-box;
	border: 1px solid #DDDDDD;
	z-index: 1;
}

.blog-main .blog-list .item .box .photo a img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate3d(-50%, -50%, 0);
	object-fit: cover;
}

.blog-main .blog-list .item .box .text {
	width: 72%;
}

.blog-main .blog-list .item .box .text span {
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	height: 90px;
}

.blog-main .blog-list .item .btn-global {
	display: block;
	width: 220px;
	margin: 40px 0 0 auto !important;
}

.blog-main .blog-list .item .btn-global a {
	box-sizing: border-box;
}

.blog-main .blog-list .item.is-item .date {
	text-align: right;
}

.blog-main .blog-list .item.is-item .box .text {
	width: 100%;
}

.blog-main .blog-list .item.is-post .box .text {
	width: 100%;
}

.blog-main .cate-name {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 40px;
}

.blog-main .cate-name .cate {
	display: inline-block;
	background: #85CD63;
	color: #FFF;
	padding: 0 15px;
	transition: all 0.35s ease;
}

.blog-main .cate-name .cate:hover {
	opacity: 0.7;
}


.post-number-single {
	margin-top: 50px;
	display: flex;
	justify-content: center;
	text-align: center;
}

.post-number-single a {
	display: inline-block;
}

.post-number-single .all {
	background: #3157A0;
	border: 1px solid #3157A0;
	text-decoration: none;
	color: #fff;
	font-size: 13px;
	line-height: 28px;
	max-width: 200px;
	margin: 0 10px;
	height: 30px;
	width: 100%;
}

.post-number-single .all:hover {
	background: #fff;
	color: #3157A0;
}

.post-number-single .prev,
.post-number-single .next {
	border: 1px solid #3157A0;
	width: 30px;
	height: 30px;
	position: relative;
}

.post-number-single .prev::before,
.post-number-single .next::before {
	position: absolute;
	content: "";
	width: 5px;
	height: 5px;
	border-bottom: 1px solid #3157A0;
	margin: 0 auto;
	top: 12px;
}

.post-number-single .prev:hover,
.post-number-single .next:hover {
	background: #3157A0;
}

.post-number-single .prev:hover::before,
.post-number-single .next:hover::before {
	border-color: #fff;
}

.post-number-single .prev::before {
	-webkit-transform: rotate(-135deg);
	transform: rotate(-135deg);
	left: 13px;
	border-left: 1px solid #3157A0;
}

.post-number-single .next::before {
	-webkit-transform: rotate(135deg);
	transform: rotate(135deg);
	right: 13px;
	border-right: 1px solid #3157A0;
}


.blog-main .wp-content p {
	margin-bottom: 30px;
}

.blog-main .wp-content img {
	max-width: 100%;
	width: auto;
}

.blog-main .wp-content h2 {
	font-size: 28px;
	margin-bottom: 30px;
}

.blog-main .wp-content h3 {
	font-size: 24px;
	margin-bottom: 30px;
}

.blog-main .wp-content h4 {
	font-size: 20px;
	margin-bottom: 30px;
}

.blog-main .wp-content ul li {
	position: relative;
	padding-left: 20px;
}

.blog-main .wp-content ul li:before {
	background: #333;
	border-radius: 50%;
	content: "";
	display: block;
	position: absolute;
	left: 0;
	top: 12px;
	width: 7px;
	height: 7px;
}

.blog-main .select-area {
	display: flex;
	align-items: center;
	margin: 0 0 50px;
}

.blog-main .select-area .select-item {
	display: flex;
	align-items: center;
	margin: 0 30px 0 0;
}

.blog-main .select-area .select-ttl {
	display: inline-block;
	margin: 0 15px 0 0;
}

.blog-main .select-area .select-category {
	-webkit-appearance: none;
	-moz-appearance: none;
	outline: none;
	text-overflow: "";
	background: #fff url(../images/share/ico_arrow_down.svg) no-repeat;
	background-size: 20px;
	background-position: right center;
	border-radius: 0;
	border: none;
	border: 1px solid rgba(0, 0, 0, 0.5);
	color: #333;
	vertical-align: middle;
	height: 35px;
	min-width: 150px;
	padding: 8px 20px 8px 10px;
}

.blog-main .select-area .select-category::-ms-expand {
	display: none;
}

@media only screen and (max-width: 800px) {

	.blog-main .select-area .select-category {
		padding: 5px 20px 5px 10px;
	}

	.blog-main {
		position: relative;
	}

	.blog-main .blog-list {
		position: relative;
	}

	.blog-main .blog-list .item+.item {
		margin-top: 40px;
		padding-top: 40px;
	}

	.blog-main .blog-list .item .date {
		margin-bottom: 25px;
		display: block;
	}

	.blog-main .blog-list .item .date span {
		margin-left: 12px;
		margin-top: 3px;
	}

	.blog-main .blog-list .item .box {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}

	.blog-main .blog-list .item .box .photo {
		width: 100%;
	}

	.blog-main .blog-list .item .box .photo a {
		display: block;
		width: 100%;
		padding-top: 55%;
	}

	.blog-main .blog-list .item .box .text {
		width: 100%;
		margin-top: 15px;
	}

	.blog-main .blog-list .item .box .text span {
		overflow: hidden;
		text-overflow: ellipsis;
		display: -webkit-box;
		-webkit-line-clamp: 3;
		-webkit-box-orient: vertical;
		height: 90px;
	}

	.blog-main .blog-list .item .box .text .btn-global {
		margin: 25px 0 0 auto;
	}

	.blog-main .blog-list .item .box .text .btn-global:hover {
		opacity: 0.7;
	}

	.blog-main .blog-list .item.is-item .date {
		text-align: right;
	}

	.blog-main .blog-list .item.is-item .box .text {
		width: 100%;
	}

	.blog-main .blog-list .item.is-post .box .text {
		width: 100%;
	}

	.blog-main .wp-content h2 {
		font-size: 24px;
	}

	.blog-main .wp-content h3 {
		font-size: 20px;
	}

	.blog-main .wp-content h4 {
		font-size: 18px;
	}

	.blog-main .date-detail span {
		padding: 0px 10px 0;
	}
}

.policy-list {
	padding-bottom: 50px;
}

.policy-list .item+.item {
	margin-top: 50px;
}

.policy-list .item .page-h3 {
	margin-bottom: 20px;
}

.style-two-coll {
	margin-bottom: 30px;
}

.style-two-coll ul {
	width: 48%;
}

ul.list-li li {
	position: relative;
}

ul.list-li li::before {
	content: "";
	width: 4px;
	height: 7px;
	position: absolute;
	top: 10px;
	left: -15px;
	background: url(../images/share/arrow_s.svg) no-repeat;
	filter: brightness(0) saturate(100%);
}

.style-two-colp {
	max-width: 80%;
	margin: 0 auto 40px;
}

.style-two-colp .col-l,
.style-two-colp .col-r {
	width: 48%;
}

@media only screen and (max-width: 800px) {

	.style-two-colp .col-l,
	.style-two-colp .col-r,
	.style-two-colp ul,
	.style-two-coll .col-l,
	.style-two-coll .col-r,
	.style-two-coll ul {
		width: 100%;
	}

	.style-two-colp .col-l,
	.style-two-coll .col-l {
		margin-bottom: 30px;
	}
}

.style-box {
	display: block;
}

.style-box .style-box-txt,
.style-box .pic-left {
	width: 100%;
}

@media screen and (min-width: 801px) {
	.style-box {
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		justify-content: space-between;
		flex-direction: row-reverse;
	}

	.style-box .pic-left {
		width: 35%;
	}

	.style-box .style10 {
		width: 60%;
	}

	.style-box .pic_img {
		width: 35%;
	}

	.style-box .style-box-txt {
		width: 60%;
	}

	.style-box.pic-left {
		flex-direction: row;
	}

	.style-box.pic-left .pic_img {
		width: 35%;
	}

	.style-box.pic-left .style-box-txt {
		width: 60%;
	}
}

.style-box-in {
	background-color: #F4F5F7;
}

.style-box-in dl {
	padding: 20px;
}

.style-box-in dl dt {
	font-weight: bold;
	margin-bottom: 10px;
}





@media screen and (min-width: 801px) {
	.image-one {
		margin: 0 auto;
		width: 50%;
	}

	footer:after {
		background: none !important;
		height: 0 !important;
	}


}

/*END Style layout*/


/* iPhone X */
@media only screen and (min-device-width: 375px) and (min-device-height: 812px) and (-webkit-device-pixel-ratio: 3) and (orientation: portrait) {
	footer:after {
		background: #3157A0;
		content: '';
		position: fixed;
		bottom: 0;
		left: 0;
		right: 0;
		height: 36px;
		z-index: 99;
	}

	#ft_fixed {
		bottom: calc(env(safe-area-inset-bottom) - 0px);
	}

	#pagetop {
		bottom: calc(env(safe-area-inset-bottom) + 130px);
	}


	.footer-fixed ul li a {
		padding: 3px 0 10px !important;
	}

	.footer-fixed ul li a img {
		top: 15px;
	}

	.footer-fixed ul li.ham-btn {
		padding-top: 25px;
	}

	.footer-fixed ul li.ham-btn {
		padding-top: 25px;
	}


}

/* iPhone XR */
@media only screen and (min-device-width: 414px) and (min-device-height: 896px) and (-webkit-device-pixel-ratio: 2) and (orientation: portrait) {
	footer:after {
		background: #3157A0;
		content: '';
		position: fixed;
		bottom: 0;
		left: 0;
		right: 0;
		height: 36px;
		z-index: 99;
	}

	#ft_fixed {
		bottom: calc(env(safe-area-inset-bottom) - 0px);
	}

	#pagetop {
		bottom: calc(env(safe-area-inset-bottom) + 130px);
	}

	.footer-fixed ul li a {
		padding: 3px 0 10px !important;
	}

	.footer-fixed ul li a img {
		top: 15px;
	}

	.footer-fixed ul li.ham-btn {
		padding-top: 25px;
	}

	.footer-fixed ul li.ham-btn {
		padding-top: 25px;
	}


}


.wp-content h2 {
	font-size: 24px !important;
	font-weight: 400;
	text-align: center;
	letter-spacing: 0.05em;
	position: relative;
	margin-bottom: 60px;
	font-family: 'FOT-セザンヌ ProN DB';
}

.wp-content h2::before {
	border: 3px solid #80B0E8;
	width: 50px;
	position: absolute;
	bottom: -10px;
	left: 50%;
	margin-left: -25px;
	content: "";
}

.wp-content h3 {
	font-size: 20px !important;
	font-weight: 400;
	letter-spacing: 0.05em;
	position: relative;
	margin-bottom: 35px !important;
	border-bottom: 1px solid #80B0E8;
	padding-bottom: 4px;
	color: #3157A0;
}

.wp-content h4 {
	font-size: 18px !important;
	font-weight: 400;
	font-style: normal;
	letter-spacing: 0.05em;
	position: relative;
	margin-bottom: 25px !important;
	padding-left: 12px;
	border-left: 3px solid #80B0E8;
	line-height: 1;
	padding-top: 0;
}

@media screen and (min-width: 801px) {
	.wp-content h2 {
		font-size: 34px !important;
	}


	.wp-content h3 {
		font-size: 30px !important;
		margin-bottom: 35px !important;
	}

	.wp-content h4 {
		font-size: 24px !important;
		padding-top: 10px;
	}

}

.blog-main ul,
.blog-main ol,
.blog-main p,
.postdata p,
.postdata ul,
.postdata ol {
	margin-bottom: 15px;
}

.blog-main a,
.postdata a {
	text-decoration: underline;
	color: #2271b1;
}

.blog-main a:hover,
.postdata a:hover {
	text-decoration: none;
}

.blog-main strong,
.postdata strong {
	font-weight: bold;
}

.blog-main em,
.postdata em {
	font-style: italic;
}

.blog-main ul li,
.postdata ul li {
	list-style: inside disc;
}

.blog-main ul li {
	list-style-type: none;
}

.blog-main ul li>ul,
.postdata ul li>ul {
	margin: 0 0 0 15px;
}

.blog-main ol li,
.postdata ol li {
	list-style: inside decimal;
}

.blog-main ol li>ol,
.postdata ol li>ol {
	margin: 0 0 0 15px;
}


.pc-only {
	display: block;
}

.sp-only {
	display: none;
}

@media (max-width: 800px) {
	.pc-only {
		display: none;
	}

	.sp-only {
		display: block;
	}
}



.table-style01 th,
.table-style01 td {
	border: 1px solid #c9c9c9;
	padding: 15px;
	vertical-align: middle;
}

.table-style01 th {
	background-color: #80B0E8;
	color: #fff;
}

.table-style01 .bg01 {
	background-color: #f5f5f5;
	color: initial;
}

.table-scroll-txt {
	display: none;
}

@media (max-width: 800px) {
	.table-scroll-txt {
		display: flex;
		align-items: center;
		margin-bottom: 10px;
	}

	.table-scroll-txt::before {
		content: "";
		display: block;
		background: url(../images/share/icon_scroll.svg) no-repeat center/contain;
		width: 30px;
		height: 24.5px;
		margin-right: 10px;
	}

	.table-scroll {
		overflow-x: scroll;
		overflow-scrolling: touch;
		-webkit-overflow-scrolling: touch;
	}

	.table-scroll::-webkit-scrollbar {
		height: 5px;
	}

	.table-scroll::-webkit-scrollbar-track {
		border-radius: 5px;
		background: #f5f6f8;
	}

	.table-scroll::-webkit-scrollbar-thumb {
		border-radius: 5px;
		background: #333;
	}

	.table-scroll table {
		margin-bottom: 10px !important;
		width: 150%;
	}
}

.v1 {
	width:100%;
	height:213px;
}
.u-slide img {
	width: auto!important;
}