/*----------------------------------------------------
☆Pager
----------------------------------------------------*/
.pagerArea .wp-pagenavi {
	width: 100%;
	margin: 50px auto 0 auto;
	text-align: center;
	font-size: 0;

	a,
	span {
		display: inline-block;
		padding: 8px 17px;
		color: #111;
		text-decoration: none;
		background: #f5f5f5;
		font-size: 1.4rem;
		margin-right: 4px;
		position: relative;
	}
}

@media screen and (max-width: 768px) {
	.pagerArea .wp-pagenavi {

		a,
		span {
			padding: 4px 12px;
			font-size: 1.2rem;
		}
	}
}

@media (hover: hover) and (pointer: fine) {

	.pagerArea .wp-pagenavi a:hover,
	.pagerArea .wp-pagenavi span:hover {
		background-color: #e7e4e4;
	}
}

@media (-ms-high-contrast: none),
(-ms-high-contrast: active) {

	.pagerArea .wp-pagenavi a:hover,
	.pagerArea .wp-pagenavi span:hover {
		background-color: #e7e4e4;
	}
}

.pagerArea .wp-pagenavi a::before,
.pagerArea .wp-pagenavi a::after {
	content: "";
	position: absolute;
	width: 5px;
	height: 7px;
	top: 18px;
}

@media screen and (max-width: 768px) {

	.pagerArea .wp-pagenavi a::before,
	.pagerArea .wp-pagenavi a::after {
		top: 12px;
	}
}

.pagerArea .wp-pagenavi .current {
	pointer-events: none;
	background-color: #111;
	color: #fff;
}

.pagerArea .wp-pagenavi .previouspostslink {
	padding-left: 22px;
}

.pagerArea .wp-pagenavi .nextpostslink {
	padding-right: 22px;
}

.pagerArea .wp-pagenavi .previouspostslink::before {
	left: 10px;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 3.5px 5px 3.5px 0;
	border-color: transparent #111 transparent transparent;
}

.pagerArea .wp-pagenavi .nextpostslink::after {
	right: 10px;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 3.5px 0 3.5px 5px;
	border-color: transparent transparent transparent #111;
}

/*----------------------------------------------------
☆Entry Form
----------------------------------------------------*/
html:has(.form[class]) {
	.wpcf7-form-control.wpcf7-radio {
		display: flex;
		flex-wrap: wrap;
		gap: 0 1em;

		.wpcf7-list-item {
			margin-inline-start: unset;
		}
	}

	.wpcf7-form-control.wpcf7-acceptance {
		.wpcf7-list-item {
			label {
				display: flex;
				justify-content: center;
			}
		}
	}

	.wpcf7-response-output {
		display: none;
	}

	.errText,
	.wpcf7-not-valid-tip,
	.wpcf7-response-output {
		background-color: #f6edee;
		border: none;
		color: #ad2d2d;
		font-size: 1.2rem;
		padding: 5px 7px;
		font-weight: 500;
		margin-top: 10px;
	}

	.errText {
		display: none;
	}

	.cauText {
		font-size: 1.1rem;
		margin-top: 10px;
		color: #828282;
		line-height: 1.6;
	}

	select {
		padding: 10px 30px 12px 15px;
		line-height: 140%;
		min-width: 10em;
		border: 1px solid #ccc;
		background: #fff;
		border-radius: 5px;
		-webkit-appearance: none;
		-moz-appearance: none;
		position: relative;
	}

	textarea {
		width: 100%;
	}

	td:has(.wpcf7-not-valid-tip) {
		.errText {
			display: block !important;
		}
	}

	td.zip,
	td.birth,
	td.graduate {
		.wpcf7-not-valid-tip {
			display: none;
		}
	}
}

@media screen and (max-width: 768px) {
	.form select {
		padding: 11px 9px 12px !important;
	}
}

/*----------------------------------------------------
☆Entry Form
----------------------------------------------------*/
.btnStyle_01 {
	max-width: 320px;
	width: 100%;
	margin: 0 auto;
}

@media screen and (max-width: 768px) {
	.btnStyle_01 {
		max-width: 240px;
	}
}

.btnStyle_01 label {
	display: block;
	background: #003461;
	color: #fff;
	border-radius: 5px;
	overflow: hidden;
	font-size: 0;
	position: relative;
	text-align: left;
}

@media screen and (max-width: 768px) {
	.btnStyle_01 label {
		border-radius: 3px;
	}
}

.btnStyle_01 label::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 0;
	height: 100%;
	background: #111;
	opacity: 0;
	transition: all .3s ease-in-out;
}

.btnStyle_01 label>span {
	font-size: 1.4rem;
	padding: 26px 30px;
	display: block;
	position: relative;
	z-index: 9;
	transition: all .3s ease-in-out;
	line-height: 1.6;
}

@media screen and (max-width: 768px) {
	.btnStyle_01 label>span {
		font-size: 1.3rem;
		padding: 20px 25px;
	}
}

.btnStyle_01 label>span::before {
	content: "";
	position: absolute;
	right: 75px;
	top: 0;
	width: 1px;
	height: 100%;
	background: #265279;
	transition: all .3s ease-in-out;
}

@media screen and (max-width: 768px) {
	.btnStyle_01 label>span::before {
		right: 62px;
	}
}

.btnStyle_01 label>span::after {
	content: "";
	position: absolute;
	top: 50%;
	right: 27px;
	transform: translateY(-50%);
	background: url("/lib/cmn_img/arw01_wh.png") no-repeat center center / cover;
	width: 17px;
	height: 7px;
	transition: all .3s ease-in-out;
}

@media screen and (max-width: 768px) {
	.btnStyle_01 label>span::after {
		right: 23px;
	}
}

.btnStyle_01 label:hover::before {
	width: 100%;
	opacity: 1;
}

.btnStyle_01 label:hover>span {
	letter-spacing: 0.05em;
}

.btnStyle_01 label:hover>span::before {
	background-color: #444;
}

.btnStyle_01 label:hover>span::after {
	right: 24px;
}

@media screen and (max-width: 768px) {
	.btnStyle_01.spLong {
		max-width: 300px;
	}
}

.btnStyle_01.gray a {
	background: #f5f5f5;
}

.btnStyle_01.gray a span {
	color: #111;
}

.btnStyle_01.gray a span::before {
	background: #ddd;
}

.btnStyle_01.gray a span::after {
	background-image: url("/lib/cmn_img/arw01.png");
}

.btnStyle_01.gray a:hover span {
	color: #fff;
}

.btnStyle_01.gray a:hover span::before {
	background-color: #555;
}

.btnStyle_01.gray a:hover span::after {
	background-image: url("/lib/cmn_img/arw01_wh.png");
}

.btnStyle_01.link a::before {
	background-color: #333;
}

.btnStyle_01.link a>span::after {
	background-image: url("/lib/cmn_img/icon_link_wh.png");
	width: 12px;
	height: 12px;
}

.btnStyle_01.bl a {
	background-color: #111;
}

.btnStyle_01.bl a>span::before {
	background: #444;
}

.btnStyle_01.sml {
	max-width: 220px;
}

@media screen and (max-width: 768px) {
	.btnStyle_01.sml {
		max-width: 200px;
	}
}

.btnStyle_01.sml a>span {
	font-size: 1.3rem;
	padding: 17px 25px;
}

@media screen and (max-width: 768px) {
	.btnStyle_01.sml a>span {
		font-size: 1.2rem;
		padding: 15px 25px;
	}
}

.btnStyle_01.sml a>span::before {
	right: 60px;
}

@media screen and (max-width: 768px) {
	.btnStyle_01.sml a>span::before {
		right: 54px;
	}
}

.btnStyle_01.sml a>span::after {
	right: 20px;
}

@media screen and (max-width: 768px) {
	.btnStyle_01.sml a>span::after {
		right: 18px;
	}
}

.btnStyle_01.sml a:hover>span::after {
	right: 16px;
}

.subscribeBtn {
	text-align: center;
	font-size: 0;
	max-width: 600px;
	width: 100%;
	margin: 0 auto;
}

.subscribeBtn input[type="button"] {
	font-size: 1.4rem;
	background-color: #003461;
	color: #FFF !important;
	display: inline-block;
	padding: 20px 0 !important;
	width: 49%;
	text-decoration: none;
	border-radius: 0 !important;
	-webkit-transition: all .3s ease-in-out;
	transition: all .3s ease-in-out;
}

.subscribeBtn input[type="button"]:hover {
	background-color: #555;
}

.subscribeBtn input[type="button"].gray {
	background-color: #ccc;
	border: 1px solid #ccc;
	color: #FFF;
	margin-right: 2%;
}

.subscribeBtn input[type="button"].gray:hover {
	background-color: #999;
	color: #fff !important;
}