
@charset "UTF-8";
/*----------------------------------------------

Layout
Parts
Lgic
---------*/

@media screen and (min-width: 769px){
	.sp-break {
		display: none;
	}
}
/*
 Layout 
*/
.small-f {
	font-size: 35px;
}
@media screen and (max-width: 768px){
	.small-f {
		font-size: 14px;
	}
}
.hi-yelow {
	color: #295BAA;
	background-color: #F2E421;
}

.mainvisual{

}
.mainvisual__ttl {
	width:1000px;
	margin: 0 auto;
	padding: 138px 0 69px;
	text-align: center;
}
@media screen and (max-width: 768px){
	.mainvisual__ttl {
		width: 85%;
		margin: 0 auto;
		padding: 80px 0 43px;
	}
}
.mainvisual__ttl .first-ttl {
	display: inline-block;
	font-size: 81px;
	font-weight: bold;
	color: #fff;
}
@media screen and (max-width: 768px){
	.mainvisual__ttl .first-ttl {
		font-size: 30px;
	}
}
.mainvisual__ttl .second-ttl {
	display: inline-block;
	margin-top: 10px;
	font-size: 32px;
	font-weight: 700;
	padding: 2px;
	color: #fff;
}
@media screen and (max-width: 768px){
	.mainvisual__ttl .second-ttl {
		font-size: 14px;
	}
}

.container {
	width: calc(1000px - 60px);
	margin: 0 auto;
	padding: 30px;
	background-color: #fff;
}
@media screen and (max-width: 768px){
	.container {
		width: 85%;
		margin: 2.5%;
		padding: 5%;
	}
}
.container p {
	margin-top: 30px;
	line-height: 1.6;
	color: #333;
	letter-spacing: 1px;
}
@media screen and (max-width: 768px){
	.container p {
		font-size:14px;
		line-height: 1.4;
		margin-top: 15px;
	}
}
.container p img {
	width: auto;
	max-width: 648px;
}
@media screen and (max-width: 768px){
	.container p img {
		width: 100%;
	}
}
.logic {
	width: 1000px;
	margin: 20px auto;
}
@media screen and (max-width: 768px){
	.logic {
		width: auto;
		padding: 10%;
	}
}
.logic p {
	font-size: 12px;
	color: #4A4A4A;
	line-height: 1.6;
}

.footer{
	background-color: #1A1A1A;
	padding:60px 0;
	align-items:center;
}
.footer h2 {
	font-size: 26px;
	font-weight: 700;
	color: #fff;
	text-align: center;
	margin-bottom: 60px;
}
@media screen and (max-width: 768px){
	.footer h2 {
		font-size: 18px;
		margin-bottom: 30px;
	}
}
.footer__linkarea {
	display: flex;
	flex-wrap: nowrap;
	justify-content: center;
}
.footer__linkarea a {
	margin: 0 1%;
}
.footer p {
	font-size: 12px;
	color: #E8E8E8;
	text-align: center;
	margin-top: 30px;
}
@media screen and (max-width: 768px){
	.footer p {
		font-size: 9px;

	}
}
.annotaion {
	color: #4A4A4A;
	width: 1000px;
	margin: 20px auto;
	font-size: 12px;
	padding:60px 0;
	align-items:center;
	line-height: 1.6;
}
@media screen and (max-width: 768px){
	.annotaion {
		width: auto;
		padding: 10%;
	}
}
.notice {
	color: #333;
	margin-top: 30px;
	margin-left: auto;
	margin-right: auto;
	font-size: 12px;
	line-height: 1.6;
}
@media screen and (max-width: 768px){
	.notice {
		width: 100%;
	}
}
/*
 Parts
*/
.border-line {
	background-color: #999999;
	width: 50%;
	height: 1px;
	margin: 20px auto;
}
.caption01 {
	font-size: 26px;
	font-weight: 700;
	padding: 15px;
	background-color: #295BAA;
	color: #fff;
}
@media screen and (max-width: 768px){
	.caption01 {
		font-size:18px;
		padding: 10px;
	}
}
.caption02 {
 font-size: 26px;
 color: #282F95;
 text-align: center;
 font-weight: 600;
}
@media screen and (max-width: 768px){
	.caption02 {
		font-size: 18px;
	}
}
.subcaption01 {
	display: block;
	font-size: 16px;
	text-align: center;
	margin: 15px 0 20px;
}
@media screen and (max-width: 768px){
	.subcaption01 {
		font-size: 14px;
	}
}
.caption03 {
	width:650px;
	display: flex;
	align-items: center;
	margin:30px auto 0 auto;
	padding:auto;
	font-weight:bold;
	font-size:26px;
	color: #282F95;
}
@media screen and (max-width: 768px){
	.caption03 {
		width: 290px;
		font-size:23px;
	}
}
.caption03:before,
.caption03:after {
	content: "";
	flex-grow: 1;
	height: 1px;
	background: #282F95;
	margin:0 35px;
}
.infograph {
	text-align: center;
}


/*
 Logic
*/
.q {
	width: 80%;
	margin: 0 auto;
	display:flex;
	justify-content: space-between;
	flex-wrap: wrap;
	background-color:white;
}
@media screen and (max-width: 768px){
	.q {
		width: 100%;
	}
}
.q dt{
	border-left: 4px solid #295BAA;
	padding:0px 0px 0px 10px;
	margin:10px 0px 10px 0px;
	text-align:left;
}
.q dd{
	display: inline-block;
	border: 1px solid #000;
	padding: 5px;
	float: left;
	margin-left: 0;
}
.q dl:nth-child(3) dd {
	border: none;
}
input[type=radio] {
	font-size:15px;
	text-wrap:nowrap;
}
input[type=text] {
	font-size:15px;
	text-wrap:nowrap;
	border: none;
}
input[type=number] {
    display: block;
    font-size: 15px;
    text-wrap: nowrap;
    border: none;
		padding: 15px;
}
.q label{
	font-size:15px;
	padding:0px 0px 0px 10px;
}
select {
	font-size:15px;
	display:block;
	border: none;
	padding:10px;
}
.buttonArea{
	width:100%;
	margin-top: 20px;
	margin-left: auto;
	margin-right: auto;
}
.button{
	display: block;
	margin-left: auto;
  margin-right: auto;
	width:226px;
	height:53px;
	font-size:14pt;
	font-weight:bold;
	color:white;
	background-color:#282F95;
	border: none;
}
.button1{
	display: block;
	width: 300px;
	text-align: center;
	font-size:20px;
	font-weight:bold;
	color:white;
	height: 72px;
	line-height: 70px;
	background-color:#c00000;
	border: none;
}
@media screen and (max-width: 768px){
	.button1{
		font-size:16px;
		width: 46%;
	}
}
.calcttl {
	color: #333;
	font-weight: 700;
}
.ansarea{
	display:flex;
	flex-wrap: wrap;
	width:100%;
	margin: 30px auto 0 auto;
	padding:auto;
}
.anstable{
	width:100%;
	margin-top: 15px;
	margin-bottom: 35px;
	border-collapse: collapse;
	border:1px solid #333;
}
.anstable th{
	border:1px solid #ffffff;
	width:25%;
	background-color:#295BAA;
	color:white;
	margin:5px;
	text-align:center;
}
.anstable td{
	border:1px solid #ffffff;
	background-color:#f4f7fd;
	color:black;
	padding:4px;
	text-align:right;
}
.anstable th,
.anstable td {
	padding: 15px;
	font-size: 20px;
}
@media screen and (max-width: 768px){
	.anstable th,
	.anstable td {
		padding: 5px;
		font-size: 13px;
	}
}
.anstable .total{
	border:1px solid #ffffff;
	background-color:#A6B0C1;
	color:black;
	padding:4px;
	text-align:center;
}
.anstable .alltotl{
	border:1px solid #ffffff;
	color:red;
	padding:4px;
	text-align:right;
	padding: 15px;
}
.anstable .kouka{
	border:1px solid #ffffff;
	color:blue;
	padding:4px;
	text-align:right;
}
.subscript {
	right: -27px;
	top: 33px;
	position: relative;
}
.required dt span {
	font-size: 11px;
	margin-left: 5px;
	color: red;
}

.debugtable{
	width:100%;
	border-collapse: collapse;
	border:1px solid #333;
}
.debugtable th{
	border:1px solid #ffffff;
	background-color:#408040;
	color:white;
	margin:5px;
	text-align:center;
}
.debugtable td{
	border:1px solid #ffffff;
	background-color:#f5f5f0;
	color:black;
	padding:1px;
	text-align:right;
}
.arrow_r {
  position:relative;
  text-decoration: none;
}
.arrow_r:before {
  content: '';
  width: 6px;
  height: 6px;
  border: 0;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  position: absolute;
  top: 50%;
  right: 10px;
  margin-top: -4px;
  transform: rotate(45deg);
}

