@charset "utf-8";
/* =========================================================================================
PAGE HEADER
=========================================================================================*/
.page-header {
	min-height: 300px;
	background: url(../images/page_header_default.webp) no-repeat center;
	background-size: cover;
	display: flex;
	align-items: center;
	justify-content: center;
	padding-block: 20px;
	margin: 0;
	position: relative;
	margin-top: 115px;
}
.page-header .inner {

}
.page-header .page-title {
	color: var(--color-dark);
	font-size: clamp(1.75rem, calc(1.118rem + 2.697vw), 2.5rem); /* min: 28px, max: 40px */
	font-weight: var(--weight-bold);
	text-align: center;
	letter-spacing: 0.025em;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	margin: 0;
}

@media only screen and (max-width: 980px) {
	.page-header {
		margin-top: 85px;
		min-height: 250px;
	}
	.page-header .inner {

	}
}
@media only screen and (max-width: 468px) {
	.page-header {
		min-height: 220px;
	}
}

/* =========================================================================================
LAYOUT
=========================================================================================*/
.entry-content section:nth-of-type(1) /*ページの一番最初のsection*/ {
	padding-top: 75px;
}
.entry-content section:nth-last-of-type(1) /*ページの一番最最後のsection*/ {
	padding-bottom: 150px;
}
@media only screen and (max-width: 820px) {
}
@media only screen and (max-width: 468px) {
	.entry-content section:nth-of-type(1) {
		padding-top: 50px;
	}
	.entry-content section:nth-last-of-type(1) {
		padding-bottom: 100px;
	}
}

/*page-link-area*/
.entry-content {
	position: relative;
}
.entry-content:has(#page-link-area) section:nth-of-type(1) {
	padding-top: 25px;
}
.entry-content #page-link-area {
	position: relative;
	z-index: 10;
	translate: 0 -2em;
}
.entry-content #page-link-area ul.page-link {
	width: 100%;
	background: #fff;
	padding: 20px 40px;
	border-radius: 0;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 10px 5%;
	filter: drop-shadow(0px 0px 3px rgba(0, 0, 0, 0.5));
}
.entry-content #page-link-area ul.page-link a {
	color: var(--color-main);
	font-weight: var(--weight-bold);
	text-decoration: none;
	padding-right: 1em;
	position: relative;
}
.entry-content #page-link-area ul.page-link a::before,
.entry-content #page-link-area ul.page-link a::after {
	content: "";
	width: 3px;
	height: 0.6em;
	border-radius: 9999px;
	background-color: var(--color-main);
	position: absolute;
	top: 50%;
	right: 0;
	transform-origin: 50% calc(100% - 1.5px);
	translate: 0 -50%;
}
.entry-content #page-link-area ul.page-link a::before {
	transform: rotate(45deg);
}
.entry-content #page-link-area ul.page-link a::after {
	transform: rotate(-45deg);
}
.entry-content #page-link-area ul.page-link a:hover {
	color: var(--sub-color);
	opacity: 1;
}
@media only screen and (max-width: 820px) {
	.entry-content #page-link-area ul.page-link {
		gap: 10px 1.5em;
		padding: 20px 30px;
	}
}
@media only screen and (max-width: 468px) {
	.entry-content #page-link-area ul.page-link {
		gap: 10px 1.5em;
		padding: 10px 20px;
	}
}
/* google map */
.entry-content .map {
	position: relative;
	min-height: 260px;
}

.entry-content .map iframe {
	width: 100%;
	aspect-ratio: 400 / 260;
	height: auto;
}

/* =========================================================================================
VK BLOCK PARTS
=========================================================================================*/
/*.greeting-block*/
.wp-block-columns.greeting-block {
	gap: 40px 7.5%;
}
.wp-block-columns.greeting-block h3 {
	font-size: clamp(1.375rem, calc(1.164rem + 0.899vw), 1.625rem); /* min: 22px, max: 26px */
	font-weight: var(--weight-bold);
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: left;
	gap: 0.25em 1em;
}
.wp-block-columns.greeting-block h3 span.post {
	font-size: clamp(1rem, calc(0.895rem + 0.449vw), 1.125rem); /* min: 16px, max: 18px */
	font-weight: var(--weight-normal);
}
.wp-block-columns.greeting-block img {
	width: 100%;
	max-width: 300px;
}
@media only screen and (max-width: 820px) {
}
@media only screen and (max-width: 468px) {
}

/*.merit-block*/
.wp-block-group.merit-block {
	width: 100%;
	max-width: 820px;
	border: 3px solid var(--color-main);
	border-radius: 10px;
	background: url(../images/page/merit_block_bg.svg) no-repeat top 50% left 0 / 250px auto;
	gap: 40px 2%;
	margin-inline: auto;
}
.wp-block-group.merit-block h3 {
	width: 250px;
	font-size: clamp(1.375rem, calc(1.164rem + 0.899vw), 1.625rem); /* min: 22px, max: 26px */
	font-weight: var(--weight-bold);
	height: 100%;
	background: none;
	padding-left: 1.25em;
	margin: 0;
}
.wp-block-group.merit-block h3::before {
	display: none;
}
.wp-block-group.merit-block ul {
	width: calc(100% - 5% - 250px);
	padding: 30px 5%;
}
@media only screen and (max-width: 768px) {
	.wp-block-group.merit-block {
		flex-direction: column;
		gap: 0;
		background: none;
	}
	.wp-block-group.merit-block h3,
	.wp-block-group.merit-block ul {
		width: 100%;
	}
	.wp-block-group.merit-block h3 {
		text-align: center;
		padding: 0.75em;
		background: var(--color-accent);
		border-radius: 10px 10px 0 0;
	}
	.wp-block-group.merit-block ul {
		padding: 20px 30px 30px;
	}
}
@media only screen and (max-width: 468px) {
}

/* =========================================================================================
COMPANY
=========================================================================================*/
body.company .entry-content table {
	width: 100%;
	max-width: var(--contents-width-small);
	margin-inline: auto;
}
@media only screen and (max-width: 820px) {
}
@media only screen and (max-width: 468px) {
}

/* =========================================================================================
BUSINESS
=========================================================================================*/
body.business .entry-content p a,
body.business .entry-content li a {
	color: var(--color-base-font);
	text-decoration: underline;
}
body.business .entry-content p a:hover,
body.business .entry-content li a:hover {
	color: var(--color-main);
	text-decoration: none;
}
body.business .wp-block-vk-blocks-border-box {
	max-width: 650px;
	gap: 5%;
}
body.business .wp-block-vk-blocks-border-box .vk_borderBox_body {
	background: #fffff5;
}
body.business .entry-content ol.grid-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
	align-items: start;
	gap: 0.75em 1em;
}
body.business .entry-content ol.grid-list li + li {
	margin-top: 0;
}

body.business .entry-content .wp-block-list li img {
	width: 100% !important;
	max-width: 400px;
	margin-block: 0.5em;
	transition: 0.3s;
}
body.business .entry-content .wp-block-list li img:hover {
	opacity: 0.8;
}
body.business .entry-content table {
	max-width: 850px;
}
body.business .parts-contact-ouisya {
	max-width: 880px;
	margin-inline: auto;
}
@media only screen and (max-width: 820px) {
	body.business .wp-block-vk-blocks-border-box .wp-block-columns {
		gap: 3.5%;
	}
}
@media only screen and (max-width: 468px) {
	body.business .wp-block-vk-blocks-border-box .wp-block-columns {
		gap: 0;
	}
}

/* =========================================================================================
INSURANCE
=========================================================================================*/
body.insurance article {
	background: var(--color-gray);
}
@media only screen and (max-width: 820px) {
}
@media only screen and (max-width: 468px) {
}

/* =========================================================================================
CONTACT
=========================================================================================*/
body.contact #main .inner {
	max-width: var(--contents-width-small);
}
@media only screen and (max-width: 820px) {
}
@media only screen and (max-width: 468px) {
}

/* =========================================================================================
404
=========================================================================================*/
body.error404 .entry-header {
	text-align: center;
	padding: 40px 20px;
	margin: 0;
}
body.error404 .error-message {
	text-align: center;
	padding: 20px;
	margin-bottom: 30px;
}
body.error404 .error-message p img {
	max-width: 300px;
	margin: 0 auto 50px;
}
@media only screen and (max-width: 820px) {
}
@media only screen and (max-width: 468px) {
}
