@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho:wght@700&display=swap');
/* ****************************************************************************

　目次

-------------------------------------------------------------------------------

　01. モジュール

******************************************************************************* */
#container {
	margin: 0;
	padding: 0;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: normal;
	color: #000;
	overflow: hidden;
}
.fnFade:hover {
	opacity: .6;
}


.fs_btn01-wrap {
	height: 110px;
}
.fs_btn01 {
	display: -webkit-box;
	display: flex;
	align-items: center;
	justify-content: center;
	position: fixed;
	right: 0;
	bottom: 0;
	left: 0;
	height: 110px;
	padding: 0 15px;
	background: rgba(0, 0, 0, 0.7);
	z-index: 101;
	box-sizing: border-box;
}
.fs_btn01.fsFixBtn-cancel{
	position: relative;
}
.fs_btn01 a {
	display: block;
	width: 100%;
	height: 70px;
	line-height: 70px;
	max-width: 506px;
	border-radius: 36px 36px;
	background: #E60012;
	color: #fff;
	font-size: 168%;
	font-weight: 500;
	text-align: center;
	text-decoration: none;
	position: relative;
}
.fs_btn01 a::before {
	content: "";
	display: block;
	width: 30px;
	height: 30px;
	margin-top: -15px;
	background-color: #fff;
	border-radius: 50%;
	position: absolute;
	top: 50%;
	right: 30px;
}
.fs_btn01 a::after {
	content: "";
	display: block;
	width: 8px;
	height: 8px;
	margin: -5px auto 0;
	border-width: 2px 2px 0 0;
	border-style: solid;
	color: #E60012;
	transform:rotate(45deg);
	position: absolute;
	top: 50%;
	right: 42px;
}



/* ==

　01. モジュール

=============================================================================== */
.fs_content {
	margin: 0 auto;
	padding: 0 20px;
}

.fsLogo01 {
	padding: 20px 20px;
}
.fsLogo01 div {
	max-width: 780px;
	margin: 0 auto;
	text-align: center;
}
@media only screen and (max-width: 1100px) {
	.fsLogo01 div {
		max-width: 80%;
	}
}

.fsMV_details{
	margin: 0 0 50px;
	padding: 0 20px;
	background-color: #002F74;
}
.fsMV_details_in{
	max-width: 1120px;
	margin: 0 auto;
	padding: 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.fsMV_detail01{
	width: 12.767%;
}
.fsMV_detail02{
	width: 64.285%;
}
.fsMV_detail03{
	width: 18.482%;
	display: flex;
	flex-direction: column;
	gap: 6px 0;
}

.fsLead01 {
	max-width: 1120px;
	margin: 0 auto;
	text-align: center;
}
.fsLead01_txt01 {
	line-height: 1.851;
	margin: 50px 0 15px;
	color: #000;
	font-size: 150%;
	font-weight: 500;
	text-align: center;
}
.fsLead01_note01{
	margin-bottom: 40px;
	color: #666;
}

@media screen and (max-width:1100px){
	.fsLead01_txt01 br.w1100{
		display: inline;
	}
}




div.fsAnchor01 {
	width: 460px;
	line-height: 1;
	margin: 40px auto 20px;
	font-size: 167%;
	font-weight: 700;
	text-align: center;
	box-sizing: border-box;
}

ul.fsAnchor01 {
	max-width: 840px;
	line-height: 1;
	margin: 0 auto 110px;
	font-size: 167%;
	font-weight: 700;
	text-align: center;
	display: flex;
	justify-content: center;
	gap: 0 30px;
}
ul.fsAnchor01 li {
	width: calc((100% - 20px) / 2);
}
.fsAnchor01 a {
	display: block;
	position: relative;
	line-height: 70px;
	padding: 0 0 2px;
	border-radius: 36px;
	background: #7134C3;
	color: #fff;
	text-align: center;
	text-decoration: none;
}
.fsAnchor01 a::after {
	content: "";
	display: block;
	width: 8px;
	height: 8px;
	margin: -6px auto 0;
	border-width: 2px 2px 0 0;
	border-style: solid;
	transform:rotate(135deg);
	position: absolute;
	top: 50%;
	right: 30px;
}

.fsTxt01{
	line-height: 1.851;
	margin: 20px 0 80px;
	color: #333;
	font-size: 134%;
	font-weight: 500;
	text-align: center;
}


/* プレゼント */
.fsPresent{
	margin: 0 20px 100px;
}
.fsPresent_in{
	max-width: 1120px;
	margin: 0 auto;
	padding: 30px 310px 30px 30px;
	border: 10px solid #EBF7F5;
	box-sizing: border-box;
	position: relative;
}
.fsPresent .fsPresent_hdTxt{
	font-size: 300%;
	color: #03917B;
	font-family: "Shippori Mincho", serif;
	font-weight: 700;
	letter-spacing: 0.28em;
	position: absolute;
	top: -1.2em;
	left: 40px;
}
.fsPresent p{
	font-size: 150%;
	line-height: 1.8;
	font-weight: 500;
}
.fsPresent p:not(.fsPresent_hdTxt) em{
	font-size: 32px;
	line-height: 1.0;
	color: #BF1F3F;
	display: inline-block;
}
.fsPresent p:not(.fsPresent_hdTxt) span{
	color: #BF1F3F;
	font-weight: 700;
}
.fsPresent figure{
	position: absolute;
	top: -50px;
	right: 40px;
}
.fsPresent figure img{
	filter:
	drop-shadow(0px 2px 6px rgba(30, 30, 36, 0.10))
	drop-shadow(0px 10px 20px rgba(30, 30, 36, 0.08));
}
.fsPresent .fsPresent_note{
	margin-top: 5px;
	font-size: 134%;
	line-height: 1.7;
	font-weight: 400;
	color: #666;
}
.fsPresent .txt_anchor01{
	margin-top: 20px;
	font-size: 150%;
	text-align: center;
}
.fsPresent .txt_anchor01 a{
	color: #000;
	text-decoration: none;
}
.fsPresent .txt_anchor01 a::after{
	content: "";
	width: 8px;
	height: 8px;
	margin-left: 10px;
	border-color: #E60012;
	border-width: 2px 2px 0 0;
	border-style: solid;
	transform: rotate(135deg);
	display: inline-block;
	position: relative;
	top: -4px;
}






/* 内容
--------------------------------------------------------------------------- */
.fsDetails{
	margin: 0 -20px 130px;
	padding: 70px 20px 80px;
	background: #284DA8;
	background: linear-gradient(0deg, rgba(40, 77, 168, 1) 0%, rgba(55, 131, 219, 1) 100%);
	overflow: hidden;
	position: relative;
	position: relative;
}

/* 雪の結晶 */
.fsSnowflakes{
	width: 1440px;
	height: 100%;
	margin-left: -720px;
	position: absolute;
	top: 0;
	left: 50%;
}
.fsSnowflakes > div{
	position: absolute;
}
.fsSnowflakes .sf_sizeL{
	opacity: 0.5;
}
.fsSnowflakes .sf_sizeS{
	opacity: 0.6;
}
.fsSnowflakes .snowflake01{
	top: 150px;
	left: 60px;
}
.fsSnowflakes .snowflake02{
	top: -13px;
	right: 200px;
	transform: rotate(-24deg);
}
.fsSnowflakes .snowflake03{
	top: 30px;
	right: -30px;
}
.fsSnowflakes .snowflake04{
	bottom: 520px;
	left: -7px;
	transform: rotate(-24deg);
}
.fsSnowflakes .snowflake05{
	bottom: 190px;
	left: 30px;
}
.fsSnowflakes .snowflake06{
	bottom: 60px;
	right: 32px;
}
/*
@media screen and (max-width:1440px){
	.fsSnowflakes{
		overflow: hidden;
	}
}
*/
@media screen and (max-width:1440px){
	.fsSnowflakes{
		width: 100%;
		margin-left: 0;
		position: static;
	}
	.fsSnowflakes .snowflake01{
		top: 140px;
		left: 10px;
	}
	.fsSnowflakes .snowflake06{
		bottom: 30px;
		right: 10px;
	}
}



/* 3つのポイント */
.fsPoint{
	margin: 0 0 60px;
}

.fsPoint h3{
	margin-bottom: 36px;
	font-size: 233%;
	color: #FFF;
	font-weight: 700;
	letter-spacing: 0.15em;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
}
.fsPoint h3 em{
	font-size: 40px;
	color: #FDD228;
}
.fsPoint h3::before{
	content: "";
	width: 10px;
	height: 40px;
	margin-top: 6px;
	margin-right: 15px;
	border-left: 3px solid #FFF;
	transform: rotate(-20deg);
	display: inline-block;
}
.fsPoint h3::after{
	content: "";
	width: 10px;
	height: 40px;
	margin-top: 6px;
	margin-left: 10px;
	border-right: 3px solid #FFF;
	transform: rotate(20deg);
	display: inline-block;
}
.fsPoint_in{
	max-width: 1120px;
	margin: 0 auto;
	display: flex;
	gap: 0 20px;
}
.fsPoint_item{
	width: calc((100% - 40px) / 3);
	display:flex;
	flex-direction: column;
	position: relative;
}
.fsPoint_item > div{
	min-height: 100%;
	padding: 30px 0 30px;
	background-color: #FFF6D1;
	clip-path: polygon(100% 0, 100% calc(100% - 32px), calc(100% - 32px) 100%, 0 100%, 0 0);
	flex-grow: 1;
	box-sizing: border-box;
	position: relative;
	z-index: 2;
}
.fsPoint_item > div::after{
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  width: 32px;
  height: 32px;
  background: #E5D39A;
  clip-path: polygon(0 0, 0% 100%, 100% 0);
  z-index: 3;
}
.fsPoint_item h4{
	width: 100%;
	margin: 0;
	background-color: #002F74;
	line-height: 1.0;
	text-align: center;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 3;
}
.fsPoint_item h4 img{
	margin: -5px 0;
	vertical-align: top;
}
.fsPoint_txt01{
	height: 100%;
	margin-top: 20px;
	font-size: 167%;
	line-height: 1.4;
	font-weight: 700;
	color: #000;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
}


.fsDetails h2{
	margin-bottom: 45px;
	font-size: 40px;
	font-weight: 700;
	font-family: "Roboto", "Noto Sans JP", sans-serif;
	color: #FFF;
	letter-spacing: 0.4em;
	text-align: center;
}
.fsDetails_bg{
	max-width: 1120px;
	margin: 0 auto;
	padding: 60px 5% 120px;
	background: #FFF url(../images/img_illust02.png) center bottom 50px no-repeat;
	background-size: 96% auto;
	box-sizing: border-box;
	position: relative;
}
.fsDetails_bg::before{
	content: "";
	width: 120px;
	height: 97px;
	background: url(../images/img_illust01.png) left top no-repeat;
	background-size: 100% auto;
	display: inline-block;
	position: absolute;
	top: -40px;
	right: 30px;
}
.fsDetails_in{
	margin-bottom: 40px;
	display: flex;
	gap:  0 40px;
}
.fsDetails_item{
	width: calc((100% - 40px) / 2);
	padding: 20px 0 0;
}
.fsDetails_tit{
	margin-bottom: 20px;
	padding: 0 20px 30px;
	background-color: #FDD228;
	border-radius: 8px;
	color: #000;
	text-align: center;
	position: relative;
}
.fsDetails_tit p.fsDetails_txt_part{
	background-color: #BF1F3F;
	padding: 5px 1em 5px 1.16em;
	font-size: 200%;
	color: #FFF;
	font-weight: 700;
	letter-spacing: 0.16em;
	display: inline-block;
	position: relative;
	top: -25px;
}
.fsDetails_tit h3{
	margin-bottom: 5px;
	font-size: 233%;
	line-height: 1.5;
	font-weight: 700;
}
.fsDetails_tit p.fsDetails_txt_time{
	font-size: 135%;
	line-height: 1.5;
	font-weight: 700;
}
.fsDetails_docs p{
	font-size: 150%;
	line-height: 1.66;
}




.fsProfile01{
	margin: 50px auto 0;
	color: #000;
}
.fsProfile01 h3{
	margin-bottom: 30px;
	font-size: 265%;
	line-height: 1.0;
	font-weight: 700;
	color: #1985C5;
	font-family: "Roboto", "Noto Sans JP", sans-serif;
	letter-spacing: 0.4em;
	display: flex;
	align-items: center;
}
.fsProfile01 h3 span{
	padding: 3px 10px 3px 0;
	background-color: #FFF;
	display: inline-block;
}
.fsProfile01 h3::after {
  content: "";
  flex: 1;
  height: 1px;
  background: #1985C5;
}
.fsProfile01 h4{
	padding: 3px 10px;
	background-color: #F2F2F2;
	font-size: 125%;
	font-weight: 600;
	color: #000;
	letter-spacing: 0.08em;
}
.fsProfile01_in{
	max-width: 1120px;
	margin: 0 auto;
	padding: 20px 0 40px;
	display: flex;
	flex-wrap: wrap;
	gap: 20px 40px;
}
.fsProfile01_item{
	width: calc((100% - 40px) / 2);
	display: flex;
	align-items: flex-start;
	gap: 0 30px;
}
.fsProfile01_item figure{
	width: 160px;
}
.fsProfile01_item > div{
	width: calc(100% - 190px);
}
.fsProfile01_item .fsProfile01_txt01{
	margin-bottom: 10px;
	font-size: 200%;
	line-height: 1.4;
	font-weight: bold;
}
.fsProfile01_item .fsProfile01_txt01 span{
	font-size: 83%;
}
.fsProfile01_item .fsProfile01_txt01 span.fsXS{
	margin-bottom: 7px;
	font-size: 62.5%;
	font-weight: 500;
	display: inline-block;
}
.fsProfile01_item .fsProfile01_txt02{
	font-size: 125%;
	line-height: 1.46;
	font-weight: 400;
}
.fsProfile01_item br.devPcTbl{
	display: inline;
}








/* 開催概要 */
.fsGaiyo01 {
	max-width: 950px;
	margin: 80px auto;
	color: #000;
}
.fsGaiyo01_tit {
	margin: 0 0 40px;
	font-size: 267%;
	letter-spacing: 0.4em;
	text-indent: 0.4em;
	text-align: center;
	position: relative;
}
.fsGaiyo01_data {
	width: 100%;
	border-top: 1px solid #ACD5ED;
}
.fsGaiyo01_data th,
.fsGaiyo01_data td {
	background-color: #fff;
	border-bottom: 1px solid #ACD5ED;
}
.fsGaiyo01_data th {
	width: 22%;
	line-height: 1.5;
	padding: 20px 20px 20px 30px;
	background-color: #F0FAFF;
	font-size: 134%;
	font-weight: 400;
	vertical-align: top;
}
.fsGaiyo01_data td {
	line-height: 1.5;
	padding: 20px 30px;
	font-size: 134%;
	font-weight: 500;
}
.fsGaiyo01_data ul {
	line-height: 1.5;
	font-size: 100%;
	font-weight: 400;
}
.fsGaiyo01_data li em{
	font-weight: 500;
}
.fsGaiyo01_data li + li {
	margin-top: 20px;
}
.fsGaiyo01_data .fsGaiyo01_notes li + li {
	margin-top: 5px;
}
.fsGaiyo01_notes{
	margin-top: 10px;
	color: #666;
	font-weight: 400;
}
.fsGaiyo01_data p.fsGaiyo01_note{
	margin-top: 10px;
	font-size: 87.5%;
	color: #666;
	font-weight: 400;
}
.fsGaiyo01_data ul.fsGaiyo01_notes {
	margin-top: 10px;
	font-size: 87.5%;
}
.fsGaiyo01_data ul.fsGaiyo01_notes li{
	margin-left: 1em;
	text-indent: -1em;
}
.fsGaiyo01_data ul.fsGaiyo01_attention {
	line-height: 1.5;
	font-size: 87.5%;
	font-weight: 400;
}
.fsGaiyo01_data .fsGaiyo01_attention li {
	margin-left: 1em;
	text-indent: -1em;
	font-weight: 400;
}
.fsGaiyo01_data .fsGaiyo01_attention li + li {
	margin-top: 10px;
}
.fsGaiyo01_data li em{
	font-weight: 500;
}





/* お申し込みボタン */
.fsEnd01 {
	padding: 30px 20px 20px;
}
.fsEnd01_in {
	max-width: 950px;
	margin: 0 auto;
	padding: 20px;
	border: 3px solid #f00;
	box-sizing: border-box;
}
.fsEnd01_txt {
	line-height: 1.75;
	color: #f00;
	font-size: 150%;
	font-weight: 700;
	text-align: center;
}



/* 完了画面 */
.fs_complete_txt01{
	margin: 40px 0 30px;
	font-size: 267%;
	color: #000;
	font-weight: 700;
	text-align: center;
}
.fs_complete_txt02{
	margin: 0 0 50px;
	font-size: 150%;
	color: #000;
	text-align: center;
}
.fsBtn01 a {
	width: 460px;
	margin: 0 auto;
	display: block;
	position: relative;
	line-height: 68px;
	padding: 0 0 2px;
	border-radius: 35px;
	background-color: #7134C3;
	font-size: 167%;
	color: #fff;
	text-align: center;
	text-decoration: none;
}
.fsBtn01 a::after {
	content: "";
	display: block;
	width: 8px;
	height: 8px;
	margin: -4px auto 0;
	border-width: 2px 2px 0 0;
	border-style: solid;
	transform:rotate(45deg);
	position: absolute;
	top: 50%;
	right: 30px;
}



/*  えらべる、建て方
------------------------------------------------------------------------------- */
.idxIndexlife01 {
	margin: 0 0 60px;
	color: #000;
}
.idxIndexlife01_tit {
	line-height: 1.461;
	margin: 0 0 38px;
	font-family: 'Noto Serif JP', serif;
	font-size: 217%;
	font-weight: 500;
	text-align: center;
}
.idxIndexlife01_txt {
	line-height: 2.1875;
	margin: 0 0 51px;
	color: #727272;
	font-size: 134%;
	font-weight: 400;
	text-align: center;
}
.idxIndexlife02_list {
	display: -webkit-box;
	display: flex;
	justify-content: space-between;
	max-width: 1000px;
	margin: 0 auto;
	font-size: 100%;
}
.idxIndexlife02_item {
	width: calc((100% - 30px) / 2);
	max-width: 460px;
	background-color: #f4f4f5;
}
.idxIndexlife02_wrap {
	height: 100%;
	color: #000;
	text-decoration: none;
	display: block;
	box-sizing: border-box;
	position: relative;
}
.idxIndexlife02_img {
	display: block;
}
.idxIndexlife02_info {
	padding: 28px 20px 30px;
}
.idxIndexlife02_tit{
	margin-bottom: 20px;
	font-size: 150%;
	line-height: 1.4;
}
/*
.item01 .idxIndexlife02_tit span{ margin-top: 0.5em; display: inline-block; }
*/
.item01 .idxIndexlife02_tit span,
.item02 .idxIndexlife02_tit span{
	font-size: 81.81818%;
	font-weight: 500;
	letter-spacing: 0;
}


.idxIndexlife02_txt{
	margin-bottom: 45px;
	font-size: 134%;
	line-height: 1.5;
	font-weight: 300;
}
.idxIndexlife02_txt em{
	font-size: 110%;
	font-weight: 500;
}
.idxIndexlife02_item li{
	margin: 0 0 7px;
	padding: 5px;
	background-color: #fff;
	border-radius: 20px;
	font-size: 13px;
	text-align: center;
}
.idxIndexlife02_link {
	color: #727272;
	font-size: 117%;
	font-weight: 500;
	text-align: right;
	position: absolute;
	right: 20px;
	bottom: 30px;
}
.idxIndexlife02_link::after {
	content: "";
	display: inline-block;
	width: 9px;
	height: 9px;
	margin: 0 0 0 8px;
	border-width: 1px 1px 0 0;
	border-style: solid;
	transform:rotate(45deg);
	vertical-align: 0;
}





