@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
/* entryBox */
#main .entryBox {
	mask: url("../img/index/bg01.png") no-repeat left top / 100% 100%;
	background-color: #96bcdd;
}
#main .entryBox .content {
	max-width: 84.6rem;
}
#main .entryBox .formBox {
	padding: 3.9rem 15.1rem 10.7rem;
	background-color: #fff;
	border: 0.3rem solid #005bab;
	border-radius: 3rem;
}
#main .entryBox .topTxt {
	margin-bottom: 5.1rem;
	text-align: center;
	font-size: 1.2rem;
	line-height: 1.75;
	font-weight: 700;
	transform: rotate(0.05deg);
}
#main .formDl {
	display: flex;
	flex-wrap: wrap;
	font-weight: 700;
	font-size: 1.2rem;
}
#main .formDl dt {
	margin-top: 0.5rem;
	width: 12rem;
	font-size: 1.4rem;
	letter-spacing: 0;
}
#main .formDl dd {
	padding: 0 0 2.8rem 3rem;
	width: calc(100% - 12.2rem);
	min-height: 8rem;
}
.formBox .must {
	padding: 0.1rem 0.3rem 0.3rem;
	color: #fff;
	line-height: 1;
	display: inline-block;
	vertical-align: middle;
	font-size: 1rem;
	text-align: center;
	border: 1px solid #000;
	border-radius: 0.2rem;
	background-color: #f15a24;
	float: right;
	margin-top: 0.2rem;
}
.formBox input[type="text"],
.formBox input[type="email"],
.formBox input[type="tel"],
.formBox input[type="number"],
.formBox input[type="submit"],
.formBox textarea,
.formBox select {
	max-width: 35rem;
	color: #000;
	width: 100%;
	height: 3rem;
	font-weight: 700;
	font-size: 1.2rem;
	border-radius: 0.6rem;
	padding: 0 1rem;
	box-sizing: border-box;
	border: 1px solid #000000;
	background: #fff;
	letter-spacing: 0.05em;
	appearance: none;
	-webkit-appearance: none;
	transform: rotate(0.05deg);
	box-sizing: border-box;
}
.formBox select {
	padding-right: 3rem;
	background: url("../img/common/icon06.png") no-repeat right 1.2rem center;
	background-size: 0.8rem auto;
}
.formBox .wid01 {
	width: 40% !important;
}
.formBox .wid02 {
	width: 23.8% !important;
}
.formBox .agreeTxt {
	margin-top: 3.8rem;
	font-size: 1rem;
	text-align: center;
}
.formBox .agreeTxt a {
	color: #0000ff;
	text-decoration: underline;
}
.formBox input[type="checkbox"] {
	display: none; 
}
.formBox input[type="checkbox"] ~ span {
	padding: 0.1rem 0 0.5rem 2.5rem;
	line-height: 2rem;
	border-radius: 0;
	border: none;
	font-weight: 700;
	display: inline-block;
	vertical-align: top;
	background: url(../img/common/check_icon01.png) no-repeat left top 0.1rem;
	background-size: 2.2rem 2.2rem;
	letter-spacing: 0.05em;
	cursor: pointer;
}
.formBox input[type="checkbox"]:checked ~ span {
	background-image: url(../img/common/check_icon02.png);
}
.formBox input[type="radio"] {
	display: none; 
}
.formBox input[type="radio"] ~ span {
	padding: 0.1rem 0 0.5rem 2.3rem;
	line-height: 1.7rem;
	border-radius: 0;
	font-weight: 700;
	border: none;
	display: inline-block;
	vertical-align: top;
	background: url(../img/common/radio_icon01.png) no-repeat left top 0.2rem;
	background-size: 1.7rem 1.7rem;
	letter-spacing: 0.05em;
	cursor: pointer;
}
.formBox input[type="radio"]:checked ~ span {
	background-image: url(../img/common/radio_icon02.png);
}
.formBox .radioUl {
	margin-right: -2rem;
	padding: 0.6rem 0.4rem 0;
	display: flex;
	flex-wrap: wrap;
	gap: 2rem 2.4rem;
}
.formBox .radioUl02 {
	gap: 2rem 1rem;
}
.formBox .textBox {
	margin: 2rem auto 0;
	max-width: 49.4rem;
	height: 20rem;
	font-size: 1.1rem;
	font-weight: 700;
	padding: 1.1rem 2.1rem;
	overflow-y: auto;
	line-height: 1.75;
	border: 1px solid #1a1a1a;
}
.formBox .textBox p {
	margin-bottom: 1.6rem;
}
.formBox .textBox p:last-child {
	margin-bottom: 0;
}
.formBox .submit {
	margin-top: 1.9rem;
	text-align: center;
}
.formBox .submit li:not(:last-child) {
	margin-bottom: 2rem;
}
.formBox .submit input {
	padding-left: 6.7rem;
	width: 15.4rem;
	height: 4.3rem;
	color: #000;
	font-size: 1.4rem;
	background: #ffd500 url("../img/common/btn_icon01.png") no-repeat left 2.5rem center;
	background-size: 3.5rem auto;
	border-radius: 5rem;
	border: none;
	letter-spacing: 0;
	cursor: pointer;
	text-align: left;
	transition: 0.3s;
}
.formBox .inputUl {
	display: flex;
	gap: 0 3.1rem;
}
.formBox .inputUl input {
	width: 15.4rem;
}
.formBox .telTxt {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
}
.formBox .telTxt input {
	width: 6rem;
}
.formBox .telTxt span {
	margin: 0 0.4rem;
}
.formBox .notes {
	margin-top: 0.5rem;
	color: #595757;
}
.formBox .errorMsg {
	margin-bottom: 3rem;
	color: #ed1c24;
	transform: rotate(0.05deg);
}
#confirmForm .formDl dt {
	margin-top: 0;
}
.formBox .submit #edit {
	padding-left: 0;
	background-image: none;
	text-align: center;
	background-color: #ffd500;
}
@media all and (min-width: 897px) {
	.formBox .submit input:hover {
		background-image: url("../img/common/btn_icon02.png");
	}
	.formBox .submit #edit:hover {
		opacity: 0.7;
	}
	.formBox .agreeTxt a:hover {
		text-decoration: none;
	}

	/* px size */
	#main .entryBox .content {
		max-width: 846px;
	}
	#main .entryBox .formBox {
		padding: 39px 140px 107px;
		border: 3px solid #005bab;
		border-radius: 30px;
	}
	#main .entryBox .topTxt {
		margin-bottom: 51px;
		font-size: 12px;
	}
	#main .formDl {
		font-size: 12px;
	}
	#main .formDl dt {
		margin-top: 5px;
		width: 122px;
		font-size: 14px;
	}
	#main .formDl dd {
		padding: 0 0 28px 30px;
		width: calc(100% - 122px);
		min-height: 80px;
	}
	.formBox .must {
		padding: 1px 3px 3px;
		font-size: 10px;
		border-radius: 2px;
		margin-top: 2px;
	}
	.formBox input[type="text"],
	.formBox input[type="email"],
	.formBox input[type="tel"],
	.formBox input[type="number"],
	.formBox input[type="submit"],
	.formBox textarea,
	.formBox select {
		max-width: 352px;
		height: 30px;
		font-size: 12px;
		border-radius: 6px;
		padding: 0 10px;
	}
	.formBox select {
		padding-right: 30px;
		background-position: right 12px center;
		background-size: 8px auto;
	}
	.formBox .agreeTxt {
		margin-top: 38px;
		font-size: 10px;
	}
	.formBox input[type="checkbox"] ~ span {
		padding: 1px 0 5px 25px;
		line-height: 20px;
		background-position: left top 1px;
		background-size: 22px 22px;
	}
	.formBox input[type="radio"] ~ span {
		padding: 1px 0 5px 23px;
		line-height: 17px;
		border-radius: 0;
		background-position: left top 2px;
		background-size: 17px 17px;
	}
	.formBox .radioUl {
		margin-right: -2px;
		padding: 6px 4px 0;
		gap: 20px 24px;
	}
	.formBox .radioUl02 {
		gap: 20px 10px;
	}
	.formBox .textBox {
		margin: 20px auto 0;
		max-width: 494px;
		height: 202px;
		font-size: 11px;
		padding: 11px 21px;
	}
	.formBox .textBox p {
		margin-bottom: 16px;
	}
	.formBox .textBox p:last-child {
		margin-bottom: 0;
	}
	.formBox .submit {
		margin-top: 19px;
	}
	.formBox .submit li:not(:last-child) {
		margin-bottom: 20px;
	}
	.formBox .submit input {
		padding-left: 67px;
		width: 154px;
		height: 43px;
		font-size: 14px;
		background-position: left 25px center;
		background-size: 35px auto;
		border-radius: 50px;
	}
	.formBox .inputUl {
		gap: 0 31px;
	}
	.formBox .inputUl input {
		width: 154px;
	}
	.formBox .telTxt input {
		width: 60px;
	}
	.formBox .telTxt span {
		margin: 0 4px;
	}
	.formBox .notes {
		margin-top: 5px;
	}
	.formBox .errorMsg {
		margin-bottom: 30px;
	}
	#confirmForm .formDl dt {
		margin-top: 0;
	}
}
@media all and (max-width: 896px) {
	#main .entryBox .formBox {
		padding: 2rem 1.5rem 4.4rem;
	}
	#main .formDl {
		display: block;
	}
	#main .formDl dt {
		margin: 0 0 1rem;
		width: auto;
	}
	#main .formDl dd {
		padding: 0 0 2.8rem 0;
		width: auto;
		min-height: 0;
	}
	.formBox .inputUl {
		gap: 0 1rem;
	}
	.formBox .inputUl input {
		width: 12.4rem;
	}
	.formBox .wid01 {
		width: 59% !important;
	}
	.formBox input[type="text"],
	.formBox input[type="email"],
	.formBox input[type="tel"],
	.formBox input[type="number"],
	.formBox input[type="submit"],
	.formBox textarea,
	.formBox select {
		max-width: inherit;
	}
	.formBox .must {
		float: none;
		margin: -0.4rem 0 0 1rem;
	}
	.formBox .radioUl {
		gap: 1rem;
		margin-right: 0;
	}
	.formBox .wid02 {
		width: 45.8% !important;
	}
	#main .entryBox {
		mask: url("../img/index/bg01_sp.png") no-repeat left top / 100% 100%;
		background-color: #96bcdd;
	}
	.formBox .textBox {
		max-width: inherit;
	}
}


#main .thanksBox {
	mask: inherit;
}
#main .thanksBox .formBox {
	font-size: 2.2rem;
	padding: 10rem 15.1rem;
}
#main .thanksBox .formBox p {
	margin-bottom: 5rem;
	transform: rotate(0.05deg);
}
#main .thanksBox .formBox p:last-child {
	margin-bottom: 0;
}
@media all and (min-width: 897px) {
	#main .thanksBox .formBox a:hover {
		text-decoration: underline;
	}
}
@media all and (max-width: 896px) {
	#main .thanksBox .formBox {
		font-size: 1.4rem;
		padding: 4.4rem 2rem 4.4rem;
	}
	#main .thanksBox {
		min-height: 89svh;
	}
}


/* mainVisual */
#main .bgBox {
	padding: 33.2rem 0 0 0;
}
#main .bgBox::after {
	mix-blend-mode: multiply; 
	background-image: url("../img/common/en_bg02.png");
}
#main .mainVisual img {
	width: 100%;
}
#main .mainVisual .content {
	padding-bottom: 4.5rem;
	position: relative;
}
#main .mainVisual .image {
	width: 32.4rem;
	margin: 0 auto;
	transform: translateX(1.9rem);
}
#main .mainVisual .title {
	margin-left: 0.6rem;
	width: 100rem;
	position: absolute;
	bottom: 6.2rem;
	left: 50%;
	transform: translateX(-50%);
}
#main .mainVisual .title .img01 {
	width: 78rem;
	position: absolute;
	bottom: calc(100% - 1px);
	left: 50%;
	transform: translateX(-50%);
	margin-left: 1.9rem;
}
#main .mainVisual .talkImg {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
}
#main .mainVisual .talk01 {
	margin: -10.1rem 0 0 -35.8rem;
	width: 37.5rem;
} 
#main .mainVisual .talk02 {
	width: 42.5rem;
	margin: 22.6rem 0 0 65rem;
}
#main .mainVisual .talk03 {
	width: 43rem;
	margin: 21.6rem 0 0 -61.8rem;
}
#main .mainVisual .talk04 {
	width: 36.5rem;
	margin: -11.9rem 0 0 39.9rem;
}
@media all and (max-width: 896px) {
	#main .mainVisual .image {
		width: 14.4rem;
	}
	#main .bgBox {
		padding-top: 23.2rem;
	}
	#main .mainVisual .title .img01 {
		width: 32rem;
		margin-left: 0;
	}
	#main .mainVisual .title {
		width: 33rem;
	}
	#main .mainVisual .talk01 {
		margin: -12.1rem 0 0 -9.8rem;
		width: 10.5rem;
	}
	#main .mainVisual .talk02 {
		width: 12rem;
		margin: 4.6rem 0 0 12rem;
	}
	#main .mainVisual .talk03 {
		width: 12rem;
		margin: 4.6rem 0 0 -12rem;
	}
	#main .mainVisual .talk04 {
		width: 10rem;
		margin: -11.9rem 0 0 10rem;
	}
	#main .mainVisual .content {
		max-width: 34.5rem;
		margin: 0 auto;
	}
}

/* showBox */
#main .showBox {
	padding: 10.3rem 0 21.7rem;
	background-color: #005bab;
}
#main .showBox .content {
	max-width: 100.4rem;
}
#main .showBox .textBox {
	margin: 0 auto 11.4rem;
	padding: 11rem 0 1rem;
	color: #005bab;
	font-size: 1.93rem;
	background-color: #fff;
	border-radius: 50%;
	max-width: 85.2rem;
	min-height: 85.2rem;
	position: relative;
	text-align: center;
}
#main .showBox .textBox p {
	margin-bottom: 2.7rem;
	transform: rotate(0.05deg);
	line-height: 2.05;
}
#main .showBox .textBox p:last-child {
	margin-bottom: 0;
}
#main .showBox .textBox .txt {
	margin-bottom: 3.8rem;
}
#main .showBox .textBox .bg {
    position: relative;
    color: rgba(0,91,171,1);
    display: inline-block;
}
#main .showBox .textBox .bg::before {
	position: absolute;
	left: 0;
	top: 51%;
	width: 100%;
	height: 69%;
	background-color: rgba(0,91,171,1);
	content: "";
	clip-path: inset(0 100% 0 0);
	border-radius: 0.3rem;
	z-index: -1;
	border-radius: 0.5rem;
	transform: translateY(-50%);
}
#main .showBox .textBox.isShow .bg {
    animation: bgShow-color 1s cubic-bezier(0.25, 1, 0.5, 1) 1 forwards;
    animation-delay: inherit;
}
#main .showBox .textBox.isShow .bg:before {
    animation: bgShow-bg 1s cubic-bezier(0.25, 1, 0.5, 1) 1 forwards;
    animation-delay: inherit;
}
@keyframes bgShow-color {
    0%,50% {
        color: rgba(0,91,171,1);
    }
    100% {
        color: rgba(255,255,255,1);
    }
}
@keyframes bgShow-bg {
    0%,50% {
        clip-path: inset(0 100% 0 0);
    }
    100% {
        clip-path: inset(0 0 0 0);
    }
}
#main .showBox .textBox .line {
	position: relative;
	z-index: 5;
}
#main .showBox .textBox .line::after {
    width: 100%;
    height: 1rem;
    background-color: #ffff00;
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: -1;
    clip-path: inset(0 100% 0 0);
}
#main .showBox .textBox.isShow .line::after {
    animation: lineright 1s cubic-bezier(0.25, 1, 0.5, 1) 1 forwards;
    animation-delay: inherit;
}
@keyframes lineright {
    0%,50% {
        clip-path: inset(0 100% 0 0);
    }
    100% {
        clip-path: inset(0 0 0 0);
    }
}
#main .showBox .textBox .image {
	width: 27.9rem;
	position: absolute;
	top: -0.9rem;
	right: -4.3rem;
}
#main .showBox .textBox .image02 {
	width: 29.7rem;
	top: auto;
	bottom: 5.6rem;
	right: auto;
	left: -10.1rem;
}
#main .showBox .title {
	margin: 0 0 6.1rem 8.5rem;
	text-align: center;
	color: #fff;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 900;
	font-size: 3.722rem;
	text-shadow: -0.3rem -0.3rem 1px #005bab,0.3rem -0.3rem 1px #005bab,-0.3rem 0.3rem 1px #005bab,0.3rem 0.3rem 1px #005bab;
	letter-spacing: 0.2em;
}
#main .showBox .title span {
	margin-bottom: 2.4rem;
	display: inline-block;
	vertical-align: top;
	position: relative;
}
#main .showBox .title span::after {
	width: 100%;
	height: 1.9rem;
	position: absolute;
	bottom: -0.4rem;
	left: 0;
	background: url("../img/index/line.png") repeat-x left top / auto 100%;
	content: "";
	z-index: -1;
}
#main .showBox .title img {
	width: 66.8rem;
}
#main .showBox .textImg {
	margin: 0 2.2rem 9rem 0;
	text-align: center;
}
#main .showBox .textImg img {
	width: 58rem;
}
#main .showBox .imgUl li {
	width: 39.7rem;
}

@media all and (min-width: 897px) {
	#main .showBox .imgUl li:nth-child(2n) {
		margin-left: auto;
	}
	#main .showBox .imgUl .item02 {
		margin-top: -19.5rem;
		margin-right: 5.5rem;
	}
	#main .showBox .imgUl .item03 {
		margin: -2.9rem 0 0 9.5rem;
	}
}
@media all and (max-width: 896px) {
	#main .showBox .textBox .image {
		width: 11.9rem;
		top: -0.9rem;
		right: -2.3rem;
	}
	#main .showBox .textBox .image02 {
		width: 13rem;
		top: auto;
		bottom: 0;
		left: -2rem;
		right: auto;
	}
	#main .showBox .textBox {
		margin-bottom: 7rem;
		font-size: 1.5rem;
		border-radius: 5rem;
		min-height: 0;
		padding: 6.4rem 0 8rem;
	}
	#main .showBox .title {
		margin: 0 0 6.1rem 0;
		font-size: 2.3rem;
		letter-spacing: 0;
	}
	#main .showBox .title span::after {
		height: 1.1rem;
		bottom: -0.5rem;
		left: 0;
	}
	#main .showBox .title span {
		margin-bottom: 1rem;
	}
	#main .showBox .textImg {
		margin: 0 0 9rem 0;
	}
	#main .showBox .textImg img {
		width: 34.5rem;
	}
	#main .showBox .imgUl {
		margin: 0 3rem;
	}
	#main .showBox .imgUl li {
		margin-bottom: 5rem;
		width: auto;
		text-align: center;
	}
	#main .showBox .imgUl li:last-child {
		margin-bottom: 0;
	}
	#main .showBox .imgUl img {
		max-width: 30rem;
		width: 100%;
	}
}


/* recordBox */
#main .recordBox {
	padding: 20.5rem 0 28.3rem;
	position: relative;
}
#main .recordBox::before {
	width: 100%;
	height: 13.4rem;
	position: absolute;
	bottom: calc(100% - 0.2rem);
	left: 0;
	background: url("../img/index/bg02.png") no-repeat left top / 100% 100%;
	content: "";
}
#main .recordBox .title {
	margin-bottom: 11rem;
	text-align: center;
}
#main .recordBox .title .inner {
	display: inline-block;
	vertical-align: top;
	position: relative;
}
#main .recordBox .title .img01 {
	width: 22.6rem;
	position: absolute;
	top: -7rem;
	left: -13.1rem;
}
#main .recordBox .title .img02 {
	width: 56.3rem;
	position: relative;
	z-index: 10;
}
#main .recordBox .title .img03 {
	width: 12rem;
	position: absolute;
	top: -2rem;
	right: -8.4rem;
}
#main .recordBox .title .img04 {
	width: 31.5rem;
	position: absolute;
	top: -7.8rem;
	right: -43.2rem;
}
#main .recordBox .subBox {
	position: relative;
}
#main .recordBox .subBox .image {
	position: absolute;
}
#main .recordBox .subBox .image.num01 {
	width: 26rem;
	top: 0.3rem;
	left: -26.2rem;
}
#main .recordBox .subBox .image.num02 {
	width: 38.2rem;
	bottom: -15.9rem;
	right: -32.8rem;
}
#main .recordBox .subBox .image.num03 {
	width: 27.5rem;
	bottom: 5.2rem;
	left: -29rem;
}
#main .recordBox .subBox .image.num04 {
	width: 38rem;
	top: 8.4rem;
	right: -33.1rem;
}
#main .recordBox .listUl {
	display: flex;
	justify-content: space-between;
	margin: 0 auto;
	padding-left: 2.6rem;
	max-width: 67rem;
	font-size: 2rem;
	line-height: 1.45;
}
#main .recordBox .listUl > li {
	width: calc(50% - 1.1rem);
}
#main .recordBox .listUl ul li {
	margin-bottom: 1.2rem;
	padding: 0.7rem 2.3rem 0.5rem 1.7rem;
	border: 1px solid #005bab;
	border-radius: 3rem;
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	box-shadow: 0.3rem 0.4rem 0 #eaa0d9;
}
#main .recordBox .listUl ul li:last-child {
	margin-bottom: 0;
}
#main .recordBox .listUl .ttl {
	flex: 1;
}
#main .recordBox .listUl span {
	transform: rotate(0.05deg);
}
#main .recordBox .listUl .num {
	margin-left: -4rem;
	white-space: nowrap;
}
#main .recordBox .listUl .size {
	margin-bottom: 0.8rem;
	font-size: 1.7rem;
	padding: 0.2rem 2.3rem 0.1rem 1.7rem;
}
#main .recordBox .listUl .size02 {
	font-size: 1.5rem;
	margin-bottom: 0.8rem;
	padding: 0.5rem 2.3rem 1rem 1.7rem;
}
#main .recordBox .listUl .size03 {
	padding: 0.4rem 2.3rem 0.6rem 1.7rem;
	font-size: 1.118rem;
}
@media all and (max-width: 896px) {
	#main .recordBox::before {
		height: 5.4rem;
	}
	#main .recordBox .title .img02 {
		width: 21rem;
	}
	#main .recordBox .title .img03 {
		width: 5rem;
		top: -2rem;
		right: -3.4rem;
	}
	#main .recordBox .title .img04 {
		width: 18.6rem;
		top: -13.2rem;
		right: -8rem;
	}
	#main .recordBox .title .img01 {
		width: 8.6rem;
		top: -3rem;
		left: -5.1rem;
	}
	#main .recordBox {
		padding: 14.5rem 0 10rem;
	}
	#main .recordBox .listUl {
		padding-left: 0;
		max-width: inherit;
		font-size: 1.4rem;
		line-height: 1.45;
	}
	#main .recordBox .listUl ul li {
		padding: 0.3rem 1.1rem 0.5rem 1.1rem;
	}
	#main .recordBox .listUl .size02 {
		font-size: 1.1rem;
		padding: 1rem 1.1rem 0.5rem 1.1rem;
	}
	#main .recordBox .listUl .size {
		font-size: 1.2rem;
		padding: 0.3rem 1.1rem 0.5rem 1.1rem;
	}
	#main .recordBox .listUl .num {
		margin-left: -1.5rem;
	}
	#main .recordBox .listUl .size02 .num {
		margin-left: 0;
	}
	#main .recordBox .listUl > li {
		width: calc(50% - 0.5rem);
	}
	#main .recordBox .listUl .size03 {
		padding: 0.3rem 1.1rem 0.5rem 1.1rem;
		font-size: 1rem;
	}
	#main .recordBox .title {
		margin-bottom: 5rem;
	}
}


/* slideBox */
#main .slideBox {
	padding: 1.9rem 0 0.7rem;
	background-color: #005bab;
}
#main .slideBox li {
	margin: 0 2.5rem;
	width: 204.2rem !important;
}
@media all and (max-width: 896px) {
	#main .slideBox li {
		margin: 0 1.5rem;
		width: 70.2rem !important;
	}
}


/* caseBox */
#main .caseBox {
	padding: 20.2rem 0 9.3rem;
	background-color: #96bcdd;
}
#main .caseBox .content {
	max-width: 103.8rem;
}
#main .caseBox .title {
	margin-bottom: 4.5rem;
	text-align: center;
}
#main .caseBox .title .inner {
	display: inline-block;
	vertical-align: top;
	position: relative;
}
#main .caseBox .title .img01 {
	width: 48.5rem;
	position: relative;
	z-index: 10;
}
#main .caseBox .title .img02 {
	width: 11rem;
	position: absolute;
	top: -3.7rem;
	left: -7rem;
}
#main .caseBox .title .img03 {
	width: 32.3rem;
	position: absolute;
	top: -9.7rem;
	left: -38.7rem;
}
#main .caseBox .listUl {
	margin-right: 4rem;
	display: flex;
	flex-wrap: wrap;
	gap: 4.9rem 6rem;
	font-size: 1.448rem;
	line-height: 1.53;
}
#main .caseBox .listUl li {
	position: relative;
	width: calc((100% - 12rem) / 3);
}
#main .caseBox .listUl .innerBox {
	padding: 6.8rem 0.5rem 4.5rem 3rem;
	background: #fff;
	border-radius: 3.7rem;
	position: relative;
	overflow: hidden;
	box-shadow: 0.9rem 0.9rem 0 #262f36;
	transition: .3s;
	display: flex;
	align-items: center;
}
#main .caseBox .listUl .image {
	display: block;
	position: absolute;
	top: -12.3rem;
  	right: -13.8rem;
	width: 23.5rem;
	z-index: 20;
	opacity: 0;
    transform: rotate(10deg);
    transform-origin: left bottom;
    transition: .5s;
    visibility: hidden;
}
#main .caseBox .listUl .bg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}
#main .caseBox .listUl .bg img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
#main .caseBox .listUl dl {
	position: relative;
	z-index: 10;
	display: flex;
	flex-wrap: wrap;
}
#main .caseBox .listUl dl dt {
	width: 6.7rem;
	font-size: 1.3rem;
	letter-spacing: -0.1em;
}
#main .caseBox .listUl dl dt span {
	display: inline-block;
	color: #fff;
	position: relative;
}
#main .caseBox .listUl dl dt span::after {
	width: 2.3rem;
	height: 2.3rem;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	background-color: #005bab;
	border-radius: 50%;
	content: '';
	z-index: -1;
}
#main .caseBox .listUl dl dd {
	width: calc(100% - 6.7rem);
	min-height: 2.9rem;
	letter-spacing: -0.05em;
}
@media all and (min-width: 897px) {
	#main .caseBox .listUl li:hover .innerBox {
		transform: scale(1.05);
		box-shadow: 1.2rem 1.2rem 0 #262f36;
	}
	#main .caseBox .listUl li:hover .image {
		opacity: 1;
		transform: rotate(0deg);
		visibility: visible;
	}


	/* px size */
	#main .caseBox .content {
		max-width: 1038px;
	}
	#main .caseBox .listUl {
		margin-right: 40px;
		gap: 49px 60px;
		font-size: 14.48px;
	}
	#main .caseBox .listUl li {
		width: calc((100% - 120px) / 3);
	}
	#main .caseBox .listUl .innerBox {
		padding: 68px 5px 45px 30px;
		border-radius: 37px;
		box-shadow: 9px 9px 0 #262f36;
	}
	#main .caseBox .listUl .image {
		top: -123px;
		right: -138px;
		width: 235px;
	}
	#main .caseBox .listUl dl dt {
		width: 67px;
		font-size: 13px;
	}
	#main .caseBox .listUl dl dt span::after {
		width: 23px;
		height: 23px;
	}
	#main .caseBox .listUl dl dd {
		width: calc(100% - 67px);
		min-height: 29px;
	}
}
@media all and (max-width: 896px) {
	#main .caseBox .title .img01 {
		width: 19.5rem;
	}
	#main .caseBox .title .img02 {
		width: 6rem;
		top: -3rem;
		left: -3.5rem;
	}
	#main .caseBox .title .img03 {
		width: 19.6rem;
		top: -14.7rem;
		left: -9rem;
		max-width: inherit;
	}
	#main .caseBox {
		padding: 15.2rem 0 9.3rem;
	}
	#main .caseBox .listUl {
		margin-right: 1.5rem;
		padding: 0 2rem;
		display: block;
	}
	#main .caseBox .listUl li {
		margin-bottom: 15rem;
		width: auto;
	}
	#main .caseBox .listUl li:last-child {
		margin-bottom: 0;
	}
	#main .caseBox .listUl .image {
		top: -13.3rem;
		right: -5.2rem;
		width: 24rem;
		visibility: inherit;
		opacity: 1;
		transform: rotate(0);
	}
	#main .caseBox .listUl {
		font-size: 1.3rem;
	}
	#main .caseBox .listUl dl dt {
		font-size: 1.2rem;
	}
	#main .caseBox .listUl dl {
		width: 100%;
		max-width: 37.5rem;
	}
	#main .caseBox .listUl .innerBox {
		justify-content: center;
	}
	#main .caseBox .title {
		margin-bottom: 14rem;
	}
}


/* supportBox */
#main .supportBox {
	padding: 23.3rem 0 0.9rem;
	background-color: #005bab;
}
#main .supportBox .content {
	margin-bottom: 14.3rem;
	max-width: 103.8rem;
}
#main .supportBox .title {
	margin-bottom: 12.7rem;
	text-align: center;
}
#main .supportBox .title .inner {
	display: inline-block;
	vertical-align: top;
	position: relative;
}
#main .supportBox .title .img01 {
	width: 56rem;
	position: relative;
	z-index: 10;
}
#main .supportBox .title .img02 {
	width: 34.3rem;
	position: absolute;
	top: -7.6rem;
	right: -34rem;
}
#main .supportBox .title .img02 .txt {
	color: #005bab;
	font-size: 1.8rem;
	font-weight: 900;
	width: 100%;
	position: absolute;
	top: 46%;
	left: 0;
	transform: translateY(-50%);
	display: block;
	text-align: center;
	line-height: 1.55;
}
#main .supportBox .listUl {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0 11.6rem;
}
#main .supportBox .listUl li {
	width: 26.7rem;
}
#main .supportBox .listUl a {
	padding: 8.9rem 1rem 8.2rem;
	display: block;
	color: #fff;
	text-align: center;
	position: relative;
	font-size: 1.6rem;
	font-weight: 800;
	background-color: #18b6ee;
	border-radius: 3rem;
}
#main .supportBox .listUl .image {
	width: 13.8rem;
	position: absolute;
	top:-6.6rem;
	left: 50%;
	transform: translateX(-50%);
	transition: .3s;
}
#main .supportBox .listUl .ttl img {
	width: 18.2rem;
}
#main .supportBox .listUl .ttl {
	margin-bottom: 5.3rem;
}
#main .supportBox .listUl .item02 a {
	background-color: #ea6177;
}
#main .supportBox .listUl .item03 a {
	background-color: #f39945;
}
#main .supportBox .slideBox02 {
	mix-blend-mode: multiply;
}
#main .supportBox .slideBox02 li {
	width: 242.5rem !important;
}
@media all and (min-width: 897px) {
	#main .supportBox .listUl a:hover .image {
		transform: translateX(-50%) scale(1.05);
	}
}
@media all and (max-width: 896px) {
	#main .supportBox .title .img01 {
		width: 22rem;
	}
	#main .supportBox .title .img02 {
		width: 26rem;
		position: absolute;
		top: -16rem;
		right: -8rem;
	}
	#main .supportBox .title {
		margin: 0 0 9.3rem 0;
	}
	#main .supportBox .title .img02 .txt {
		font-size: 1.2rem;
		margin-top: -0.5rem;
	}
	#main .supportBox {
		padding: 18.3rem 0 0.9rem;
	}
	#main .supportBox .listUl {
		display: block;
	}
	#main .supportBox .listUl li {
		margin-bottom: 7rem;
		width: auto;
	}
	#main .supportBox .listUl li:last-child {
		margin-bottom: 0;
	}
	#main .supportBox .listUl .ttl img {
		width: 14.2rem;
	}
	#main .supportBox .listUl .image {
		width: 12rem;
		top: -4.6rem;
	}
	#main .supportBox .listUl a {
		font-size: 1.5rem;
		padding-bottom: 6.2rem;
	}
	#main .supportBox .listUl .ttl {
		margin-bottom: 3.3rem;
	}
	#main .supportBox .slideBox02 li {
		width: 100rem !important;
	}
	#main .supportBox .content {
		margin-bottom: 10.3rem;
	}
}



/* faqBox */
#main .faqBox {
	margin-bottom: -15rem;
	padding: 16.7rem 0 23.2rem;
	background: url("../img/index/bg03.jpg") repeat left top / 3.6rem auto;
}
#main .faqBox  .content {
	max-width: 88.8rem;
}
#main .faqBox .bg {
	padding: 7.9rem 4rem;
	background-color: #fff;
}
#main .faqBox .headLine01 {
	margin-bottom: 4.5rem;
	color: #005bab;
	font-size: 3rem;
	font-weight: 800;
}
#main .faqBox .headLine01 img {
	width: 27.7rem;
}
#main .faqBox .headLine01 span {
	display: inline-block;
	transform: rotate(0.05deg);
	line-height: 1.4;
	letter-spacing: 0.3em;
}
#main .faqBox .faqDl {
	margin: 0 auto;
	max-width: 56.4rem;
	font-size: 1.4rem;
	line-height: 1.43;
	transform: rotate(0.05deg);
}
#main .faqBox .faqDl .innerBox {
	padding: 0 2rem 2.4rem;
	position: relative;
}
#main .faqBox .faqDl dt {
	padding: 2.2rem 4rem 1.6rem 1.8rem;
	border-top: 1px solid #231815;
	position: relative;
	cursor: pointer;
}
#main .faqBox .faqDl dt:first-child {
	border-top: none;
}
#main .faqBox .faqDl dt::before,
#main .faqBox .faqDl .innerBox::before {
	position: absolute;
	top: 2.1rem;
	left: 0;
	content: "Q.";
}
#main .faqBox .faqDl .innerBox::before {
	top: 0;
	content: "A.";
}
#main .faqBox .faqDl dt::after {
	margin-top: 0.2rem;
	width: 2.1rem;
	height: 2.1rem;
	position: absolute;
	top: 50%;
	right: 0.9rem;
	content: "";
	transform: translateY(-50%);
	background: url("../img/index/faq_icon01.png") no-repeat left top / 100% 100%
}
#main .faqBox .faqDl dt.on::after {
	background-image: url("../img/index/faq_icon02.png");
}
#main .faqBox .faqDl dd {
	display: none;
}
@media all and (min-width: 897px) {
	/* px size */
	#main .faqBox  .content {
		max-width: 888px;
	}
	#main .faqBox .bg {
		padding: 79px 40px;
	}
	#main .faqBox .faqDl {
		max-width: 564px;
		font-size: 14px;
	}
	#main .faqBox .faqDl .innerBox {
		padding: 0 20px 24px;
	}
	#main .faqBox .faqDl dt {
		padding: 22px 40px 16px 18px;
	}
	#main .faqBox .faqDl dt::before,
	#main .faqBox .faqDl .innerBox::before {
		top: 21px;
	}
	#main .faqBox .faqDl dt::after {
		margin-top: 2px;
		width: 21px;
		height: 21px;
		right: 9px;
	}
	#main .faqBox .faqDl .innerBox::before {
		top: 0;
	}
}
@media all and (max-width: 896px) {
	#main .faqBox .headLine01 img {
		width: 11.7rem;
	}	
	#main .faqBox .headLine01 {
		font-size: 1.8rem;
	}
	#main .faqBox .headLine01 span {
		letter-spacing: 0.1em;
	}
	#main .faqBox {
		margin-bottom: -15rem;
		padding: 6.7rem 0 20rem;
		background-size: 2rem auto;
	}
	#main .faqBox .bg {
		padding: 2rem 1rem;
	}
	#main .faqBox .faqDl {
		max-width: inherit;
	}
	#main .faqBox .faqDl dt::after {
		width: 1.7rem;
  		height: 1.7rem;
	}
}



/* popBox */
.popBox {
	max-width: 101.6rem;
	margin: 0 auto;
	padding: 3rem;
	background-color: #f39945;
	border-radius: 6.5rem;
}
#pop02 {
	background-color: #ea6177;
}
#pop03 {
	background-color: #18b6ee;
}
.popBox .innerBox {
	padding: 7.9rem 5.8rem;
	background-color: #fff;
	position: relative;
	font-size: 2rem;
	line-height: 1.95;
	border-radius: 3.5rem;
}
.popBox .innerBox p {
	margin-bottom: 3.9rem;
	transform: rotate(0.05deg);
}
.popBox .innerBox p:last-child {
	margin-bottom: 0;
}
.popBox .close {
	width: 2.2rem;
	position: absolute;
	top: 4.1rem;
	right: 5.4rem;
	cursor: pointer;
}
@media all and (min-width: 897px) {
	.popBox .close:hover {
		opacity: 0.7;
	}
}
@media all and (max-width: 896px) {
	.popBox {
		max-width: 94%;
		padding: 1rem;
		border-radius: 3rem;
	}
	.popBox .innerBox {
		padding: 7rem 1.5rem;
		font-size: 1.4rem;
		line-height: 1.95;
		border-radius: 2.5rem;
	}
	.popBox .close {
		width: 2.2rem;
		top: 2rem;
		right: 2rem;
	}
}

.mfp-fade.mfp-bg {
	opacity: 0;
	-webkit-transition: all 0.5s ease-out;
	transition: all 0.5s ease-out;
}
.mfp-fade.mfp-bg.mfp-ready {
	opacity: 0.8;
}
.mfp-fade.mfp-bg.mfp-removing {
	opacity: 0;
}
.mfp-fade.mfp-wrap .mfp-content {
	opacity: 0;
	-webkit-transition: all 0.5s ease-out;
	transition: all 0.5s ease-out;
}
.mfp-fade.mfp-wrap.mfp-ready .mfp-content {
	opacity: 1;
}
.mfp-fade.mfp-wrap.mfp-removing .mfp-content {
	opacity: 0;
}

.mfp-container {
	position: fixed;
	overflow-y: auto;
}




/* privacy
--------------------------------------*/
.privacy_box .txt {
	margin-bottom: 2rem;
}
.privacy_box .mb0 {
	margin-bottom: 0 !important;
}
.privacy_box table {
	border-collapse: collapse;
}
.privacy_box p a {
	color: #1919ef;
}
.privacy_list {
	margin: 0 0 2rem 1.4rem;
	list-style: decimal;
}
.privacy_tbl {
	border-top: 1px solid #ec6c00;
	border-left: 1px solid #ec6c00;
	margin-bottom: 3rem;
}
.privacy_tbl th,.privacy_tbl td {
	border-bottom: 1px solid #ec6c00;
	border-right: 1px solid #ec6c00;
	padding: 0.5rem 1rem;
}
.privacy_tbl th {
	background-color: #fbddd2;
	font-weight: normal;
}
.privacy_btxt {
	color: #ec6c00;
	font-size: 120%;
	font-weight: bold;
}
.privacy_dl {
	margin-bottom: 3rem;
}
.privacy_dl dt {
	color: #ec6c00;
	font-size: 110%;
}
.privacy_dl dd {
	margin: 0;
}
.privacy_dl .box_list li {
	text-indent: -1em;
	margin-left: 1em;
}
.privacy_dl .box_list2 li {
	text-indent: -2em;
	margin-left: 2em;
}
.privacy_mark {
	display: flex;
}
.privacy_mark .image {
	width: 7.5rem;
	margin-right: 2rem;
}
.privacy_mark .txt {
	flex: 1;
}
@media all and (min-width: 897px) {
	.privacy_box p a:hover {
		text-decoration: underline;
	}
}