

:root {
	--main-bg-color: #FFFFFF;
	--point-bg-color: #E6F6FD;
	--point-color: #00A0E9;
	--point-color-hover: #5FB7E1;
	--point-color-light01: #E6F6FD;
	--point-color-middle01: #5FB7E1;
	--point-color-middle02: #A3DEF8;
	--point-color-dark01: #1A98D4;
}

body,div,p,a,img,h,h1,h2,h3,h4,h5,h6,hr,header,footer,section,article {
	margin: 0px;
	padding: 0px;
	border: 0px;
}

body {
	margin: 0px;
	padding: 0px;
	/*font-family: 'Noto Sans JP', sans-serif;*/
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 12px;
	font-weight: 400;
	background-color: var( --main-bg-color );
}

img {
	margin: 0px;
	padding: 0px;
	border: 0px;
}

.cb {
	clear: both;
}

.cb hr {
	display: none;
}

.anc01 {
	display: block;
	width: 0px;
	height: 0px;
	line-height: 0px;
}

#bodybox {
	position: relative;
	width: 100%;
	height: 100%;
	margin: 0px 0px 0px 0px;
	min-width: 1360px;
	overflow-x: hidden;
}

#headerbase {
	position: relative;
	width: 100%;
	height: 500px;
	margin: 0px 0px 0px 0px;
}

header {
	position: relative;
	width: 1360px;
	height: calc( 100% - 2px );
	margin: 0px auto 0px auto;
	padding-top: 1px;
	padding-bottom: 1px;
}

.midbase, #footerbase {
	position: relative;
	width: 100%;
	margin: 0px 0px 0px 0px;
}

.midbox, footer {
	position: relative;
	width: 1360px;
	margin: 0px auto 0px auto;
	padding-top: 1px;
	padding-bottom: 1px;
}

#footerbase {
	height: auto;
	background-color: var( --main-bg-color );
}

footer {
	height: auto;
	padding-bottom: 135px;
}

.rtt01 {
	display: block;
	position: relative;
	width: 68px;
	height: 1em;
	margin: 60px 0px 82px auto;
	padding-top: 38px;
	font-family: 'Poppins', sans-serif;
	font-size: 12px;
	font-weight: 400;
	line-height: 1em;
	text-align: center;
	vertical-align: top;
	color: #FFFFFF;
	letter-spacing: 0.1em;
	cursor: pointer;
	transition-duration: 150ms;
	will-change: transform;
}

.rtt01:hover {
	/*color: rgba( 240, 180, 0, 0.7 );*/
	/*opacity: 0.7;*/
	-webkit-filter: drop-shadow( 0px 0px 4px rgba( 255, 255, 255, 0.8 ) );
	drop-shadow( 0px 0px 4px rgba( 255, 255, 255, 0.8 ) );
}

.rtt01::before {
	content: '';
	display: block;
	position: absolute;
	left: -3px;
	right: 0px;
	top: 0px;
	margin: auto;
	width: 0px;
	height: 29px;
	border-right: solid 1px #FFFFFF;
}

.rtt01::after {
	content: '';
	display: block;
	position: absolute;
	left: -3px;
	right: -1px;
	top: 1px;
	margin: auto;
	width: 0px;
	height: 12px;
	border-left: solid 1px #FFFFFF;
	-webkit-transform-origin: center top;
	transform-origin: center top;
	-webkit-transform: rotate( -52deg );
	transform: rotate( -52deg );
}

footer .rtt01 {
	position: absolute;
	left: -2048px;
	right: -2048px;
	bottom: 127px;
	margin: auto;
}

#obione {
	display: block;
	position: relative;
	width: 100%;
	height: 111px;
	margin: -1px auto 0px auto;
	padding-top: 1px;
	padding-bottom: 1px;
	z-index: 1;
}

/*
#obione::before {
	content: '';
	display: block;
	position: absolute;
	left: -2048px;
	right: -2048px;
	top: 0px;
	margin: auto;
	width: 4096px;
	height: 100%;
	background-color: var( --main-bg-color );
}
*/

#headlogo01 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-ms-flex-line-pack: start;
	align-content: flex-start;
	position: absolute;
	/*left: calc( 50% - 960px + 45px );*/
	left: calc( 50% - 50vw + 45px );
	top: 30px;
	margin: 0px 0px 0px 0px;
	width: 242px;
	height: 41px;
	text-decoration: none;
	will-change: transform;
}

#headlogo01:hover {
	/*opacity: 0.7;*/
	-webkit-filter: drop-shadow( 0px 0px 2px rgba( 255, 255, 255, 0.8 ) );
	filter: drop-shadow( 0px 0px 2px rgba( 255, 255, 255, 0.8 ) );
	transition-duration: 150ms;
}

/*
@media ( max-width: 1920px ) {
	#headlogo01 {
		left: calc( 50% - 50vw + 45px );
	}
}
*/

@media ( max-width: 1360px ) {
	#headlogo01 {
		left: 45px;
	}
}

#headlogo01 .logo01 {
	display: block;
	position: relative;
	width: 57px;
	margin: 0px 0px 0px 0px;
}

#headlogo01 .logo01 img, #headlogo01 .logo01 svg {
	display: block;
	position: relative;
	width: 100%;
	border: 0px;
}

#headlogo01 .cnb01 {
	display: block;
	position: relative;
	width: calc( 100% - 57px - 9px );
	margin: 11px 0px 0px 9px;
}

#headlogo01 .cnj01 {
	display: block;
	position: relative;
	width: 170px;
	margin: 0px 0px 0px 0px;
	vertical-align: top;
}

#headlogo01 .cnj01 img, #headlogo01 .cnj01 svg {
	display: block;
	position: relative;
	width: 100%;
	border: 0px;
}

#headlogo01 .cne01 {
	display: block;
	position: relative;
	width: 172px;
	margin: 4px 0px 0px 0px;
	vertical-align: top;
}

#headlogo01 .cne01 img, #headlogo01 .cne01 svg {
	display: block;
	position: relative;
	width: 100%;
	border: 0px;
}

#menubox {
	display: block;
	position: absolute;
	left: -2048px;
	right: -2048px;
	bottom: 13px;
	margin: auto;
	width: 54vw;
	max-width: 1200px;
	min-width: 730px;
	height: auto;
	padding: 0px;
	/*background-color: #FFCCCC;*/
}

#menucont {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-ms-flex-line-pack: start;
	align-content: flex-start;
	position: relative;
	margin: 0px auto 0px auto;
	padding: 0px;
	list-style: none;
}

#menucont li {
	display: block;
	position: relative;
	padding: 0px;
	height: auto;
	text-align: center;
}

#menucont li a {
	display: inline-block;
	position: relative;
	height: auto;
	margin: 0px 0px 0px 0px;
	padding: 10px 5px 14px 5px;
	text-decoration: none;
	text-align: center;
	vertical-align: top;
	color: #000000;
	/*background-color: #FFCCFF;*/
	transition-duration: 150ms;
}

#menucont li a:hover {
	opacity: 0.7;
}

#menucont li a .mtj {
	display: block;
	position: relative;
	height: 1em;
	margin: 0px auto 0px auto;
	font-size: 13px;
	font-weight: 400;
	line-height: 1em;
	vertical-align: top;
	letter-spacing: 0.075em;
}

#hnavibox01 {
	display: block;
	position: absolute;
	/*right: calc( 50% - 960px );*/
	right: calc( 50% - 50vw );
	top: 0px;
	width: 288px;
	height: 113px;
	margin: 0px 0px 0px 0px;
	padding: 0px;
	background-color: var( --point-color-middle01 );
	overflow: hidden;
	will-change: transform;
}

/*
@media ( max-width: 1920px ) {
	#hnavibox01 {
		right: calc( 50% - 50vw );
	}
}
*/

@media ( max-width: 1360px ) {
	#hnavibox01 {
		right: 0px;
	}
}

#hnavicont01 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: end;
	-ms-flex-pack: end;
	justify-content: flex-end;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-ms-flex-line-pack: start;
	align-content: flex-start;
	position: relative;
	width: 100%;
	height: 100%;
	margin: 0px 0px 0px 0px;
	padding: 0px;
	list-style: none;
	will-change: transform;
}

#hnavicont01 li {
	display: block;
	position: relative;
	margin: 0px;
	padding: 0px;
	height: 100%;
	vertical-align: top;
}

#hnavicont01 li a {
	display: block;
	position: relative;
	width: 144px;
	margin: 0px 0px 0px 0px;
	padding-top: 1px;
	padding-bottom: 1px;
	height: calc( 100% - 2px );
	font-family: 'Barlow', serif;
	text-decoration: none;
	text-align: center;
	vertical-align: top;
	color: #FFFFFF;
	transition-duration: 150ms;
	will-change: transform;
}

#hnavicont01 li a:hover {
	-webkit-filter: brightness( 110% );
	filter: brightness( 110% );
}

#hnavicont01 .nvib {
	display: block;
	position: relative;
	width: 36px;
	height: 36px;
	margin: 28px auto 0px auto;
}

#hnavicont01 .nvicon {
	display: block;
	position: absolute;
	left: -2048px;
	right: -2048px;
	top: -2048px;
	bottom: -2048px;
	margin: auto;
	border: 0px;
}

#hnavicont01 .hnvi_phone {
	background-color: #2AAAE2;
}

#hnavicont01 .hnvi_phone .nvicon {
	width: 20px;
}

/*
#hnavicont01 .hnvi_sns_i {
	background-color: #05539A;
}

#hnavicont01 .hnvi_sns_i .nvicon {
	width: 26px;
}
*/

#hnavicont01 .hnvi_mail {
	background-color: #05539A;
}

#hnavicont01 .hnvi_mail .nvicon {
	width: 35px;
}

#hnavicont01 .nvit {
	display: block;
	position: relative;
	height: 1em;
	margin: 5px auto 0px auto;
	font-size: 10px;
	font-weight: 600;
	line-height: 1em;
	letter-spacing: 0.075em;
	vertical-align: top;
}

#midfootbase {
	/*background-color: var( --point-bg-color );*/
}

#midfootbox {
	margin-top: -1px;
}

#mfcore01 {
	display: block;
	position: relative;
	height: 570px;
	margin: -1px auto 0px auto;
	padding-top: 1px;
	padding-bottom: 1px;
}

#mfcore02 {
	display: block;
	position: relative;
	height: 126px;
	margin: 0px auto 0px auto;
	padding-top: 1px;
	padding-bottom: 1px;
}

#mfcore03 {
	display: block;
	position: relative;
	height: 285px;
	margin: -1px auto 0px auto;
	padding-top: 1px;
	padding-bottom: 1px;
}

#mfcore03::before {
	content: '';
	display: block;
	position: absolute;
	left: -2048px;
	right: -2048px;
	top: 0px;
	margin: auto;
	width: 100vw;
	height: 100%;
	min-width: 1920px;
	background-color: #002D42;
}

#mflinkbox01 {
	display: block;
	position: relative;
	width: 1258px;
	height: 306px;
	margin: 143px auto 0px auto;
}

#mflinkcont01 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-ms-flex-line-pack: start;
	align-content: flex-start;
	position: relative;
	width: 100%;
	height: 100%;
	margin: 143px auto 0px auto;
}

.mflitem {
	display: block;
	position: relative;
	width: 616px;
	height: 306px;
	margin: 0px 13px 0px 13px;
	text-decoration: none;
	color: #231815;
	background-color: #F1F4FA;
	border-radius: 18px;
	transition-duration: 150ms;
	will-change: transform;
}

.mflitem:nth-of-type(odd) {
	margin-left: 0px;
}

.mflitem:nth-of-type(even) {
	margin-right: 0px;
}

.mflitem:hover {
	/*
	-webkit-filter: brightness( 102% );
	filter: brightness( 102% );
	*/
	background-color: #F4F7FC;
}

.mflitem .core {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-ms-flex-line-pack: start;
	align-content: flex-start;
	position: relative;
	padding: 80px 90px 60px 90px;
}

.mflitem .core .c01 {
	display: block;
	position: relative;
	width: 250px;
	vertical-align: top;
	transition-duration: 150ms;
}

.mflitem:hover .core .c01 {
	opacity: 0.8;
}

.mflitem .core .c02 {
	display: block;
	position: relative;
	width: calc( 100% - 250px );
	height: 166px;
	margin-top: -14px;
	vertical-align: top;
}

.mflitem .itj {
	display: block;
	position: relative;
	margin: 0px 0px 0px 0px;
	font-size: 23px;
	font-weight: 500;
	line-height: 30px;
	text-align: left;
	vertical-align: top;
}

.mflitem .ite {
	display: block;
	position: relative;
	margin: 18px 0px 0px 0px;
	font-family: 'Poppins', sans-serif;
	font-size: 11px;
	font-weight: 600;
	line-height: 1em;
	text-align: left;
	vertical-align: top;
	color: #9FA0A0;
	letter-spacing: 0.2em;
}

.mflitem .vm {
	display: block;
	position: relative;
	width: 122px;
	margin: 62px 0px 0px 0px;
	font-size: 12px;
	font-weight: 400;
	line-height: 1em;
	text-align: left;
	vertical-align: top;
	color: #231815;
	letter-spacing: 0.2em;
}

.mflitem .vm::before, .mflitem .vm::after {
	content: '';
	display: block;
	position: absolute;
	right: 0px;
	width: 0px;
	height: 6px;
	border-right: solid 1px #231815;
}

.mflitem .vm::before {
	bottom: 50%;
	-webkit-transform-origin: right bottom;
	transform-origin: right bottom;
	-webkit-transform: rotate( -33deg );
	transform: rotate( -33deg );
}

.mflitem .vm::after {
	top: 50%;
	-webkit-transform-origin: right top;
	transform-origin: right top;
	-webkit-transform: rotate( 33deg );
	transform: rotate( 33deg );
}

#mfli01 .illust {
	width: 187px;
}

#mfli02 .illust {
	width: 134px;
	box-shadow: 0px 0px 9px rgba( 0, 0, 0, 0.12 );
}

.mflitem:hover .core .illust {
	transform: scale( 1.1 );
}

.mflitem .core .c02 .illust {
	display: block;
	position: absolute;
	left: -2048px;
	right: -2048px;
	top: -2048px;
	bottom: -2048px;
	margin: auto;
	border: 0px;
	transition-duration: 300ms;
}

#mfnavibox01 {
	display: block;
	position: absolute;
	left: -2048px;
	right: -2048px;
	bottom: 0px;
	width: 1920px;
	height: 128px;
	margin: auto;
}

#mfnavicont01 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-ms-flex-line-pack: start;
	align-content: flex-start;
	position: absolute;
	left: -2048px;
	right: -2048px;
	bottom: 0px;
	margin: auto;
	list-style: none;
	width: 1920px;
	height: 128px;
	padding: 0px;
}

#mfnavicont01 li {
	display: block;
	position: relative;
	height: 100%;
	margin: 0px 0px 0px 0px;
	padding: 0px;
	vertical-align: top;
}

#mfnavicont01 li a {
	display: block;
	position: relative;
	width: 640px;
	height: calc( 100% - 2px );
	margin: 0px 0px 0px 0px;
	padding-top: 1px;
	padding-bottom: 1px;
	text-decoration: none;
	color: #FFFFFF;
	transition-duration: 150ms;
	will-change: transform;
}


#mfnavicont01 .nvib {
	display: block;
	position: relative;
	width: 40px;
	height: 40px;
	margin: 35px auto 0px auto;
}

#mfnavicont01 .nvicon {
	display: block;
	position: absolute;
	left: -2048px;
	right: -2048px;
	top: -2048px;
	bottom: -2048px;
	margin: auto;
	border: 0px;
	transition-duration: 150ms;
	will-change: transform;
}

#mfnavicont01 li a:hover .nvicon {
	-webkit-filter: drop-shadow( 0px 0px 4px rgba( 255, 255, 255, 0.8 ) );
	filter: drop-shadow( 0px 0px 4px rgba( 255, 255, 255, 0.8 ) );
}

#mfnavicont01 .mfnvi_phone {
	background-color: #2AAAE2;
}

#mfnavicont01 .mfnvi_phone::before {
	content: '';
	display: block;
	position: absolute;
	right: 0px;
	top: 0px;
	width: 50vw;
	height: 100%;
	min-width: 960px;
	background-color: inherit;
}

#mfnavicont01 .mfnvi_phone .nvicon {
	width: 22px;
}

#mfnavicont01 .mfnvi_mail {
	background-color: #167CCD;
}

#mfnavicont01 .mfnvi_mail::before {
	content: '';
	display: block;
	position: absolute;
	left: 0px;
	top: 0px;
	width: 50vw;
	height: 100%;
	min-width: 960px;
	background-color: inherit;
}

#mfnavicont01 .mfnvi_mail .nvicon {
	width: 35px;
}

#mfnavicont01 .mfnvi_sns_i {
	background-color: #05539A;
}

#mfnavicont01 .mfnvi_sns_i .nvicon {
	width: 29px;
}

#mfnavicont01 .nvit {
	display: block;
	position: relative;
	height: 1em;
	margin: 3px auto 0px auto;
	font-size: 11px;
	font-weight: 700;
	text-align: center;
	vertical-align: top;
	letter-spacing: 0.075em;
	transition-duration: 150ms;
	will-change: transform;
}

#mfnavicont01 .mfnvi_phone .nvit, #mfnavicont01 .mfnvi_sns_i .nvit {
	font-family: 'Barlow', sans-serif;
}

#mfnavicont01 .mfnvi_phone .nvit {
	margin-top: 5px;
}

#mfnavicont01 .mfnvi_mail .nvit {
	font-size: 10px;
	letter-spacing: 0.005em;
}

#mfnavicont01 li a:hover .nvit {
	text-shadow: 0px 0px 4px rgba( 255, 255, 255, 0.8 );
}

#mfbannerbox01 {
	display: block;
	position: relative;
	width: 1254px;
	margin: 60px auto 57px auto;
}

#mfbannercont01 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-ms-flex-line-pack: start;
	align-content: flex-start;
	position: relative;
	width: 100%;
	margin: 0px auto 0px auto;
	padding: 0px;
	list-style: none;
}

#mfbannercont01 li {
	display: block;
	position: relative;
	width: 357px;
	margin: 0px 24px 0px 24px;
	padding: 0px;
	vertical-align: top;
	background-color: #FFFFFF;
}

#mfbannercont01 li:nth-of-type(odd) {
	margin-left: 0px;
}

#mfbannercont01 li:nth-of-type(even) {
	margin-right: 0px;
}

.mfbanner {
	display: block;
	position: relative;
	width: 100%;
	margin: 0px 0px 0px 0px;
	padding: 0px;
	vertical-align: top;
	transition-duration: 150ms;
	will-change: transform;
}

.mfbanner:hover {
	-webkit-filter: brightness( 120% ) saturate( 140% ) contrast( 80% );
	filter: brightness( 120% ) saturate( 140% ) contrast( 80% );
	/*opacity: 0.8;*/
}

.mfbanner img, .mfbanner svg {
	display: block;
	position: relative;
	width: 100%;
	border: 0px;
}

.imenubox {
	display: block;
	position: absolute;
	left: -2048px;
	right: -2048px;
	top: 0px;
	margin: auto;
	width: 100vw;
	/*max-width: 1920px;*/
	max-width: 2048px;
	min-width: 1360px;
	height: 100%;
	padding: 0px;
}

.imenucont {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-ms-flex-line-pack: start;
	align-content: flex-start;
	position: relative;
	list-style: none;
	width: 100%;
	height: 100%;
	margin: 0px auto 0px auto;
	padding: 0px;
}

.imenucont li {
	display: block;
	position: relative;
	width: 14.285%;
	/* flex: 1 0 14.285%; */
	flex-grow: 1;
	/*max-width: 240px;*/
	margin: 0px 0px 0px 0px;
	padding: 0px;
	height: 100%;
}

.imenucont li a {
	display: block;
	position: relative;
	/*width: 240px;*/
	width: 100%;
	height: calc( 100% - 2px );
	padding: 1px 0px 1px 0px;
	text-decoration: none;
	text-align: center;
	vertical-align: top;
	color: #FFFFFF;
	transition-duration: 150ms;
}

.imenucont li a .ib {
	display: block;
	position: absolute;
	left: 0px;
	right: 0px;
	top: -12%;
	bottom: 0px;
	margin: auto;
	/*
	width: 120px;
	height: 100px;
	*/
	width: 50%;
	aspect-ratio: 1.2 / 1;
	/* height: 41.6%; */
	/*margin: 42px auto 0px auto;*/
}

.imenucont li a .ib img, .imenucont li a .ib svg {
	display: block;
	position: absolute;
	left: -2048px;
	right: -2048px;
	top: -2048px;
	bottom: -2048px;
	margin: auto;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform-origin: center bottom;
	transition-duration: 200ms;
}

.imenucont li a:hover .ib img, .imenucont li a:hover .ib svg {
	-webkit-transform: scale( 1.73 );
	transform: scale( 1.73 );
}

.imenucont li a .it {
	display: block;
	position: absolute;
	left: 0px;
	right: 0px;
	bottom: 23%;
	margin: auto;
	font-size: 12px;
	font-weight: 500;
	line-height: 1em;
	text-align: center;
	vertical-align: top;
	letter-spacing: 0.075em;
}

.imi01 { background-color: #00A9C7; }
.imi02 { background-color: #08803C; }
.imi03 { background-color: #0078DC; }
.imi04 { background-color: #EA5505; }
.imi05 { background-color: #E64B82; }
.imi06 { background-color: #E8AD00; }
.imi07 { background-color: #DF3C3C; }
.imi08 { background-color: #994A94; }

#hbmenuplate {
	display: block;
	position: fixed;
	top: -150vh;
	left: 0px;
	width: 480px;
	height: calc( 130vh - 2px );
	padding-top: 1px;
	padding-bottom: 1px;
	background-color: #FFFFFF;
	-webkit-font-feature-settings: 'palt';
	font-feature-settings: 'palt';
	z-index: 2;
	transition-duration: 300ms;
}

#hbmbtn {
	display: none;
}

#hbmpheadbox {
	display: block;
	position: relative;
	width: 100%;
	height: 93px;
	margin: -1px 0px 0px 0px;
	/*background-color: rgba( 200, 200, 255, 0.3 );*/
}

#hbmlogo01 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-ms-flex-line-pack: start;
	align-content: flex-start;
	position: absolute;
	left: 26px;
	top: 21px;
	width: 222px;
	height: 53px;
	text-decoration: none;
	color: #000000;
	/*transition-duration: 150ms;*/
}

#hbmlogo01:hover {
	/*opacity: 0.7;*/
}

#hbmlogo01 .logo01 {
	display: block;
	position: relative;
	width: 53px;
}

#hbmlogo01 .logo01 img, #hbmlogo01 .logo01 svg {
	display: block;
	position: relative;
	width: 100%;
	border: 0px;
}

#hbmlogo01 .cnb01 {
	display: block;
	position: relative;
	width: calc( 100% - 53px - 9px );
	margin: 10px 0px 0px 9px;
}

#hbmlogo01 .cnj01 {
	display: block;
	position: relative;
	width: 157px;
	margin: 0px 0px 0px 0px;
	vertical-align: top;
}

#hbmlogo01 .cnj01 img, #hbmlogo01 .cnj01 svg {
	display: block;
	position: relative;
	width: 100%;
	border: 0px;
}

#hbmlogo01 .cne01 {
	display: block;
	position: relative;
	width: 160px;
	margin: 4px 0px 0px 0px;
	vertical-align: top;
}

#hbmlogo01 .cne01 img, #hbmlogo01 .cne01 svg {
	display: block;
	position: relative;
	width: 100%;
	border: 0px;
}

#hbmpcont {
	display: block;
	position: relative;
	margin: 0px 0px 0px 0px;
	padding-top: 1px;
	padding-bottom: 1px;
}

#hbmenubox {
	display: block;
	position: relative;
	margin: 0px 0px 0px 0px;
	padding: 0px;
	/*background-color: rgba( 255, 200, 200, 0.3 );*/
}

#hbmpfootbox {
	display: block;
	position: relative;
	width: 100%;
	margin: 0px auto 0px auto;
}

#hbmpnavibox01 {
	display: block;
	position: relative;
	width: 100%;
	height: auto;
}

#hbmpnavicont01 {
	display: block;
	position: relative;
	list-style: none;
	width: 100%;
	margin: 0px auto 0px auto;
	padding: 0px;
}

#hbmpnavicont01 li {
	display: block;
	position: relative;
	width: 100%;
	height: auto;
	margin: 0px 0px 0px 0px;
	padding: 0px;
	vertical-align: top;
}

#hbmpnavicont01 li a {
	display: block;
	position: relative;
	width: 100%;
	height: 161px;
	margin: 0px auto 0px auto;
	padding-top: 1px;
	padding-bottom: 1px;
	text-decoration: none;
	color: #FFFFFF;
	transition-duration: 150ms;
}

#hbmpnavicont01 li a:hover {
	-webkit-filter: brightness( 110% );
	filter: brightness( 110% );
}

#hbmpnavicont01 .nvib {
	display: block;
	position: relative;
	width: 52px;
	height: 52px;
	margin: 45px auto 0px auto;
}

#hbmpnavicont01 .nvicon {
	display: block;
	position: absolute;
	left: -2048px;
	right: -2048px;
	top: -2048px;
	bottom: -2048px;
	margin: auto;
	border: 0px;
}

#hbmpnavicont01 .mfnvi_phone {
	background-color: #2AAAE2;
}

#hbmpnavicont01 .mfnvi_phone .nvicon {
	width: 28px;
}

#hbmpnavicont01 .mfnvi_mail {
	background-color: #167CCD;
}

#hbmpnavicont01 .mfnvi_mail .nvicon {
	width: 45px;
}

#hbmpnavicont01 .mfnvi_sns_i {
	background-color: #05539A;
}

#hbmpnavicont01 .mfnvi_sns_i .nvicon {
	width: 37px;
}

#hbmpnavicont01 .nvit {
	display: block;
	position: relative;
	height: 1em;
	margin: 4px auto 0px auto;
	font-size: 14px;
	font-weight: 700;
	text-align: center;
	vertical-align: top;
	letter-spacing: 0.075em;
}

#hbmpnavicont01 .mfnvi_phone .nvit, #hbmpnavicont01 .mfnvi_sns_i .nvit {
	font-family: 'Barlow', sans-serif;
}

#hbmpnavicont01 .mfnvi_phone .nvit {
	margin-top: 6px;
}

#hbmpnavicont01 .mfnvi_mail .nvit {
	font-size: 13px;
	letter-spacing: 0.005em;
}

.stcont {
	display: block;
	position: relative;
	width: 1250px; /* 1360px; */
	margin: 93px auto 90px auto;
	-webkit-font-feature-settings: 'palt';
	font-feature-settings: 'palt';
}

.stbox01 {
	display: block;
	position: relative;
	margin: 0px auto 0px auto;
}

.stbox01 .ste {
	display: block;
	position: relative;
	margin: 0px auto 0px 0px;
	font-family: 'Poppins', sans-serif;
	font-size: 32px;
	font-weight: 600;
	line-height: 1em;
	text-align: left;
	vertical-align: top;
	color: #2AAAE2;
	letter-spacing: 0.075em;
}

.stbox01 .stj {
	display: block;
	position: relative;
	margin: 7px auto 0px 0px;
	font-size: 12px;
	font-weight: 400;
	line-height: 1em;
	text-align: left;
	vertical-align: top;
	letter-spacing: 0.075em;
}

.stbox02 {
	display: block;
	position: relative;
	margin: 0px auto 0px auto;
}

.stbox02 .ste {
	display: block;
	position: relative;
	margin: 0px auto 0px 0px;
	font-family: 'Poppins', sans-serif;
	font-size: 13px;
	font-weight: 600;
	line-height: 1em;
	text-align: left;
	vertical-align: top;
	color: #2AAAE2;
	letter-spacing: 0.05em;
}

.stbox02 .stj {
	display: block;
	position: relative;
	margin: 26px auto 0px 0px;
	font-size: 28px;
	font-weight: 500;
	line-height: 1em;
	text-align: left;
	vertical-align: top;
	letter-spacing: 0.075em;
}

#footercore {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-ms-flex-line-pack: start;
	align-content: flex-start;
	position: relative;
	/*width: 100%;*/
	width: 1250px;
	min-height: 102px;
	/*margin: 80px auto 0px auto;*/
	margin: 66px auto 0px auto;
	text-align: center;
	color: #000000;
	/*background-color: #FFCCCC;*/
}

#footercore a {
	text-decoration: none;
	color: #000000;
}

#fmenubox {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-ms-flex-line-pack: start;
	align-content: flex-start;
	position: relative;
	width: 100%;
	margin: 0px auto 0px auto;
	padding-bottom: 53px;
	font-size: 12px;
	font-weight: 400;
	line-height: 23px;
	color: #000000;
	letter-spacing: 0.05em;
	border-bottom: solid 1px #47382E;
}

#fmenubox a {
	text-decoration: none;
	color: #000000;
	transition-duration: 150ms;
}

#fmenubox a:hover {
	opacity: 0.7;
}

#fmenucont {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-ms-flex-line-pack: start;
	align-content: flex-start;
	position: relative;
	width: 100%;
	height: 164px;
	list-style: none;
	margin: 0px 0px 0px 0px;
	padding: 0px;
}

#fmenucont li {
	display: inline-block;
	position: relative;
	margin: 0px 100px 0px 0px;
	padding: 0px;
	vertical-align: top;
}

#fmenucont li a {
	display: block;
	position: relative;
	margin: 0px 0px 0px 0px;
	text-align: left;
	vertical-align: top;
}

#fmenucont li a .mtj {
	display: block;
	position: relative;
	height: 1em;
	margin: 22px 0px 0px 0px;
	font-size: 13px;
	font-weight: 400;
	line-height: 1em;
	vertical-align: top;
	letter-spacing: 0.05em;
}

#footlogo01 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-ms-flex-line-pack: start;
	align-content: flex-start;
	position: relative;
	width: 277px;
	height: 73px;
	margin: 54px 0px 0px 0px;
	padding: 0px;
	text-decoration: none;
	transition-duration: 150ms;
	will-change: transform;
}

#footlogo01:hover {
	opacity: 0.7;
	/*
	-webkit-filter: drop-shadow( 3px 3px 3px rgba( 0, 0, 0, 0.3 ) );
	filter: drop-shadow( 3px 3px 3px rgba( 0, 0, 0, 0.3 ) );
	*/
}

#footlogo01 .logo01 {
	display: block;
	position: relative;
	width: 73px;
	vertical-align: top;
}

#footlogo01 .logo01 img, #footlogo01 .logo01 svg {
	display: block;
	position: relative;
	width: 100%;
	border: 0px;
}

#footlogo01 .cnb01 {
	display: block;
	position: relative;
	width: calc( 100% - 73px - 7px );
	margin: 15px 0px 0px 7px;
}

#footlogo01 .cnj01 {
	display: block;
	position: relative;
	width: 197px;
	margin: 0px 0px 0px 0px;
	vertical-align: top;
}

#footlogo01 .cnj01 img, #footlogo01 .cnj01 svg {
	display: block;
	position: relative;
	width: 100%;
	border: 0px;
}

#footlogo01 .cne01 {
	display: block;
	position: relative;
	width: 198px;
	margin: 5px 0px 0px 0px;
	vertical-align: top;
}

#footlogo01 .cne01 img, #footlogo01 .cne01 svg {
	display: block;
	position: relative;
	width: 100%;
	border: 0px;
}

#footinfo01 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	-ms-flex-line-pack: start;
	align-content: flex-start;
	position: relative;
	/*width: 800px;*/
	max-width: 920px;
	margin: 48px 0px 0px 48px;
	font-size: 12px;
	font-weight: 400;
	line-height: 15px;
	text-align: left;
	vertical-align: top;
	letter-spacing: 0.05em;
}

.fidl {
	display: block;
	position: relative;
	margin: 16px 0px 0px 48px;
	padding: 0px;
}

.fidl dt {
	display: block;
	position: relative;
	margin: 0px 0px 0px 0px;
	padding: 0px;
	vertical-align: top;
}

.fidl dd {
	display: block;
	position: relative;
	margin: 7px 0px 0px 0px;
	padding: 0px;
	vertical-align: top;
}

#footcopy {
	display: block;
	position: absolute;
	left: -2048px;
	right: -2048px;
	bottom: 43px;
	margin: auto;
	width: 410px;
	/*font-family: 'Poppins', sans-serif;*/
	font-size: 13px;
	font-weight: 400;
	line-height: 1em;
	text-align: center;
	vertical-align: top;
	letter-spacing: 0.075em;
}

.pcbr {
	display: block;
}

.mbbr {
	display: none;
}

.pcil {
	display: inline-block;
}

.mbil {
	display: none;
}

#rsvt_pc {
	display: block;
	position: absolute;
	left: 0px;
	top: 0px;
	width: 1px;
	height: 1px;
}

#rsvt_m {
	display: none;
	position: absolute;
	left: 0px;
	top: 0px;
	width: 1px;
	height: 1px;
}

/* #region common =================================== */
.img-box {
	position: relative;
	overflow: hidden;
	box-sizing: border-box;
}
.img-box img, .img-box video {
	position: absolute;
	height: 100%;
	width: 100%;
	margin: auto;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	object-fit: cover;
}


.link-btn01 {
	display: block;
	width: 215px;
	height: 46px;
	padding-right: 36px;
	font-size: 13px;
	font-weight: 500;
	line-height: 46px;
	text-decoration: none;
	text-align: center;
	color: #231815;
	background-color: #FFFFFF;
	border-radius: 23px;
	border: solid 1px #231815;
	letter-spacing: 0.1em;
	box-shadow: 0px 0px 12px rgb( 0, 0, 0, 0.12 );
	transition-duration: 150ms;
	will-change: transform;
}
.link-btn01:hover {
	opacity: 0.7;
}
.link-btn01::before, .link-btn01::after {
	content: '';
	display: block;
	position: absolute;
	right: 30px;
	width: 0px;
	height: 7px;
	border-right: solid 1px #231815;
}
.link-btn01::before {
	bottom: 50%;
	transform-origin: right bottom;
	transform: rotate( -33deg );
}
.link-btn01::after {
	top: 50%;
	transform-origin: right top;
	transform: rotate( 33deg );
}
@media only screen and (max-width: 640px) {
    .link-btn01 {
        width: 278px;
        height: 60px;
        margin: 55px auto 0px auto;
        padding-right: 46px;
        font-size: 17px;
        line-height: 60px;
        border-radius: 30px;
    }
}
/* #endregion common -------------------------------- */

/* #region insta-block =================================== */
.insta-block {
	margin-top: 180px;
	margin-bottom: 110px;
}
.insta-box {
	margin: 55px auto 0px auto;
}
.insta-list {
	display: flex;
	list-style: none;
	gap: 12px;
	width: 1252px;
	margin: 0 auto;
	padding: 0;
}
.insta-item {
	position: relative;
	flex: 1 1 20%;
}
.insta-link {
	display: block;
	width: 100%;
	aspect-ratio: 1 / 1;
	box-shadow: 1px 1px 10px rgba( 0, 0, 0, 0.15 );
}
.insta-link:hover {
	opacity: 0.6;
}
.insta-link .img-box {
	width: 100%;
	aspect-ratio: 1 / 1;
}
.insta-link .img-box img {
	transition: transform 0.3s cubic-bezier(0.4, 0.6, 0.6, 1);
}
.insta-link:hover .img-box img  {
	transform: scale(1.1);
}
.insta-block .link-btn01 {
	position: absolute;
	right: 0;
	top: 10px;
}
@media only screen and (max-width: 640px) {
	.insta-block {
        margin-top: 110px;
        margin-bottom: 80px;
	}
	.insta-list {
		width: 100%;
		padding-bottom: 20px;
		overflow-x: auto;
	}
	.insta-item {
		flex: 0 0 410px;
	}
	.insta-block .link-btn01 {
			position: relative;
			right: auto;
			top: auto;
	}
}
/* #endregion insta-block -------------------------------- */