*{
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	-webkit-text-size-adjust: 100%;
	text-decoration: none;
	text-shadow: none;
	-webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}


html{
	height: 100%;
}

html,body{
	min-height: 100%;
}

body{
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
	word-wrap: break-word;
	opacity: 0;
	color: var(--color-grey-default);
	counter-reset: list-counter;
	font-size: clamp(14px, 1.6vw, 16px);
}
.serif{
	font-family: 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", HGS明朝E, メイリオ, Meiryo, serif;
}
/* font-family: 'Noto Sans JP', sans-serif; */
/* font-family: 'Noto Serif JP', serif; */
/* font-family: 'Oswald', sans-serif; */


/* element
---------------------*/
a,
a:active,
a:hover,
a:visited{
	color: #0064b0;
	cursor: pointer;
}

a,
a:hover,
a:before,
a:after{
	transition: all 0.3s;
	-webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
}

a:hover{
	opacity: 0.7;
}

.button::before,
.button::after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}
.button,
.button::before,
.button::after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	transition: all 0.3s;
	-webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
}


ul{
	margin: 0;
	padding: 0;
	list-style: none;
}
li{
	line-height: 1.6;
}
p{
	margin: 0 0 20px;
	font-size: clamp(14px, 1.6vw, 16px);
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.06rem;
}

figure{
	margin: 0;
}

.ol{
	padding-left: 30px;
	list-style: decimal outside;
}

ol li{
	margin-bottom: 15px;
	letter-spacing: 1px;
	line-height: 1.6;
}
ul li{
	margin-bottom: 10px;
	font-size: clamp(14px, 1.6vw, 16px);
	line-height: 1.4;
	letter-spacing: 0.06rem;
}
/*.list li:before{
	content: '';
	display: inline-block;
	width: 22px;
	height: 22px;
	background: #007CCA;
	vertical-align: middle;
	margin-right: 5px;
}*/
table{
	font-size: clamp(14px, 1.6vw, 16px);
	line-height: 1.5;
}
.table{
	width: 100%;
	border: 1px solid var(--color-grey-accent);
	margin-bottom: 30px;
}
.table thead{
	background: #eeead6;
}
.table thead th{
	text-align: center;
	vertical-align: middle;
}
.table thead th .note{
	font-size: clamp(10px, 1.6vw, 12px);
}
.table caption.bottom{
	caption-side: bottom;
	padding: 10px 0;
	font-size: 14px;
	line-height: 1.5;
}
.table caption.left{
	text-align: left;
}
.table caption.right{
	text-align: right;
}
.table tr:nth-child(2n){
	background: #f6f6f6;
}
.table th,
.table td{
	font-weight: normal;
	border: 1px solid var(--color-grey-accent);
	padding: 20px;
	vertical-align: middle;
	line-height: 1.5;
	letter-spacing: 0.1rem;
}

.table .classify{
	width: 12%;
}
.table .summary{
	width: 76%;
}
.table .result{
	width: 12%;
	text-align: center;
}

table.lineTable{
	width: 100%;
	margin: 0 auto 60px;
	border-top: 1px solid var(--color-grey-accent);
}
table.lineTable tr{
	border-bottom: 1px solid var(--color-grey-accent);
}
table.lineTable th,
table.lineTable td{
	padding: 20px;
	text-align: left;
	font-weight: normal;
	line-height: 1.5;
}
table.lineTable th{
	width: 20%;
	white-space: nowrap;
}
table.lineTable td{
	width: 80%;
}
table.lineTable caption.left{
	text-align: left;
}
input[type="text"],
input[type="email"],
textarea{
	width: 100%;
}
input[type="submit"],
button{
	background: none;
	border: none;
}
iframe{
	vertical-align: bottom;
}


.textillate br{
	display: block !important;
}


.flexBox{
	display: flex;
	flex-flow: row nowrap;
	justify-content: flex-start;
}
.flexBox.wrap{
	flex-wrap: wrap;
}
.flexBox.around{
	justify-content: space-around;
}
.flexBox.between{
	justify-content: space-between;
}
.flexBox.w-center{
	justify-content: center;
}
.flexBox.v-center{
	align-items: center;
}
.col2 .flex{
	width: 48%;
}
.flex img{
	max-width: 100%;
	height: auto;
}
@media screen and (max-width: 820px){
	.flexBox.col2 .flex{
		width: 100%;
	}
}

@media screen and (max-width: 640px) {
	.flexBox{
		display: block;
	}
	.flexBox.col2 .flex {
		width: 100%;
	}
	.flexBox.col2 .flex:last-child{
		padding-top: 20px;
		margin-top: 40px;
	}
	.flexBox.col2 .flex.blue{
		position: relative;
	}
	.flexBox.col2 .flex.blue:last-child::before{
		content: "";
		display: block;
		height: 20px;
		width: calc(100% + 40px);
		position: absolute;
		left: -20px;
		top: -20px;
		background: #d9e1e9;
	}
}



/* BR IMG
---------------------*/
.spbr{ display: none; }
.tbbr{ display: none; }
.imgsp{ display: none;}
@media screen and (max-width: 1024px) {
	.br::before {
		content: "\A";
		white-space: pre;
	}
}

@media screen and (max-width: 820px) {
	.tbbr{
		display: inline;
	}
	.tbnobr{
		display: none;
	}
	.tbimg100{
		width: 100%;
	}
}

@media screen and (max-width: 640px) {
	.spbr {
		display: inline;
	}
	.spimg100{
		width: 100%;
	}
	.imgpc{ display: none; }
	.imgsp {
		display: inline-block;
	}
}

/* Util
---------------------*/
.note{
	font-size: clamp(10px, 1.6vw, 12px) !important;
}
.ann{
	font-size: 0.5rem;
	vertical-align: top;
}
.img100{
	width: 100%; height: auto;
}
.block{display: block;}
.txtC{text-align: center;}
.txtR{text-align: right;}
.indent{text-indent: -1em !important;}
.bold{font-weight: bold !important;}
.w-auto{width: auto !important;}

.mb0{margin-bottom: 0px !important;}
.mb10{margin-bottom: 10px !important;}
.mb20{margin-bottom: 20px !important;}
.mb30{margin-bottom: 30px !important;}
.mb40{margin-bottom: 40px !important;}
.mb50{margin-bottom: 50px !important;}
.mb70{margin-bottom: 70px !important;}
.mb80{margin-bottom: 80px !important;}
.mb100{margin-bottom: 100px !important;}

.mt0{margin-top: 0px !important;}
.mt10{margin-top: 10px !important;}
.mt20{margin-top: 20px !important;}
.mt30{margin-top: 30px !important;}
.mt40{margin-top: 40px !important;}
.mt50{margin-top: 50px !important;}
.mt100{margin-top: 100px !important;}

.ml20{margin-left: 20px;}
.ml40{margin-left: 40px;}

.mr20{margin-right: 20px;}
.mr40{margin-right: 40px;}

.pt10{padding-top: 10px !important;}
.pt20{padding-top: 20px !important;}
.pt30{padding-top: 30px !important;}
.pt40{padding-top: 40px !important;}
.pt50{padding-top: 50px !important;}

.bdt{border-top: 1px solid #7a7a7a;}
.bdb{border-bottom: 1px solid #717171;}
.bdn{border: none !important;}
.underline{text-decoration: underline;}

.tb{
	display: table;
}
.tc{
	display: table-cell;
	vertical-align: middle;
}

.br{display: block;}
br.pcNoBr{display: none;}

.icon{
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
	line-height: 1;
	position: relative;
}
.icon:before,
.icon:after{
	font-weight: 900 !important;
}
.bg-fix{
	background-attachment: fixed;
}

.btnGroup{
	display: flex;
	flex-flow: row nowrap;
	justify-content: space-evenly;
	align-items: center;
	margin: 3vw 0 0;
}
.btn{
	position: relative;
	width: 75%;
	min-width: 280px;
	max-width: 360px;
	margin: 3% auto;
	padding: 25px 30px;
	display: inline-block;
	font-size: clamp(14px, 1.6vw, 16px);
	line-height: 1.2;
	cursor: pointer;
	overflow: hidden;
	opacity: 1 !important;
}
.btn.wide{
	max-width: 100% !important;
	width: 75% !important;
}
.btn span {
	position: relative;
	z-index: 35;
}

p.btnWrap{
	margin-bottom: 0;
	text-align: center;
}

/* btn
---------------------*/
.btn01{
	color: #fff !important;
	text-align: center;
	background: #1B439A;
	border: 1px solid #1B439A;
}

.btn01:before {
	content: '';
	position: absolute;
	top: -3px;
	left: -3px;
	z-index: -1;
	width: 150%;
	height: 150%;
	background: #fff;
	transform-origin: right top;
	transform: skewX(-30deg) scale(0, 1);
	transition: transform 0.5s;
	transition-timing-function: cubic-bezier(0.6, 0, 0.4, 1);
	z-index: 0;
}
.btn01.on{
	color: #0064b0 !important;
}
.btn01.on i{
	color: #0064b0 !important;
}
.btn01:hover:before {
	transform-origin: left top;
	transform: skewX(-30deg) scale(1, 1);
}


.btn02 {
	color: #0064b0 !important;
	text-align: center;
	background: #fff;
	border: 1px solid #0064b0;
}

.btn02:before {
	content: '';
	position: absolute;
	top: -3px;
	left: -3px;
	z-index: -1;
	width: 150%;
	height: 150%;
	background: #0064b0;
	transform-origin: right top;
	transform: skewX(-30deg) scale(0, 1);
	transition: transform 0.5s;
	transition-timing-function: cubic-bezier(0.6, 0, 0.4, 1);
	z-index: 0;
}

.btn02 span,
.btn02 i {
	color: #0064b0 !important;
}

.btn02.on span{
	color: #fff !important;
}

.btn02.on i {
	color: #fff !important;
}

.btn02:hover:before {
	transform-origin: left top;
	transform: skewX(-30deg) scale(1, 1);
}

.btn03 {
	color: #fff !important;
	text-align: center;
	background: #666;
	border: 1px solid #666;
}

.btn03:before {
	content: '';
	position: absolute;
	top: -3px;
	left: -3px;
	z-index: -1;
	width: 150%;
	height: 150%;
	background: #fff;
	transform-origin: right top;
	transform: skewX(-30deg) scale(0, 1);
	transition: transform 0.5s;
	transition-timing-function: cubic-bezier(0.6, 0, 0.4, 1);
	z-index: 0;
}

.btn03 span,
.btn03 i {
	color: #fff !important;
}

.btn03.on span,
.btn03.on i {
	color: #666 !important;
}

.btn03:hover:before {
	transform-origin: left top;
	transform: skewX(-30deg) scale(1, 1);
}

.btn04 {
	color: var(--color-blue) !important;
	text-align: center;
	background: #fff;
	border: none;
}

.btn04:before {
	content: '';
	position: absolute;
	top: -3px;
	left: -3px;
	z-index: -1;
	width: 150%;
	height: 150%;
	background: var(--color-blue);
	transform-origin: right top;
	transform: skewX(-30deg) scale(0, 1);
	transition: transform 0.5s;
	transition-timing-function: cubic-bezier(0.6, 0, 0.4, 1);
	z-index: 0;
}

.btn04 span,
.btn04 i{
	color: var(--color-blue) !important;
}

.btn04.on span{
	color: #fff !important;
}

.btn04.on i {
	color: #fff !important;
}

.btn04:hover:before {
	transform-origin: left top;
	transform: skewX(-30deg) scale(1, 1);
}


.ico-circle {
	width: 25px;
	height: 25px;
	border-radius: 50%;
	margin-left: 10px;
	display: flex;
	flex-flow: row nowrap;
	justify-content: center;
	align-items: center;
	float: right;
	position: relative;
	z-index: 35;
	transition: all 0.2s linear 0.2s;
	color: #fff;
	background: #000f4a;
}

.ico-circle i{
	font-size: clamp(14px, 1.6vw, 16px);
}

.ico-circle.fff{
	background: #fff;
	color: #000f4a;
}

.btn04 .ico-circle.fff {
	background: #fff;
	color: #E6000A;
}

#formReset.btn02{
	border: 2px solid #aaa;
	color: #aaa;
}
#formBack.btn02{
	background: #ffabab;
}
#formBack.btn02 i{
	left: 20px !important;
	right: auto !important;
}


@media screen and (max-width: 820px){
}

@media screen and (max-width: 640px){

	table.lineTable th,
	table.lineTable td{
		display: block;
	}
	table.lineTable th{
		width: 100%;
		padding-top: 20px;
		font-weight: bold;
		background: #E3E0E0;
	}
	table.lineTable td{
		width: 100%;
	}

	.btnGroup {
		display: block;
	}

	.btn{
		min-width: 300px !important;
		font-size: clamp(14px, 1.6vw, 16px);
		width: 90%;
		display: flex;
		flex-flow: row nowrap;
		justify-content: center;
		align-items: center;
	}
	.btn .text{
		width: 85%;
	}
}




.wp-block-table table{
	width: 100%;
	margin: 0 auto 60px;
}
.wp-block-table table tr{
	border-bottom: 1px solid #E3E0E0;
}
.wp-block-table table th,
.wp-block-table table td{
	padding: 20px;
	text-align: left;
	font-weight: normal;
	line-height: 1.5;
}
.wp-block-table table tr td:first-child{
	width: 20%;
    white-space: nowrap;
}
.wp-block-table table tr td:last-child{
	width: 80%;
}
.wp-block-table table caption.left{
	text-align: left;
}


@media screen and (max-width: 640px){
	.spnobr{
		display: none;
	}
	.wp-block-table table th,
	.wp-block-table table td{
		display: block;
	}
	.wp-block-table table td:first-child{
		width: 100% !important;
		padding-top: 20px;
		font-weight: bold;
        background: #E3E0E0;
	}
	.wp-block-table table td{
		width: 100%;
	}
	.img100{
		width: 100%; height: auto;
	}
}
