body {
	font-family: 'Noto Sans JP', "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	color: #222;
	width: 100%;
	max-width: 700px;
	margin: 0 auto;
}
img {
	width: 100%;
	height: auto;
}
.large {
	font-size: 120%;
}
.larger {
	font-size: 150%;
}
.font_90 {
	font-size: 90%;	
}
.font_75 {
	font-size: 75%;	
}
.small {
	font-size: 14px;
}
.smaller {
	font-size: 12px;
}
.letter {
	letter-spacing: -0.05em;
}
.bold {
	font-weight: bold;
}
.bolder {
	font-weight: bolder;
}
.center {
	text-align: center;
}
.left {
	text-align: left;
}
.right {
	text-align: right;
}
.italic {
	font-style: italic;
}
.marker {
	background: linear-gradient(transparent 65%, #fff22a 65%);
	padding-right: 0.15em;
	padding-left: 0.15em;
}
.underline {
	display: inline-block;
	background: linear-gradient(transparent calc(100% - 1px), #000 1px);
	padding-bottom: 0.05em;
}
.underline_white {
	display: inline-block;
	background: linear-gradient(transparent calc(100% - 3px), #fff 3px);
	padding-bottom: 0.1em;
}
.underline_yellow {
	display: inline;
	background: linear-gradient(transparent calc(100% - 3px), #f4e025 3px);
	padding-bottom: 0.1em;
}
.underline_blue {
	display: inline;
	background: linear-gradient(transparent calc(100% - 3px), #9fc8df 3px);
	padding-bottom: 0.1em;
}
.underline_pink {
	display: inline;
	background: linear-gradient(transparent calc(100% - 2px), #f24d8b 2px);
	padding-bottom: 0.1em;
}
.underline_green {
	display: inline;
	background: linear-gradient(transparent calc(100% - 2px), #03955c 2px);
	padding-bottom: 0.1em;
}
.ribbon {
	color: #fff;
	display: inline-block;
	padding-right: 0.15em;
	padding-left: 0.15em;
}
.ribbon:not(.r_blue) {
	background-color: #c03014;
}
.ribbon.r_blue {
	background-color: #0075c2;
}
.ribbon.r_white {
	color: unset;
	background-color: #fff;
}
.dot {
	line-height: 1;
	position: relative;
	display: inline-flex;
	align-items: flex-end;
	height: 1.35em;
	margin-top: 0.25em;
}
.dot::before {
	content: '';
	display: block;
	border-radius: 50%;
	width: 0.2em;
	height: 0.2em;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
}
.ribbon:has(.dot) {
	line-height: 1;
	display: inline-block;
	padding-top: 0.3em;
	padding-bottom: 0.3em;
	margin-top: 0.3em;
}
.ribbon .dot::before {
	background-color: #fff!important;
}
.deep_orange .dot::before {
	background-color: #c03014;
}
.deep_blue .dot::before {
	background-color: #0059b3;
}
.green .dot::before {
	background-color: #03955c;
}
.orange {
	color: #e8550c;
}
.deep_orange {
	color: #c03014;
}
.orange_6 {
	color: #f6775f;
}
.blue {
	color: #0079d6;
}
.blue_6 {
	color: #016daa;
}
.deep_blue {
	color: #0059b3;
}
.yellow {
	color: #fff22a;
}
.yellow_6 {
	color: #d0a600;
}
.yellow_6_2 {
	color: #f4e025;
}
.green {
	color: #03955c;
}
.pink {
	color: #f24d8b;
}
.text_gradation {
	display: inline-block;
	background: linear-gradient(20deg, #c51c1c, #da4b04 71%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}
.gradation {
	padding: 5px;
	margin: 1em 0;
}
.g_orange {
	background: linear-gradient(20deg, #c51c1c, #da4b04 71%);
}
.g_blue {
	background: linear-gradient(20deg, #387bd7, #39a8ef 71%);
}
.bg_gray {
	background-color: #f4f4f4;
}
.half {
	display: inline-block;
	transform: scaleX(0.5);
}
.annotation {
	font-size: 10px;
	color: #666;
}
.arrow_area::before {
	content: '';
	display: block;
	width: 100%;
	height: 10px;
	position: relative;
	z-index: 1;
}
.arrow_shadow {
	filter: drop-shadow(0 3px 6px #ccc);
	position: relative;
}
.arrow {
	clip-path: polygon(0% 0%, 50% 100%, 100% 0);
	aspect-ratio: 10 / 1;
	margin-top: -1px;
	margin-bottom: 30px;
}
.speek_line {
	border-bottom: 3px solid;
	width: fit-content;
	padding-bottom: 5px;
	margin: 0 auto calc(20px + 0.8em);
	position: relative;
}
.speek_line::before,
.speek_line::after {
	content: '';
	display: block;
	height: 0.8em;
	position: absolute;
	bottom: -0.8em;
}
.speek_line::before {
	content: '';
	background-color: #fff;
	width: 0.6em;
	left: 1.55em;
}
.speek_line::after {
	clip-path: polygon(54% 0, 68% 11%, 28% 74%, 91% 41%, 100% 55%, 9% 100%, 0 90%);
	width: 0.8em;
	left: 1em;
}
.speek_line:not(.ora):not(.blu) {
	border-bottom-color: #c03014;
}
.speek_line:not(.ora):not(.blu)::after {
	background-color: #c03014;
}
.speek_line.ora {
	border-bottom-color: #e8550c;
}
.speek_line.ora::after {
	background-color: #e8550c;
}
.speek_line.blu {
	border-bottom-color: #0075c2;
}
.speek_line.blu::after {
	background-color: #0075c2;
}


/* header
-------------------------------------------------------*/
.logo {
	font-size: 1.2em;
	font-weight: bolder;
	color: #011a50;
}
.pr_text {
	font-size: 12px;
	text-align: right;
	color: #666;
}
@media screen and (max-width: 768px) {
	.pr_text {
		padding: 5px;
	}
}


/* footer
-------------------------------------------------------*/
footer {
	text-align: center;
	color: #011a50;
}
#sub_footer .inner {
	text-align: center;
}
#sub_footer .inner a {
	line-height: 3em;
	display: inline-block;
	padding: 0 1em;
}


/* 404
-------------------------------------------------------*/
section:has(h1.entry-title) {
	font-size: 2em;
	border: 1px solid #c03014;
	padding: 1em 0;
	margin: 1em 10px;
}
.error404 section {
	text-align: center;
}
.error404 section p {
	margin-bottom: 30px;
}


/* content
-------------------------------------------------------*/
.inner {
	padding: 0 20px 20px;
}
@media screen and (max-width: 768px) {
	.inner {
		padding: 0 10px 20px;
	}
}


/* content
-------------------------------------------------------*/
#header {
	display: flex;
	align-items: end;
	justify-content: space-between;
	margin-bottom: 5px;
}
#header .wp-block-image img {
	max-width: 125px;
	margin-left: 5px;
}


/* introduction
-------------------------------------------------------*/
body h1:first-of-type{
	line-height: 0;
}
.introduction h1 {
	margin-bottom: 10px;
}
.introduct_1,
.introduct_2 {
	padding: 0 10px;
}
.introduct_1 {
	position: relative;
	top: -5px;
	z-index: -1;
	margin-bottom: -10px;
}
.speech_bubble {
	display: flex;
	justify-content: space-between;
}
.speech_bubble:first-of-type {
	margin-bottom: 0.5em;
}
.speech_bubble p {
	background-color: #fbd7c7;
	border-radius: 10px;
	display: flex;
	align-items: center;
	padding: 10px;
	width: calc(75% - 10px);
	position: relative;
}
.speech_bubble p {
	margin-top: 10px;
}
.speech_bubble p::after {
	content: '';
	background-color: #fbd7c7;
	display: block;
	width: 1em;
	height: 1em;
	position: absolute;
}
.speech_bubble:first-of-type p::after {
	clip-path: polygon(0 0, 100% 40%, 0 100%);
	top: 1em;
	right: calc(-1em + 1px);
}
.speech_bubble:nth-of-type(2) p::after {
	clip-path: polygon(0 60%, 100% 0, 100% 100%);
	bottom: 1em;
	left: calc(-1em + 1px);
}
.speech_bubble img {
	width: 25%;
}
.speech_bubble_2 p {
	border-radius: 10px;
	width: 80%;
	padding: 0.5em 1em;
	filter: drop-shadow(0 3px 1px #2ac085) drop-shadow(0 -3px 1px #2ac085) drop-shadow(3px 0 1px #2ac085) drop-shadow(-3px 0 1px #2ac085);
	position: relative;
}
.speech_bubble_2:has(+ .speech_bubble_2) p {
	margin-bottom: 1.5em;
}
.speech_bubble_2 + .speech_bubble_2 p {
	float: right;
	margin-bottom: 0.75em;
}
.speech_bubble_2 p::after {
	content: '';
	background-color: #f4f4f4;
	display: block;
	width: 2em;
	height: 0.75em;
	position: absolute;
	bottom: -0.75em;
}
.speech_bubble_2:has(+ .speech_bubble_2) p::after {
	clip-path: polygon(25% 0, 0 100%, 100% 0);
	left: 2em;
}
.speech_bubble_2 + .speech_bubble_2 p::after {
	clip-path: polygon(0 0, 100% 100%, 75% 0);
	right: 2em;
}
.introduct_2 {
	background-color: #f5f5f5;
	padding-bottom: 10px;
	position: relative;
	top: -17px;
	z-index: -2;
	margin-bottom: -17px;
}
.introduct_2 .arrow {
	background-color: #fff;
	margin-bottom: 20px;
}
.introduct_2_white {
	background-color: #fff;
	padding: 10px;
}
.three_conditions {
	display: flex;
	align-items: center;
	justify-content: center;
}
.three_conditions > div:nth-of-type(2n-1) {
	background-color: #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 85px;
	aspect-ratio: 1;
	margin: 15px 0;
}
.three_conditions > div:nth-of-type(2n) {
	color: #fff;
	margin: 0 5px;
}
.introduct_2 .dot::before {
	background-color: #000;
}
.introduct_2 > *:last-of-type .ribbon {
	padding-left: 1em;
	padding-right: 1em;
}
.introduct_2 > *:last-child{
	margin-bottom: 0;
}
.introduct_2 > *:not(:last-child) {
	margin-bottom: 20px;
}
.introduct_1.t2 .speech_bubble p {
	font-size: 17px;
	font-weight: bold;
}
.introduct_7 {
	overflow: hidden;
	padding: 23px 13px 23px 13px;
}


/* golden_rule
-------------------------------------------------------*/
.rule .arrow_area::before {
	background-color: #f5f5f5;
}
.rule .arrow {
	background-color: #f5f5f5;
}
.rule h3 {
	font-size: 125%;
	line-height: 1.2;
	text-align: center;
}
.rule dt {
	font-weight: bold;
	display: flex;
	align-items: stretch;
	margin-bottom: 20px;
	position: relative;
}
.rule .dot::before {
	background-color: #000;
}
.rule dt div:first-of-type {
	line-height: 1;
	background-color: #f5f5f5;
	padding: 10px;
	display: flex;
	flex-flow: column;
	justify-content: center;
}
.rule dt div:last-of-type {
	line-height: 1;
	background-color: #f3dfd5;
	padding: 5px 10px;
	flex: 1;
	display: flex;
	align-items: center;
}
.rule:not(.simple) dt .italic {
	font-size: 200%;
}
.rule dt .italic {
	letter-spacing: -0.05em;
	margin-right: 0.15em;
}
.rule dd {
	font-size: 13px;
	display: flex;
}
.rule dd:not(:last-of-type) {
	margin-bottom: 30px;
}
.rule dd > *:first-of-type {
	flex: 1;
}
.rule dd > *:last-of-type {
	display: flex;
	align-items: center;
	width: 40%;
	padding-left: 10px;
}
.rule_foot {
	background-color: #f5f5f5;
}
.rule_foot .arrow {
	background-color: #fff;
	margin-bottom: 0;
}

/* rule simple
-------------------------------------------------------*/
.rule.simple dt .italic {
	font-size: 150%;
}
.rule.simple img {
	width: 30%;
	min-width: 100px;
	display: block;
	margin: 0 auto;
}
.anchor_button {
	display: block;
	background-color: #d4dbdb;
	border-radius: 5px;
	width: 50%;
	min-width: 180px;
	padding: 10px 0;
	margin: 0 auto;
}
.anchor_button::after {
	content: '';
	background-color: #000;
	display: block;
	clip-path: polygon(0 0, 10% 0, 50% 80%, 90% 0, 100% 0, 50% 100%);
	width: 1.5em;
	height: 0.75em;
	margin: 0.25em auto 0;
}
.none_arrow .arrow_area::before {
	background-color: transparent;
}
.none_arrow .arrow_shadow {
	filter: none;
}
.none_arrow :not(.rule_foot) .arrow {
	background-color: transparent;
}


/* dontfail
-------------------------------------------------------*/
.dontfail {
	margin-bottom: 0;
}
.dontfail .arrow_area::before {
	background-color: #f5f5f5;
}
.dontfail .arrow {
	background-color: #f5f5f5;
}
.dontfail_1 {
	background-color: #fff;
}
.dontfail .dontfail_1 > *:not(:last-child) {
	margin-bottom: 1em;
}
.point_x {
	display: flex;
	align-items: center;
	justify-content: center;
}
.point_x > div {
	line-height: 1.2;
	display: flex;
	flex-flow: column;
	align-items: center;
}
.point_x > div:first-of-type,
.point_x > div:last-of-type {
	background-color: #fff;
	border-radius: 50%;
	width: 125px;
	aspect-ratio: 1 / 1;
	margin: 15px 0;
}
.point_x img {
	width: 40%;
	margin: 15px 0 5px;
}
.point_x > div > div {
	flex: 1;
	display: flex;
	flex-flow: column;
	justify-content: center;
	padding-bottom: 15px;
}
.point_x > div:nth-of-type(2) {
	font-size: 200%;
	color: #fff;
	padding: 10px;
}
.dontfail_2_arrow {
	background-color: #f5f5f5;
	position: relative;
	z-index: -1;
}
.dontfail_2_arrow .arrow {
	background-color: #fff;
	margin-bottom: 0;
}
.dontfail_2 {
	background-color: #f5f5f5;
	padding-top: 30px;
	position: relative;
	z-index: -2;
}


/* privatejob_arrow
-------------------------------------------------------*/
.privatejob {
	background-color: #fff;
	position: relative;
}
.privatejob .inner > *:not(h3):not(img:last-of-type) {
	margin-bottom: 20px;
}
.privatejob .arrow_area::before {
	background-color: #f5f5f5;
}
.privatejob .arrow {
	background-color: #f5f5f5;	
}
.privatejob_data_title {
	color: #fff;
	display: flex;
	align-items: center;
	margin-right: 5px;
	margin-bottom: 5px;
	margin-left: 5px;
}
.privatejob_data_title:first-of-type {
	margin-top: 5px;
}
.privatejob_data_title:not(:first-of-type) {
	margin-top: 10px;
}
.privatejob_data_title::before {
	content: '';
	background-color: #ffffff90;
	display: block;
	clip-path: polygon(0 0, 0% 100%, 100% 50%);
	width: 0.8em;
	height: 0.8em;
	margin-right: 0.5em;
}
.privatejob_data {
	font-size: 110%;
	background-color: #fff;
	width: fit-content;
	padding: 5px 10px;
	margin-right: 5px;
	margin-left: calc(5px + 1.3em);
}
.gradation .privatejob_data:not(:last-of-type) {
	margin-bottom: 10px;
}
.gradation .privatejob_data:last-of-type {
	margin-bottom: 5px;
}
.dotted {
	border: none;
	border-top: 2px dotted #fff;
}


/* rank_scroll
-------------------------------------------------------*/
.scroll-x:has(.rank_scroll) {
	overflow-x: auto;
}
.rank_scroll {
	display: flex;
	width: fit-content;
}
.rank_scroll > div {
	display: flex;
	flex-flow: column;
	justify-content: space-between;
	min-width: 13em;
	flex: 1;
}
.rank_scroll > div:not(:last-of-type) {
	margin-right: 10px
}
.rank_scroll .crown {
	height: calc(3em + 6px);
	padding-bottom: 0.5em;
}
.rank_scroll .crown img {
	height: 3em;
	width: auto;
}
.rank_scroll a {
	display: block;
	text-decoration: underline;
}
.rank_scroll_star {
	border: 1px solid #dbdbdb;
	border-radius: 5px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.2em;
	margin: 0.5em 0;
}
.rank_scroll_star h5 {
	letter-spacing: -0.1em;
	margin-right: 0.5em;
}
.rank_scroll_star .five_star {
	font-size: 10px;
}
.rank_scroll_star > div {
	background-color: #ffecda;
	border-radius: 5px;
	padding: 0 0.2em;
}
.rank_scroll_star > div > p > span {
	font-size: 10px;
}


/* recommend
-------------------------------------------------------*/
.recommend {
	margin-bottom: 20px;
}
.rank_icon {
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	filter: drop-shadow(3px 3px 0 #ccc);
	width: 3.5em;
	height: 3.5em;
	position: relative;
	padding-top: 0.5em;
	margin-right: 1em;
}
.recommend section > .box:nth-of-type(1) .rank_icon {
	color: #e8550c;
}
.recommend section > .box:nth-of-type(2) .rank_icon,
.recommend section > .box:nth-of-type(3) .rank_icon {
	color: #fff;
}
.rank_icon .backstar {
	display: block;
	width: 3.5em;
	height: 3.5em;
	z-index: -1;
	position: absolute;
	margin-top: -0.5em;
}
.recommend section > .box:nth-of-type(1) .rank_icon .backstar {
	background-color: #f5ec5b;
}
.recommend section > .box:nth-of-type(2) .rank_icon .backstar {
	background-color: #a2a4a3;
}
.recommend section > .box:nth-of-type(3) .rank_icon .backstar {
	background-color: #b48a3e;
}
.rank_icon .backstar:nth-of-type(1) {
	transform: scale(0.75);
}
.rank_icon .backstar:nth-of-type(2) {
	transform: rotate(18deg) scale(0.75);
}
.rank_icon .backstar:nth-of-type(3) {
	transform: rotate(36deg) scale(0.75);
}
.rank_icon .backstar:nth-of-type(4) {
	transform: rotate(54deg) scale(0.75);
}
.rank_icon .backstar:nth-of-type(5) {
	transform: rotate(72deg) scale(0.75);
}
.rank_icon .rank_num {
	font-size: 1.75em;
	margin-top: -0.3em;
}


/* comparison
-------------------------------------------------------*/
div:has(> .table_rank),
div:has(> .table_column) {
	width: 660px;
}
.table_rank,
.table_column {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	overflow: hidden;	
}
.table_column {
	border: 2px solid #7697a6;
	border-radius: 10px 0 0 10px;
}
.table_rank > p,
.table_column > p {
	width: calc(100% / 6);
}
.table_rank > p,
.table_column > p:not(.service) {
	display: flex;
	align-items: center;
	justify-content: center;
}
.table_rank > p {
	padding-bottom: 10px;
}
.table_rank img {
	width: 50%;
}
.table_column > p.th {
	color: #fff;
	background-color: #0084cf;
}
.table_column > p:not(.th):nth-of-type(-n+16) {
	background-color: #fff881;
}
.table_column.th8 > p:nth-of-type(8n + 1) { order: 1; }
.table_column.th8 > p:nth-of-type(8n + 2) { order: 2; }
.table_column.th8 > p:nth-of-type(8n + 3) { order: 3; }
.table_column.th8 > p:nth-of-type(8n + 4) { order: 4; }
.table_column.th8 > p:nth-of-type(8n + 5) { order: 5; }
.table_column.th8 > p:nth-of-type(8n + 6) { order: 6; }
.table_column.th8 > p:nth-of-type(8n + 7) { order: 7; }
.table_column.th8 > p:nth-of-type(8n + 8) { order: 8; }
.table_column.th8 > p.th:not(:nth-of-type(8)) {
	border-bottom: 1px solid #fff;
}
.table_column.th8 > p:not(.th):not(:nth-of-type(8n + 8)) {
	border-bottom: 1px solid #7697a6;
}
.table_column.th8 > p:not(.th):not(:nth-last-of-type(-n + 8)) {
	border-right: 1px solid #7697a6;
}
.table_column .service a {
	line-height: 1.2;
	text-decoration: underline;
	text-align: center;
	color: #0095db;
	display: block;
}
.table_column.th8 > p:not(:nth-of-type(8n + 1)) {
	height: 4em;
}
.evaluation {
	display: block;
	width: 2.5em;
}
.evaluation:not(.e3) {
	height: 2.5em;
}
.evaluation::before,
.evaluation.e1::before {
	content: '';
	display: block;
	height: 100%;
}
.evaluation {
	position: relative;
}
.evaluation.e1::before,
.evaluation.e1::after {
	border: 4px solid #ea3f3f;
	border-radius: 50%;
}
.evaluation.e1::after {
	content: '';
	display: block;
	width: 1.7em;
	height: 1.7em;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%)
}
.evaluation.e2::before {
	border: 4px solid #3f88ea;
	border-radius: 50%;
}
.evaluation.e3 {
	height: 2.175em;
}
.evaluation.e3::before {
	background-color: #3fc8a9;
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
}
.evaluation.e3::after {
	content: '';
	background-color: #fff;
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
	display: block;
	width: 1.7em;
	height: 1.479em;
	position: absolute;
	top: 55%;
	left: 50%;
	transform: translate(-50%, -50%)
}
.table_column > p:not(.th):nth-of-type(-n+16) .evaluation.e3::after {
	background-color: #fff881;
}
.button_mini {
	font-weight: bold;
	text-align: center;
	color: #fff;
	box-shadow: 0 3px 3px #9b9b9b;
	border-radius: 10px;
	display: block;
	padding: 0.5em;
	margin-bottom: 3px;
}
@media screen and (max-width: 768px) {
	.inner:has(.scroll-x) {
		position: relative;
		padding: 0;
	}
	.inner:has(.scroll-x)::after {
		content: "";
		background: linear-gradient(to right, transparent, #fff);
		display: block;
		width: 10px;
		height: 100%;
		position: absolute;
		right: 0;
		top: 0;
	}
	.scroll-x {
		overflow-x: scroll;
	}
	.scroll-x > * {
		padding: 0 10px;
	}
}


/* searchform
-------------------------------------------------------*/
.searchform:not(.simple) {
	position: relative;
}
.searchform.radius {
	border-radius: 10px;
	margin: 10px;
}
.searchform .arrow_area::before,
.searchform .arrow {
	background-color: #fff;
}
.searchform .arrow_shadow {
	filter: drop-shadow(0 3px 6px #00000050);
	z-index: 0;
}
.searchform h3 {
	text-align: center;
	color: #fff;
}
.searchform h3.arrow_none {
	padding-top: 1em;
}
.searchform:not(.simple) h3 {
	font-size: 175%;
	font-weight: bold;
	letter-spacing: 0.1em;
	padding-bottom: 1em;
}
.searchform.radius h3 {
	font-size: 125%;
	padding: 0.5em 0 0.5em 1.5em;
	position: relative;
}
.searchform.radius h3::before {
	content: '';
	position: absolute;
	top: calc(50% - 0.45em);
	left: calc(50% - 6.2em);
	font-size: 21px;
	width: 0.8em;
	height: 0.8em;
	box-sizing: border-box;
	border: 0.15em solid #fff;
	border-radius: 50%;
	background-color: transparent;
}
.searchform.radius h3::after {
	content: '';
	position: absolute;
	top: calc(50% + 0.12em);
	left: calc(50% - 5.52em);
	font-size: 21px;
	transform: rotate(-45deg);
	width: 0.17em;
	height: 0.46em;
	box-sizing: border-box;
	background-color: #fff;
}
.h_before {
	font-size: calc(100% / 1.75);
}
.h_before::before {
	content: '＼';
}
.h_before::after {
	content: '／';
}
@keyframes scroll-left {
	from {
		transform: translateX(0);
	}
	to {
		transform: translateX(-100%);
	}
}
.logos {
	background-color: #fff;
	display: flex;
	overflow: hidden;
	padding: 5px 0;
}
.searchform .logos {
	margin-bottom: 20px;
}
.searchform.radius .logos {
	width: calc(100% - 10px);
	min-height: 45px;
	margin: 0 auto 1em;
}
.logos ul {
	display: flex;
	animation: scroll-left 30s infinite linear 0.5s both;
}
.logos ul li {
	display: flex;
	height: 35px;
	margin-right: 10px;
}
.searchform:not(.simple) form > div {
	filter: drop-shadow(0 3px 6px #00000050);
}
form > div:not(.submit):not(.window) {
	display: flex;
	padding: 5px;
}
.searchform:not(.simple) form > div:not(.submit) {
	margin-bottom: 1em;
}
.searchform:not(.simple) form > div:not(.submit) {
	background-color: #fff;
	border: 2px solid #cecdc8;
}
form > div > h4 {
	width: 4.5em;
	border-right: 2px solid #cecdc8;
	padding-top: 0.25em;
	padding-right: 1em;
}
form > div > div > h5 {
	padding-top: 0.25em;
	padding-left: 0.5em;
}
form > div > div {
	flex: 1;
}
form label {
	color: #a2a4a3;
	display: inline-block;
	width: calc(50% - 0.25em);
	padding: 0.5em 0.5em 0.5em 2em;
	margin-bottom: 0.5em;
	position: relative;
}
form label:nth-of-type(2n - 1) {
	margin-right: 0.5em;
}
form label.colspan_2 {
	width: 100%;
	margin-right: 0;
}
form label:has(input:checked) {
	font-weight: bold;
	color: #3fa1cf;
	background-color: #fceaea;
}
form label::before {
	content: '';
	background-color: #fff;
	border: 0.4em solid #e5e5e5;
	border-radius: 50%;
	display: inline-block;
	width: 1.2em;
	height: 1.2em;
	position: absolute;
	top: 50%;
	left: 0.5em;
	transform: translateY(-50%);
}
form label:has(input:checked)::before {
	border-color: #3fa1cf;
}
div:has(> select) {
	position: relative;
	margin-bottom: 0.25em;
}
div:has(> select)::before {
	content: '';
	background-color: #666;
	display: block;
	clip-path: polygon(0 0, 100% 0, 50% 100%);
	width: 0.8em;
	height: 0.6em;
	position: absolute;
	right: 0.5em;
	top: 50%;
	transform: translateY(-50%);
}
select {
	text-align-last: center;
	background-color: #fceaea;
	border-radius: 5px;
	width: calc(100% - 0.5em);
	padding: 0.75em 1.3em 0.75em 0.5em;
	margin-top: 0.25em;
	margin-left: 0.5em;
}
select.select_none {
	background-color: #e5e5e5;
}
select option {
	background-color: #fff;
}
form .button {
	box-shadow: none;
	padding: 0;
}
form .button:after {
	content: '';
	background-color: #fff;
	display: block;
	clip-path: polygon(0 0, 100% 50%, 0 100%);
	width: 0.75em;
	height: 1.25em;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(calc(-50% + 2.5em), -50%);
}
form input[type="submit"] {
	line-height: 1;
	display: block;
	width: 100%;
	padding: 1em 1em 1em 0;
	position: relative;
	z-index: 1;
}
.g_blue .button {
	box-shadow: 0 4px 4px #fff;
}
@media screen and (max-width: 768px) {
	form {
		font-size: 13px;
	}
}


/* searchform simple
-------------------------------------------------------*/
.searchform.simple {
	background-color: #00abe4;
	padding-bottom: 20px;
}
:not(#page_search) .searchform.simple {
	margin-bottom: 20px;
}
.searchform.simple h3 {
	padding: 0.5em 0;
}
.searchform.simple .inner {
	background-color: #fff;
	border: 2px solid #cecdc8;
	border-radius: 10px;
	padding: 0;
	margin: 0 20px;
}
.searchform.simple form > div > h4 {
	font-weight: bold;
	color: #a2a4a3;
	padding-top: 0.75em;
}
.searchform.simple form > div > div {
	margin-top: 0.5em;
}
.searchform.simple .submit {
	margin: 10px 10px 0;
}
@media screen and (max-width: 768px) {
	.searchform.simple .inner {
		margin: 0 10px;
	}
}


/* searchform t2
-------------------------------------------------------*/
form.t2 label,
form.ai3 label,
form.we1 label,
form.we2 label,
form.we3 label,
form.agent label,
form.month label,
form.pj1 label,
form.pj2 label,
form.top-9 label {
	color: gray;
}
form.t2 label:has(input:checked),
form.ai3 label:has(input:checked),
form.we1 label:has(input:checked),
form.we2 label:has(input:checked),
form.we3 label:has(input:checked),
form.agent label:has(input:checked),
form.month label:has(input:checked),
form.pj1 label:has(input:checked),
form.pj2 label:has(input:checked),
form.top-9 label:has(input:checked) {
	color: #fff;
	background-color: #3fa1cf;
}
form.t2 label:has(input:checked)::before,
form.ai3 label:has(input:checked)::before,
form.we1 label:has(input:checked)::before,
form.we2 label:has(input:checked)::before,
form.we3 label:has(input:checked)::before,
form.agent label:has(input:checked)::before,
form.month label:has(input:checked)::before,
form.pj1 label:has(input:checked)::before,
form.pj2 label:has(input:checked)::before,
form.top-9 label:has(input:checked)::before {
	border-color: #fff;
	background-color: #3fa1cf;
}
.searchform .arrow_area.t2::before,
.searchform .arrow_area.t2 .arrow,
.searchform .arrow_area.top-9::before,
.searchform .arrow_area.top-9 .arrow {
	background-color: #f5f5f5;
}


/* search
-------------------------------------------------------*/
#page_search section:not(.searchform):not(.search_month),
.recommend section {
	padding: 10px;
}
#page_search section:not(.searchform),
.recommend.gra section {
	background-color: #f5f5f5;
}
.search_month {
	text-align: right;
}
.search_month > span {
	letter-spacing: 0.1em;
	background-color: #838383;
	color: #fff;
	padding: 0 1em;
	position: relative;
}
.search_month span::before {
	content: '';
	background-color: #838383;
	display: block;
	clip-path: polygon(100% 0, 0 50%, 100% 100%);
	width: 0.75em;
	height: 100%;
	position: absolute;
	top: 0;
	left: -0.75em;
}
.conditions {
	background-color: #fff;
	box-shadow: 0 0 5px #b8b8b8;
	display: flex;
	flex-wrap: wrap;
	padding: 10px 10px 0;
	margin-bottom: 1em;
}
.conditions li {
	line-height: 2;
	color: #fff;
	background-color: #e8550c;
	border-radius: 2em;
	padding: 0 0.75em;
	margin: 0 10px 10px 0;
}
.conditions_num {
	font-size: 300%;
	font-family: monospace;
	line-height: 1.2;
	color: #fff;
	background-color: #e8550c;
	border-radius: 10px;
	display: inline-block;
	padding: 0 0.5em;
	margin: 0 5px;
}
.sort {
	display: flex;
}
.sort a {
	font-size: 12px;
	line-height: 1.2;
	text-align: center;
	background-color: #fff;
	border: 2px solid #b0b6b6;
	box-shadow: 0 3px 5px #9b9b9b;
	border-radius: 10px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: calc((100% - 20px) / 3);
	padding: 10px 5px;
}
.sort a p {
	text-align: left;
}
.sort a img {
	width: 20px;
}
.sort a:not(:last-of-type) {
	margin-right: 10px;
}
.box {
	background-color: #fff;
	filter: drop-shadow(0 6px 4px #ccc);
	padding: 20px 10px;
	margin-bottom: 30px;
}
.box_title {
	line-height: 1.2;
	border-bottom: 3px solid #e8550c;
	display: flex;
	padding-bottom: 20px;
	margin-bottom: 20px;
}
.box_title h4 {
	font-size: 125%;
}
.box_rank {
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 3em;
	padding: 0.25em 0.5em 0.25em 0;
	margin: 0 0.5em 0 -10px;
	position: relative;
}
.box_rank::after {
	content: '';
	background-color: #fff;
	display: block;
	clip-path: polygon(100% 0%, 100% 100%, 0% 50%);
	width: 0.8em;
	height: 100%;
	position: absolute;
	right: -1px;
	top: 0;
}
.box_rank img {
	width: auto;
	height: 0.8em;
	margin-right: 0.15em;
}
.box_title h4 {
	display: flex;
	align-items: center;
}
.box .box_rank {
	background-color: #e8550c;
}
body:not(.search-results) .box:nth-of-type(1) .box_rank {
	background-color: #e4ca0c;
}
body:not(.search-results) .box:nth-of-type(2) .box_rank {
	background-color: #a2a4a3;
}
body:not(.search-results) .box:nth-of-type(3) .box_rank {
	background-color: #b48a3e;
}
.box_title + a,
.star,
.features {
	display: block;
	margin-bottom: 20px;
}
.star {
	margin-top: 10px;
}
.box a:has(img) {
	display: block;
	margin: 10px 0 0;
}
.star_data.star_total {
	border-color: #e8550c;
}
.star_data.star_total > div:last-of-type {
	background-color: #feead8;
}
.star_data.star_total > div:last-of-type span {
	font-size: 250%;
}
.star > h5 {
	font-weight: bold;
}
.star_data {
	display: flex;
	border: 1px solid #666;
}
.star_data:not(:has(+ .text_service)) {
	margin-bottom: 10px;
}
.star_data > div {
	display: flex;
}
.star_data > div:first-of-type {
	background-color: #f5f5f5;
	border-right: 1px solid #666;
	width: 60%;
	align-items: center;
	justify-content: space-between;
	padding: 0 10px;
}
.star_data > div:first-of-type > div {
	display: flex;
	align-items: center;
}
.star_data > div:last-of-type {
	font-weight: bold;
	flex: 1;
	justify-content: center;
}
.text_service {
	border: 1px solid #666;
	border-top: none;
}
.text_service ul {
	padding: 7.5px;
}
.text_service ul li {
	line-height: 1;
	color: #fff;
	border-radius: 5px;
	display: inline-block;
	padding: 0.3em 0.6em;
	margin: 2.5px;
}
.text_service ul li:not(.not_selected) {
	background-color: #83acc1;
}
.text_service ul li.not_selected {
	background-color: #dadcdd;
}
.five_star {
	white-space: nowrap;
	color: #cecdc8;
	margin-right: 0.5em;
	position: relative;
}
.five_star::after {
	content: '★★★★★';
	overflow: hidden;
	color: #e8550c;
	position: absolute;
	left: 0;
}
.five_star[data-rate="1.0"]:after{ width: 20%; }
.five_star[data-rate="1.1"]:after{ width: 22%; }
.five_star[data-rate="1.2"]:after{ width: 24%; }
.five_star[data-rate="1.3"]:after{ width: 26%; }
.five_star[data-rate="1.4"]:after{ width: 28%; }
.five_star[data-rate="1.5"]:after{ width: 30%; }
.five_star[data-rate="1.6"]:after{ width: 32%; }
.five_star[data-rate="1.7"]:after{ width: 34%; }
.five_star[data-rate="1.8"]:after{ width: 36%; }
.five_star[data-rate="1.9"]:after{ width: 38%; }
.five_star[data-rate="2.0"]:after{ width: 40%; }
.five_star[data-rate="2.1"]:after{ width: 42%; }
.five_star[data-rate="2.2"]:after{ width: 44%; }
.five_star[data-rate="2.3"]:after{ width: 46%; }
.five_star[data-rate="2.4"]:after{ width: 48%; }
.five_star[data-rate="2.5"]:after{ width: 50%; }
.five_star[data-rate="2.6"]:after{ width: 52%; }
.five_star[data-rate="2.7"]:after{ width: 54%; }
.five_star[data-rate="2.8"]:after{ width: 56%; }
.five_star[data-rate="2.9"]:after{ width: 58%; }
.five_star[data-rate="3.0"]:after{ width: 60%; }
.five_star[data-rate="3.1"]:after{ width: 62%; }
.five_star[data-rate="3.2"]:after{ width: 64%; }
.five_star[data-rate="3.3"]:after{ width: 66%; }
.five_star[data-rate="3.4"]:after{ width: 68%; }
.five_star[data-rate="3.5"]:after{ width: 70%; }
.five_star[data-rate="3.6"]:after{ width: 72%; }
.five_star[data-rate="3.7"]:after{ width: 74%; }
.five_star[data-rate="3.8"]:after{ width: 76%; }
.five_star[data-rate="3.9"]:after{ width: 78%; }
.five_star[data-rate="4.0"]:after{ width: 80%; }
.five_star[data-rate="4.1"]:after{ width: 82%; }
.five_star[data-rate="4.2"]:after{ width: 84%; }
.five_star[data-rate="4.3"]:after{ width: 86%; }
.five_star[data-rate="4.4"]:after{ width: 88%; }
.five_star[data-rate="4.5"]:after{ width: 90%; }
.five_star[data-rate="4.6"]:after{ width: 92%; }
.five_star[data-rate="4.7"]:after{ width: 94%; }
.five_star[data-rate="4.8"]:after{ width: 96%; }
.five_star[data-rate="4.9"]:after{ width: 98%; }
.five_star[data-rate="5.0"]:after{ width: 100%; }
.five_star_num {
	font-family: monospace;
	transform: scaleX(1.3);
}
.star .annotation {
	text-align: right;
}
.list_2_count.list_3 + .annotation {
	text-align: left;
}
.list_2_count .features h5,
.limited h5 {
	font-size: 120%;
	font-weight: bold;
	color: #e8550c;
	border-bottom: 3px solid #e8550c;
	padding-bottom: 10px;
	margin-bottom: 20px;
}
.features h6 {
	font-weight: bold;
	background-color: #feead8;
	padding: 5px;
}
.features div {
	font-size: 14px;
	margin-bottom: 10px;
}
.carousel {
	position: relative;
	width: 100%;
	margin: 0 auto 20px;
}
.carousel > input {
	position: absolute;
	z-index: -1;
	opacity: 0;
}
.carousel__main {
	overflow: hidden;
	position: relative;
	margin: 0 -5px;
}
.carousel_control {
	display: none;
}
.btn_prev,
.btn_next {
	background-color: #e8550c;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	position: absolute;
	top: 50%;
	z-index: 1;
	transform: translateY(-50%);
	transition: opacity 0.3s;
	cursor: pointer;
}
.btn_prev {
	left: 0;
	padding-right: 4px;
}
.btn_next {
	right: 0;
	padding-left: 4px;
}
.btn_arrow_prev,
.btn_arrow_next {
	background-color: #fff;
	content: '';
	display: block;
	width: 13.92px;
	height: 16px;
}
.btn_arrow_prev {
	clip-path: polygon(0 50%, 100% 0, 100% 100%);
}
.btn_arrow_next {
	clip-path: polygon(0 0, 100% 50%, 0 100%);
}
.carousel > input:nth-child(1):checked ~ .carousel__main .carousel_control:nth-child(1) {
	display: block;
}
.carousel > input:nth-child(2):checked ~ .carousel__main .carousel_control:nth-child(2) {
	display: block;
}
.carousel > input:nth-child(3):checked ~ .carousel__main .carousel_control:nth-child(3) {
	display: block;
}
.carousel > input:nth-child(4):checked ~ .carousel__main .carousel_control:nth-child(4) {
	display: block;
}
.carousel > input:nth-child(1):checked ~ .carousel__main .carousel_content {
	transform: translateX(calc(-100% * 0));
}
.carousel > input:nth-child(2):checked ~ .carousel__main .carousel_content {
	transform: translateX(calc(-100% * 1));
}
.carousel > input:nth-child(3):checked ~ .carousel__main .carousel_content {
	transform: translateX(calc(-100% * 2));
}
.carousel > input:nth-child(4):checked ~ .carousel__main .carousel_content {
	transform: translateX(calc(-100% * 3));
}
.carousel_content {
	display: flex;
	align-items: center;
	white-space: nowrap;
	transition: transform 0.3s ease-out;
}
.carousel_item {
	flex-shrink: 0;
	width: calc(100% - 74px);
	margin: 0 37px;
}
.button {
	font-size: 150%;
	font-weight: bold;
	text-align: center;
	color: #fff;
	box-shadow: 0 5px 5px #9b9b9b;
	border-radius: 10px;
	display: block;
	overflow: hidden;
	padding: 1em 0;
	margin-bottom: 10px;
	position: relative;
}
.button:not(.ora) {
	background: linear-gradient(#0353ac 28%, #0378b7 72%);
}
.button.ora,
.button_mini.ora {
	background: linear-gradient(#e9293b, #f85c3a);
}
.button::before {
	content: '';
	background: linear-gradient(#f1f1f110, transparent);
	border-radius: 50%;
	display: block;
	width: 150%;
	height: 3.4em;
	position: absolute;
	left: 50%;
	bottom: -1.7em;
	transform: translateX(-50%);
}
.button span {
	padding-right: 1em;
	position: relative;
	z-index: 1;
}
.button span::after {
	content: '';
	background-color: #fff;
	display: block;
	clip-path: polygon(0 0, 100% 50%, 0 100%);
	width: 0.5em;
	height: 1em;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
}
.pagination {
	display: flex;
	justify-content: center;
	margin: 20px 0 0;
}
.pagination li {
	font-weight: bold;
	border-radius: 5px;
	margin: 0 5px;
}
.pagination li:not(.current) {
	color: #fff;
	background: linear-gradient(#0353ac 28%, #0378b7 72%);
}
.pagination li.current {
	color: #a2a4a3;
	background: #fff;
	outline: 1px solid #a2a4a3;
	outline-offset: -1px;
}
.pagination li *:first-of-type {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2em;
	height: 2em;
}


/* list_2
-------------------------------------------------------*/
.box.list_2 {
	padding-right: 15px;
	padding-left: 15px;
}
.box.list_2 .box_rank {
	margin-left: -15px;
}
.box.list_2 .box_title {
	font-size: 17px;
	padding-bottom: 15px;
	margin-bottom: 10px;
}
.star:has(.list_2_stars) {
	margin-bottom: 10px;
}
.list_2_stars {
	display: flex;
	border: 2px solid #dbdbdb;
	border-radius: 5px;
	padding: 5px;
	margin-bottom: 10px;
}
.list_2_count {
	border: 2px solid #dbdbdb;
	border-radius: 5px;
}
.list_2_stars > div:first-of-type {
	line-height: 1.2;
	background-color: #ffecda;
	border-radius: 5px;
	display: flex;
	flex-flow: column;
	align-items: center;
	justify-content: center;
	width: 38%;
	margin-right: 5px;
}
.list_2_stars > div:first-of-type .five_star {
	margin: 0;
}
.list_2_stars > div:last-of-type {
	line-height: 1.2;
	flex: 1;
}
.list_2_stars > div:last-of-type > div {
	display: flex;
	align-items: center;
	height: 2.4em;
}
.list_2_stars > div:last-of-type > div:not(:last-of-type),
.list_2_count > div:not(:last-of-type) {
	border-bottom: 2px dashed #dbdbdb;
}
.list_2_stars > div:last-of-type > div > h5 {
	font-size: 10px;
	flex: 1;
}
.list_2_count > div {
	display: flex;
	align-items: center;
	padding: 0.25em 0;
}
.list_2_count > div > h5 {
	border-right: 2px solid #dbdbdb;
	width: 60%;
	padding: 0.25em 0.5em;
}
.list_2_count.list_3 > div > h5 {
	width: 6em;
}
div:has(.list_2_count):not(:has(.list_2_stars)) > .list_2_count > div > h5 {
	position: relative;
	padding-left: 2em;
}
div:has(.list_2_count):not(:has(.list_2_stars)) > .list_2_count > div > h5::before {
	content: '';
	background-color: #f19601;
	border-radius: 50%;
	display: block;
	width: 1.2em;
	height: 1.2em;
	position: absolute;
	top: 50%;
	left: 0.5em;
	transform: translateY(-50%);
}
div:has(.list_2_count):not(:has(.list_2_stars)) > .list_2_count > div > h5::after {
	content: '';
	background-color: #fff;
	display: block;
	clip-path: polygon(15% 38%, 40% 64%, 87% 16%, 100% 29%, 41% 89%, 0% 50%);
	width: 0.8em;
	height: 0.8em;
	position: absolute;
	top: 50%;
	left: 0.7em;
	transform: translateY(-50%);
}
.list_2_count > div > div {
	flex: 1;
	display: flex;
	justify-content: center;
}
.list_2_count.list_3 > div > div {
    justify-content: flex-start;
	padding: 0 0.5em;
}
.list_2_count > .text_service {
	border: none;
	padding: 0.25em 0.25em 0;
}
.list_2_count > .text_service ul {
	display: flex;
	flex-flow: wrap;
	padding: 0;
}
.list_2_count > .text_service ul li {
	margin: 0 0.25em 0.25em 0;
}
.list_2_count > .text_service ul li:nth-of-type(1) { order: 1; }
.list_2_count > .text_service ul li:nth-of-type(2) { order: 2; }
.list_2_count > .text_service ul li:nth-of-type(5) { order: 3; }
.list_2_count > .text_service ul li:nth-of-type(4) { order: 4; }
.list_2_count > .text_service ul li:nth-of-type(3) { order: 5; }
.list_2_features > div {
	border: 2px solid #dbdbdb;
	border-radius: 5px;
	margin: 0.25em 0 10px;
}
.list_2_features h6 {
	background-color: #ffecda;
}
.list_2_features > div > h6,
.list_2_features > div > div {
	padding: 0.5em;
}
.list_2_features > div > div:not(:last-of-type) {
	border-bottom: 2px dashed #dbdbdb;
	padding-bottom: 1.5em;
}
.box.list_2:last-of-type {
	margin-bottom: 0;
}
.list_2_features.jobposting > .annotation {
    border: none;
    border-radius: 0;
    margin: -10px 0 10px;
}
.white_arrow {
	position: relative;
	display: inline-block;
	width: 1em;
	height: 1em;
	margin-right: 0.5em;
}
.white_arrow::before,
.white_arrow::after {
	content: '';
	display: inline-block;
	width: 1em;
	height: 1em;
	position: absolute;
	top: 0;
	left: 0;
}
.white_arrow::before {
	background-color: #000;
	clip-path: polygon(60% 15%, 100% 50%, 60% 85%, 60% 65%, 0 65%, 0 35%, 64% 35%);
}
.white_arrow::after {
	background-color: #fff;
	clip-path: polygon(63% 22%, 97% 50%, 63% 78%, 63% 62%, 3% 62%, 3% 38%, 68% 38%);
}

/* links
-------------------------------------------------------*/
.links {
	margin-top: 10px;
}
.links .inner {
	display: flex;
	flex-wrap: wrap;
}
.links .inner a {
	width: calc(50% - 5px);
}
.links .inner a:nth-of-type(2n-1) {
	margin-right: 10px;
}


/* content_link
-------------------------------------------------------*/
.content_link a {
	padding-right: 1.5em;
}
.content_link a::after {
	content: '';
	background-color: #fff;
	display: block;
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
	width: 1.1em;
	height: 0.9em;
	position: absolute;
	top: 50%;
	left: calc(50% + 2em);
	transform: translateY(-50%);
}


/* single
-------------------------------------------------------*/
.single_main {
	display: flex;
	flex-flow: column;
	justify-content: center;
	align-items: center;
	height: 90vh;
	padding: 0 10px;
}
.single_main > * {
	margin-bottom: 1em;
}
.single_main img {
	max-width: 450px;
}
.load {
	padding: 53px 0;
	position: relative;
}
.load .text {
	font-size: 14px;
	line-height: 1;
	letter-spacing: -0.05em;
	color: #848484;
}
.load .content {
	width: 120px;
	height: 120px;
	margin: -67px 0 0;
	position: absolute;
	left: calc(50% - 60px);
	border: 3px solid transparent;
	border-top-color: #b5b5b5;
	border-bottom-color: #b5b5b5;
	border-radius: 50%;
	animation: loader 2s linear infinite;
}
.load .content:before {
	content: "";
	position: absolute;
	left: 5px;
	right: 5px;
	top: 5px;
	bottom: 5px;
	border: 3px solid transparent;
	border-top-color: #ccc;
	border-bottom-color: #ccc;
	border-radius: 50%;
	animation: loader 3s linear infinite;
}
.load .content:after {
	content: "";
	position: absolute;
	left: 15px;
	right: 15px;
	top: 15px;
	bottom: 15px;
	border: 3px solid transparent;
	border-top-color: #e5e5e5;
	border-bottom-color: #e5e5e5;
	border-radius: 50%;
	animation: loader 1.5s linear infinite;
}
@keyframes loader {
	0% {
		-webkit-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
		transform: rotate(0deg);
	}
	100% {
		-webkit-transform: rotate(360deg);
		-ms-transform: rotate(360deg);
		transform: rotate(360deg);
	}
}
.link a {
	font-weight: bold;
	text-decoration: underline;
	margin: 0 0.25em;
}


/* page_shindan
-------------------------------------------------------*/
#page_shindan {
	& h2 {
		text-align: center;
		background-color: #45a9f6;
		border-top: 9px double #fff;
		border-bottom: 9px double #fff;
		display: flex;
		align-items: center;
		justify-content: center;
		padding: 0.5em 0;
	}
	& h2 > span:first-of-type {
		font-weight: bolder;
		line-height: 1;
		background-color: #fff000;
		border-radius: 50%;
		display: flex;
		flex-flow: column;
		align-items: center;
		justify-content: center;
		width: 3em;
		height: 3em;
		margin-right: 0.5em;
	}
	& h2 > span:last-of-type {
		display: inline-block;
		background: linear-gradient(#fff000, #fff);
		background: -webkit-linear-gradient(#fff000, #fff);
		-webkit-background-clip: text;
		-webkit-text-fill-color: transparent;
		filter: drop-shadow(0px 6px 1px #000982) drop-shadow(-1px -1px 1px #000982) drop-shadow(1px -1px 0px #000982) drop-shadow(-1px 0 1px #000982) drop-shadow(1px 0 1px #000982);
	}
	& form {
		font-size: inherit;
	}
	& form label {
		font-weight: bold;
		text-align: center;
		color: #00045c;
		background-color: #fff;
		border: 2px solid #00045c;
		border-radius: 5px;
		padding: 0.5em 0;
		box-shadow: #aaa 0 3px 2px;
	}
	& form label:has(input:checked) {
		color: #fff;
		background-color: #00045c;
	}
	& form label::before {
		content: none;
	}
	& .window {
		display: none;
		flex-flow: column;
		min-height: 65vh;
	}
	& .window h3 {
		margin-bottom: 10px;
	}
	& .window h3 > span:first-of-type {
		background-color: #fff000;
		display: inline-block;
		padding: 0.5em;
		margin-right: 0.5em;
	}
	& .window h3 + div {
		display: flex;
		align-items: center;
	}
	& .window h3 + div > div {
		width: 100%;
	}
	& form .window label.back_button,
	& form .window label.next_button {
		color: #000346;
		background-color: #fff000;
		border-color: #fff000;
		margin-top: 20px;
	}
	& form .window.w1 label.back_button {
		color: #ddd;
		background-color: #fff;
		border: 2px solid #ddd;
	}
	& form .window .submit {
		display: flex;
	}
	& form .window .submit label.back_button {
		padding: 0 0.5em;
		width: fit-content;
		display: flex;
		align-items: center;
	}
	& form .window .submit .button {
		margin-top: 20px;
		flex: 1;
	}
	& form .window > div:last-of-type {
		display: flex;
		flex: 0;
	}
	& #w1:checked ~ div .window.w1,
	& #w2:checked ~ div .window.w2,
	& #w3:checked ~ div .window.w3,
	& #w4:checked ~ div .window.w4,
	& #w5:checked ~ div .window.w5,
	& #w6:checked ~ div .window.w6 {
		display: flex;
	}
}


/* page_company
-------------------------------------------------------*/
.margin30 {
	margin-bottom: 30px;
}
#page_company .inner > ol {
	list-style-type: decimal;
	margin-left: 1.3em;
}
#page_company .inner > ol > li {
	margin-bottom: 0.5em;
}
#page_company .inner > ol > li > ol {
	counter-reset: my-counter;
	list-style: none;
	padding: 0;
	margin: 0;
}
#page_company .inner > ol > li > ol li {
	padding-left: 1.75em;
	position: relative;
	margin-top: 0.25em;
}
#page_company .inner > ol > li > ol li:before {
	content: counter(my-counter);
	counter-increment: my-counter;
	font-size: 85%;
	line-height: 1;
	border: 1px solid;
	border-radius: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 1.3em;
	width: 1.3em;
	position: absolute;
	top: 0.3em;
	left: 0;
}


/* page_survey
-------------------------------------------------------*/
hr.title_ul {
    border: none;
    border-bottom: 3px solid #333;
	margin-bottom: 1em;
}
#page_survey .inner > ul {
	list-style-type: disc;
	margin-left: 1.3em;
}
.scroll-x > div:has(.table) {
	width: fit-content;
}
.table {
    width: fit-content;
	border-top: 1px solid;
	border-left: 1px solid;
}
.table .tr {
	display: flex;
}
.table .tr > div {
	border-right: 1px solid;
	border-bottom: 1px solid;
}
.table .th > div:not(:last-of-type),
.table .th .rowspan > div > div:not(:last-of-type) {
	border-bottom: 1px solid;
}
.table .th .rowspan > div:not(:last-of-type) {
	border-right: 1px solid;
}
.table .tr .rowspan {
	width: 100%;
	height: 100%;
	display: flex;
	flex: 1;
}
.table .tr .th .rowspan > div {
	width: 50%;
}
.table .tr .th:not(:has(.rowspan)):has(> :nth-child(2)) > div:nth-child(2) {
	flex: 1;
}
.table .tr .th .rowspan > div,
.table .tr .th .rowspan > div > div,
.table .tr .th:not(:has(.rowspan)):has(> :nth-child(2)) > div:nth-child(2) {
    display: flex;
	align-items: end;
}
.table .tr .th .rowspan > div:has(div) {
	flex-flow: column;
}
.table .tr .th .rowspan > div > div {
    width: 100%;
}
.table .tr .th .rowspan > div > div:last-of-type {
    flex: 1;
}
.table .tr .th:first-of-type,
.table .tr .td:first-of-type {
	width: 13em;
}
.table .tr .th {
	display: flex;
	flex-flow: column;
}
.table .tr .th:has(.rowspan) {
	width: 13em;
}
.table .tr .th:not(:first-of-type):not(:has(.rowspan)),
.table .tr .td:not(:first-of-type) {
	width: 6.5em;
}
.table .tr .th > div:not(.rowspan),
.table .tr .th .rowspan > div:not(:has(div)),
.table .tr .th .rowspan > div > div,
.table .tr .td {
	padding: 0.25em;
}
#page_survey .scroll-x {
	overflow-x: scroll;
}
@media screen and (max-width: 768px) {
    #page_survey .inner {
        padding: 0 10px 20px;
    }
    #page_survey .scroll-x {
        margin-right: -10px;
        margin-left: -10px;
    }
}


/* top-4
-------------------------------------------------------*/
.introduct_top-4 {
	padding-top: 20px;
	margin-bottom: 40px;
}
.introduct_top-4 > *:not(.border_top-4) {
	margin-bottom: 20px;
}
.border_top-4 {
	border: 2px solid #fe5e5e;
	border-radius: 10px;
	padding: 10px 10px 10px calc(15px + 1.4em);
	margin-right: 5%;
	margin-left: 5%;
	position: relative;
}
.border_top-4::before,
.border_top-4::after {
	content: '';
	display: block;
	position: absolute;
}
.border_top-4::before {
	background-color: #61c606;
	border-radius: 50%;
	width: 1.4em;
	height: 1.4em;
	top: 10px;
	left: 10px;
}
.border_top-4::after {
	background-color: #ffff;
	clip-path: polygon(17% 54%, 28% 43%, 38% 54%, 70% 22%, 81% 33%, 38% 75%, 17% 54%);
	position: absolute;
	width: 1.4em;
	height: 1.4em;
	top: 10px;
	left: 10px;
}
.supervisor {
	display: flex;
	align-items: center;
}
.supervisor > img {
	width: 25%;
	margin-right: 1em;
}
.top-4_content h3 {
	color: #fff;
	background-color: #0075c2;
	padding: 10px 20px;
	margin-bottom: 20px;
}
.top-4_content .inner {
	margin-bottom: 10px;
}
.top-4_content ul li {
	display: flex;
	border-bottom: 1px solid #85c1ff;
	margin-bottom: 20px;
}
.top-4_content ul li > p:first-of-type {
	color: #fff;
	background-color: #85c1ff;
	width: 1.5em;
	display: flex;
	align-items: center;
	justify-content: center;
}
.top-4_content ul li > p:last-of-type {
	flex: 1;
	padding: 0.25em 0 0.25em 0.5em;
}


/* top-4_2
-------------------------------------------------------*/
.top-4_content.c2 .inner > *:not(h4) {
	margin-bottom: 20px;
}
.recommend_one {
	border-top-width: calc(2.16em + 10px);
	border-right-width: 10px;
	border-bottom-width: 10px;
	border-left-width: 10px;
	border-style: solid;
	border-color: #84c1ff;
}
.recommend_one h4 {
	letter-spacing: -0.05em;
	color: #fff;
	background-color: #0e73d9;
	border-radius: 2em;
	width: fit-content;
	padding: 0 1.5em;
	margin: -2.16em auto 10px;
}
.recommend_one > p {
	padding: 10px;
}
.good {
	text-align: center;
	color: #fe5e5e;
	position: relative;
	padding-top: 1.5em;
}
.good::before {
	content: 'Good';
	font-size: 2.8em;
	line-height: 1;
	color: #fe5e5e20;
	position: absolute;
	bottom: 0.05em;
	right: 50%;
}
#top-4_m3 h4 {

}
.top-4_content .dot::before {
	background-color: #000;
}


/* top-5
-------------------------------------------------------*/
#page_top-5 .links.type_s .inner {
	padding-bottom: 0;
}
h3.top-5_title {
	color: #fff;
	padding: 10px 20px;
	margin-bottom: 20px;
	overflow: hidden;
}
h3.top-5_title,
.top-5_content.dontfail .gradation {
	background: linear-gradient(#0353ac, #0378b7);
	position: relative;
	overflow: hidden;
}
h3.top-5_title::after,
.top-5_content.dontfail .gradation::after {
	content: '';
	background: linear-gradient(#ffffff15, transparent);
	border: 1px;
	border-radius: 50%;
	display: block;
	width: 150%;
	height: calc(3.2em + 20px);
	position: absolute;
	top: 50%;
	left: -25%;
}
.top-5_content h3 .white_ribbon {
	background-color: #fff;
	display: inline-block;
	padding-right: 1em;
	padding-left: 1em;
}
.top-5_content.searchform {
	margin-bottom: 20px;
}
.top-5_content.rule dt div:last-of-type {
	background-color: #dbe3fa;
}
.top-5_content.dontfail {
	margin-bottom: 20px;
}
.top-5_content.dontfail .point_x img {
	filter: hue-rotate(200deg);
}
.top-5_content.dontfail .dontfail_2 {
	background-color: #dbe3fa;
	border: 6px double #fff;
	padding-top: 20px;
}
.top-5_content.content_link a::after {
	left: calc(50% + 3em);
}


/* top-6
-------------------------------------------------------*/
.drop_shadow_6 {
	filter: drop-shadow(0 0 3px #42b3f2);
}
h1:has(.visual_text) {
	position: relative;
}
.visual_text {
	font-size: clamp(1rem, 7.6vw, 3.3rem);
	color: #fff;
	display: block;
	width: max-content;
	position: absolute;
	top: calc(50% - (1.5em * 1.4) - 0.7em);
	left: 50%;
	transform: translatex(-50%);
}
.visual_text:has(> span:nth-of-type(-n+5):last-of-type):has(> span + span) {
	line-height: 1.4;
	top: calc(50% - (2em * 1.4) - 0.3em);
}
.visual_text:has(> span:nth-of-type(-n+4):last-of-type) {
	line-height: 1.2;
	top: calc(50% - (2em * 1.4) - 0.9em);
}
.visual_text:has(> span:nth-of-type(-n+3):last-of-type) {
	line-height: 1.3;
	top: calc(50% - (1.5em * 1.4) - 0.7em);
}
.visual_text > span.bg_white {
	line-height: 1;
	color: #3aa0f2;
	background-color: #fff;
	display: inline-block;
	padding: 0.15em 0.5em;
}
.visual_text:has(> span:nth-of-type(-n+4):last-of-type) > span.bg_white {
	margin-top: 0.15em;
	margin-bottom: 0.15em;
}
.visual_text:has(> span:nth-of-type(-n+3):last-of-type) > span.bg_white {
	margin-bottom: 0.25em;
}
.visual_text > span:last-of-type {
	display: block;
}
.visual_month {
	font-size: clamp(1rem, 5vw, 2rem);
	line-height: 1em;
	color: #fff;
	border: 1px solid #fff;
	border-radius: 50%;
	aspect-ratio: 1 / 1;
	display: flex;
	flex-flow: column;
	align-items: center;
	justify-content: center;
	width: 4.5em;
	padding-top: 0.25em;
	position: absolute;
	top: -1.15em;
	right: -0.5em;
}
h1 + .inner {
	padding-top: 30px;
}
.paperclip {
	position: relative;
}
.paperclip::after {
	content: '';
	display: inline-block;
	width: 20px;
	height: 31px;
	background-image: url(../images/top-6/paperclip.png);
	background-size: contain;
	background-repeat: no-repeat;
	position: absolute;
	top: -8px;
	right: 10%;
}
.bg_border_pink {
	border: 1px solid #333;
	position: relative;
}
div.bg_border_pink {
	padding: 10px;
	margin: 5px 0 1em 10px;
}
span:has(span.bg_border_pink) {
	background: linear-gradient(90deg, #fbc9bf calc(100% - 0.2em), transparent calc(100% - 0.2em));
	padding: 0.2em 0 0 0.2em;
	position: relative;
	z-index: 0;
}
span.bg_border_pink {
	line-height: 2;
	padding: 0 0.4em 0.1em 0.2em;
}
div.bg_border_pink::before {
	content: '';
	background-color: #fbc9bf;
	width: 100%;
	height: 100%;
	position: absolute;
	left: -10px;
	top: -5px;
	z-index: -1;
}
.bg_border_pink:has(.underline_white:last-of-type) {
	padding-bottom: calc(0.1em + 15px);
}
.search_box_d {
	background-color: #fff;
	border: 3px solid #eaeaea;
	border-radius: 0.8em;
	display: inline-block;
	padding: 0 1em 0 2.5em;
	margin: 0.6em 0.25em 0.3em 0;
	position: relative;
}
.search_box_d::before,
.search_box_d::after {
	content: '';
	display: block;
	position: absolute;
	transform: translateY(-50%);
}
.search_box_d::before {
	border: 3px solid #016daa;
	border-radius: 50%;
	width: 0.8em;
	height: 0.8em;
	top: calc(50% - 0.1em);
	left: 0.5em;
}
.search_box_d::after {
	background-color: #016daa;
	clip-path: polygon(0 35%, 35% 0, 100% 65%, 65% 100%);
	width: 0.4em;
	height: 0.4em;
	top: calc(50% + 0.3em);
	left: 1.1em;
}
.top-6_content .inner {
	padding-top: 20px;
}
.bg_blue_6 {
	background-color: #e9f6ff;
}
.bottom_bg_parts {
	position: relative;
	margin-bottom: calc(2.5em + 20px);
}
.bottom_bg_parts::after {
	content: '';
	background-color: #e9f6ff;
	border-radius: 0 0 50% 50%;
	display: block;
	width: 100%;
	height: 5em;
	position: absolute;
	bottom: -2.5em;
	left: 0;
	z-index: -1;
}
.point_circle {
	position: relative;
	height: 300px;
}
.point_circle span {
	border: 1px solid;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 175px;
	aspect-ratio: 1 / 1;
	position: absolute;
}
.point_circle span:nth-of-type(1) {
	top: 20px;
	left: 50%;
	transform: translateX(-50%);
}
.point_circle span:nth-of-type(2) {
	bottom: 0;
	left: calc(50% - 70px);
	transform: translateX(-50%);
}
.point_circle span:nth-of-type(3) {
	bottom: 0;
	left: calc(50% + 70px);
	transform: translateX(-50%);
}
.top_bg_parts {
	background: linear-gradient(#fff, #39a8ef 50%);
	padding-top: calc(2.5em + 20px);
	position: relative;
	z-index: -1;
}
.top_bg_parts::before {
	content: '';
	background-color: #fff;
	border-radius: 0 0 50% 50%;
	display: block;
	width: 100%;
	height: 5em;
	position: absolute;
	top: -2.5em;
	left: 0;
	z-index: -1;
}
.top_bg_parts2 {
	background: linear-gradient(#fff 20%, #97D2F6 20%, #39a8ef 35%);
	padding-top: calc(2.5em + 20px);
	position: relative;
}
.ribbon:has(+ br + .ribbon) {
	margin-bottom: 0.25em;	
}
.searchform:has(+ .top-6_content) {
	margin-bottom: 20px;
}
.top-6_content h3 {
	color: #fff;
	background-image: url(../images/top-6/top-6_content_h3.png);
	background-size: cover;
	background-position: top left;
	padding: 0.5em 0;
}
.top-6_content .memo {
	background: linear-gradient(135deg, #fff calc(100% - 40px), transparent calc(100% - 40px));
	position: relative;
	padding: calc(1.5em * 1.5 + 15px) 15px 15px;
	margin-top: calc(1.5em * 1.5);
}
.top-6_content .memo img {
	width: 80%;
}
.top-6_content .memo:has(+ .memo) {
	margin-bottom: calc(1.5em * 1.5 + 10px);
}
.top-6_content .memo:last-of-type {
	margin-bottom: 20px;
}
.top-6_content .number {
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, #f4e025 68%, #f4cf25 68%);
	border-radius: 50%;
	width: 3em;
	aspect-ratio: 1 / 1;
	position: absolute;
	top: -1.5em;
	left: 0;
}
.top-6_content .memo h4 {
	border-bottom: 2px solid #016daa;
	padding-bottom: 0.25em;
	margin-bottom: 0.5em;
}
.top-6_content .memo p:has(span.bg_border_pink) {
	line-height: 2;
}
.top-6_content .inner:has(+ h3) {
	margin-bottom: 20px;
}
.top-6_content .inner > h4 {
	margin-bottom: 20px;
}
.top-6_content details {
	background-color: #fff;
	border: 2px solid #016daa;
	padding: 15px;
	margin-bottom: 15px;
}
.top-6_content details summary {
	position: relative;
}
.top-6_content details summary::after {
	content: '';
	background-color: #016daa;
	display: block;
	clip-path: polygon(15% 25%, 50% 60%, 85% 25%, 100% 35%, 50% 85%, 0 35%);
	width: 1em;
	height: 1em;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	transition: 0.25s all;
}
.top-6_content details[open] summary::after {
	transform: rotate(180deg) translateY(50%);
}
.top-6_content details summary span {
	line-height: 1;
	border: 1px solid;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.25em;
	aspect-ratio: 1 / 1;
	margin-right: 0.5em;
}
summary {
	display: block;
	list-style: none;
}
summary::-webkit-details-marker {
	display:none;
}
.top-6_content details hr {
	border-bottom: 3px solid #e9f6ff;
	margin: 10px 0;
}
.top-6_content.content_link .button {
	background: linear-gradient(#0353ac, #147db9);
	box-shadow: 0 -4px 4px #cacaca;
	border-radius: 25px;
}
.top-6_content.content_link .button::before {
	content: none;
}

/* top-6 fk2
-------------------------------------------------------*/
.top-6_content.fk2 h3 {
	display: flex;
	flex-flow: column;
	justify-content: center;
	align-items: center;
	min-height: 4em;
}
.top-6_content.fk2 .point {
	text-align: left;
	background-color: #fff;
	border: 3px solid #707070;
	border-radius: 1em;
	padding: 0.5em 0.75em;
	margin: 1em 0;
}
.top-6_content.fk2 .point li {
	padding-left: 1.25em;
	position: relative;
}
.top-6_content.fk2 .point li::before,
.top-6_content.fk2 .point li::after {
	content: "";
	width: 1.1em;
	height: 1.1em;
	display: block;
	position: absolute;
	top: 0.3em;
	left: 0;
}
.top-6_content.fk2 .point li::before {
	background-color: #000;
	clip-path: polygon(15% 35%, 40% 55%, 85% 15%, 100% 30%, 40% 85%, 0% 50%);
}
.top-6_content.fk2 .point li::after {
	background-color: #16c60c;
	clip-path: polygon(15% 40%, 40% 60%, 85% 20%, 95% 30%, 40% 80%, 5% 50%);

}
.top-6_content.fk2 .cta {
	margin-top: 1em;
}
.top-6_content.fk2 .button {
	font-size: 125%;
}
.top-6_content.fk2 .button span {
    display: inline-block;
}
.top-6_content.fk2 .example {
	text-align: left;
	background-color: #fff;
	border: 3px solid #707070;
	border-radius: 1em;
	padding: 0.5em 0.75em;
	margin: 1em 0;
}

/* top-6 anim
-------------------------------------------------------*/
.wrap_right {
	display: inline-block;
	overflow: hidden;
	position: relative;
	opacity: 0;
}
.wrap_right.anim {
	opacity: 1;
}
.wrap_right.anim::before {
	animation: wrap_right_anim 250ms forwards;
	background: #fff;
	content: '';
	inset: 0;
	pointer-events: none;
	position: absolute;
	z-index: 1;
}
.wrap_right.anim.delay::before {
	animation-delay: 750ms;
}
@keyframes wrap_right_anim {
	100% {
		transform: translateX(100%);
	}
}
span:has(> span > .fadeup) {
	display: flex;
	align-items: baseline;
}
span:has(> .fadeup) {
	overflow: hidden;
}
.fadeup {
	line-height: 1;
	display: inline-block;
	opacity: 0;
}
.fadeup.anim {
	animation: fadeup_anim 0.75s forwards;
	animation-delay: 250ms;
}
.fadeup.anim_1s {
	animation: fadeup_anim 1s forwards;
	animation-delay: 1s;
}
@keyframes fadeup_anim {
	0% {
		opacity: 0;
		transform: translateY(1em);
	}
	100% {
		opacity: 1;
		transform: translateY(0);
	}
}


/* top-7
-------------------------------------------------------*/
.top-7_content .underline {
	display: inline;
}
.top-7_content h3 {
	color: #fff;
	background-color: #03955c;
	background-image: none;
	position: relative;
	padding: 1.25em 0;
	overflow: hidden;
}
.top-7_content h3 > span {
	position: relative;
}
.top-7_content h3::before {
	content: '';
	background-color: #2bc186;
	border-radius: 50%;
	display: block;
	width: 114%;
	aspect-ratio: 1 / 0.55;
	position: absolute;
	left: 50%;
	top: 0.75em;
	transform: translateX(-50%);
}
#introduction .top-7_content .inner {
	padding-top: 20px;
	margin-bottom: min(calc(100vw * 0.21 / 2) + 20px, calc(700px * 0.21 / 2) + 20px);
	position: relative;
}
#introduction .top-7_content .inner > * {
	position: relative;
}
#introduction .top-7_content .inner::before {
	content: '';
	background-color: #f4f4f4;
	border-radius: 50%;
	display: block;
	width: 100vw;
	max-width: 100%;
	aspect-ratio: 1 / 0.21;
	position: absolute;
	left: 50%;
	bottom: max(calc(-100vw * 0.21 / 2), calc(-700px * 0.21 / 2));
	transform: translateX(-50%);
}
#introduction .top-7_content .inner > img {
	margin: 20px auto;
}
.top-7_content .comparison {
	line-height: 2;
	letter-spacing: 0.1em;
	background-color: #fff;
	padding: 10px;
	margin-bottom: 20px;
}
.top-7_content .comparison > p {
	text-align: left;
	width: fit-content;
	margin: 0 auto;
}
.top-7_content .comparison .com {
	color: #fff;
	border-radius: 5px;
	padding: 0.25em 0.5em;
	margin-right: 0.5em;
}
.top-7_content .comparison .com.a {
	background-color: #e59496;
}
.top-7_content .comparison .com.b {
	background-color: #dabf55;
}
.top_bg_parts.bg_green {
	background: linear-gradient(#fff, #03955c);
}
.searchform.bg_green {
	background-color: #03955c;
	margin-bottom: 20px;
}
#contents:has(.searchform.bg_green) .conditions li {
	background-color: #03955c;	
}
.searchform.bg_green .button:not(.ora),
.top-7_content.content_link .button {
	background: linear-gradient(#ffbb68, #ffa000, #ffbb68);
	border: 2px solid #ffffffa0;
	box-shadow: 2px 2px 0 #ffa000, -2px 2px 0 #ffa000, -2px -2px 0 #ffa000, 2px -2px 0 #ffa000, 0 8px 3px #00000020;
	width: calc(100% - 6px);
	margin-right: auto;
	margin-left: auto;
}
.top-7_content.content_link .button {
	line-height: 1;
	padding-top: calc(1em - 3px);
	padding-bottom: calc(1em - 3px);
}
.searchform.bg_green .button::before,
.top-7_content.content_link .button::before {
	content: none;
}
.top-7_content .memo h4 {
	border-bottom-color: #03955c;
}
.top-7_content details {
	border-color: #03955c;
}
.top-7_content details summary::after {
	background-color: #03955c;
}
.top-7_content details hr {
	border-bottom-color: #b3dfce;
}

/* top-9
-------------------------------------------------------*/
.top-9_content .inner {
	padding-top: 20px;
}
.top-9_searchform .button {
  background: linear-gradient(to bottom, hsl(125deg 51.47% 82.09%) 9%, hsl(125deg 44.89% 67.47%) 28%, hsl(125 50% 35% / 1) 88%);
  box-shadow: 0 3px 2px #fff, inset 3px 3px 4px #5cc54f82, inset -3px 0px 4px #5cc54f82;
}
.searchform:has(+ .top-9_content) {
	margin-bottom: 20px;
}
.top-9_content > p {
  padding: 0 27px 20px;
  display: flex;
}
.top-9_content h3 {
	color: #fff;
	background-image: url(../images/top-9-fk1/top-9_content_h3.png);
	background-size: cover;
	background-position: top left;
	padding: 0.5em 0;
}
.top-9_content .memo {
	background: linear-gradient(135deg, #fff calc(100% - 40px), transparent calc(100% - 40px));
	position: relative;
	padding: calc(1.5em * 1.5 + 15px) 15px 15px;
	margin-top: calc(1.5em * 1.5);
}
.top-9_content .memo img {
	width: 80%;
}
.top-9_content .memo:has(+ .memo) {
	margin-bottom: calc(1.5em * 1.5 + 10px);
}
.top-9_content .memo:last-of-type {
	margin-bottom: 20px;
}
.top-9_content .number {
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, #f4e025 68%, #f4cf25 68%);
	border-radius: 50%;
	width: 3em;
	aspect-ratio: 1 / 1;
	position: absolute;
	top: -1.5em;
	left: 0;
}
.top-9_content .memo h4 {
	border-bottom: 2px solid #016daa;
	padding-bottom: 0.25em;
	margin-bottom: 0.5em;
}
.top-9_content .memo p:has(span.bg_border_pink) {
	line-height: 2;
}
.top-9_content .inner:has(+ h3) {
	margin-bottom: 20px;
}
.top-9_content .inner > h4 {
	margin-bottom: 20px;
}
.top-9_content details {
	background-color: #fff;
	border: 2px solid #016daa;
	padding: 15px;
	margin-bottom: 15px;
}
.top-9_content details summary {
	position: relative;
}
.top-9_content details summary::after {
	content: '';
	background-color: #016daa;
	display: block;
	clip-path: polygon(15% 25%, 50% 60%, 85% 25%, 100% 35%, 50% 85%, 0 35%);
	width: 1em;
	height: 1em;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	transition: 0.25s all;
}
.top-9_content details[open] summary::after {
	transform: rotate(180deg) translateY(50%);
}
.top-9_content details summary span {
	line-height: 1;
	border: 1px solid;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.25em;
	aspect-ratio: 1 / 1;
	margin-right: 0.5em;
}
.top-9_content details hr {
	border-bottom: 3px solid #e9f6ff;
	margin: 10px 0;
}
.top-9_content.content_link .button {
  background: linear-gradient(to bottom, hsl(125deg 51.47% 82.09%) 9%, hsl(125deg 44.89% 67.47%) 28%, hsl(125 50% 35% / 1) 88%);
  box-shadow: 0 -4px 4px #cacaca, inset 3px 3px 4px #5cc54f82, inset -3px 0px 4px #5cc54f82;
	border-radius: 25px;
}
.top-9_content.content_link .button::before {
	content: none;
}

.top-9-fk1_fv_contents .carousel__main {
  margin: 0 0;
}

.top-9-fk1_fv_contents .carousel_item {
  position: relative;
  display: flex;
  justify-content: center;
}

.top-9-fk1_fv_contents .carousel_content:last-of-type .carousel_item:not(:first-of-type){
  &:before  {
    content: "";
    background-image: url(../images/top-9-fk1/top-9-fk1_fv_bg.png);
    display: block;
    position: absolute;
    width: calc(100% + 37px * 2);
    height: 100%;
    z-index: -1;
    top: 0;
    left: -37px;
  }
  img {
    width: calc(100% * 0.78);
  }
}

.top-9-fk1_fv_contents .btn_prev, .btn_next {
  background-color: initial;
}
.top-9-fk1_fv_contents .btn_prev {
  left: 5%;
  padding-right: 0;
}
.top-9-fk1_fv_contents .btn_next {
  right: 5%;
  padding-left: 0;
}
.top-9-fk1_fv_contents .carousel_control:nth-child(1) .btn_next {
  position: absolute;
  top: 55%;
  right: clamp(36px, 80vw, 0px);
  width: clamp(200px, 80vw, 500px);
  display: block;
  height: 18%;
  background: transparent;
  border-radius: initial;
}
.top-9-fk1_fv_contents .link_searchform_wrapper {
  position: absolute;
  right: 50%;
  transform: translateX(50%);
  top: 66%;
  display: block;
  width: 55%;
  height: 34%;
  background: transparent;
  border-radius: initial;
  z-index: 1;

  a {
    display: block;
    width: 100%;
    height: 100%;
  }
}

.top-9-fk1_fv_contents .carousel_content:last-of-type .carousel_item:last-of-type::after {
  display: block;
  background-image: url(../images/top-9-fk1/top-9-fk1_fv_i.png);
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  width: 38%;
  aspect-ratio: 239 / 174;
  position: absolute;
  bottom: 0;
  right: 0;
}

.top-9-fk1_fv_contents input:nth-child(2):checked ~ .carousel__main .carousel_control:nth-child(2) {
  label.btn_next::after {
    content: "１/３";
    font-size: 1.4em;
    display: block;
    position: absolute;
    bottom: -20px;
    width: 3em;
    left: -.5em;
    font-weight: bold;
    color: #fff;
    text-shadow: 1px 2px 4px #50b2fb;
  }
}

.top-9-fk1_fv_contents input:nth-child(3):checked ~ .carousel__main .carousel_control:nth-child(3) {
  label.btn_next::after {
    content: "２/３";
    font-size: 1.4em;
    display: block;
    position: absolute;
    bottom: -20px;
    width: 3em;
    left: -.5em;
    font-weight: bold;
    color: #fff;
    text-shadow: 1px 2px 4px #50b2fb;
  }
}

.top-9-fk1_fv_contents input:nth-child(4):checked ~ .carousel__main .carousel_control:nth-child(4) {
  label.btn_next::after {
    content: "３/３";
    font-size: 1.4em;
    display: block;
    position: absolute;
    bottom: -20px;
    width: 3em;
    left: -.5em;
    font-weight: bold;
    color: #fff;
    text-shadow: 1px 2px 4px #50b2fb;
  }
}