@charset "UTF-8";

input[type="submit"],
input[type="button"],
input[type="reset"] {
	-webkit-appearance: none;
	border-radius: 0;
	-webkit-box-sizing: content-box;
	-webkit-appearance: button;
	appearance: button;
	border: none;
	box-sizing: border-box;
	cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration,
input[type="reset"]::-webkit-search-decoration {
	display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus
input[type="reset"]::focus {
	outline-offset: -2px;
}

#main-area {
	background-color: #eceaeb;
	background-repeat: no-repeat;
	background-image: url(../images/mv_bg.jpg);
	padding-top: 78px;
}

.column01 {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	padding-top: 81px;
	padding-bottom: 97px;
}

.column01 .inner {
	padding-top: 42px;
}

.column01 > .red {
	color: #ff004e;
}
.column01 > .red strong {
	font-weight: bold;
	text-decoration: underline;
}

.h3 {
	font-size: 20px;
	line-height: 25px;
	font-weight: bold;
	color: #223e6c;
	border-bottom: 3px solid #e6e9ea;
}

.h3 + .table {
	margin-top: 20px;
}
.table {
	width: 100%;
	display: table;
	background-color: #daeaf1;
}
.td {
	display: table-cell;
	text-align: center;
	padding-top: 23px;
	padding-bottom: 20px;
	position: relative;
}

.td a p {
	font-size: 14px;
	line-height: 20px;
	font-weight: bold;
	padding-bottom: 15px;
	position: relative;
}
.td a p::before {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 8px 8px 0 8px;
	border-color: #223e6c transparent transparent transparent;
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	margin-left: auto;
	margin-right: auto;
}
.td a p + img {
	margin-top: 14px;
}

.table + .h3 {
	margin-top: 62px;
}

.column01 table {
	margin-top: 16px;
	width: 100%;
	border-top:  1px solid #aaaaaa;
}
.column01 tr {
	border-bottom: 1px solid #aaaaaa;
}
.column01 th,
.column01 td {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	padding-top: 9px;
	padding-bottom: 10px;
}
.column01 th {
	font-size: 14px;
	font-weight: bold;
	color: #223e6c;
	vertical-align: top;
	padding-top: 21px;
	padding-bottom: 10px;
	padding-left: 15px;
	width: 223px;
	position: relative;
}
.column01 th .hissu,
.column01 th .nini {
	display: inline-block;
	width: 40px;
	height: 23px;
	font-size: 12px;
	line-height: 23px;
	vertical-align: middle;
	text-align: center;
	color: #fff;
	position: absolute;
	right: 26px;
	top: 17px;
	font-weight: normal;
}
.column01 th .hissu {
	background-color: #8e2222;
}
.column01 th .nini {
	background-color: #aaa;
}

.column01 td input,
.column01 td textarea,
.column01 td .selectArea {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	display: inline-block;
	border: 1px solid #e1e1e1;
	border-radius: 4px;
	width: 100%;
	padding-left: 12px;
	background-color: #fff;
}
.column01 td input {
	height: 40px;
	font-size: 14px;
	/*color: #999;*/
}
.column01 td input.w341 {
	width: 341px;
}
.column01 td textarea {
	height: 164px;
	padding-top: 11px;
	padding-bottom: 11px;
}

.column01 td .selectArea {
	position:relative;
	width:178px;
	height: 40px;
}
.selectArea .selectObj {
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
	opacity:0; 
}
.column01 td select {
	width: 178px;
	height: 40px;
	cursor: pointer;
}
.selectTxt {
	line-height: 40px;
	vertical-align: middle;
	position: relative;
}


.radio {
	-webkit-transition: background-color 0.2s linear;
	transition: background-color 0.2s linear;
	position: relative;
	display: inline-block;
	padding: 12px 12px 12px 30px;
	vertical-align: middle;
	cursor: pointer;
	font-size: 14px;
}
.radio::after {
	-webkit-transition: border-color 0.2s linear;
	transition: border-color 0.2s linear;
	content: '';
	display: block;
	margin-top: -10px;
	width: 18px;
	height: 18px;
	background-color: #fff;
	border: 1px solid #bbb;
	border-radius: 50%;
	position: absolute;
	top: 50%;
	left: 5px;
}

.column01 td input[type=radio] {
	display: none;
}
.radio::before {
	-webkit-transition: opacity 0.2s linear;
	transition: opacity 0.2s linear;
	content: '';
	display: block;
	margin-top: -5px;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background-color: #223e6c;
	opacity: 0;
	position: absolute;
	top: 50%;
	left: 10px;
	z-index: 1;
}
input[type=radio]:checked + .radio::before {
	opacity: 1;
}
.column01 td label.radio:nth-of-type(n+2) {
	margin-left: 79px;
}


.scl {
	width: 100% !important;
	height: 224px;
	overflow: scroll;
	line-height: 24px;
}




.selectBtn {
	width: 26px;
	height: 34px;
	background-color: #e1e1e1;
	border-radius: 2px;
	position: absolute;
	top: 2px;
	right: 2px;
}
.selectBtn::before {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 6px 3.5px 0 3.5px;
	border-color: #223e6c transparent transparent transparent;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin-top: auto;
	margin-bottom: auto;
	margin-left: auto;
	margin-right: auto;
}

.column01 .formBtm {
	margin-top: 30px;
}

.formBtm {
	display: block;
	text-align: center;
}
.formBtm label + label {
	margin-left: 6px;
}
.formBtm input[type="reset"],
.formBtm input[type="submit"] {
	display: inline-block;
	text-align: center;
	cursor: pointer;
	letter-spacing: .01em;
	border: none;
	vertical-align: bottom;
	border-radius: 2px;
}
.formBtm input[type="reset"] {
	color: #333;
	background-color: #ddd;
	width: 97px;
	height: 39px;
	font-size: 12px;
	line-height: 39px;
}
.formBtm input[type="submit"] {
	color: #fff;
	background-color: #1b81b2;
	width: 271px;
	height: 50px;
	font-size: 20px;
	font-weight: bold;
	line-height: 50px;
}


@media only screen and (min-width: 981px){
	.column01 > .red {
		margin-top: 20px;
		text-align: center;
	}
	.td + .td::before {
		content: "";
		width: 1px;
		height: 106px;
		background-image: url(../images/dot01.gif);
		background-repeat: no-repeat;
		background-position: center;
		position: absolute;
		left: 0;
		top: 0;
		bottom: 0;
		margin-top: auto;
		margin-bottom: auto;
	}
	.td a {
		pointer-events: none;
	}
}



 /* +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
SP max-width: 980px
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

@media only screen and (max-width: 980px) {
	.column01 .inner {
		padding-inline: 10px;
	}
	#main-area {
		padding-top: 43px;
		background-image: url(../images/mv_bg_sp.jpg);
		background-repeat: no-repeat;
		background-size: cover;
		background-position-x: 60%; 
	}
	#main-area .mv_text01 img {
		width: 167px;
	}
	.column01 {
		padding-top: 36px;
		padding-bottom: 50px;
	}
	.sTitle {
		font-size: 13px;
		line-height: 20px;
	}
	.column01 .inner {
		padding-top: 45px;
	}

	.column01 > .red {
		padding-left: 1em;
		text-indent: -1em;
		margin: 15px 20px 0;
	}

	.h3 {
		font-size: 15px;
		line-height: 13px;
		border-bottom: 2px solid #e6e9ea;
		padding-bottom: 5px;
	}
	.h3 + .table {
		margin-top: 14px;
	}
	.table + .h3 {
		margin-top: 0px;
	}
	.table {
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		box-sizing: border-box;
		padding-top: 26px;
		padding-bottom: 24px;
	}
	.td {
		padding-top: 0;
		padding-bottom: 0;
		display: block;
	}
	.td + .td {
		padding-top: 17px;
	}
	.td a p {
		padding-bottom: 10px;
	}
	.td a img {
		margin-top: 7px;
	}

	.column01 th {
		font-size: 12px;
		padding-top: 9px;
		padding-left: 0px;
		width: 108px;
	}

	.column01 th .hissu, .column01 th .nini {
		width: 35px;
		height: 20px;
		right: auto;
		top: 30px;
		left: 0;
	}

	.column01 td input,
	.column01 td textarea,
	.column01 td .selectArea,
	.column01 td .scl {
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		box-sizing: border-box;
		display: inline-block;
		border: 1px solid #e1e1e1;
		border-radius: 4px;
		width: 100%;
		padding-left: 12px;
	}
	.column01 td input {
		font-size: 12px;
	}
	.column01 td input.w341 {
		width: 100%;
	}
	.column01 td .selectArea {
		position: relative;
		width: 142px;
		height: 40px;
	}
	.column01 td select {
		width: 142px;
	}
	.radio {
		font-size: 12px;
	}
	.column01 td label.radio:nth-of-type(n+2) {
		margin-left: 0;
	}
	.scl {
		height: 376px;
	}

	.formBtm {
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		box-sizing: border-box;
		padding-bottom: 51px;
		position: relative;
	}

	.formBtm label:first-of-type {
		position: absolute;
		bottom: 0;
		left: 0;
		right: 0;
		margin-left: auto;
		margin-right: auto;
	}


	form + .h3 {
		margin-top: 48px;
	}
}


@media only screen and (max-width: 374px) {
}


/*form */
#formWrap h3 {
	text-align: center;
	font-size: 20px;
	line-height: 25px;
	font-weight: bold;
	color: #223e6c;
	margin-bottom: 60px;
}

#formWrap .formTable{
	margin-bottom: 30px;
}

#formWrap input[type="button"], #formWrap input[type="submit"], .brown{
	display: inline-block;
	text-align: center;
	cursor: pointer;
	letter-spacing: .01em;
	border: none;
	vertical-align: bottom;
	border-radius: 2px;
}
#formWrap input[type="submit"] {
	color: #fff;
	background-color: #1b81b2;
	width: 271px;
	height: 50px;
	font-size: 20px;
	font-weight: bold;
	line-height: 50px;
}
#formWrap input[type="button"] {
	color: #333;
	background-color: #ddd;
	width: 97px;
	height: 39px;
	font-size: 12px;
	line-height: 39px;
}
.brown {
	color: #333;
	background-color: #ddd;
	width: 146px;
	height: 39px;
	font-size: 12px;
	line-height: 39px;
	margin-left: auto;
	margin-right: auto;
	display: block;
}

@media only screen and (max-width: 980px) {
	#formWrap input[type="button"] {
		margin-top: 10px;
	}
}

#checkList { background: #87cee8; }
#checkList .cTitle {
	color: #223e6c;
	font-weight: bold;
	text-align: center;
}
#checkList .list { position: relative; }
#checkList .list::before,
#checkList .list::after {
	position: absolute;
}
#checkList .list::before {
	width: 0;
	height: 0;
	content: "";
	display: block;
	border-style: solid;
	border-color: #f8833e transparent transparent;
}
#checkList .list::after {
	color: #fff;
	font-weight: bold;
	content: "こちらを\Aチェック";
	white-space: pre;
	border-radius: 50%;
	background-color: #f8833e;
	display: flex;
	align-items: center;
	justify-content: center;
}
#checkList .list > li {
	display: flex;
	background: #fff;
	border-radius: 10px;
}
#checkList .list > li .listCheck label {
	line-height: 0;
	cursor: pointer;
	display: inline-block;
	vertical-align: middle;
}
#checkList .list > li .listCheck input[type="checkbox"] {
	width: 0;
	height: 0;
	margin: 0;
	padding: 0;
	border: none;
	background: none;
}
#checkList .list > li .listCheck input[type="checkbox"] + span {
	content: "";
	background: #fff;
	display: inline-block;
	border: solid #f8833e;
	position: relative;
}
#checkList .list > li .listCheck input[type="checkbox"] + span::after {
	content: "";
	opacity: 0;
	display: block;
	position: absolute;
	border-right: solid #f8833e;
	border-bottom: solid #f8833e;
	transform: scale(1.2) rotate(45deg);
	transition-duration: .3s;
	transition-property: transform, opacity;
}
#checkList .list > li .listCheck input[type="checkbox"]:checked + span::after {
	opacity: 1;
	transform: scale(1) rotate(45deg);
}
#checkList .list > li .listText {
	color: #223e6c;
	font-weight: bold;
}
#checkList .list > li .textBox {
	border: 1px solid #e1e1e1;
}
#checkList .list > li .textBoxInner ol > li > span:first-child {
	text-indent: 0;
	display: inline-block;
}
@media only screen and (min-width: 981px) {
	#checkList { padding: 60px 90px 50px; }
	#checkList .cTitle { font-size: 26px; }
	#checkList .list { margin-top: 50px; }
	#checkList .list::before {
		top: -8px;
		left: 46px;
		border-width: 14px 11px 0;
	}
	#checkList .list::after {
		top: -107px;
		left: 7px;
		width: 100px;
		height: 100px;
		font-size: 16px;
		line-height: 23px;
	}
	#checkList .list > li {
		padding: 23px 28px 23px 40px;
	}
	#checkList .list > li + li { margin-top: 20px; }
	#checkList .list > li .listCheck { width: 60px; }
	#checkList .list > li .listCheck input[type="checkbox"] + span {
		width: 30px;
		height: 30px;
		border-width: 2px;
	}
	#checkList .list > li .listCheck input[type="checkbox"] + span::after {
		top: -2px;
		left: 8px;
		width: 10px;
		height: 22px;
		border-width: 5px;
	}
	#checkList .list > li:hover .listCheck input[type="checkbox"]:not(:checked) + span::after {
		opacity: 0.3;
		transition-duration: 0s;
		transform: scale(1) rotate(45deg);
	}
	#checkList .list > li .listCheck + div { width: calc(100% - 60px); }
	#checkList .list > li .listText { font-size: 21px; }
	#checkList .list > li .textBox {
		height: 242px;
		font-size: 12px;
		line-height: 2;
		margin-top: 26px;
	}
	#checkList .list > li .textBoxInner {
		padding: 4px 10px 0 3px;
	}
	#checkList .list > li .textBoxInner ol > li {
		text-indent: -2.5em;
		padding-left: 2.5em;
	}
	#checkList .list > li .textBoxInner ol > li > span:first-child {
		width: 2.5em;
	}
}
@media only screen and (max-width: 980px) {
	#checkList {
		margin-top: 13px;
		padding: 35px 20px 35px;
	}
	#checkList .cTitle {
		font-size: 19px;
		line-height: 25px;
	}
	#checkList .list { margin-top: 57px; }
	#checkList .list::before {
		top: -5px;
		left: 22px;
		border-width: 9.5px 7.5px 0;
	}
	#checkList .list::after {
		top: -70px;
		left: -4px;
		width: 66px;
		height: 66px;
		font-size: 12px;
		line-height: 15px;
	}
	#checkList .list > li { padding: 12px 15px 10px; }
	#checkList .list > li + li { margin-top: 10px; }
	#checkList .list > li .listCheck {
		width: 36px;
		padding: 10px 0;
		align-self: flex-start;
	}
	#checkList .list > li .listCheck + div {
		width: calc(100% - 36px);
		align-self: center;
	}
	#checkList .list > li .listCheck input[type="checkbox"] + span {
		width: 18px;
		height: 18px;
		border-width: 1px;
	}
	#checkList .list > li .listCheck input[type="checkbox"] + span::after {
		top: 0;
		left: 6px;
		width: 6px;
		height: 12px;
		border-width: 2.5px;
	}
	#checkList .list > li .listText {
		font-size: 14px;
		line-height: 20px;
	}
	#checkList .list > li .textBox {
		height: 375px;
		max-height: calc(100vh - 50px);
		font-size: 12px;
		line-height: 20px;
		margin-top: 13px;
		margin-bottom: 23px;
	}
	#checkList .list > li .textBoxInner { padding-right: 10px; }
	#checkList .list > li .textBoxInner ol > li {
		text-indent: -2em;
		padding-left: 2em;
	}
	#checkList .list > li .textBoxInner ol > li > span:first-child { width: 2em; }
}

#telBox {
	display: none;
	background-color: #f2f2f2;
}
#telBox .title {
	color: #223e6c;
	font-weight: bold;
	text-align: center;
	letter-spacing: 0.1em;
}
#telBox .telList li {
	display: flex;
	background: #fff;
	align-items: center;
}
#telBox .telList .area {
	color: #fff;
	display: flex;
	font-weight: bold;
	letter-spacing: 0.1em;
	text-align: center;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}
#telBox .telList .sapporo .area { background-color: #223e6c; }
#telBox .telList .tokyo .area { background-color: #1b81b2; }
#telBox .telList .osaka .area { background-color: #2caea3; }
#telBox .telList .area span { display: block; }
#telBox .telList .area .minor::before {
	content: "";
	display: block;
	border-top: 1px solid #fff;
}
#telBox .telList .information .number a::before {
	content: "";
	display: inline-block;
	vertical-align: bottom;
	background: url(../../common/images/header-tel_icon01.png) no-repeat center center;
	background-size: 100%;
	aspect-ratio: 1 / 1;
}
#telBox .telList .information .number a img { vertical-align: bottom; }
#telBox .telList .information .address dt {
	color: #223e6c;
	font-weight: bold;
}
#telBox .telList .information .address dd { color: #828282; }
#telBox .caution {
	color: #ff004e;
	text-align: center;
}
#telBox .caution strong {
	font-weight: bold;
	text-decoration: underline;
}
@media only screen and (min-width: 981px) {
	#telBox { padding-block: 60px; }
	#telBox .title {
		font-size: 19px;
		line-height: 36px;
	}
	#telBox .telList {
		max-width: 644px;
		margin-top: 28px;
		margin-inline: auto;
	}
	#telBox .telList li { padding: 11px; }
	#telBox .telList li + li { margin-top: 10px; }
	#telBox .telList .area {
		width: 128px;
		min-width: 128px;
		font-size: 20px;
		aspect-ratio: 1 / 1;
	}
	#telBox .telList .area .minor::before {
		width: 85px;
		margin-block: 12px;
	}
	#telBox .telList .information { padding-left: 30px; }
	#telBox .telList .information .number a { pointer-events: none; }
	#telBox .telList .information .number a::before {
		width: 36px;
		margin-right: 12px;
	}
	#telBox .telList .information .number a img { height: 35px; }
	#telBox .telList .information .address {
		display: flex;
		font-size: 12px;
		line-height: 19px;
		margin-top: 25px;
	}
	#telBox .telList .information .address dt {
		margin-right: 10px;
		padding-right: 10px;
		border-right: 1px solid #223e6c;
	}
	#telBox .caution {
		font-size: 16px;
		line-height: 26px;
		margin-top: 18px;
	}
}
@media only screen and (max-width: 980px) {
	#telBox { padding: 35px 10px 36px; }
	#telBox .title {
		font-size: 14px;
		line-height: 25px;
	}
	#telBox .telList { margin-top: 30px; }
	#telBox .telList li { padding: 7px; }
	#telBox .telList li + li { margin-top: 7px; }
	#telBox .telList .area {
		width: 80px;
		height: 147px;
	}
	#telBox .telList .information {
		margin-left: 15px;
	}
	#telBox .telList .information .number a::before {
		width: 22px;
		margin-right: 7px;
	}
	#telBox .telList .information .number a img { height: 20px; }
	#telBox .telList .information .address {
		font-size: 10px;
		line-height: 15px;
		margin-top: 18px;
		padding-left: 10px;
		border-left: 1px solid #223e6c;
	}
	#telBox .telList .information .address dd { margin-top: 5px; }
	#telBox .caution {
		font-size: 11px;
		line-height: 17px;
		margin-top: 12px;
	}
}