@charset "utf-8";

/* page-about.css */
.slug_about .container {
	background-color: var(--color-cp-b);
}

.slug_about .title-alias {
	font-weight: 500;
	letter-spacing: 0.1em;
	font-size: var(--ft-size14);
	color: var(--color-cp-r);
}

.slug_about main h2.style-h1 {
	margin-bottom: var(--space-s40);
	color: #FFFFFF;
}

.slug_about main .wp-block-group:not(.mv-area) {
	padding-bottom: var(--space-s100);
}

.set-line {
	display: flex;
	align-items: center;
	margin-bottom: var(--space-s40);
	gap: 2.6rem;
}

.set-line::after {
	content: "";
	flex-grow: 1;
	height: 1px;
	background-color: var(--color-main-text);
}

.mv-area {
	width: 100%;
	height: 100%;
	margin-bottom: var(--space-s100);
	background: #000000 url("../images/about/mv_bg.webp") 50% 0 no-repeat;
	background-size: cover;
	border-radius: 0 0 150px 0;
	aspect-ratio: 64 / 35;
}

.mv-area > div {
	display: flex;
	flex-flow: column nowrap;
	justify-content: center;
	height: 100%;
}

.mv-area .title-alias {
	margin-bottom: 0.8rem;
}

.mv-area h1 {
	margin-bottom: var(--space-s40);
	line-height: 1;
	font-size: 6.0rem;
	color: #FFFFFF;
}

.mv-area h1 + p {
	margin: 0 0 2.0rem;
	font-size: 2.4rem;
}

.mv-area ul.anchor-link {
	display: flex;
	width: fit-content;
	margin-top: var(--space-s60);
	padding: 1.4rem 4.0rem;
	border-radius: 99em;
	background-color: #FFFFFF;
	color: #333333;
	gap: 1.6rem 3.2rem;
}

.mv-area ul.anchor-link a {
	display: flex;
	flex-flow: row nowrap;
	align-items: center;
	gap: 0.8rem;
}

.mv-area ul.anchor-link a::after {
	content: "";
	width: 16px;
	height: 16px;
	background: url("../images/icon_arrow_cd_r.svg") 50% 50% no-repeat;
	background-size: contain;
	flex-shrink: 0;
}

.company-area > div {
	position: relative;
}

.wp-block-table.company-tbl table,
.wp-block-table.company-tbl th,
.wp-block-table.company-tbl td {
	border: 0;
}

.wp-block-table.company-tbl {
	width: min(100%,800px);
	margin: 0 auto var(--space-s40);
}

.wp-block-table.company-tbl table tr:not(:last-of-type) {
	border-bottom: 1px solid var(--color-main-text);
}

.wp-block-table.company-tbl table tr td {
	padding: 2.0rem 0;
	vertical-align: top;
}

.wp-block-table.company-tbl table tr td:nth-of-type(1) {
	width: calc(5em + 4.5rem);
}

.wp-block-table.company-tbl table tr td:nth-of-type(2) {
	width: auto;
}

.wp-block-columns.company-img {
	width: min(100%,800px);
	margin: 0 auto;
}

.company-char {
	position: absolute;
	right: 0;
	top: 0;
	width: 41.875%;
	transform: translateY(-50%);
}

.history-tbl-box {
	width: min(100%,800px);
	margin: 0 auto var(--space-s50);
}

.wp-block-table.history-tbl table,
.wp-block-table.history-tbl th,
.wp-block-table.history-tbl td {
	border: 0;
}

.wp-block-table.history-tbl td {
	padding: 1.0rem 0;
	vertical-align: top;
}

.wp-block-table.history-tbl table tr td:nth-of-type(1) {
	width: calc(4ex + (0.02em * 4) + 2.0rem + 9px);
	padding: 0.5rem 0 1.0rem;
	font-weight: 700;
	font-size: 2.2rem;
}

.wp-block-table.history-tbl table tr td:nth-of-type(1)::after {
	content: "";
	display: inline-block;
	width: 9px;
	height: 9px;
	margin-left: 1.0rem;
	border-radius: 50%;
	background-color: var(--color-main-text);
	vertical-align: 3px;
}

.wp-block-table.history-tbl table tr td:nth-of-type(2) {
	width: calc(2.25em + (0.02em * 3));
	text-align: right;
}

.wp-block-table.history-tbl table tr td:nth-of-type(3) {
	width: auto;
	padding-left: 1.4rem;
}

.history-cert-box {
	width: min(100%,800px);
	margin: 0 auto;
}

.history-cert-box h4 {
	margin-bottom: 1.5rem;
}

.wp-block-table.history-cert-tbl table,
.wp-block-table.history-cert-tbl th,
.wp-block-table.history-cert-tbl td {
	border: 0;
}

.wp-block-table.history-cert-tbl {
	margin-bottom: var(--space-s40);
	border-top: 1px solid var(--color-main-text);
}

.wp-block-table.history-cert-tbl:last-of-type {
	margin-bottom: 0;
}

.wp-block-table.history-cert-tbl table tr {
	border-bottom: 1px solid var(--color-main-text);
}

.wp-block-table.history-cert-tbl table tr td {
	padding: 0.5rem 0.8rem;
	vertical-align: top;
}

.wp-block-table.history-cert-tbl table tr td:nth-of-type(1) {
	width: calc(6.5em + 1.6rem);
	background-color: #226995;
}

.wp-block-table.history-cert-tbl table tr td:nth-of-type(2) {
	width: auto;
}

.facilities-area h4.style-h3:has(+ .fac-box) {
	width: min(100%,800px);
	margin: 0 auto 2.0rem;
}

.wp-block-columns.fac-box {
	width: min(100%,800px);
	margin: 0 auto var(--space-s80);
}

.wp-block-columns.fac-box ul.wp-block-list.fac-list {
	padding: 2.4rem;
	border: 1px solid var(--color-main-text);
	border-radius: 8px;
}

.wp-block-columns.fac-box ul.wp-block-list.fac-list li {
	padding-left: 1.5em;
}

.wp-block-columns.fac-box ul.wp-block-list.fac-list li + li {
	margin-top: 0.5rem;
}

.wp-block-columns.fac-box ul.wp-block-list.fac-list li strong {
	margin-left: -1.5em;
	font-weight: 700;
}

.wp-block-columns.fac-box ul.wp-block-list.fac-list li strong::before {
	content: "";
	display: inline-block;
	width: 16px;
	height: 16px;
	margin-right: 0.5em;
	background-color: var(--color-main-text);
	border-radius: 50%;
	vertical-align: -2px;
}

p.fac-note {
	width: fit-content;
	margin: 1.0rem auto 0;
	font-size: var(--ft-size14);
}

p.fac-note strong {
	display: inline-block;
	margin-right: 0.5em;
	padding: 0.2rem 0.8rem;
	border: 1px solid var(--color-main-text);
	border-radius: 8px;
	font-weight: 400;
}

.facilities-area h5:has(+ .fac-comp-tbl) {
	margin-bottom: var(--space-s50);
	font-weight: 700;
	font-size: 2.0rem;
}

.facilities-area .wp-block-table.fac-comp-tbl {
	width: min(100%,800px);
	margin: 0 auto var(--space-s100);
}

.facilities-area h3:has(+ .fac-tile) {
	margin-bottom: 2.0rem;
}

.wp-block-columns.fac-tile {
	flex-wrap: wrap !important;
	margin: 0 0 var(--space-s100);
}

.wp-block-columns.fac-tile:last-of-type {
	margin-bottom: 0;
}

.wp-block-columns.fac-tile .wp-block-column {
	flex-basis: auto !important;
	flex-grow: 0 !important;
	width: calc((100% - 4em) / 3);
}

.fac-tile .fac-tile-ttl {
	margin: 1.2rem auto 0;
	width: fit-content;
	font-weight: 700;
}

.fac-tile .fac-tile-text {
	margin: 1.8rem 0 1.4rem;
}

.fac-tile .fac-tile-spec {
	font-size: var(--ft-size14);
}

.wp-block-table.fac-tile-tbl table,
.wp-block-table.fac-tile-tbl th,
.wp-block-table.fac-tile-tbl td {
	border: 0;
}

.wp-block-table.fac-tile-tbl {
	border-top: 1px solid var(--color-main-text);
}

.wp-block-table.fac-tile-tbl table tr {
	border-bottom: 1px solid var(--color-main-text);
}

.wp-block-table.fac-tile-tbl table tr td {
	padding: 0.5rem 0.8rem;
	vertical-align: top;
}

.wp-block-table.fac-tile-tbl table tr td:nth-of-type(1) {
	width: auto;
	background-color: #226995;
}

.wp-block-table.fac-tile-tbl table tr td:nth-of-type(2) {
	width: calc(3em + 1.6rem);
	text-align: center;
}

.quality-area > div {
	background: url(../images/about/about_quality_bg.svg) 100% 0 no-repeat;
	background-size: 33.125% auto;
}

.quality-area > div > h2 + p,
.quality-area > div > .wp-block-columns,
.quality-area > div > h4 {
	width: min(100%,800px);
	margin-left: auto;
	margin-right: auto;
}

.quality-area > div > h2 + p {
	margin-bottom: var(--space-s40);
}

.wp-block-columns.quality-policy {
	justify-content: space-between !important;
	padding: 4.6rem 6.25% 4.6rem 9.375%;
	margin-bottom: var(--space-s30);
	background-color: #226995;
	border-radius: 10px;
}

.wp-block-columns.quality-policy:nth-of-type(2) {
	margin-bottom: var(--space-s80);
}

.wp-block-columns.quality-policy .wp-block-column {
	flex-basis: auto !important;
	flex-grow: 0 !important;
}

.wp-block-columns.quality-policy .wp-block-column:nth-of-type(1) {
	width: fit-content;
	flex-shrink: 0;
}

.wp-block-columns.quality-policy .wp-block-column:nth-of-type(1) h3 {
	margin-bottom: 1.4rem;
}

.wp-block-columns.quality-policy .wp-block-column:nth-of-type(2) {
	max-width: 472px;
}

.wp-block-columns.quality-tbl-box {
	margin-bottom: var(--space-s80);
}

.wp-block-columns.quality-tbl-box:last-of-type {
	margin-bottom: 0;
}

.wp-block-table.quality-tbl table,
.wp-block-table.quality-tbl th,
.wp-block-table.quality-tbl td {
	border: 0;
}

.wp-block-table.quality-tbl {
	border-top: 1px solid var(--color-main-text);
}

.wp-block-table.quality-tbl table tr {
	border-bottom: 1px solid var(--color-main-text);
}

.wp-block-table.quality-tbl table tr td {
	padding: 0.5rem 0.8rem;
	vertical-align: top;
}

.wp-block-table.quality-tbl table tr td:nth-of-type(1) {
	width: auto;
	background-color: #226995;
}

.wp-block-table.quality-tbl table tr td:nth-of-type(2) {
	width: auto;
}

/* ================================================ */
@media (max-width: 1000px) {
}

/* ================================================ */
@media (max-width: 840px) {
}

/* ================================================ */
@media (max-width: 640px) {
}

/* ================================================ */
@media (max-width: 480px) {
}