@charset "UTF-8";
/* CSS Document */
/*=======================================
  共　通
=======================================*/
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');
:root {
	--ULOS-TEXT-DARK:#3C3C3C;
	--ULOS-BLUE: #002C5C;
	--ULOS-BLUE-BG: #BCD3E8;
	--ULOS-LIGHT-BLUE: #00B5E2;
	--ULOS-LIGHT-BLUE-BG: #C3EAF7;
	--ULOS-RED: #e60909;
	--ULOS-RED-BG: #F4D6D6;
	--ULOS-LGRAY-BG: #F8F8F8;
	--ULOS-GREEN01: #008033;
	--ULOS-GREEN02: #036D3B;
	--ULOS-LIGHT-GREEN-TXT: #64db00;
	--ULOS-LIGHT-GREEN: #b6ff56;
	--ULOS-DARK-GREEN: #003F2A;
	--ULOS-EME-GREEN: #00c5aa;

	--karuta-bg: #EBF6FE;
	--karuta-blue: #7FC1F7;
	--karuta-darkblue: #27427C;
	--karuta-green: #008B5E;
	--karuta-darkgreen: #163E2C;
}

html {
	background:#FFF;
	color:#000;
	font-size: 625%;/*rem用100px*/
	/*scrollbar hidden*/
	/*-ms-overflow-style: none;*//* IE, Edge 対応 */
	/*scrollbar-width: none;*//* Firefox 対応 */
}
/*scrollbar hidden*/
html::-webkit-scrollbar {/* Chrome, Safari 対応 */
	/*display:none;*/
}

html.lock{
	overflow: hidden;
	-ms-touch-action: none;
	touch-action: none;
}

body{
	/*font-size:12px;*/
	font-size: 0.12em;/*rem用12px 以下rem chrome対策でem 以下fontsizeはremで1/100指定*/
	font-family: 'Noto Sans JP', sans-serif;/*Regular 400 Bold 700*/
	font-weight: 600;
	font-feature-settings: "palt";/*Google Notoは効く、Adobe notoは効かない、メイリオは効かない*/
	line-height:1.0;
	letter-spacing:0px;
	-webkit-text-size-adjust: 100%;/*スマホ文字拡大対策*/
	background:var(--karuta-bg);
}
.fgo_b{	font-family: 'Noto Sans JP', sans-serif !important; font-weight: 700!important;}

::selection {
  color: white;
  background-color:var(--ULOS-GREEN01);
}

/* --A-- */
a {
	cursor:pointer;
	text-decoration:none;
	-webkit-tap-highlight-color:rgba(0,0,0,0);/*リンクタップ時のハイライト表示無効*/
}
a.noLink{cursor: default;}

a:hover {
	text-decoration:none;
}
/* --HEADLINE-- */
h1, h2, h3, h4, h5, h6 {
	font-size:100%;
	margin:0;
	font-weight: 600;
	/*max-height: 100%;android chrome 文字大きくなるバグ対策→meta initial-scale あれば大丈夫*/
}
/* --OTHER TAGS-- */
p {
	margin-bottom:0;
	text-align:left;
	width:auto;
	/*max-height: 100%;android chrome 文字大きくなるバグ対策→meta initial-scale あれば大丈夫*/
}
em, strong {
	font-weight:bold;
}
/* --clearfix-- */
.clf:after{
	content: ".";
	display: block;
	height: 0;
	font-size:0;
	clear: both;
	visibility:hidden;
}
.clf{
	display: inline-block;
}
	/* Hides from IE Mac */
	* html .clf{
		height: 1%;
	}
	.clf{
		display:block;
	}
	

.vm,
.vmTxt{
	display: inline-block;
	position: relative;
	top:50%;
	transform: translateY(-50%);
}
/*========
上下中央寄せ
========*/
/*上下中央寄せ*/
.vmf,
.pc_vmf{
	display: flex;
	flex-direction: column;
	justify-content: center;
}
/*上下左右中央寄せ*/
.vmf_c,
.pc_vmf_c{
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
.vmg_c,
.pc_vmg_c{
	display: grid;
	place-content: center;
	place-items: center;
}
.flex,
.pc_flex{
	display: flex;
}
.f_warp,.pc_f_warp	{flex-wrap: wrap;}
.f_ac,.pc_f_ac			{align-items: center;}
.f_as,.pc_f_as			{align-items: flex-start;}
.f_ae,.pc_f_ae			{align-items: flex-end;}
.f_dr,.pc_f_dr			{flex-direction: row-reverse;}/*逆順*/
.f_dc,.pc_f_dc			{flex-direction: column;}
.f_cc,.pc_f_cc			{justify-content: center;}
.f_ce,.pc_f_ce			{justify-content: flex-end;}/*後ろ付き*/
.f_cb,.pc_f_cb			{justify-content: space-between;}
.f_warp.f_fit > *,
.f_warp.pc_f_fit > *,
.pc_f_warp.pc_f_fit	> *,
.pc_f_warp.f_fit > *{
  flex: 1;
  min-width: fit-content;
}

.grid,
.pc_grid{display: grid;}
.grid .ga1,
.pc_grid .pc_ga1{grid-area: 1/1;}



.opBtf a,
a.opBtf{
	opacity: 1;
	transition: opacity 0.25s ease;
}
.opBtf a:not(.noLink):hover,
a.opBtf:not(.noLink):hover{
	opacity: 0.5;
	transition: opacity 0.35s ease;
}

a.op_hov .op{
	opacity: 1;
	transition: opacity 0.25s ease;
}
a.op_hov:not(.noLink):hover .op{
	opacity: 0.5;
	transition: opacity 0.35s ease;
}


.zoomBt a,
a.zoomBt{
	transform: scale(1.0);
	transition: transform 0.35s ease;
}
.zoomBt a,
a.zoomBt,
.zoomBt a *,
a.zoomBt *{
	backface-visibility: hidden;/*chrome transition 1pxズレ対策*/
}
.zoomBt a:not(.noLink):hover,
a.zoomBt:not(.noLink):hover{
	transition: transform 0.2s ease;
	transform: scale(1.15);
}


a.zoomImg_hov img.zoomImg,
.zoomImg_hovKey:has(a.zoomImg_hov) img.zoomImg{
	transform: scale(1);
	transition: transform 0.75s ease;
}
a.zoomImg_hov:not(.noLink):hover img.zoomImg,
.zoomImg_hovKey:has(a.zoomImg_hov:not(.noLink):hover) img.zoomImg,
.imgShowKey.show .zoomImg_hovKey:has(a.zoomImg_hov:not(.noLink):hover) img.zoomImg,
.imgShowKey.show a.zoomImg_hov:not(.noLink):hover img.zoomImg{
	transform: scale(1.1);
}

/*imgShowKeyとinViewを併用*/
.imgShowKey img.imgShowAni,
.imgShowKey .zoomImg_hovKey:has(a.zoomImg_hov) img.imgShowAni,
.imgShowKey a.zoomImg_hov img.imgShowAni{
	opacity: 0;
	transform: scale(1.3);
	transition:
		opacity 1s ease,
		transform 1s ease;
}
.imgShowKey.show img.imgShowAni,
.imgShowKey.show .zoomImg_hovKey:has(a.zoomImg_hov) img.imgShowAni,
.imgShowKey.show a.zoomImg_hov img.imgShowAni{
	opacity: 1;
	transform: scale(1.0);
}


a.txt_hovAni {
  display: inline;
  background-image: linear-gradient(#000, #000);
  background-size: 0% 1px;
  background-position: 0% 100%;
  background-repeat: no-repeat;
	transition: background 0.35s ease;
}

a.txt_hovAni:hover {
  background-size: 100% 1px;
}

#loaderOuter{
	position:fixed;
	width:100%;
	height:100%;
	z-index:499;
	background:#FFF;
}
#loader{
	position: fixed;
	top:50%;
	left:50%;
	z-index:90;
}
.sp{display: none !important;}
/*.pc{display: none !important;}*/

.noEvent{pointer-events:none;}/*IE11以降（IE11ではaタグには利かない）*/
.wrapper{overflow: hidden;}
.yokoSc::-webkit-scrollbar,
.yokoSc_pc::-webkit-scrollbar {
	display: none;
}

img.obFit,
img.obFit_ct{width: 100%;height: 100%;}
img.obFit   {object-fit: cover;}
img.obFit_ct{object-fit: contain;}
img.obPos_tc,
img.pc_obPos_tc{object-position: top center;}
img.obPos_bc,
img.pc_obPos_bc{object-position: bottom center;}

.bdr999,
.pc_bdr999{
	isolation: isolate;
	border-radius: 9999px;
}
/*splide利用するしているページでoverflow:hiddeen;など使っている要素に*/
.willc_trans{will-change: transform;}





/*txtBtAni*/
a .txtBtAni{display: inline-block;}
a:hover:not(.noLink) .txtBtAni{
	position: relative;
	animation: txtBtAni 0.5s ease 0s 1 normal both;
}
@keyframes         txtBtAni {
	0% {
		top: 0;
		opacity: 1;
	}
	30% {
		top: -0.25em;
		opacity: 0;
	}
	31% {
		top: 0.25em;
		opacity: 0;
	}
	100% {
		top:0;
		opacity: 1;
	}
}


/*icon_next*/
a.icon_next .icon{
	display: grid;
	place-content: center;
	place-items: center;
	transition: background 0.35s ease;
}
a.icon_next .icon::before{
	content: '';
	display: block;
	mask-size: 100% 100%;
	transition: background 0.35s ease;
}
a.icon_next .icon_arrow01::before{
	width: 17px;
	height: 10px;
	mask-image: url('../img/icon_arrow01.svg');
}
a.icon_next .icon_bk::before				{background: #000;}
a.icon_next .icon_w::before					{background: rgba(255,255,255,1);}
a.icon_next .icon_wBk::before				{background: rgba(255,255,255,1);}
a.icon_next:hover .icon_wBk::before	{background: rgba(0,0,0,1);}

a.icon_next:hover .icon.iconAni::before					{animation: iconAni 0.5s ease 0.1s 1 normal both;}
a.icon_next:hover .icon.iconAni_deg90::before		{animation: iconAni_deg90 0.5s ease 0.1s 1 normal both;}
a.icon_next:hover .icon.iconAni_deg-90::before	{animation: iconAni_deg-90 0.5s ease 0.1s 1 normal both;}
@keyframes         iconAni {
	0% {
		transform: translateX(0px);
		opacity: 1;
	}
	50% {
		transform: translateX(10px);
		opacity: 0;
	}
	51% {
		transform: translateX(-10px);
		opacity: 0;
	}
	100% {
		transform: translateX(0px);
		opacity: 1;
	}
}
@keyframes         iconAni_deg90 {
	0% {
		transform: translateY(0);
		opacity: 1;
	}
	50% {
		transform: translateY(10px);
		opacity: 0;
	}
	51% {
		transform: translateY(-10px);
		opacity: 0;
	}
	100% {
		transform: translateY(0);
		opacity: 1;
	}
}
@keyframes         iconAni_deg-90 {
	0% {
		transform: translateY(0);
		opacity: 1;
	}
	50% {
		transform: translateY(-10px);
		opacity: 0;
	}
	51% {
		transform: translateY(10px);
		opacity: 0;
	}
	100% {
		transform: translateY( 0);
		opacity: 1;
	}
}

/*oneByOneTxt*/
.oneByOneTxt,
.oneByOneTxt span{opacity: 0;}
.oneByOneTxt span{display: inline-block; transform: translateY(0.35em);}
.oneByOneTxt.startAni{opacity: 1;}
.oneByOneTxt.startAni span{animation: oneByOneAni 0.35s ease-out forwards;}
@-webkit-keyframes oneByOneAni {
	0% {
		transform: translateY(0.35em);
		opacity: 0;
	}
	100% {
		transform: translateY(0);
		opacity: 1;
	}
}
@keyframes         oneByOneAni {
	0% {
		transform: translateY(0.35em);
		opacity: 0;
	}
	100% {
		transform: translateY(0);
		opacity: 1;
	}
}


/*=============================
  header
=============================*/
header{
	position: fixed;
	top:0;
	left:0;
	background: #FFF;
	width: 100%;
	height: 60px;
	padding: 0px 15px;
	z-index: 500;
}
header .logo{
	width: 136px;
	height: auto;
	margin-right: auto;
}

header .btList > li > a{
	display: block;
	background: #000;
	color: #FFF;
	font-size: 0.17rem;
	letter-spacing: 0.1em;
	line-height: calc(23/17);
	padding: 0.25em 1em 0.35em 1.25em;
}



/* fw
=============================*/
header .fw {
	position: fixed;
	top:0;
	left:0;
	width: 100%;
	height: 100%;
	z-index: 200;
	/*-webkit-backdrop-filter: blur(30px);
	backdrop-filter: blur(30px);*/
	/*background: rgba(255,255,255,0.8);*/
	display: none;
	overflow: auto; /*togglemodal使う場合*/
	padding: 150px 30px 100px;
}
header .fw > .fw_bg{
	position: fixed;
	top:0;
	left:0;
	width: 100%;
	height: 100%;
	z-index: -1;
	opacity: 0.3;
	background: #000;
}
header .fw > .fw_inner .fw_close{
	width: 50px;
	height: 50px;
	position: absolute;
	top:-25px;
	right:-25px;
}
header .fw > .fw_inner .fw_close a{
	display: grid;
	place-content: center;
	place-items: center;
	width: 100%;
	height: 100%;
	background: #000;
}
header .fw > .fw_inner .fw_close a::before{
	content: '';
	width: 20px;
	height: 20px;
	display: block;
	-webkit-mask-image: url('../img/icon_close.svg');
	mask-image: url('../img/icon_close.svg');
	mask-size: 100% 100%;
	background: #FFF;
}

header .fw.opening {
	display: flex;
	-webkit-animation: fw_opening 0.8s ease 0s 1 normal both;
	animation: fw_opening 0.8s ease 0s 1 normal both;
}
header .fw.opened{display: flex;}

header .fw.closing {
	display: flex;
	-webkit-animation: fw_closing 0.25s ease 0s 1 normal both;
	animation: fw_closing 0.25s ease 0s 1 normal both;
}
header .fw.closed{display: none;}

@-webkit-keyframes fw_opening {
	0% {
		-moz-perspective:1300px;
		-webkit-perspective: 1300px;
				perspective: 1300px;
		-webkit-transform: scale(1.5);
		-ms-transform: scale(1.5);
			transform: scale(1.5);
		filter: alpha(opacity=000);
		opacity: 0.0;
	}
	100% {
		-webkit-transform: scale(1.0);
		-ms-transform: scale(1.0);
			transform: scale(1.0);
		filter: alpha(opacity=100);
		opacity: 1.0;
	}
}
@keyframes         fw_opening {
	0% {
		-moz-perspective:1300px;
		-webkit-perspective: 1300px;
				perspective: 1300px;
		-webkit-transform: scale(1.5);
		-ms-transform: scale(1.5);
			transform: scale(1.5);
		filter: alpha(opacity=000);
		opacity: 0.0;
	}
	100% {
		-webkit-transform: scale(1.0);
		-ms-transform: scale(1.0);
			transform: scale(1.0);
		filter: alpha(opacity=100);
		opacity: 1.0;
	}
}

@-webkit-keyframes fw_closing {
	0% {
		-webkit-transform: scale(1.0);
		-ms-transform: scale(1.0);
			transform: scale(1.0);
		filter: alpha(opacity=100);
		opacity: 1.0;
	}
	100% {
		-moz-perspective:1300px;
		-webkit-perspective: 1300px;
				perspective: 1300px;
		-webkit-transform: scale(1.5);
		-ms-transform: scale(1.5);
			transform: scale(1.5);
		filter: alpha(opacity=000);
		opacity: 0.0;
	}
}
@keyframes         fw_closing {
	0% {
		-webkit-transform: scale(1.0);
		-ms-transform: scale(1.0);
			transform: scale(1.0);
		filter: alpha(opacity=100);
		opacity: 1.0;
	}
	100% {
		-moz-perspective:1300px;
		-webkit-perspective: 1300px;
				perspective: 1300px;
		-webkit-transform: scale(1.5);
		-ms-transform: scale(1.5);
			transform: scale(1.5);
		filter: alpha(opacity=000);
		opacity: 0.0;
	}
}

header .fw > .fw_inner{
	width: 100%;
	max-width: 800px;
	padding: 35px 50px 45px;
	margin:auto;
	position: relative;
	z-index: 10;
	background: #FFF;
	isolation: isolate;
	-webkit-border-radius: 10px;
	border-radius: 10px;
}
header .fw > .fw_inner .fw_tit{
	text-align: center;
	position: relative;
}
header .fw > .fw_inner .fw_tit .kc_txt{
	display: inline-block;
	font-size: 0.18rem;
	letter-spacing: 0.1em;
	padding: 0.35em 2em 0.4em;
	border: 1px solid;
	background: #FFF;
	position: relative;
	z-index: 1;
	border-color: #000;
}
header .fw > .fw_inner .fw_tit .fw_bd{
	position: absolute;
	top:50%;
	left:0;
	width: 100%;
	height: 1px;
	z-index: 0;
	background: #000;
}
header .fw > .fw_inner .fw_ecList{
	max-width: 700px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 15px;
}
header .fw > .fw_inner .fw_ecList li{
	width: 50%;
	padding: 30px;
	position: relative;
}
header .fw > .fw_inner .fw_ecList li a{
	display: block;
	width: fit-content;
	margin-left: auto;
	margin-right: auto;
	
}
header .fw > .fw_inner .fw_ecList li a .fw_logo{
	width: fit-content;
	height: 50px;
	margin-left: auto;
	margin-right: auto;
	
}
header .fw > .fw_inner .fw_ecList li a .fw_logo{
	width: fit-content;
	height: 50px;
	margin-left: auto;
	margin-right: auto;
}
header .fw > .fw_inner .fw_ecList li a .fw_txt{
	width: fit-content;
	margin-left: auto;
	margin-right: auto;
	font-size: 0.16rem;
	line-height: 1.5;
	letter-spacing: 0.1em;
	margin-top: 1em;
	color: #FFF;
	padding: 0.25em 1.5em 0.35em;
	background: #000;
}


/*=============================
 footer
=============================*/
footer{background: #FFF;}
footer .btArea{
	position: relative;
}
footer .btArea .bg_movie{
	position: absolute;
	bottom:0;
	left:0;
	width: 100%;
	height: 100%;
	overflow: hidden;
	/*opacity: 0.4;*/
	z-index: -1;
	mix-blend-mode:multiply;
	opacity: 0.4;
}
footer .btArea .bg_movie video {
	position: absolute;
	top:50%;
	left:50%;
	min-width: 100%;
	min-height: 100%;
	-webkit-transform: translate(-50%,-50%);
	transform: translate(-50%,-50%);
}
footer #backToTop{
	position: absolute;
	top:70px;
	right: 70px;
	width: 56px;
}
footer .btArea .btList{
	padding-top: 65px;
	padding-left: 75px;
	padding-bottom: 75px;
}
footer .btArea .btList li:nth-child(n+2){
	margin-top: 40px;
}
footer .btArea .btList li a{
	font-size: 0.35rem;
	letter-spacing: -0.05em;
	color: var(--ULOS-DARK-GREEN);
}

footer .btArea .bt_faq {
	background:var(--ULOS-DARK-GREEN);
}
footer .btArea .bt_twitter {
	background:#000;
}
footer .btArea .bt a{
	display: block;
	text-align: center;
	padding: 1.25em 0 1em;
	font-size: 0.2rem;
	font-weight: 700;
	letter-spacing: 0.15em;
	color: #FFFFFF;
}
footer .btArea .bt_twitter a span::before{
	display: inline-block;
	content: url( 'data:image/svg+xml;utf-8,<svg viewBox="0 0 1200 1227" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M714.163 519.284L1160.89 0H1055.03L667.137 450.887L357.328 0H0L468.492 681.821L0 1226.37H105.866L515.491 750.218L842.672 1226.37H1200L714.137 519.284H714.163ZM569.165 687.828L521.697 619.934L144.011 79.6944H306.615L611.412 515.685L658.88 583.579L1055.08 1150.3H892.476L569.165 687.854V687.828Z" fill="white"/></svg>' );
	width: 24px;
	vertical-align: middle;
	margin-right: 1em;
}


footer .gfooter{
	-js-display: flex;
	display: -webkit-flex;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0 15px;
}
footer .gfooter ul{
	-js-display: flex;
	display: -webkit-flex;
	display: flex;
}
footer #gfooterTop ul{
}
footer #gfooterTop ul img{
	height: 19px;
	width: auto;
}
footer #gfooterTop .logo img{
	height: 36px;
	width: auto;
}



footer #gfooterBottom{
	background: #EEEEEE;
	color: #828282;
}
footer #gfooterBottom ul{
	padding: 7px 0;
}
footer #gfooterBottom li:nth-child(n+2){
	margin-left: 10px;
}
footer #gfooterBottom a{
	color: #828282;
	text-decoration: none;
	font-size: 0.12rem;
}