@charset "utf-8";


body {
	font: normal 16px/1.8 "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", Arial, Verdana, sans-serif;
	text-align: left;
	line-height: 1.6;
	color: #333333;
	text-align: justify;
	overflow-x: hidden;
	margin: 0!important;
}

body .sp-item {
	display: none !important;
}

body .pc-item {
	display: block !important;
}

@media screen and (max-width: 640px) {
	body {
		min-width: inherit;
		height: 100%;
	}

	body .sp-item {
		display: block !important;
	}

	body .pc-item {
		display: none !important;
	}

	body .sp-item img {
		width: 100%;
	}

	section .sp-item img {
		width: 90%;
		text-align: center;
		margin: auto;
	}
}

@media screen and (max-width: 640px) {
	.sp img {
		max-width: 90%;
	}

	.sp02 img {
		max-width: 100%;
	}

	.sp03 img {
		max-width: 70%;
	}
}

.fl_left {
	float: left;
}

.fl_right {
	float: right;
}

.ov_hd {
	overflow: hidden;
}

.bg_none {
	background-image: none !important;
}

a.rollover:hover {
	opacity: 0.7;
	filter: alpha(opacity=70);
	-ms-filter: "alpha( opacity=70 )";
}

.rollover:hover {
	opacity: 0.7;
	filter: alpha(opacity=70);
	-ms-filter: "alpha( opacity=70 )";
}

.center {
	text-align: center;
}

.right {
	text-align: right;
}

.line_0 {
	line-height: 0;
}

.zindex {
	z-index: 200;
}

input[type=radio] {
	width: 15px;
	height: 15px;
	vertical-align: middle;
}

input[type=image]:hover {
	opacity: 0.7;
	filter: alpha(opacity=70);
	-ms-filter: "alpha( opacity=70 )";
}



/* 共通ここまで */



/* ----------------------------------------------------
    header
---------------------------------------------------- */
.main {
	text-align: center;
}

.main img {
	width: 100%;
}

@media screen and (max-width: 640px) {
	body {
		font-size: 16px;
		line-height: 1.5;
	}
}

header h1 {
	position: relative;
	width: 100%;
	margin-top: 0 !important;
}

.demo-ttl {
	position: absolute;
	width: 62%;
	top: 35%;
	left: 3%;
}

.demo-inner {
	position: relative;

	overflow: hidden;
}

.demo-inner img {
	width: 100%;
}

.demo-mask {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	-webkit-mask-image: url('../img/FV_effe.png');
	mask-image: url('../img/FV_effe.png');
	-webkit-mask-size: 100% auto;
	mask-size: 100% auto;
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-position: left top;
	mask-position: left top;
}

.demo-hikari {
	position: absolute;
	top: -2%;
	left: -60%;
	width: 20%;
	padding: 30% 0 0;
	background-image: radial-gradient(circle, rgb(255, 255, 255) 0%, rgba(255, 255, 255, 0) 100%);
	transform: skewX(30deg);
	animation-name: demo_kirari;
	animation-duration: 1s;
	/* animation-iteration-count: 2, 0, infinite; */
	animation-iteration-count: infinite;
	animation-timing-function: linear;
}

@keyframes demo_kirari {
	100% {
		left: 100%;
	}
}
/* @keyframes move {
  20%, 100% {
    opacity: 0;
    transform: translate(200px, 0);
  }} */

@media screen and (max-width: 640px) {
.demo-ttl {
	width: 94%;
	top: 28%;
	left: 4%;
}}
/* ----------------------------------------------------
    sec
---------------------------------------------------- */
section {
	padding: 100px 0px;
}

.cont_Wrap {
	width: 724px;
	text-align: center;
	margin: auto;
}

.cont_Wrap img{
	width: 100%;
}

.cont {
	margin-bottom: 70px;
}



.mb20 {
	margin-bottom: 20px;
}

.mb40 {
	margin-bottom: 40px;
}

.red {
	color: #A43B3F;
}

.fb {
	font-weight: bolder;
}

@media screen and (max-width: 640px) {
	section {
		padding: 40px 0;
	}

	.cont_Wrap {
		width: 98%;
	}

	.cont {
		margin-bottom: 5px;
	}

	.in_txt {
		font-family: "Zen Kaku Gothic New", sans-serif;
		font-size: 14px;
		font-weight: 300;
		padding: 10px 10px;
		line-height: 1.5;
	}
}

/* ----------------------------------------------------
    CTA
---------------------------------------------------- */

.CTA {
	width: 100%;
	text-align: center;
	margin: auto;
	padding-top: 80px;
	padding-bottom: 100px;
	background: url(../img/CTA_bg.jpg);
	background-position: center;
	background-size: cover;
}


.btn_cont {
	position: relative;
}

.btn_cont img {
	width: 100%;
	margin-bottom: 20px;
}

.btn {
	position: absolute;
	width: 95%;
	text-align: center;
	margin: auto;
	bottom: 9%;
	left: 0;
	right: 0;
}

.btn:hover {
	opacity: 0.8;
	transition: .3s;
}

.btn_box {
	margin-top: 20px;
}

@media screen and (max-width: 640px) {
	.CTA {
		padding-top: 40px;
		padding-bottom: 40px;
	}

	.btn_cont {
		position: relative;
	}

	.btn {
		/* width: 90%; */
		position: absolute;
		bottom: 10%;
		text-align: center;
		margin: auto;
		left: 0;
		right: 0;
	}

}

/* ----------------------------------------------------
    sec00
---------------------------------------------------- */


/* ----------------------------------------------------
    sec01
---------------------------------------------------- */
.sec01{
	background-color: #eff4f9;
}

/* ----------------------------------------------------
    sec02
---------------------------------------------------- */
.sec02{
	background-color: #eff4f9;
}

/* ----------------------------------------------------
    sec03
---------------------------------------------------- */
.sec03{
	background-color: #1367ab;
}

/* ----------------------------------------------------
    sec04
---------------------------------------------------- */




/* ----------------------------------------------------
    sec05
---------------------------------------------------- */

/* ----------------------------------------------------
    sec06
---------------------------------------------------- */


/* ----------------------------------------------------
    sec07
---------------------------------------------------- */


/* ----------------------------------------------------
    sec08
---------------------------------------------------- */


/* ----------------------------------------------------
    sec09
---------------------------------------------------- */


/* ----------------------------------------------------
    sec10
---------------------------------------------------- */

/* ----------------------------------------------------
    sec11
---------------------------------------------------- */


/* ----------------------------------------------------
    sec12
---------------------------------------------------- */



/* ----------------------------------------------------
    sec13
---------------------------------------------------- */



/* ----------------------------------------------------
    sec14
---------------------------------------------------- */

/* ----------------------------------------------------
    sec15
---------------------------------------------------- */


/* ----------------------------------------------------
    sec16
---------------------------------------------------- */


/* ----------------------------------------------------
    sec17
---------------------------------------------------- */


/* ----------------------------------------------------
    sec18
---------------------------------------------------- */


/* ----------------------------------------------------
    sec19
---------------------------------------------------- */


/* ----------------------------------------------------
    sec20
---------------------------------------------------- */


footer {
	padding: 15px 0px;
	font-size: 14px;
	background-color: #004ea1;
	color: #fff;
}

@media screen and (max-width: 740px) {
	footer {
		padding: 15px 0px;
		font-size: 2.5vw;
	}
	}
.Copyright {
	display: block;
	text-align: center;
	margin: auto;
}

footer nav {
	width: 90%;
	display: flex;
	justify-content: center;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
	margin-top: 15px;
	margin-bottom: 20px;
}

footer li {
	list-style-type: none;
	margin-right: 30px;
	margin-left: 30px;
}

footer a {
	text-decoration-line: none;
	color: #fff;
	font-weight: 600;

}

.hover:hover{
	opacity: 0.6;
	transition: 0.3s;
}