@charset "utf-8";
/* CSS Document */

/*----------------------------------------
共通
----------------------------------------*/
*, ::before, ::after {
  box-sizing: border-box;
}
body{
	font-family: "小塚ゴシック Pro","Kozuka Gothic Pro","ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	min-width: 100%;
}
img{
	width: auto;
	max-width: 100%;
}

.header_wrap,
.footer_wrap{
	width: 100%;
	max-width: 950px;
}

/*----------------------------------------
mv-area
----------------------------------------*/
.mv-area{
  background-color: #fff67f;
  background-image:
    radial-gradient(#fff 20%, transparent 20%),
    radial-gradient(#fff 20%, transparent 20%);
  background-size: 28px 28px;
  background-position: 0 0, 14px 14px;
}
.mv-area_in{
	width: 100%;
	max-width: 1024px;
	margin: 0 auto;
	padding: 55px 80px 15px;
}
.mv-area__title{
	font-size: 78px;
	font-weight: 800;
	line-height: 1;
}

/*----------------------------------------
各section
----------------------------------------*/
.sec{
	padding: 50px 0;
}
.sec_in{
	width: 100%;
	max-width: 1024px;
	margin: 0 auto;
	text-align: center;
}
.sec-head__lead{
	color: #6e6e6e;
	font-size: 24px;
	font-weight: 500;
	line-height: 1.3;
	position: relative;
	display: inline-block;
	padding: 0 20px;
}
.sec-head__lead::before,
.sec-head__lead::after{
	position: absolute;
	top: -10%;
	content: "";
	width: 2px;
	height: 120%;
	background: #6e6e6e;
	border-radius: 3px;
}
.sec-head__lead::before{
	left: 0;
	transform: rotate(-25deg);
}
.sec-head__lead::after{
	right: 0;
	transform: rotate(25deg);
}
.sec-head__title{
	color: #ff6400;
	font-size: 46px;
	font-weight: bold;
}
.sec-head__title .p_down{
	font-size: .8em;
}

@media only screen and ( max-width : 1024px ) {
	.sec{
		padding: 50px 30px;
	}
	.sec_in{
		width: 100%;
	}
}

.cap_area{
	font-size: 13px;
}
.cap_area p{
	text-indent: -1em;
	margin-left: 1em;
}


.sec-try{
	background: #ffe8d9;
}
.sec-try .sec-head + p{
	font-size: 25px;
	font-weight: bold;
	margin: 1rem 0;
}
.sec-try .btn_line img {
	width: 490px;
	transition: opacity .15s ease , transform .15s ease;
}
.sec-try .btn_line a:hover img {
	opacity: .8;
	transform: translateY(2px);
}
.sec-try p.txt_g{
	color: #6e6e6e;
	font-size: 20px;
	margin: 1rem 0 0;
}
.sec-try .cap_area{
	margin-top: 1rem;
}

.sec-usage{
	background: #ffffe5;
}
.sec-usage__box{
	margin: 40px 0;
}
.sec-usage__box:last-of-type{
	margin-bottom: 0;
}
.sec-usage__box-title{
	color: #6e6e6e;
	font-size: 32px;
	font-weight: bold;
	text-align: left;
	margin-bottom: .5rem;
	padding: 0 135px;
}
.sec-usage__box-title .circle{
	display: inline-block;
	width: 50px;
	height: 50px;
	text-align: center;
	line-height: 50px;
	border-radius:50%;
	color: #ffffe5;
	background: #ff6400;
	margin-right: .5rem;
}
.sec-usage__box-img{
	margin: 0 135px;
}
#usage02.sec-usage__box .sec-usage__box-img,
#usage03.sec-usage__box .sec-usage__box-img{
	position: relative;
}
#usage02.sec-usage__box .sec-usage__box-img::before{
	content: url("../img/usage_pc02_01.png");
	position: absolute;
	left: -40px;
	top: 22%;
}
#usage02.sec-usage__box .sec-usage__box-img::after{
	content: url("../img/usage_pc02_02.png");
	position: absolute;
	right: -40px;
	top: 22%;
}
#usage03.sec-usage__box .sec-usage__box-img::after{
	content: url("../img/usage_pc03_01.png");
	position: absolute;
	right: -40px;
	top: 22%;
}
.sec-usage__box-lead{
	color: #ff6400;
	font-size: 34px;
	font-weight: bold;
	line-height: 1.2;
	margin-top: 40px;
}
.sec-usage__box-lead .com_pc{
	display: inline;
}
.sec-usage__box-lead .p_up{
	font-size: 1.25em;
}
.sec-usage__box-lead .p_up > .p_up{
	font-size: 1.8em;
}
.sec-usage__box-lead .marker{
	background:linear-gradient(transparent 50%, #fff92e 50%);
	padding-bottom: 5px;
}
.sec-usage .usage_arrow{
	width: 78px;
}
.usage01_arrow,.usage02_arrow{
	position: relative;
}
.usage01_arrow::after,
.usage02_arrow::after{
	content: "";
	position: absolute;
	top: 50%;
	right: -235px;
	transform: translateY(-50%);
	display: block;
	width: 210px;
}
.usage01_arrow::after{
	height: 130px;
	background: url("../img/usage_icon01.svg")no-repeat left center;
}
.usage02_arrow::after{
	height: 110px;
	background: url("../img/usage_icon02.svg")no-repeat left center;
}

.sec-outline .cap_area{
	counter-reset: number 0;
	text-align: left;
	margin-top: 50px;
	display: flex;
	justify-content: center;
}
.sec-outline .cap_area ol{
	display: table;
}
.sec-outline .cap_area li{
	display: table-row;
}
.sec-outline .cap_area li::before{
	display: table-cell;
	white-space: nowrap;
	counter-increment: number;
  content: "※"counter(number)"：";
}

.sec-contact{
	background: #fff67f;
}
.sec-contact .sec_in > p{
	font-size: 27px;
	line-height: 1.4;
	margin-bottom: 1em;
	letter-spacing: .05em;
}
.sec-contact .btn_wrap{
	display: flex;
	justify-content: space-between;
	padding: 0 80px;
	margin-top: 50px;
}
.sec-contact .btn_wrap .btn{
	width: 49%;
	max-width: 420px;
}
.sec-contact .btn_wrap .btn a{
	display: block;
	color: #fff;
	font-size: 20px;
	font-weight: 600;
	text-decoration: none;
	text-align: center;
	padding: 15px 20px;
	border-radius: 100px;
	position: relative;
	transition: opacity .15s ease , transform .15s ease;
}
.sec-contact .btn_wrap .btn a:hover{
	opacity: .8;
	transform: translateY(2px);
}
.sec-contact .btn_wrap .btn a .p_up{
	font-size: 1.4em;
}
.sec-contact .btn_wrap .btn a::after{
	position: absolute;
	content: "";
	width: 20px;
	height: 20px;
	top: 50%;
	right: 20px;
	transform: translateY(-50%);
	background: url("../img/icon_arrow_r.svg") no-repeat 0 0;
}
.sec-contact .btn_wrap .btn_online a{
	background: #ff6400;
}
.sec-contact .btn_wrap .btn_store a{
	background: #28ae36;
}

/*----------------------------------------
modal
----------------------------------------*/
.modal{
	display: none;
	height: 100vh;
	position: fixed;
	top: 0;
	width: 100%;
}
.modal__bg{
	background: rgba(0,0,0,0.7);
	height: 100vh;
	position: absolute;
	width: 100%;
}
.modal__content{
	background: #fff;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%,-50%);
	width: 100%;
	max-width: 900px;
	max-height: 100%;
	/*overflow-y: auto;*/
	border-radius: 40px;
}
.modal-sec{
	display: flex;
	justify-content: space-around;
	padding: 40px;
}
.modal-sec__text{
	width: 51%;
}
.modal-sec__text p{
	text-align: left;
	font-size: 28px;
	font-weight: 500;
	line-height: 1.6;
	margin-bottom: 1rem;
}
.modal-sec__qr{
	max-width: 275px;
	border: 2px solid #231815;
}
.modal-close-btn{
	display: inline-block;
	position: absolute;
	top: calc(-60px + -1rem);
	right: 0;
}
.modal-close-btn .close_btn{
	display: block;
	width: 60px;
	height: 60px;
	background: #89c681;
	border-radius: 100%;
	position: relative;
}
.modal-close-btn .close_btn::before,
.modal-close-btn .close_btn::after{
	content: "";
	display: block;
	width: 60%;/*バツ線の長さ*/
	height: 5px;/*バツ線の太さ*/
	background: #fff;
	transform: rotate(45deg);
	transform-origin:0% 50%;
	position: absolute;
	top: calc(25% - 1px);
	left: 30%;
}
.modal-close-btn .close_btn::after{
	transform: rotate(-45deg);
	transform-origin:100% 50%;
	left: auto;
	right: 30%;
}

/*----------------------------------------
floating-banner
----------------------------------------*/
.floating-banner {
	display: none;
	position: fixed;
	z-index: 99999;
	top: 50vh;
	right: 0;
	width: 100%;
	max-width: 300px;
	background: #ffffaa;
	padding: 15px 30px;
}
.floating-banner p img{
	margin-bottom: 1rem;
}

/*----------------------------------------
固定footエリア
----------------------------------------*/
.floatCv_wrap {
    position: fixed;
    bottom: 0;
    left: 0;
    z-index: 1;
    width: 100%;
    height: 80px;
    box-shadow: 0 0 4px rgb(24 24 24 / 20%);
    background: #fff;
}
.floatCv_in {
    display:-webkit-box;
  	display:-ms-flexbox;
  	display:flex;
    -webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
    -webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
    position: relative;
    width: 950px;
    height: 100%;
    padding: 0 110px;
    margin: 0 auto;
}
.floatCv_in:before {
    content: "";
    position: absolute;
    display: block;
    width: 80px;
    height: 71px;
    left: 0;
    bottom: 0;
    background: url("../img/chara_iq02.png?data=20220127") no-repeat 0 0;
}
.footer_in{
	margin-top: 0;
}
.pre_wrap {
    padding: 60px 0 50px;
}
.pre_in {
    background: url(../img/hokensim-img01.jpg) no-repeat top center;
    display: flex;
    align-items: center;
    margin-bottom: 18px;
    height: 322px;
}
.pre_in .btn_line {
    width: 490px;
    margin: 0 auto;
}
.pre_in .btn_line img {
    transition: transform .15s ease;
}
.pre_in .btn_line a:hover img {
    transform: translateY(2px);
}
.pre-txt {
    position: relative;
    padding: 5px 22px;
    display: inline-block;
    line-height: 1;
    margin-bottom: 20px;
}
.pre-txt::before,
.pre-txt::after {
    content: "";
    position: absolute;
    width: 8px;
    height: 100%;
    top: 0;
}
.pre-txt::before {
    border-left: 1px solid #707070;
    border-top: 1px solid #707070;
    border-bottom: 1px solid #707070;
    left: 0;
}
.pre-txt::after {
    border-right: 1px solid #707070;
    border-top: 1px solid #707070;
    border-bottom: 1px solid #707070;
    right: 0;
}
.preSet-txt {
    color: #FF6400;
    font-size: 70px;
    font-weight: bold;
    margin-bottom: 30px;
    line-height: 1.16;
}
.preSet-txt .preSet-line {
    font-size: 49px;
    position: relative;
}
.preSet-txt .preSet-line::before {
    content: "";
    z-index: -1;
    width: 100%;
    height: 18px;
    background: #FFF92E;
    position: absolute;
    bottom: -12px;
}
.preSet-txt .preSet-line::after {
    content: "";
    background: url(../img/hokensim-icn01.svg) no-repeat center;
    width: 48px;
    height: 58px;
    right: -5px;
    bottom: -90px;
    position: absolute;
}
.preSet-txt .preSet-line .fz-l {
    font-size: 114px;
    letter-spacing: -0.05em;
}
.preadd-txt {
    font-size: 13px;
}
