@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');

/* ---------------------------------------------------------------
	Reset
--------------------------------------------------------------- */
/* 
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com 
Twitter: @rich_clark
*/

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
    margin:0;
    padding:0;
    border:0;
    outline:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}

body {
    line-height:1;
}

article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section { 
    display:block;
}

nav ul {
    list-style:none;
}

blockquote, q {
    quotes:none;
}

blockquote:before, blockquote:after,
q:before, q:after {
    content:'';
    content:none;
}

a {
    margin:0;
    padding:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}

/* change colours to suit your needs */
ins {
    background-color:#ff9;
    color:#000;
    text-decoration:none;
}

/* change colours to suit your needs */
mark {
    background-color:#ff9;
    color:#643813;
    font-style: normal;
    font-weight:bold;
}

del {
    text-decoration: line-through;
}

abbr[title], dfn[title] {
    border-bottom:1px dotted;
    cursor:help;
}

table {
    border-collapse:collapse;
    border-spacing:0;
}

/* change border colour to suit your needs */
hr {
    display:block;
    height:1px;
    border:0;
    border-top:1px solid #cccccc;
    margin:1em 0;
    padding:0;
}

input, select {
    vertical-align:middle;
}

/* add to
---------------------------------------------------------- */
html{
	-webkit-text-size-adjust: 100%;
	box-sizing: border-box;
}
*, *:before, *:after{
	box-sizing: inherit;
}
main{
	display: block;
}
img {
	border-style: none;
}
button, input, select, textarea {
	font-family: inherit;
	font-weight: inherit;
	font-size: 100%;
	line-height: 1.15;
	margin: 0;
}



/* ---------------------------------------------------------------
	Base
--------------------------------------------------------------- */
body {
	color: #333;
	font-size: 23px;
	font-weight: normal;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	line-height: 1.5;
	word-break: normal;
	overflow-wrap: break-word;
	word-wrap: break-word;
	background-color: #fff;
	-webkit-font-smoothing: antialiased;
	text-align: center;
}
.noto{
	font-family: "Noto Sans JP", sans-serif;
}
img{
	max-width: 100%;
	height: auto !important;
	display: block;
	margin: auto;
}
/* PCのみ */
@media all and (min-width: 751px) {
	body{
		min-width: 750px;
	}
	#all{
		min-width: 1120px;
	}
	.inner{
		width: 1120px;
		margin: auto;
	}
	.inner_in{
		width: 900px;
		margin: auto;
	}
	
	a,
	a img{
		-webkit-transition: 0.3s;
		-moz-transition: 0.3s;
		-o-transition: 0.3s;
		-ms-transition: 0.3s;
		transition: 0.3s;
	}
	a:hover{
		text-decoration: none;
	}
	a:hover img{
		opacity: 0.7;
		filter: alpha(opacity=70);
		-ms-filter: "alpha( opacity=70 )";
	}
	.sp_only{
		display: none;
	}
}
/* SPのみ */
@media all and (max-width: 750px) {
	body{
		width: 100%;
		min-width: 320px;
		font-size: calc(26vw / 750 * 100);
	}
	#all{
		width: 100%;
	}
}



/* ---------------------------------------------------------------
	Content
--------------------------------------------------------------- */
.bg_light{
	background: #dfeaff;
}
.bg_blue{
	background: #0c2780;
}
.bg_gray{
	background: #f2f2f2;
}

/* video
---------------------------------------------------------- */
video{
	display: block;
	outline: 2px solid #0c2780;
	border-radius: 12px;
	box-sizing: border-box;
	object-fit: cover;
	outline-offset: -1px;
}
.wrap_movie{
	position: relative;
}
.wrap_movie video{
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	width: 320px;
}
.wrap_movie.movie02 video{
	bottom: 8%;
}
.wrap_movie.tool video{
	bottom: 21%;
}
.wrap_movie.alert video{
	top: 24%;
}
.wrap_movie.demo video{
	bottom: 23%;
}
.wrap_movie.knockout video{
	top: 0;
}
.wrap_movie.beginner video{
	top: 30%;
}
/* SPのみ */
@media all and (max-width: 750px) {
	video{
		width: 100%;
		border-radius: calc(25vw / 750 * 100);
	}
	.wrap_movie video{
		width: calc(655vw / 750 * 100);
	}
	.wrap_movie.movie02 video{
		bottom: 4%;
	}
	.wrap_movie.tool video{
		bottom: 14%;
	}
	.wrap_movie.alert video{
		top: 16%;
	}
	.wrap_movie.demo video{
		bottom: 15%;
	}
	.wrap_movie.knockout video{
		width: 79%;
	}
	.wrap_movie.beginner video{
		width: 82%;
	}
}


/* fv
---------------------------------------------------------- */

/* PCのみ */
@media all and (min-width: 751px) {
	header{
		background: #0c2780;
		height: 64px;
	}
	header img{
		margin-left: 38px;
	}
}

.fv{
	position: relative;
}
/* PCのみ */
@media all and (min-width: 751px) {
	.fv_orange{
		background: #ff961e;
	}
	.fv_blue{
		background: #004aff;
	}
	.fv_orange img{
		margin-left: 54px;
	}
	.fv_blue img{
		margin-left: 115px;
	}
	.fv_content img{
		margin-left: 0;
	}
	.fv_reason{
		background: #425390;
	}
	.fv_reason img{
		margin-left: 0;
	}
	.fv video{
		position: absolute;
		top: 6%;
		left: 53%;
		width: 465px;
	}
}
/* SPのみ */
@media all and (max-width: 750px) {
	.fv video{
		width: 90%;
		margin: auto;
	}
}


/* tieup
---------------------------------------------------------- */
.tieup{
	position: relative;
}
.tieup a{
	position: absolute;
	display: block;
	bottom: 14%;
	left: 0;
	right: 0;
	margin: auto;
	width: 570px;
}
/* SPのみ */
@media all and (max-width: 750px) {
	.tieup a{
		width: calc(585vw / 750 * 100);
		bottom: 7.5%;
	}
}


/* popup
---------------------------------------------------------- */
.js-popup-open {
	cursor: pointer;
}
.js-popup {
	display: none;
	height: 100vh;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 3;
}
.popup_bg {
	background: rgba(0,0,0,0.7);
	height: 100vh;
	position: fixed;
	width: 100%;
}
.popup_content {
	background: #fff;
	left: 50%;
	/*padding: 30px;*/
	position: fixed;
	top: calc(50% - 10px);
	transform: translate(-50%,-50%);
	width: 750px;
	/*border-radius: 10px;*/
	font-size: 1.2rem;
	max-width: 700px;
	text-align: center;
	max-height: 90vh;
	overflow-y: scroll;
}
.popup_content .js-popup-close {
	cursor: pointer;
	display: block;
	width: 240px;
	height: 2.5em;
	margin: 1em auto 0;
}
.popup_content_in{
	position: relative;
}
.popup_content_in button{
	display: block;
	position: absolute;
	top: 35.5%;
	left: 0;
	right: 0;
	margin: auto;
}
/* PCのみ */
@media all and (min-width: 1120px) {
	.popup_content{
		width: 1020px;
		max-width: 1020px;
	}
	.popup_content_in button{
		top: 43.5%;
		width: 570px;
	}
}
@media all and (min-width: 751px) {
	.popup_content{
		width: 95%;
		max-width: 1000px;
	}
	.popup_content_in button{
		top: 43.5%;
		width: 56%;
	}
}
@media (max-width: 750px) {
	.popup_content {
		padding: 20px;
		width: 94%;
		font-size: max(calc(12vw / 750 * 100), 11px);
	}
	.popup_content .js-popup-close {
		width: min(240px,85%);
	}
}


/* ページアクセス時モーダル
---------------------------------------------------------- */
.modal {
  visibility: hidden;
  opacity: 0;
  position: fixed;
  z-index: 1;
  left: 0;
  top: 0;
  width: 100%;
  height: 100vh;
  overflow: auto;
  background-color: rgba(0,0,0,0.7);
  transition: opacity 0.5s, visibility 0.5s;
}
.modal-content{
	background-color: #fff;
	margin: 0 auto;
	width: 750px;
	max-width: 650px;
	position: fixed;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%);
}
.modal-content_in{
	position: relative;
}
.close-button{
	position: absolute;
	bottom: 6%;
	left: 0;
	right: 0;
	margin: auto;
	width: 85%;
	cursor: pointer;
	transition: .2s;
}
.close-button:hover{
	opacity: 0.7;
}

.modal.is-visible {
  visibility: visible;
  opacity: 1;
}

/* PCのみ */
@media all and (min-width: 1120px) {
	.modal-content{
		width: 80%;
		max-width: 1200px;
		padding: 40px;
		background: #004aff;
	}
	.modal-content_in{
		background: #fff;
		border-radius: 10px;
		max-width: 1120px;
	}
	.close-button{
		width: 452px;
		bottom: 8%;
	}
}
@media all and (max-width: 1119px) and (min-width: 751px) {
	.modal-content{
		width: 90%;
		max-width: 1200px;
		padding: 40px;
		background: #004aff;
	}
	.modal-content_in{
		background: #fff;
		border-radius: 10px;
		max-width: 1120px;
	}
	.modal-content_in img{
		width: 90%;
		max-width: 740px;
	}
	.close-button{
		width: 66%;
		max-width: 452px;
		bottom: 8%;
	}
}
@media (max-width: 750px) {
	.modal-content{
		width: 94%;
	}
}


/* cv
---------------------------------------------------------- */
.cv .inner_in{
	position: relative;
}
.cv_btn{
	position: absolute;
	top: 35%;
	left: 51%;
}
button{
	padding: 0;
	border: none;
	outline: none;
	font: inherit;
	color: inherit;
	background: none;
	cursor: pointer;
	transition: .2s;
}
.cv button,
.cv a{
	display: block;
	margin: 3% 0;
}
/* PCのみ */
@media all and (min-width: 751px) {
	button:hover{
		opacity: 0.7;
	}
}
/* SPのみ */
@media all and (max-width: 750px) {
	.cv_btn{
		top: 52%;
		left: 0;
		right: 0;
		margin: auto;
		width: calc(550vw / 750 * 100);
	}
}


/* why / feature
---------------------------------------------------------- */
/* PCのみ */
@media all and (min-width: 751px) {
	.wrap_h2{
		background: url("img/bg_tit_arrow.png") no-repeat center bottom;
		background-size: cover;
	}
	.why .wrap_h2,
	.why .wrap_h2 .inner{
		height: 300px;
	}
	.feature .wrap_h2,
	.feature .wrap_h2 .inner{
		height: 265px;
	}
	.wrap_h2 .inner{
		display: flex;
		align-items: center;
		justify-content: center;
	}
}

.spread_info{
	margin: 1% auto 2%;
	font-size: 16px;
	text-align: left;
	font-feature-settings: "palt";
}
.spread .spread_info{
	margin-top: -1.5%;
}
.ul_kome{
	list-style: none;
}
.ul_kome > li::before{
	content: "※";
}
.ul_kome > li{
	margin-left: 1.2em;
	text-indent: -1.2em;
	display: inline-block;
}
.ul_hyphen{
	list-style: none;
}
.ul_hyphen > li::before{
	content: "- ";
}
.ul_hyphen > li{
	margin-left: 0.5em;
	text-indent: -0.5em;
}
.spread_date{
	text-align: right;
}
.spread_link{
	color: #004aff;
	font-size: 20px;
	text-underline-offset: 0.5em;
}
/* PCのみ */
@media all and (min-width: 751px) {
	.spread_info{
		width: 766px;
	}
}
/* SPのみ */
@media all and (max-width: 750px) {
	.spread_info{
		font-size: calc(16vw / 750 * 100);
		margin-bottom: 5%;
	}
	.spread_link{
		font-size: calc(26vw / 750 * 100);
	}
}


/* spread
---------------------------------------------------------- */
.spread{
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 500;
	font-feature-settings: "palt";
	letter-spacing: 0.01em;
	background: #fff;
	border-radius: 10px;
	padding: 0 4% 5%;
}
.spread h4{
	color: #004aff;
	font-size: 34px;
	font-weight: 500;
	padding-top: 1.5em;
	margin-bottom: 1.4em;
	line-height: 1.35;
	letter-spacing: 0.06em;
}
.spread h4 + p{
	font-size: 18px;
	margin-bottom: 2em;
}
.spread h5{
	margin: 1.2em 0;
}

.ul_price{
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	margin-bottom: 5%;
}
.ul_price > li{
	background: #dfeaff;
	border-radius: 10px;
	color: #0c2780;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	justify-content: center;
	padding: 2.5% 0;
}
.ul_price > li:first-child{
	flex-wrap: nowrap;
}
.ul_price > li > div{
	margin: 0;
}
.ul_price_currency{
	color: #121212;
	font-size: 16px;
}
.ul_price_currency img{
	width: 75px;
	margin-bottom: 2%;
}
.ul_price > li:first-child .ul_price_currency{
	font-size: 20px;
	margin-right: 2%;
}
.ul_price > li:first-child .ul_price_currency img{
	width: 92px;
	margin-bottom: 8%;
}
.ul_price_price{
	font-size: 73px;
	line-height: 1;
	letter-spacing: -0.05em;
}
.ul_price_price span:last-child{
	font-size: 24px;
	letter-spacing: 0;
	display: inline-block;
	margin-left: 0.1em;
}
.ul_price_price.wrap_kara{
	font-size: 55px;
}
.ul_price_price.wrap_kara .kara{
	font-size: 21px;
	display: inline-block;
	vertical-align: middle;
	margin: 0.5em 0.1em 0;
}
.ul_price_price.wrap_kara .kara_after{
	font-size: 30px;
}
.ul_price > li:first-child .ul_price_price{
	font-size: 170px;
	margin-top: -0.1em;
}
.ul_price > li:first-child .ul_price_price span:last-child{
	font-size: 40px;
}
.ul_price > li:first-child .ul_price_price.wrap_kara{
	font-size: 120px;
}
.ul_price > li:first-child .ul_price_price.wrap_kara .kara{
	font-size: 35px;
}
.ul_price > li:first-child .ul_price_price.wrap_kara .kara_after{
	font-size: 57px;
}
.spread_sec03 .ul_price > li:not(:first-child) .ul_price_price span{
	display: block;
}
.spread_annotation{
	font-size: 11px;
	margin: -2.5em 0 3.5em;
	text-align: right;
}
/* PCのみ */
@media all and (min-width: 751px) {
	.spread{
		margin-bottom: 5%;
	}
	.ul_price > li{
		width: 180px;
		min-height: 240px;
	}
	.ul_price > li:first-child{
		width: 434px;
	}
	.spread_sec02 .ul_price > li:first-child{
		width: 460px;
	}
	.spread_sec03{
		width: 86%;
		margin: auto;
	}
	.spread_sec03 .ul_price > li:not(:first-child) .ul_price_price{
		width: 100%;
	}
	.spread_annotation{
		margin-right: 1em;
	}
}
/* SPのみ */
@media all and (max-width: 750px) {
	.spread{
		margin: 0 3%;
		padding-bottom: 12%;
	}
	.spread h4{
		padding-top: 1.5em;
		font-size: calc(48vw / 750 * 100);
		margin-bottom: 1.1em;
	}
	.spread h4 + p{
		font-size: calc(20vw / 750 * 100);
		margin-bottom: 2.3em;
	}
	.spread_sec01 h5 img{
		width: calc(233vw / 750 * 100);
	}
	.spread_sec02 h5 img{
		width: calc(350vw / 750 * 100);
	}
	.spread_sec03 h5 img{
		width: calc(196vw / 750 * 100);
	}
	.ul_price{
		justify-content: space-between;
	}
	.ul_price > li{
		border-radius: calc(16vw / 750 * 100);
		width: 31.5%;
		margin-bottom: 3.5%;
		padding: 3% 0;
	}
	.spread_sec03 .ul_price > li{
		width: 48.5%;
		display: flex;flex-wrap: nowrap;
		justify-content: space-around;
		padding: 4.5% 3%;
	}
	.ul_price > li:first-child{
		width: 100%;
		min-height: calc(300vw / 750 * 100);
	}
	.ul_price_currency{
		font-size: calc(20vw / 750 * 100);
	}
	.spread_sec01 .ul_price > li:not(:first-child) .ul_price_currency{
		display: flex;
		flex-wrap: nowrap;
		align-items: center;
		justify-content: space-between;
		text-align: left;
	}
	.spread_sec01 .ul_price > li:not(:first-child) .ul_price_currency img{
		margin-right: 0.51em;
	}
	.ul_price_currency img{
		width: calc(63vw / 750 * 100);
	}
	.ul_price > li:first-child .ul_price_currency{
		font-size: calc(26vw / 750 * 100);
	}
	.ul_price > li:first-child .ul_price_currency img{
		width: calc(115vw / 750 * 100);
	}
	.ul_price_price{
		font-size: calc(82vw / 750 * 100);
	}
	.ul_price_price span:last-child{
		font-size: calc(30vw / 750 * 100);
	}
	.ul_price_price.wrap_kara{
		font-size: calc(58vw / 750 * 100);
	}
	.ul_price_price.wrap_kara .kara{
		font-size: calc(23vw / 750 * 100);
	}
	.ul_price_price.wrap_kara .kara_after{
		font-size: calc(37vw / 750 * 100);
	}
	.ul_price > li:first-child .ul_price_price{
		font-size: calc(274vw / 750 * 100);
	}
	.ul_price > li:first-child .ul_price_price span:last-child{
		font-size: calc(54vw / 750 * 100);
	}
	.ul_price > li:first-child .ul_price_price.wrap_kara{
		font-size: calc(192vw / 750 * 100);
	}
	.ul_price > li:first-child .ul_price_price.wrap_kara .kara{
		font-size: calc(56vw / 750 * 100);
	}
	.ul_price > li:first-child .ul_price_price.wrap_kara .kara_after{
		font-size: calc(90vw / 750 * 100);
	}
	.spread_annotation{
		font-size: calc(16vw / 750 * 100);
	}
}


/* feature02
---------------------------------------------------------- */
.feature02{
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 500;
}
.feature02_cont > section{
	padding-bottom: 50px;
}
.feature02_cont h4 img{
	width: 225px;
	margin: 5% auto 2%;
}
.ul_feature02{
	list-style: none;
}
.ul_feature02 > li{
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 2.2% 0;
	background: url("img/border_dot.png") repeat-x bottom;
	transition: .2s;
}
.ul_feature02_flag{
	display: flex;
	margin-left: 1%;
}
.ul_feature02_flag img{
	border: 1px solid #878787;
	border-radius: 50%;
	width: 46px;
	height: 46px !important;
	object-fit: cover;
	margin: 0 -4%;
}
.feature02_02 .ul_feature02 img{
	width: 50px;
}
.ul_feature02_pair{
	font-size: 19px;
	color: #000;
	line-height: 1.3;
	margin: 0 auto 0 0;
	text-align: left;
	font-feature-settings: "palt";

}
.feature02_02 .ul_feature02_pair{
	margin-left: 6%;
}
.ul_feature02_price{
	margin-top: -0.2em;
	color: #0c2780;
	font-size: 67px;
	line-height: 1;
}
.ul_feature02_price span.kara{
	font-size: 50px;
	display: inline-block;
	vertical-align: middle;
	margin-top: -0.3em;
}
.ul_feature02_price span.kara_after{
	font-size: 56px;
}
.ul_feature02_price span:last-child{
	font-size: 32px;
	display: inline-block;
	margin-left: 0.1em;
}
/* PCのみ */
@media all and (min-width: 751px) {
	.feature02_cont{
		background: #fff;
		border-radius: 0 0 10px 10px;
		padding: 0.5% 6.4% 6%;
	}
	.ul_feature02{
		display: flex;
		flex-wrap: wrap;
	}
	.ul_feature02 > li{
		width: 50%;
	}
	.ul_feature02 > li:nth-child(odd){
		padding-right: 3%;
	}
	.ul_feature02 > li:nth-child(even){
		padding-left: 3%;
	}
}
/* SPのみ */
@media all and (max-width: 750px) {
	.feature02{
		background: #fff;
		margin: 0 5.8%;
		border-radius: calc(20vw / 750 * 100);
		position: relative;
		padding: calc(295vw / 750 * 100) 6% 12%;
	}
	.feature02 h3{
		margin: auto;
		width: calc(618vw / 750 * 100);
		position: absolute;
		top: -2%;
		left: 0;
		right: 0;
	}
	.feature02_cont > section{
		padding-bottom: 8%;
	}
	.feature02_cont h4{
	}
	.feature02_cont h4 img{
		width: calc(282vw / 750 * 100);
		margin: 8% auto 3%;
	}
	.ul_feature02 > li{
		padding: 3.5% 0;
	}
	.feature02_02 .ul_feature02 > li{
		padding-left: 3.5%;
	}
	.ul_feature02_flag{
		display: flex;
		margin-left: 2%;
	}
	.ul_feature02_flag img{
		width: calc(58vw / 750 * 100);
		height: calc(58vw / 750 * 100) !important;
		margin: 0 -4%;
	}
	.feature02_02 .ul_feature02 img{
		width: calc(60vw / 750 * 100);
	}
	.ul_feature02_pair{
		font-size: calc(24vw / 750 * 100);
	}
	.ul_feature02_price{
		font-size: calc(84vw / 750 * 100);
	}
	.ul_feature02_price span.kara{
		font-size: calc(57vw / 750 * 100);
	}
	.ul_feature02_price span.kara_after{
		font-size: calc(66vw / 750 * 100);
	}
	.ul_feature02_price span:last-child{
		font-size: calc(40vw / 750 * 100);
	}
}

/* もっと見るボタン */
.ul_feature02 li.hidden {
	opacity: 0;
	height: 0;
	margin: 0;
	padding: 0;
	visibility: hidden;
}
.wrap_btn_feature02_more{
	margin-top: -100px;
	width: 100%;
	height: 200px;
	background: linear-gradient(rgba(255,255,255,0),rgba(255,255,255,1) 25%);
	position: relative;
}
.btn_feature02_more{
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
}
/* PCのみ */
@media all and (min-width: 751px) {
	.btn_feature02_more{
		width: 450px;
	}
}
/* SPのみ */
@media all and (max-width: 750px) {
	.wrap_btn_feature02_more{
		margin-top: -26vw;
		height: 30vw;
	}
}

.feature02_annotation{
	font-size: 11px;
	margin-top: 2em;
	text-align: right;
}
/* SPのみ */
@media all and (max-width: 750px) {
	.feature02_annotation{
		font-size: calc(16vw / 750 * 100);
		text-align: right;
	}
}


/* fv_spread
---------------------------------------------------------- */
.fv_spread01{
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 500;
	position: relative;
	border: 2px solid #0c2780;
	border-radius: 10px;
	background: #fff;
}
.fv_spread01::after{
	content: "";
	display: block;
	background: url("img/icon_fv_spread_fukidashi_pc.png") no-repeat;
	background-size: contain;
	width: 24px;
	height: 13px;
	position: absolute;
	left: 0;
	right: 0;
	bottom: -13px;
	margin: auto;
}
.fv_spread01 table{
	width: 100%;
}
.fv_spread th{
	background: #425390;
	color: #fff;
	text-align: center;
	font-size: 18px;
	font-weight: normal;
	padding: 0.25em;
}
.fv_spread th sup{
	font-size: 11px;
	vertical-align: super;
	margin-left: 0.3em;
}
.fv_spread .fv_spread_tb01 th{
	width: 50%;
}
.fv_spread .fv_spread_tb01 th:first-child{
	border-right: 2px dotted #d3d7e5;
	border-radius: 5px 0 0 0;
}
.fv_spread .fv_spread_tb01 th:last-child{
	border-radius: 0 5px 0 0;
}
.fv_spread td{
	padding: 1% 0;
}
.fv_spread .fv_spread_tb01 td:first-child{
	border-right: 2px dotted #707dab;
}
.fv_spread_tb02 ul{
	width: 52%;
	margin: auto;
}
.fv_spread .ul_feature02 > li{
	width: 100%;
	padding: 2.5% 4%;
	background: none;
}
.fv_spread .ul_feature02_flag img{
	width: 29px;
	height: 29px !important;
}
.fv_spread .ul_feature02_pair{
	font-size: 12px;
}
.fv_spread .ul_feature02_price{
	font-size: 40px;
}
.fv_spread .ul_feature02_price span:last-child{
	font-size: 18px;
}
.fv_spread .ul_feature02_price span.kara{
	font-size: 35%;
}
.fv_spread .ul_feature02_price span.kara_after{
	font-size: 60%;
}
.fv_spread_cfd_img{
	margin-right: 3%;
}
.fv_spread_cfd_img img{
	width: 30px;
}
.fv_spread_annotation{
	font-size: 9px;
	position: absolute;
	right: 0;
	color: #000;
	margin-top: 0.5em;
}
/* PCのみ */
@media all and (min-width: 751px) {
	.fv_spread{
		width: 524px;
		position: absolute;
		bottom: 0;
		left: 50%;
	}
	.fv_spread02{
		margin-top: 2.5%;
	}
}
/* SPのみ */
@media all and (max-width: 750px) {
	.fv_spread01{
		width: 92%;
		margin: 0 auto 2%;
		border-width: 4px;
	}
	.fv_spread01::after{
		background-image: url("img/icon_fv_spread_fukidashi_sp.png");
		width: 39px;
		height: 20px;
		bottom: -20px;
	}
	.fv_spread th{
		font-size: calc(26vw / 750 * 100);
		padding: 0.25em;
	}
	.fv_spread th sup{
		font-size: calc(13vw / 750 * 100);
	}
	.fv_spread td{
		padding: 2% 0;
	}
	.fv_spread_tb02 ul{
		width: 57%;
	}
	.fv_spread_tb01 .ul_feature02 > li{
		padding: 2% 7%;
		display: grid;
		grid-auto-flow: column;
		grid-template-rows: repeat(2, auto);
	}
	.fv_spread .ul_feature02_flag{
		min-width: 12vw; /* 銘柄名が現在より長くなる場合はここを調整 */
		justify-content: center;  /* 銘柄名が現在より長くなる場合は左寄せにした方が良いかも */
	}
	.fv_spread .ul_feature02_flag img{
		width: calc(40vw / 750 * 100);
		height: calc(40vw / 750 * 100) !important;
	}
	.fv_spread .ul_feature02_pair{
		font-size: calc(15vw / 750 * 100);
		min-width: 12vw; /* 銘柄名が現在より長くなる場合はここを調整 */
		text-align: center;  /* 銘柄名が現在より長くなる場合は左寄せにした方が良いかも */
	}
	.fv_spread .ul_feature02_price{
		font-size: calc(50vw / 750 * 100);
		min-width: 12vw; /* 銘柄名が現在より長くなる場合はここを調整 */
	}
	.fv_spread .ul_feature02_price span:last-child{
		font-size: calc(24vw / 750 * 100);
	}
	.fv_spread .ul_feature02_price span.kara{
		font-size: 35%;
	}
	.fv_spread .ul_feature02_price span.kara_after{
		font-size: 60%;
	}
	.fv_spread_cfd_img{
		margin-right: 3%;
	}
	.fv_spread_cfd_img img{
		width: calc(40vw / 750 * 100);
	}
	.fv_spread_annotation{
		font-size: calc(9vw / 750 * 100);
		right: 5%;
	}
}
/* more small SPのみ */
@media all and (max-width: 550px) {
	.fv_spread01{
		width: 92%;
		margin: auto;
		border-width: 2px;
	}
	.fv_spread01::after{
		width: calc(39px / 2);
		height: calc(20px / 2);
		bottom: calc(-20px / 2);
	}
}


/* about
---------------------------------------------------------- */
.about{
	background: #f2f2f2;
	border-radius: 20px;
	padding-bottom: 5%;
}
.about h3{
	background: #0c2780;
	height: 80px;
	display: flex;
	align-items: center;
	border-radius: 20px 20px 0 0;
}
.about > dl{
	width: 835px;
	margin: auto;
}
.about > dl > dt{
	position: relative;
	cursor: pointer;
	background: #004aff;
	border-radius: 10px;
	height: 60px;
	display: flex;
	align-items: center;
}
.about > dl.on > dt{
	border-radius: 10px 10px 0 0;
}
.about > dl > dt::after{
	content: "";
	display: inline-block;
	background: url("img/icon_arrow.png") no-repeat;
	background-size: contain;
	width: 22px;
	height: 14px;
	position: absolute;
	top: 35%;
	right: 5.5%;
	transform: rotate(180deg);
	transition: .2s;
}
.about > dl.on > dt::after{
	transform: rotate(0);
}
.about > dl > dd{
	display: none;
	background: #fff;
	border-radius: 0 0 20px 20px;
	padding: 4% 0;
}
/* SPのみ */
@media all and (max-width: 750px) {
	.about{
		width: calc(660vw / 750 * 100);
		margin: auto;
		border-radius: calc(20vw / 750 * 100);
	}
	.about h3{
		height: calc(104vw / 750 * 100);
		border-radius: calc(20vw / 750 * 100) calc(20vw / 750 * 100) 0 0;
	}
	.about h3 + img{
		width: calc(544vw / 750 * 100);
	}
	.about h3 img{
		width: calc(450vw / 750 * 100);
	}
	.about > dl{
		width: calc(617vw / 750 * 100);
	}
	.about > dl > dt{
		height: calc(75vw / 750 * 100);
	}
	.about > dl > dt::after{
		width: calc(28vw / 750 * 100);
		height: calc(17vw / 750 * 100);
	}
	.about > dl > dt img{
		width: calc(158vw / 750 * 100);
	}
	.about > dl > dd{
		padding: 6% 0;
	}
	.about > dl > dd img{
		width: calc(539vw / 750 * 100);
	}
}


/* support_btn
---------------------------------------------------------- */
.support_btn{
	position: relative;
}
.support_btn ul{
	list-style: none;
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
}
/* PCのみ */
@media all and (min-width: 751px) {
	.support_btn ul{
		bottom: 24%;
		display: flex;
		justify-content: space-between;
		width: 82%;
	}
}
/* SPのみ */
@media all and (max-width: 750px) {
	.support_btn ul{
		width: 90%;
		bottom: 13%;
	}
	.support_btn ul li{
		margin: 3% 0;
	}
}


/* fixed
---------------------------------------------------------- */
@keyframes shiny {
	0% {
		transform: scale(0) rotate(25deg);
		opacity: 0;
	}
	30% {
		transform: scale(0) rotate(25deg);
		opacity: 0;
	}
	50% {
		transform: scale(1) rotate(25deg);
		opacity: 1;
	}
	70% {
		transform: scale(50) rotate(25deg);
		opacity: 0;
	}
	100% {
		transform: scale(50) rotate(25deg);
		opacity: 0;
	}
}
@keyframes anime1 {
	0% {
		transform: scale(0.9,0.9);
	}
	43% {
		transform: scale(0.9,0.9);
	}
	50% {
		transform: scale(1,1);
	}
	57% {
		transform: scale(0.9,0.9);
	}
	100% {
		transform: scale(0.9,0.9);
	}
}

.fixed{
	width: 100%;
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	padding: 20px 0 15px;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.5s ease, visibility 0.5s ease;
}
.btn_fixed{
	display: block;
	width: 45%;
	margin: auto;
	position: relative;
	overflow: hidden;
	animation: anime1 5s ease 1s infinite alternate;
}
.btn_fixed::after {
	content: '';
	position: absolute;
	top: -100px;
	left: -100px;
	width: 50px;
	height: 50px;
	background-image: linear-gradient(100deg,  rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, 1) 100%, rgba(255, 255, 255, 0) 0%);
	animation-name: shiny;
	animation-duration: 5s;
	animation-timing-function: ease-in-out;
	animation-iteration-count: infinite;
}
.txt_fixed{
	display: block;
	margin: 1% auto 0;
	width: 18%;
}
/* SPのみ */
@media all and (max-width: 750px) {
	.fixed{
		padding: 4% 0 2%;
	}
	.btn_fixed{
		width: calc(680vw / 750 * 100);
	}
	.txt_fixed{
		width: calc(306vw / 750 * 100);
		margin: 2% auto 0;
	}
}



/* ---------------------------------------------------------------
	Footer
--------------------------------------------------------------- */
footer{
	background: #09193a;
	margin-bottom: 170px;
	color: #fff;
	font-size: 16px;
	padding: 50px 0;
}
footer > div{
	max-width: 1400px;
	margin: auto;
}
.ul_foot_link{
	list-style: none;
	font-size: 16px;
	text-align: left;
}
.ul_foot_link li{
	margin-bottom: 0.5em;
}
.ul_foot_link li a{
	color: #fff;
	text-decoration: none;
}
.ul_foot_link li a:hover{
	text-decoration: underline;
}
.foot_txt{
	width: 50%;
	text-align: left;
	font-size: 13px;
}
.foot_txt_ssl{
	margin-top: 1.5em;
	display: flex;
	align-items: center;
}
.foot_txt_ssl img{
	margin: 0 1em 0 0;
}
.wrap_ul_sns{
	text-align: left;
}
.ul_sns{
	margin-top: 1em;
	list-style: none;
	display: flex;
}
.ul_sns li{
	margin: 0 0.4em;
}
.ul_sns li a img{
	display: block;
	width: 28px;
}
/* PCのみ */
@media all and (min-width: 751px) {
	footer > div{
		display: flex;
		justify-content: space-around;
	}
}
/* SPのみ */
@media all and (max-width: 750px) {
	footer{
		margin-bottom: 32%;
		padding: 10% 4%;
	}
	.ul_foot_link{
		margin: 0 0 5%;
	}
	.foot_txt{
		width: 100%;
		font-size: 12px;
	}
	.wrap_ul_sns{
		text-align: center;
		margin-top: 7%;
	}
	.ul_sns{
		width: 60%;
		margin: 3% auto 0;
		justify-content: center;
	}
}

