@charset "utf-8";
/* CSS Document */
@font-face {
	font-family: 'Helvetica';
	src:url(../Helvetica-Bold.ttf);
}
*{
	box-sizing:border-box;
	padding:0;
	margin:0;
	word-break:normal;
	word-wrap:break-word;

}
body{
	font-family: "Noto Sans JP", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3","ヒラギノ角ゴ Pro W6", "メイリオ","Meiryo",Arial, sans-serif;
	/*font-family: "Yu Mincho", "游明朝", "游明朝体", "	Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Hiragino Mincho Pro", "ヒラギノ明朝 Pro", "MS Mincho", "ＭＳ 明朝", "	MS PMincho", "ＭＳ Ｐ明朝", "Sawarabi Mincho";*/
/*font-family: 'Roboto', sans-serif;*/
	background-color:#FDFAFF;
	color:#413847;
	font-size: 16px;
	line-height: 1.6;
}
img{
	vertical-align:bottom;
	margin:0;
	padding:0;
	border:0;
	max-width:100%;
}
.clearfix:before,
.clearfix:after{
	display: table;
  	content: " ";
}
.clearfix:after{
	clear: both;
}
table {
  border-spacing: 0;
  border-collapse: collapse;
}
td,
th {
  padding: 0;
}
table {
  background-color: transparent;
}
table col[class*="col-"] {
  position: static;
  display: table-column;
  float: none;
}
table td[class*="col-"],
table th[class*="col-"] {
  position: static;
  display: table-cell;
  float: none;
}
ul li{
	/*list-style:none;*/
}
h1,h2,h3,h4,h5,h6,p{
	margin:0px;
}

.os-animation{
    opacity: 0;
}  

.os-animation.animated{
    opacity: 1;
}
.fixedcontainer{
	max-width:1200px;
	margin:0 auto;
	width: 90%;
	padding:0px;
}
a{
	color: inherit;
}
a:visited,
a:link,
a:hover,
a:active,
a:focus{
	outline:none;
	text-decoration:none;
}
a:hover{
	opacity:0.8;
	transition:opacity 0.5s ease;
}

.text-center{
	text-align:center;
}
.text-left{
	text-align:left;
}
.text-right{
	text-align:right;
}
.visible-sp{
	display:none;
}
.hidden-sp{
	display:block;
}

.lp_header{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 2;
	padding: 16px 0;
}
.logo{
	font-size: 24px;
	font-weight: bold;
	color: #fff;
	letter-spacing: 0.05em;
}
.fv{
	position: relative;
}
.fv::before{
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(to right, #FFC1E5 0%, #E7C6FF 50%, #A9C8FF 100%);
	border-bottom-right-radius: 200px;
}
.fv_in{
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: row-reverse;
	justify-content: space-between;
	align-items: center;
	padding: 27px 0 2px;
	max-width: 1000px;
	margin: 0 auto;
}
.fv_content{
	text-align: center;
	color: #fff;
}
.fv_content h3{
	font-size: 24px;
	letter-spacing: 0.08em;
}
.fv_content h2{
	font-size: 80px;
	font-weight: 900;
	letter-spacing: 0.05em;
}
.fv_content p{
	font-weight: 500;
	font-size: 18px;
	letter-spacing: 0.08em;
	margin: 40px 0;
}
.lp_main .btn,
.lp_footer .btn{
	font-size: 16px;
	padding: 11px 20px;
	display: inline-block;
	border-radius: 8px;
	background-color: #413847;
	color: #fff;
}
.campaign{
	padding-top: 96px;
}
.points{
	display: flex;
	justify-content: space-between;
}
.point_item{
	width: 275px;
	text-align: center;
	background-color: #fff;
	border-radius: 24px;
	box-shadow: 0 0 20px rgba(65,56,71, 0.15);
	padding: 0 0 32px;
	position: relative;
}
.point_item::before{
	content: '';
	position: absolute;
	top: -44px;
	left: 50%;
	transform: translateX(-50%);
	width: 100px;
	height: 100px;
	border-radius: 50%;
	background-color: #fff;
	box-shadow: 0 0 20px rgba(65,56,71, 0.15);
	z-index: -1;
}
.point_item::after{
	content: '';
	position: absolute;
	top: -44px;
	left: 50%;
	transform: translateX(-50%);
	width: 100px;
	height: 100px;
	border-radius: 50%;
	background-color: #fff;
	z-index: 1;
}
.point_item *{
	position: relative;
	z-index: 2;
}
.point_item img{
	margin-top: -25px;
	margin-bottom: 20px;
}
.point_item h3{
	font-size: 18px;
	letter-spacing: 0.05em;
	margin-bottom: 20px;
}
.point_item p{
	font-weight: 500;
}
.campaign_content{
	text-align: center;
	position: relative;
	margin-top: 114px;
	padding: 64px 0 40px;
	background: rgba(231,198,255,0.4);
	border-radius: 220px;
	border: 1.4px solid #E7C6FF;
	box-shadow: 0 0 20px rgba(65,56,71, 0.15);
}
.campaign_ttl{
	position: absolute;
	font-size: 28px;
	padding: 8px 56px;
	background: linear-gradient(to right, #FFC1E5 0%, #E7C6FF 50%, #A9C8FF 100%);
	border-radius: 40px;
	color: #fff;
	transform: translate(-50%,-50%);
	left: 50%;
	top: 0;
	letter-spacing: 0.08em;
}
.campaign_ttl span{
	font-family: 'Helvetica';
}
.campaign_content h2{
	font-size: 40px;
	margin-bottom: 24px;
	letter-spacing: 0.05em;
}
.campaign_content h4{
	font-size: 24px;
	font-weight: bold;
	letter-spacing: 0.5px;
}
.campaign_content ul{
	margin: 0 auto;
	text-align: left;
	width: fit-content;
	counter-reset: campaign-counter;
}
.campaign_content ul li{
	list-style: none;
	font-size: 24px;
	font-weight: 600;
	position: relative;
	padding-left: 50px;
	position: relative;
	margin-bottom: 12px;
	counter-increment: campaign-counter;
	letter-spacing: 0.05em;
}
.campaign_content ul li:last-child{
	margin-bottom: 0;
}
.campaign_content ul li::before{
	content: counter(campaign-counter);
	position: absolute;
	top: 0;
	left: 0;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background-color: #fff;
	font-family: 'Helvetica';
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: bold;
	font-size: 20px;
	line-height: 1;
}
.campaign_content ul li span{
	font-size: 18px;
}
.campaign_concept p{
	margin: 32px 0 8px;
	font-size: 18px;
	padding: 0 14px;
	font-weight: 400;
	letter-spacing: 0.05em;
	position: relative;
}
.campaign_concept p::before{
	content: '';
	position: absolute;
	left: 0;
	bottom: 0;
	width: 14px;
	height: 24px;
	background: url('../img/left.svg') center center no-repeat;
	background-size: contain;
}
.campaign_concept p::after{
	content: '';
	position: absolute;
	right: 0;
	bottom: 0;
	width: 14px;
	height: 24px;
	background: url('../img/right.svg') center center no-repeat;
	background-size: contain;
}
.campaign_concept p strong{
	font-weight: bold;
}
.campaign_concept{
	display: flex;
	justify-content: center;
}
.features{
	padding-top: 88px;
}
.sec_ttl{
	text-align: center;
	font-size: 40px;
	letter-spacing: 0.05em;
	margin-bottom: 48px;
}
.sec_ttl span{
	display: block;
	font-size: 18px;
	color: #E7C6FF;
	font-weight: 500;
}
.features .sec_ttl{
	margin-bottom: 8px;
}
.feature_subttl{
	text-align: center;
	margin-bottom: 48px;
}
.feature_item{
	display: flex;
	align-items: center;
}
.feature_content{
	margin-bottom: 98px;
	text-align: center;
}
.feature_content h4{
	font-size: 56px;
	font-weight: 700;
	letter-spacing: 0.05em;
	font-family: 'Helvetica';
	background: linear-gradient(to bottom, #FFC1E5 0%, #E7C6FF 50%, #A9C8FF 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
.feature_content h3{
	font-size: 30px;
	letter-spacing: 0.05em;
	margin-bottom: 24px;
}
.feature_content p{
	font-size: 18px;
	font-weight: 500;
	letter-spacing: 0.05em;
}
.feature_imgs{
	display: flex;
	align-items: start;
	position: relative;
	padding-bottom: 30px;
}
.feature_imgs img{
	position: relative;
	z-index: 1;
}
.feature_imgs img:last-child{
	margin-left: -20px;
	margin-top: 98px;
}
.feature_imgs::before{
	content: url(../img/feature-back.png);
	position: absolute;
	bottom: 0;
	left: 100px;
	z-index: -1;
}
.feature_item.reserve{
	flex-direction: row-reverse;
}
.feature_item.reserve .feature_imgs img:last-child{
	margin-left: 0;
	margin-top: 0;
}
.feature_item.reserve .feature_imgs img:first-child{
	margin-left: -20px;
	margin-top: 98px;
}
.feature_item.reserve .feature_imgs::before{
	left: auto;
	right: 100px;
}
.faq{
	padding: 88px 0;
}
.faq_in{
	max-width: 892px;
	margin: 0 auto;
}
.faq_item{
	border-top: 1px solid #E5DFF0;
	position: relative;
	font-size: 18px;
}
.faq_item:last-child{
	border-bottom: 1px solid #E5DFF0;
}
.faq_ttl{
	letter-spacing: 0.05em;
	font-weight: 700;
	padding: 24px 52px 24px 12px;
	margin: 0;
	cursor: pointer;
	position: relative;
}
.faq_ttl::after{
	content: '+';
	position: absolute;
	right: 20px;
	top: 50%;
	transform: translateY(-50%);
	font-size: 24px;
	font-weight: 300;
	color: #413847;
	transition: transform 0.3s ease;
}
.faq_item.active .faq_ttl::after{
	content: '−';
	transform: translateY(-50%) rotate(0deg);
}
.faq_ans{
	display: none;
	letter-spacing: 0.05em;
	line-height: 1.6;
	padding: 0 52px 24px 46px;
	margin: 0;
	font-weight: 500;
	position: relative;
}
.faq_ans::before{
	content: 'A.';
	position: absolute;
	top: 0;
	left: 12px;
	letter-spacing: 0.05em;
	color: #413847;
}
.passion{
	padding: 88px 0 112px;
}
.passion_in{
	border-radius: 200px 24px 200px 24px;
	background: rgba(255,255,255,0.4);
	box-shadow: 0 0 20px rgba(65,56,71, 0.15);
	padding: 56px 0;
}
.passion_content{
	max-width: 892px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
}
.passion_img{
	width: 450px;
}
.passion_img iframe{
	width: 100%;
}
.passion_text{
	width: 394px;
}
.passion_text h3{
	font-size: 20px;
	margin-bottom: 16px;
}
.passion_text p{
	font-size: 16px;
	font-weight: 500;
	margin-bottom: 32px;
	line-height: 1.6;
	letter-spacing: 0.8px;
}
.passion_text ul{
	display: flex;
	gap: 24px;
}
.passion_text ul li{
	list-style: none;
}
.lp_footer{
	border-radius: 200px 200px 0 0;
	color: #fff;
	background: linear-gradient(to bottom, #FFC1E5 0%, #E7C6FF 50%, #A9C8FF 100%);
}
.footer_in{
	display: flex;
	justify-content: space-between;
	max-width: 856px;
	margin: 0 auto;
	width: 90%;
}
.footer_img img{
	width: 430px;
}
.footer_content_in{
	width: 350px;
	text-align: center;
}
.footer_ttl{
	font-size: 52px;
	font-weight: 700;
	margin-bottom: 24px;
}
.footer_content_in{
	padding-top: 88px;
}
.copyright{
	margin-top: 104px;
}
