/******************************************************************
foundation - override
******************************************************************/
main {
	overflow: clip;
}

main.helpd h4 {
	margin: initial;
	padding: initial;
	border: initial;
	font-weight: bold;
}

main.helpd .virtual_tour {
	border-top: none;
	padding: 0;
}

@media print, screen and (min-width: 769px) {
	.contact-info__item--buttons {
		justify-content: center;
	}
}
/*--------------------------------------------
* Relation related services
--------------------------------------------*/
.relation-related-services {
	margin: 0 auto 100px;
}

.relation-contents__item--button a:hover {
	color: #fff;
}

/******************************************************************
component - section
******************************************************************/
.c-section {
	position: relative;
	overflow: hidden;
	margin: 0 !important;
}
.c-section--offset-cut {
	padding-block: 0.1px;
}
.c-section__vertical {
	max-width: 1060px;
	margin-inline: auto;
	padding-inline: 0;
}
@media screen and (max-width: 768px) {
	.c-section__vertical {
		padding-inline: 0;
	}
}
.c-section__vertical {
	margin-block: 6rem;
}
@media screen and (max-width: 768px) {
	.c-section__vertical {
		margin-block: 4rem;
	}
}
.c-section__vertical--slim {
	max-width: 900px;
	margin-inline: auto;
	padding-inline: 0;
}
@media screen and (max-width: 768px) {
	.c-section__vertical--slim {
		padding-inline: 0;
	}
}
.c-section__vertical--full {
	max-width: none;
	padding-inline: 0;
}
.c-section__top {
	max-width: 1060px;
	margin-inline: auto;
	padding-inline: 0;
}
@media screen and (max-width: 768px) {
	.c-section__top {
		padding-inline: 0;
	}
}
.c-section__top {
	margin-top: 6rem;
}
@media screen and (max-width: 768px) {
	.c-section__top {
		margin-top: 4rem;
	}
}
.c-section__top--slim {
	max-width: 900px;
	margin-inline: auto;
	padding-inline: 0;
}
@media screen and (max-width: 768px) {
	.c-section__top--slim {
		padding-inline: 0;
	}
}
.c-section__top--full {
	max-width: none;
	padding-inline: 0;
}
.c-section__bottom {
	max-width: 1060px;
	margin-inline: auto;
	padding-inline: 0;
}
@media screen and (max-width: 768px) {
	.c-section__bottom {
		padding-inline: 0;
	}
}
.c-section__bottom {
	margin-bottom: 6rem;
}
@media screen and (max-width: 768px) {
	.c-section__bottom {
		margin-bottom: 4rem;
	}
}
.c-section__bottom--slim {
	max-width: 900px;
	margin-inline: auto;
	padding-inline: 0;
}
@media screen and (max-width: 768px) {
	.c-section__bottom--slim {
		padding-inline: 0;
	}
}
.c-section__bottom--full {
	max-width: none;
	padding-inline: 0;
}
.c-section__fit {
	max-width: 1060px;
	margin-inline: auto;
	padding-inline: 0;
}
@media screen and (max-width: 768px) {
	.c-section__fit {
		padding-inline: 0;
	}
}
.c-section__fit--slim {
	max-width: 900px;
	margin-inline: auto;
	padding-inline: 0;
}
@media screen and (max-width: 768px) {
	.c-section__fit--slim {
		padding-inline: 0;
	}
}
.c-section__fit--slim2 {
	max-width: 600px;
	margin-inline: auto;
	padding-inline: 0;
}
@media screen and (max-width: 768px) {
	.c-section__fit--slim2 {
		padding-inline: 0;
	}
}
.c-section__fit--full {
	max-width: none;
	padding-inline: 0;
}
.c-section--achievements {
	overflow: initial;
	position: relative;
	padding-block: 0.1px;
}
.c-section--achievements::before {
	position: absolute;
	content: "";
	margin: auto;
	box-sizing: border-box;
	vertical-align: middle;
	top: 0;
	left: 50%;
	width: 100vw;
	height: 100%;
	transform: translateX(-50%);
	background-color: #fffced;
}
/******************************************************************
component - c-flexbox
******************************************************************/
.c-flexbox {
	display: flex;
	flex-wrap: wrap;
}
.c-flexbox > [class*=c-flexbox__item], .c-flexbox > .c-flexbox__item5col {
	position: relative;
	box-sizing: border-box;
}
.c-flexbox > [class*=c-flexbox__item]:has(> .c-button:first-child):has(> .c-button:last-child), .c-flexbox > .c-flexbox__item5col:has(> .c-button:first-child):has(> .c-button:last-child) {
	display: flex;
}
.c-flexbox > [class*=c-flexbox__item]:has(> .c-button-visual:first-child):has(> .c-button-visual:last-child), .c-flexbox > .c-flexbox__item5col:has(> .c-button-visual:first-child):has(> .c-button-visual:last-child) {
	display: flex;
}
.c-flexbox--center {
	justify-content: center;
}
.c-flexbox--right {
	justify-content: flex-end;
}
.c-flexbox--vertical > [class*=c-flexbox__item], .c-flexbox--vertical > .c-flexbox__item5col {
	display: flex;
	align-items: center;
}
.c-flexbox--bottom > [class*=c-flexbox__item], .c-flexbox--bottom > .c-flexbox__item5col {
	display: flex;
	align-items: flex-end;
}
.c-flexbox {
	--flexbox-gap-y: 1rem;
	--flexbox-gap-x: 1rem;
	margin-right: calc(var(--flexbox-gap-x) * -1);
}
.c-flexbox--center {
	margin-inline: calc(var(--flexbox-gap-x) * -0.5);
}
.c-flexbox--right {
	margin-right: initial;
	margin-left: calc(var(--flexbox-gap-x) * -1);
}
.c-flexbox {
	gap: var(--flexbox-gap-y) var(--flexbox-gap-x);
}
.c-flexbox > .c-flexbox__item1 {
	width: calc(8.3333333333% - var(--flexbox-gap-x));
}
.c-flexbox > .c-flexbox__item2 {
	width: calc(16.6666666667% - var(--flexbox-gap-x));
}
.c-flexbox > .c-flexbox__item3 {
	width: calc(25% - var(--flexbox-gap-x));
}
.c-flexbox > .c-flexbox__item4 {
	width: calc(33.3333333333% - var(--flexbox-gap-x));
}
.c-flexbox > .c-flexbox__item5 {
	width: calc(41.6666666667% - var(--flexbox-gap-x));
}
.c-flexbox > .c-flexbox__item6 {
	width: calc(50% - var(--flexbox-gap-x));
}
.c-flexbox > .c-flexbox__item7 {
	width: calc(58.3333333333% - var(--flexbox-gap-x));
}
.c-flexbox > .c-flexbox__item8 {
	width: calc(66.6666666667% - var(--flexbox-gap-x));
}
.c-flexbox > .c-flexbox__item9 {
	width: calc(75% - var(--flexbox-gap-x));
}
.c-flexbox > .c-flexbox__item10 {
	width: calc(83.3333333333% - var(--flexbox-gap-x));
}
.c-flexbox > .c-flexbox__item11 {
	width: calc(91.6666666667% - var(--flexbox-gap-x));
}
.c-flexbox > .c-flexbox__item12 {
	width: calc(100% - var(--flexbox-gap-x));
}
.c-flexbox > .c-flexbox__item5col {
	width: calc(20% - var(--flexbox-gap-x));
}
@media screen and (max-width: 1060px) {
	.c-flexbox.pc-vw {
		--flexbox-gap-y: 1.5094339623vw;
		--flexbox-gap-x: 1.5094339623vw;
	}
}
.c-flexbox--m {
	--flexbox-gap-y: 1rem;
	--flexbox-gap-x: 1rem;
}

.c-flexbox--2x {
	--flexbox-gap-y: 2rem;
	--flexbox-gap-x: 2rem;
}

@media screen and (max-width: 1060px) {
	.c-flexbox--2x.pc-vw {
		--flexbox-gap-y: 3.0188679245vw;
		--flexbox-gap-x: 3.0188679245vw;
	}
}
@media screen and (max-width: 768px) {
	.c-flexbox.sp-destroy {
		display: initial;
		flex-wrap: initial;
		margin-right: initial;
		margin-left: initial;
		gap: initial;
	}
	.c-flexbox.sp-destroy > * {
		position: initial;
		box-sizing: initial;
		width: initial;
	}
	.c-flexbox {
		--flexbox-gap-y: 0.9rem;
		--flexbox-gap-x: 0.9rem;
	}
	.c-flexbox > .sp-item1 {
		width: calc(8.3333333333% - var(--flexbox-gap-x));
	}
	.c-flexbox > .sp-item2 {
		width: calc(16.6666666667% - var(--flexbox-gap-x));
	}
	.c-flexbox > .sp-item3 {
		width: calc(25% - var(--flexbox-gap-x));
	}
	.c-flexbox > .sp-item4 {
		width: calc(33.3333333333% - var(--flexbox-gap-x));
	}
	.c-flexbox > .sp-item5 {
		width: calc(41.6666666667% - var(--flexbox-gap-x));
	}
	.c-flexbox > .sp-item6 {
		width: calc(50% - var(--flexbox-gap-x));
	}
	.c-flexbox > .sp-item7 {
		width: calc(58.3333333333% - var(--flexbox-gap-x));
	}
	.c-flexbox > .sp-item8 {
		width: calc(66.6666666667% - var(--flexbox-gap-x));
	}
	.c-flexbox > .sp-item9 {
		width: calc(75% - var(--flexbox-gap-x));
	}
	.c-flexbox > .sp-item10 {
		width: calc(83.3333333333% - var(--flexbox-gap-x));
	}
	.c-flexbox > .sp-item11 {
		width: calc(91.6666666667% - var(--flexbox-gap-x));
	}
	.c-flexbox > .sp-item12 {
		width: calc(100% - var(--flexbox-gap-x));
	}
	.c-flexbox > .sp-item5col {
		width: calc(20% - var(--flexbox-gap-x));
	}
	.c-flexbox--m {
		--flexbox-gap-y: 0.9rem;
		--flexbox-gap-x: 0.9rem;
	}
	.c-flexbox.sp-m {
		--flexbox-gap-y: 0.9rem;
		--flexbox-gap-x: 0.9rem;
	}
	.c-flexbox--2x {
		--flexbox-gap-y: 1.8rem;
		--flexbox-gap-x: 1.8rem;
	}
	.c-flexbox.sp-2x {
		--flexbox-gap-y: 1.8rem;
		--flexbox-gap-x: 1.8rem;
	}
}

/******************************************************************
component - frame-bg
******************************************************************/
.c-frame-bg {
	background-color: #f2f2f2;
	padding: 2rem;
}
@media screen and (max-width: 768px) {
	.c-frame-bg {
		padding: 0.9rem;
	}
}

/******************************************************************
component - frame-border
******************************************************************/
.c-frame-border {
	border: 1px solid #ccc;
	padding: 2rem;
}
@media screen and (max-width: 768px) {
	.c-frame-border {
		padding: 0.9rem;
	}
}

/******************************************************************
component - frame-point
******************************************************************/
.c-frame-point {
	position: relative;
	margin-top: 3em;
	background-color: #eaf5fc;
	border-radius: 30px;
	padding: 30px;
	padding-top: 40px;
}
@media screen and (max-width: 768px) {
	.c-frame-point {
		border-radius: 20px;
		padding: 20px;
		padding-top: 30px;
	}
}
.c-frame-point__head {
	margin: 0;
	position: absolute;
	top: 0;
	transform: translateY(-50%);
	left: 15px;
	width: fit-content;
	text-align: center;
}
.c-frame-point__head--center {
	left: 0;
	right: 0;
	margin-inline: auto;
}
.c-frame-point__head {
	background-color: #CC0033;
	border-radius: 100vw;
	padding: 0.5em 1em;
	color: #fff;
	font-size: 1rem;
	font-weight: bold;
}
/******************************************************************
component - step-list
******************************************************************/
.c-step-list > *:not(:last-child) {
	position: relative;
	margin-bottom: 65px;
	position: relative;
}
.c-step-list > *:not(:last-child)::after {
	transition-property: top, right, bottom, left, opacity;
	transition-duration: 0.2s;
	position: absolute;
	content: "";
	margin: auto;
	box-sizing: border-box;
	vertical-align: middle;
	width: 22px;
	height: 22px;
	border-color: #CC0033;
	border-style: solid;
	border-top-width: 22px;
	border-right: 11px solid transparent !important;
	border-bottom-width: 0;
	border-left: 11px solid transparent !important;
	bottom: -46px;
	left: 0;
	right: 0;
}
@media screen and (max-width: 768px) {
	.c-step-list > *:not(:last-child) {
		margin-bottom: 40px;
		position: relative;
	}
	.c-step-list > *:not(:last-child)::after {
		transition-property: top, right, bottom, left, opacity;
		transition-duration: 0.2s;
		position: absolute;
		content: "";
		margin: auto;
		box-sizing: border-box;
		vertical-align: middle;
		width: 14px;
		height: 14px;
		border-color: #CC0033;
		border-style: solid;
		border-top-width: 14px;
		border-right: 7px solid transparent !important;
		border-bottom-width: 0;
		border-left: 7px solid transparent !important;
		bottom: -28px;
		left: 0;
		right: 0;
	}
}
.c-step-list > *:not(:last-child)::after {
	transform: scaleX(2);
}

/******************************************************************
component - plus-list
******************************************************************/
.c-plus-list > *:not(:last-child) {
	position: relative;
	margin-bottom: 65px;
	position: relative;
}
.c-plus-list > *:not(:last-child)::before, .c-plus-list > *:not(:last-child)::after {
	position: absolute;
	content: "";
	margin: auto;
	box-sizing: border-box;
	vertical-align: middle;
	transition-property: all;
	transition-duration: 0.3s;
	transition-timing-function: cubic-bezier(0.3, 2, 0.6, 1);
}
.c-plus-list > *:not(:last-child)::before {
	background-color: #333;
	width: 21px;
	height: 3px;
	bottom: -33px;
	right: 0;
	left: 0;
}
.c-plus-list > *:not(:last-child)::after {
	background-color: #333;
	width: 3px;
	height: 21px;
	bottom: -42px;
	right: 0;
	left: 0;
}
@media screen and (max-width: 768px) {
	.c-plus-list > *:not(:last-child) {
		margin-bottom: 40px;
		position: relative;
	}
	.c-plus-list > *:not(:last-child)::before, .c-plus-list > *:not(:last-child)::after {
		position: absolute;
		content: "";
		margin: auto;
		box-sizing: border-box;
		vertical-align: middle;
		transition-property: all;
		transition-duration: 0.3s;
		transition-timing-function: cubic-bezier(0.3, 2, 0.6, 1);
	}
	.c-plus-list > *:not(:last-child)::before {
		background-color: #333;
		width: 12px;
		height: 2px;
		bottom: -21px;
		right: 0;
		left: 0;
	}
	.c-plus-list > *:not(:last-child)::after {
		background-color: #333;
		width: 2px;
		height: 12px;
		bottom: -26px;
		right: 0;
		left: 0;
	}
}

/******************************************************************
component - list-disc
******************************************************************/
.c-list-disc {
	line-height: 1.5;
}
.c-list-disc > * {
	margin-left: 1.5em;
	list-style: disc;
}
.c-list-disc > *::marker {
	font-weight: bold;
	color: inherit;
}
.c-list-disc--gutter > *:not(:first-child) {
	margin-top: 0.75em;
}
.c-list-disc__red {
	color: #CC0033;
	font-weight: bold;
	font-size: 110%;
}

/******************************************************************
component - list-order
******************************************************************/
.c-list-order {
	line-height: 1.5;
}
.c-list-order:has(> :nth-child(10)) {
	margin-left: 0.75em;
}
.c-list-order > * {
	margin-left: 1.5em;
	list-style: decimal;
}
.c-list-order--servicenow > * {
	margin-left: 1.5em;
	list-style: decimal;
}
.c-list-order--servicenow > *::marker {
	font-weight: bold;
	color: #CC0033;
}
.c-list-order--servicenow > *:not(:first-child) {
	margin-top: 0.75em;
}
.c-list-order--servicenow strong {
	font-weight: bold;
	color: #CC0033;
}

/******************************************************************
component - list-arrow
******************************************************************/
.c-list-arrow {
	line-height: 1.5;
}
.c-list-arrow > * {
	padding-left: 1.5em;
	position: relative;
}
.c-list-arrow > *::after {
	transition-property: top, right, bottom, left, opacity;
	transition-duration: 0.2s;
	position: absolute;
	content: "";
	margin: auto;
	box-sizing: border-box;
	vertical-align: middle;
	width: 8px;
	height: 8px;
	border-color: #CC0033;
	border-style: solid;
	border-top: 4px solid transparent !important;
	border-right-width: 0;
	border-bottom: 4px solid transparent !important;
	border-left-width: 8px;
	top: 0;
	left: 0.5em;
	transform: translateY(calc(0.5lh - 50%));
}
.c-list-arrow {
	font-weight: bold;
}
.c-list-arrow > *:not(:first-child) {
	margin-top: 0.75em;
}

/******************************************************************
component - list-note
******************************************************************/
.c-list-note {
	display: table;
	line-height: 1.5;
}
.c-list-note__item {
	display: table-row;
}
.c-list-note__head {
	display: table-cell;
	padding-right: 0.75em;
	white-space: nowrap;
	vertical-align: top;
}
.c-list-note__head--bold {
	font-weight: bold;
}
.c-list-note__body {
	display: table-cell;
	vertical-align: top;
}
.c-list-note__body a {
	word-break: break-all;
}
.c-list-note__body--bold {
	font-weight: bold;
}

/******************************************************************
component - image
******************************************************************/
a:has(> .c-image) {
	display: block;
	color: inherit;
	text-decoration: none;
}
@media (any-hover: hover) {
	a:has(> .c-image):hover {
		text-decoration: none;
		color: inherit;
	}
}
a:has(> .c-image):focus {
	text-decoration: none;
	color: inherit;
}

a:has(> .c-image:not(.c-image--full):not(.c-image--object-fit)) {
	width: fit-content;
	margin-inline: auto;
}

a:has(> .c-image.c-image--left:not(.c-image--full):not(.c-image--object-fit)) {
	margin-inline: initial;
}

a:has(> .c-image.c-image--right:not(.c-image--full):not(.c-image--object-fit)) {
	margin-inline: auto 0;
}

.c-image {
	display: table;
	width: fit-content;
	margin-inline: auto;
}
.c-image--left {
	margin-inline: initial;
}
.c-image--right {
	margin-inline: auto 0;
}
.c-image--circle-frame {
	flex-direction: column;
}
.c-image--circle-frame .c-image__body {
	box-sizing: border-box;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: #f1f1f1;
	aspect-ratio: 1/1;
	border-radius: 50%;
	padding: 30px;
	margin-inline: auto;
}
.c-image--circle-frame {
	display: flex;
}
.c-image--circle-frame .c-image__caption {
	flex-grow: 1;
	display: flex;
	align-items: center;
}
.c-image__caption {
	display: table-caption;
	caption-side: top;
	min-height: 3em;
	line-height: 1.4;
	font-size: 90%;
}
@media screen and (max-width: 768px) {
	.c-image__caption {
		font-size: 12px;
	}
}
.c-image__caption:first-child {
	margin-bottom: 0.5rem;
}
.c-image__caption:last-child {
	margin-top: 0.5rem;
}
.c-image__caption--slash {
	position: relative;
	width: fit-content;
	margin-inline: auto;
	padding-inline: 1.5em;
	text-align: center;
}
.c-image__caption--slash::before {
	position: absolute;
	content: "";
	margin: auto;
	box-sizing: border-box;
	vertical-align: middle;
	top: 0;
	bottom: 0;
	left: 0.4em;
	height: 1.6em;
	border-left: 2px solid #333;
	transform: rotate(-20deg);
}
.c-image__caption--slash::after {
	position: absolute;
	content: "";
	margin: auto;
	box-sizing: border-box;
	vertical-align: middle;
	top: 0;
	right: 0.4em;
	bottom: 0;
	height: 1.6em;
	border-right: 2px solid #333;
	transform: rotate(20deg);
}

/******************************************************************
component - image-column
******************************************************************/
.c-image-column {
	--max-img-width: fit-content(50%);
	--max-img-width-sp: fit-content(40%);
}
.c-image-column:has(.js-swiper) {
	--max-img-width: 50%;
	--max-img-width-sp: 40%;
}
.c-image-column {
	display: grid;
	grid-template-areas: "img body";
	grid-template-columns: var(--max-img-width) 1fr;
}
@media screen and (max-width: 768px) {
	.c-image-column {
		grid-template-columns: var(--max-img-width-sp) 1fr;
	}
}
.c-image-column--right {
	grid-template-areas: "body img";
	grid-template-columns: 1fr var(--max-img-width);
}
@media screen and (max-width: 768px) {
	.c-image-column--right {
		grid-template-columns: 1fr var(--max-img-width-sp);
	}
}
.c-image-column__body {
	grid-area: body;
}
.c-image-column__img {
	grid-area: img;
}
.c-image-column__img > *:not(:last-child) {
	margin-bottom: 1.5rem;
}
@media screen and (max-width: 768px) {
	.c-image-column__img > *:not(:last-child) {
		margin-bottom: 1.35rem;
	}
}
.c-image-column--vertical {
	align-items: center;
}
.c-image-column {
	--image-column-gap: 1rem;
	gap: var(--image-column-gap);
}
@media screen and (max-width: 1060px) {
	.c-image-column.pc-vw {
		--image-column-gap: 1.5094339623vw;
	}
}
.c-image-column--2x {
	--image-column-gap: 2rem;
}

@media screen and (max-width: 1060px) {
	.c-image-column--2x.pc-vw {
		--image-column-gap: 3.0188679245vw;
	}
}
@media screen and (max-width: 768px) {
	.c-image-column {
		--image-column-gap: 0.9rem;
	}
	.c-image-column.sp-top {
		align-items: stretch;
	}
	.c-image-column.sp-vertical {
		align-items: center;
	}
	.c-image-column.sp-row {
		grid-template-areas: "img" "body";
		grid-template-columns: 100%;
	}
	.c-image-column.sp-row .c-image-column__img {
		width: fit-content;
		margin-inline: auto;
		max-width: 100% !important;
	}
	.c-image-column.sp-row-reverse {
		grid-template-areas: "body" "img";
	}
	.c-image-column--2x {
		--image-column-gap: 1.8rem;
	}
	.c-image-column.sp-2x {
		--image-column-gap: 1.8rem;
	}
}

/******************************************************************
component - image-scroll
******************************************************************/
@media screen and (max-width: 768px) {
	.c-image-scroll {
		overflow-x: scroll;
	}
	.c-image-scroll::-webkit-scrollbar {
		width: 5px;
		background: #F1F1F1;
	}
	.c-image-scroll::-webkit-scrollbar:horizontal {
		height: 5px;
		background: #F1F1F1;
	}
	.c-image-scroll::-webkit-scrollbar-thumb {
		background: #BCBCBC;
		border-radius: 2px;
	}
	.c-image-scroll::-webkit-scrollbar-thumb:horizontal {
		background: #BCBCBC;
		border-radius: 2px;
	}
	.c-image-scroll img {
		max-width: none;
		width: auto;
		margin-right: 0;
		height: 400px;
	}
}

/******************************************************************
component - table
******************************************************************/
.c-table-scroll .c-table {
	min-width: 1060px;
}

.c-table {
	width: 100%;
}
.c-table th, .c-table td {
	line-height: 1.5;
	vertical-align: middle;
}
.c-table th {
	text-align: center;
	font-weight: bold;
}
.c-table--achievements {
	margin-bottom: 10px;
	font-size: 14px;
}
.c-table--achievements td {
	background-color: #fff;
}
.c-table--pclcm {
	margin-bottom: 0;
}

/******************************************************************
component - table-scroll
******************************************************************/
.c-table-scroll {
	overflow-x: auto;
}
.c-table-scroll::-webkit-scrollbar {
	width: 5px;
	background: #F1F1F1;
}
.c-table-scroll::-webkit-scrollbar:horizontal {
	height: 5px;
	background: #F1F1F1;
}
.c-table-scroll::-webkit-scrollbar-thumb {
	background: #BCBCBC;
	border-radius: 2px;
}
.c-table-scroll::-webkit-scrollbar-thumb:horizontal {
	background: #BCBCBC;
	border-radius: 2px;
}
.c-table-scroll {
	scrollbar-width: thin;
	scrollbar-color: #BCBCBC #F1F1F1;
}
.c-table-scroll--100vw {
	box-sizing: border-box;
}
@media screen and (max-width: 1060px) {
	.c-table-scroll--100vw {
		width: calc(100vw - var(--scrollbar));
		margin: 0 calc(50% - 50vw + var(--scrollbar) / 2);
		padding-inline: 0;
	}
}
@media screen and (max-width: 768px) {
	.c-table-scroll--100vw {
		padding-inline: 0;
	}
}

/******************************************************************
component - heading
******************************************************************/
.c-heading-s {
	line-height: 1.5;
	margin-top: 0;
	font-weight: bold;
	margin-bottom: 0.8rem;
}
.c-heading-s__red {
	color: #CC0033;
}

.c-heading-m {
	line-height: 1.5;
	margin-top: 0;
	font-weight: bold;
	font-size: 18px;
}

.c-heading-l {
	line-height: 1.5;
	margin-top: 0;
	font-weight: bold;
	font-size: 22px;
}
.c-heading-l__red {
	color: #CC0033;
}

.c-heading-feature {
	font-weight: bold;
	line-height: 1.5;
	font-size: 24px !important;
}
@media screen and (max-width: 768px) {
	.c-heading-feature {
		font-size: 20px !important;
	}
}
.c-heading-feature__red {
	color: #CC0033;
}

.c-heading-red {
	font-size: 20px !important;
	font-weight: bold;
	line-height: 1.5;
	color: #CC0033;
}
.c-heading-red__num {
	vertical-align: middle;
	width: 38px;
}
@media screen and (max-width: 768px) {
	.c-heading-red__num {
		width: 20px;
	}
}

.c-heading-achievements {
	text-align: center;
	font-size: 26px !important;
	font-weight: bold;
	line-height: 1.5;
}

.c-heading-casestudy {
	font-weight: bold;
	line-height: 1.5;
	font-size: 24px !important;
}
@media screen and (max-width: 768px) {
	.c-heading-casestudy {
		font-size: 20px !important;
	}
}
.c-heading-casestudy__red {
	margin-bottom: 0.5em;
	display: block;
	width: fit-content;
	padding: 0.35em 0.75em 0.25em 0.75em;
	background-color: #CC0033;
	color: #fff;
	font-size: 18px !important;
}

/******************************************************************
component - lead
******************************************************************/
.c-lead {
	line-height: 1.8;
	font-size: 20px;
}
@media screen and (max-width: 768px) {
	.c-lead {
		font-size: 16px;
	}
}
.c-lead strong {
	font-weight: bold;
}
.c-lead__red {
	color: #CC0033;
}
.c-lead__line {
	padding-bottom: 5px;
	display: inline;
	background-image: linear-gradient(180deg, transparent 55%, #fffd96 55%, #fffd96 90%, transparent 90%);
	background-repeat: no-repeat;
	background-size: 100% 100%;
}

/******************************************************************
component - text
******************************************************************/
.c-text {
	line-height: 1.5;
}
.c-text strong {
	font-weight: bold;
}
.c-text__small {
	font-size: 14px;
}
.c-text__red {
	color: #CC0033;
}

/******************************************************************
component - text-underline
******************************************************************/
.c-text-underline {
	line-height: 2;
	font-weight: normal;
	padding-bottom: 5px;
	display: inline;
	background-image: linear-gradient(180deg, transparent 55%, #fffd96 55%, #fffd96 90%, transparent 90%);
	background-repeat: no-repeat;
	background-size: 100% 100%;
}

/******************************************************************
component - balloon
******************************************************************/
.c-balloon {
	border-radius: 15px;
	background-color: #eaf5fc;
	font-weight: bold;
	padding: 16px;
	font-size: 15px;
}
@media screen and (max-width: 768px) {
	.c-balloon {
		font-size: 14px;
	}
}
.c-balloon {
	position: relative;
	margin-top: 16px;
	position: relative;
}
.c-balloon::after {
	transition-property: top, right, bottom, left, opacity;
	transition-duration: 0.2s;
	position: absolute;
	content: "";
	margin: auto;
	box-sizing: border-box;
	vertical-align: middle;
	width: 22px;
	height: 22px;
	border-color: #eaf5fc;
	border-style: solid;
	border-top-width: 0;
	border-right: 11px solid transparent !important;
	border-bottom-width: 22px;
	border-left: 11px solid transparent !important;
	top: -18px;
	left: 0;
	right: 0;
}
@media screen and (max-width: 768px) {
	.c-balloon {
		margin-top: 12px;
		position: relative;
	}
	.c-balloon::after {
		transition-property: top, right, bottom, left, opacity;
		transition-duration: 0.2s;
		position: absolute;
		content: "";
		margin: auto;
		box-sizing: border-box;
		vertical-align: middle;
		width: 16px;
		height: 16px;
		border-color: #eaf5fc;
		border-style: solid;
		border-top-width: 0;
		border-right: 8px solid transparent !important;
		border-bottom-width: 16px;
		border-left: 8px solid transparent !important;
		top: -14px;
		left: 0;
		right: 0;
	}
}
.c-balloon::after {
	transform: scaleX(2);
}

/******************************************************************
project - task-list
******************************************************************/
.p-task-list {
	--column: 2;
	--gap: 60px;
}
@media screen and (max-width: 768px) {
	.p-task-list {
		--column: 1;
		--gap: 30px;
	}
}
.p-task-list {
	display: flex;
	flex-wrap: wrap;
	margin-right: calc(var(--gap) * -1);
	gap: var(--gap);
}
.p-task-list > * {
	box-sizing: border-box;
	width: calc(100% / var(--column) - var(--gap));
}
.p-task-list > * > *:not(:last-child) {
	margin-bottom: 20px;
}
.p-task-list > * {
	border: 1px solid #ccc;
	background-color: #eaf5fc;
	padding: 30px;
}
@media screen and (max-width: 768px) {
	.p-task-list > * {
		padding: 20px;
	}
}
.p-task-list h4 {
	text-align: center;
	font-weight: bold;
	font-size: 20px !important;
}
.p-task-list h4 span {
	padding-bottom: 5px;
	display: inline;
	background-image: linear-gradient(180deg, transparent 55%, #fffd96 55%, #fffd96 90%, transparent 90%);
	background-repeat: no-repeat;
	background-size: 100% 100%;
}
.p-task-list div {
	text-align: center;
	background-color: #fff;
	padding-block: 18px;
}
.p-task-list p {
	text-align: center;
	font-weight: bold;
	color: #444444;
}
/******************************************************************
project - red-aria
******************************************************************/
.p-red-aria {
	padding: 20px;
	background-color: #CC0033;
	color: #fff;
}
@media screen and (max-width: 768px) {
	.p-red-aria {
		font-size: 14px;
	}
}
.p-red-aria * {
	color: #fff;
}
.p-red-aria__title {
	margin: 0;
	font-weight: bold;
}
@media screen and (max-width: 768px) {
	.p-red-aria__title {
		font-size: 16px;
	}
}
/******************************************************************
project - pclcm
******************************************************************/
.p-pclcm {
	display: grid;
	grid-template-columns: auto 400px;
	grid-template-rows: auto 1fr;
	grid-template-areas: "head img" "body img";
	gap: 2rem 60px;
}
@media screen and (max-width: 768px) {
	.p-pclcm {
		grid-template-columns: 100%;
		grid-template-areas: "head" "img" "body";
		gap: 30px;
	}
}
.p-pclcm__head {
	grid-area: head;
}
.p-pclcm__body {
	grid-area: body;
}
.p-pclcm__img {
	grid-area: img;
}
/******************************************************************
project - case-study
******************************************************************/
.p-case-study-info {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
}
.p-case-study-info dt {
	padding-right: 0.5em;
	font-weight: bold;
	background: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNzkiIGhlaWdodD0iNzYiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHhtbDpzcGFjZT0icHJlc2VydmUiIG92ZXJmbG93PSJoaWRkZW4iPjxnIHRyYW5zZm9ybT0idHJhbnNsYXRlKC03NzMgLTI2NjA4KSI+PGc+PGc+PGc+PGc+PHBhdGggZD0iTTQxLjg5OTMgNjUuMDUyMSAzOC40OTMzIDUwLjY1NzcgNDEuMzE4MiA0OC4xNzA3IDQxLjE0MjUgNDQuMTE2QzM5LjgxMDUgNDQuNDA3OCAzOC40NTEzIDQ0LjU1NzIgMzcuMDg3NyA0NC41NjJMMzYuOTc5NSA0NC41NjJDMzUuNjE1MiA0NC41NDM5IDM0LjI1NjUgNDQuMzg1NSAzMi45MjQ4IDQ0LjA4ODlMMzIuNzQ5MSA0OC4xNDM3IDM1LjU2MDQgNTAuNjMwNiAzMi40MzgyIDY0LjM3NjMgMjMuNzQ3NSA0NC40NTM4Qy00LjIwMzQ1IDUxLjg4NzYgMC4yNTY4MDIgNzYgMC4yNTY4MDIgNzZMMzcuNDEyMSA3NlpNMzIuNDM4MiA2NC4zNzYzIDM0LjM1NzUgNjguOTMxMloiIGZpbGw9IiM0MDQwNDAiIGZpbGwtcnVsZT0ibm9uemVybyIgZmlsbC1vcGFjaXR5PSIxIiB0cmFuc2Zvcm09Im1hdHJpeCgxLjA0NDk4IDAgMCAxIDc3NC4yNjUgMjY2MDgpIi8+PHBhdGggZD0iTTUwLjM4NzMgNDQuNDQwMyA0MS44OTkzIDY1LjA1MjEgMzcuMzk4NSA3NiA3My44OTE1IDc2QzczLjg5MTUgNzYgNzguMzkyMyA1MS44ODc2IDUwLjM4NzMgNDQuNDQwM1oiIGZpbGw9IiM0MDQwNDAiIGZpbGwtcnVsZT0ibm9uemVybyIgZmlsbC1vcGFjaXR5PSIxIiB0cmFuc2Zvcm09Im1hdHJpeCgxLjA0NDk4IDAgMCAxIDc3NC4yNjUgMjY2MDgpIi8+PHBhdGggZD0iTTM3LjA2MDYgNDIuMzU4OUM0OC41NTE2IDQyLjE1MTcgNTcuNzAwMSAzMi42NzA1IDU3LjQ5NjcgMjEuMTc5NCA1Ny40OTY3IDkuNDYxMTQgNDguMzQ2NCAwIDM3LjA2MDYgMCAyNS43NzQ5IDAgMTYuNjI0NiA5LjQ2MTE0IDE2LjYyNDYgMjEuMTc5NCAxNi40MjEyIDMyLjY3MDUgMjUuNTY5NyA0Mi4xNTE3IDM3LjA2MDYgNDIuMzU4OVoiIGZpbGw9IiM0MDQwNDAiIGZpbGwtcnVsZT0ibm9uemVybyIgZmlsbC1vcGFjaXR5PSIxIiB0cmFuc2Zvcm09Im1hdHJpeCgxLjA0NDk4IDAgMCAxIDc3NC4yNjUgMjY2MDgpIi8+PC9nPjwvZz48L2c+PC9nPjwvZz48L3N2Zz4=") left center/40px auto no-repeat;
	min-height: 40px;
	padding-left: 50px;
	display: flex;
	align-items: center;
}
@media screen and (max-width: 768px) {
	.p-case-study-info dt {
		width: 100%;
	}
}
.p-case-study-info dd {
	border: 1px solid #333;
	border-radius: 100vw;
	padding: 0.35em 1em 0.25em 1em;
}

.p-case-study {
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
	justify-content: space-between;
}
.p-case-study__item {
	width: calc(50% - 15px);
}
@media screen and (max-width: 768px) {
	.p-case-study__item {
		width: 100%;
	}
}
.p-case-study__item--1col {
	width: 100%;
}
.p-case-study__title {
	margin: 0 0 1rem 0;
	background-color: #333;
	color: #fff;
	border-radius: 100vw;
	padding: 0.25em 1em 0.15em 1em;
	font-weight: bold;
	text-align: center;
}
.p-case-study__title--red {
	background-color: #CC0033;
}
.p-case-study__title--blue {
	background-color: #09205C;
}
.p-case-study__arrow {
	margin-top: 0;
	position: relative;
	margin-inline: auto;
	width: fit-content;
	font-weight: bold;
	margin-bottom: 50px;
	position: relative;
}
.p-case-study__arrow::after {
	transition-property: top, right, bottom, left, opacity;
	transition-duration: 0.2s;
	position: absolute;
	content: "";
	margin: auto;
	box-sizing: border-box;
	vertical-align: middle;
	width: 22px;
	height: 22px;
	border-color: #CC0033;
	border-style: solid;
	border-top-width: 22px;
	border-right: 11px solid transparent !important;
	border-bottom-width: 0;
	border-left: 11px solid transparent !important;
	bottom: -30px;
	left: 0;
	right: 0;
}
.p-case-study__arrow::after {
	transform: scaleX(2);
}

/******************************************************************
project - microsoft365
******************************************************************/
.p-microsoft365 > *:not(:last-child) {
	margin-bottom: 5px;
}
.p-microsoft365 > * {
	display: flex;
}
@media screen and (max-width: 768px) {
	.p-microsoft365 > * {
		flex-direction: column;
	}
}
.p-microsoft365 dt {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 10px;
	flex-shrink: 0;
	width: 160px;
	padding: 20px 10px;
}
@media screen and (max-width: 768px) {
	.p-microsoft365 dt {
		width: 100%;
		flex-direction: row-reverse;
		padding: 10px 10px;
	}
}
.p-microsoft365 dt {
	background-color: #CC0033;
	text-align: center;
	font-weight: bold;
	font-size: 18px;
}
.p-microsoft365 dt span {
	color: #fff;
}
.p-microsoft365 dt img {
	max-width: 110px;
}
@media screen and (max-width: 768px) {
	.p-microsoft365 dt img {
		height: 35px;
	}
}
.p-microsoft365 dd {
	flex-grow: 1;
	background-color: #f2f2f2;
	display: flex;
	align-items: center;
	padding: 20px;
	line-height: 1.5;
	font-weight: bold;
	font-size: 18px;
}
@media screen and (max-width: 768px) {
	.p-microsoft365 dd {
		font-size: 16px;
	}
}
.p-microsoft365 dd strong {
	color: #CC0033;
}
.p-microsoft365-point {
	position: relative;
}
@media print, screen and (min-width: 769px) {
	.p-microsoft365-point {
		margin-top: 3em;
	}
}
.p-microsoft365-point {
	border: 3px solid #CC0033;
	border-radius: 30px;
}
@media screen and (max-width: 768px) {
	.p-microsoft365-point {
		border-radius: 10px;
	}
}
.p-microsoft365-point__head {
	margin: 0;
}
@media print, screen and (min-width: 769px) {
	.p-microsoft365-point__head {
		position: absolute;
		top: 0;
		transform: translateY(-50%);
		width: fit-content;
		left: 0;
		right: 0;
		margin-inline: auto;
	}
}
.p-microsoft365-point__head {
	text-align: center;
	background-color: #CC0033;
	padding: 0.75em 1.5em;
	color: #fff;
	font-weight: bold;
	line-height: 1.5;
	font-size: 20px;
}
@media screen and (max-width: 768px) {
	.p-microsoft365-point__head {
		font-size: 18px;
	}
}
.p-microsoft365-point__body {
	padding: 30px;
	padding-top: 60px;
}
@media screen and (max-width: 768px) {
	.p-microsoft365-point__body {
		padding: 20px;
	}
}
.p-microsoft365-point__body--balloon {
	padding-inline: 60px;
}
@media screen and (max-width: 768px) {
	.p-microsoft365-point__body--balloon {
		padding-inline: 20px;
	}
}

/******************************************************************
project - related-services
******************************************************************/
.p-related-services {
	display: flex;
	flex-direction: row-reverse;
	border: 1px solid #ccc;
	text-decoration: none;
}
@media screen and (max-width: 768px) {
	.p-related-services {
		flex-direction: column-reverse;
	}
}
@media (any-hover: hover) {
	.p-related-services:hover {
		opacity: 0.8;
	}
}
.p-related-services:focus {
	opacity: 0.8;
}
.p-related-services__body {
	align-self: center;
	padding: 16px 22px;
	line-height: 1.5;
}
.p-related-services__body h3 {
	color: #09357f;
	font-weight: bold;
	font-size: 15px;
}
.p-related-services__body p {
	font-size: 15px;
}
.p-related-services__img {
	flex-shrink: 0;
	width: 260px;
}
@media screen and (max-width: 768px) {
	.p-related-services__img {
		width: 100%;
	}
}
.p-related-services__img img {
	width: 100%;
	vertical-align: middle;
}
.p-related-services__img img:hover {
	opacity: 1;
}

/******************************************************************
project - security
******************************************************************/
.p-security {
	line-height: 1.5;
}
.p-security > *:not(:last-child) {
	margin-bottom: 20px;
}
.p-security__title {
	font-weight: bold;
	text-align: center;
	font-size: 20px;
}
@media screen and (max-width: 768px) {
	.p-security__title {
		font-size: 16px;
	}
}
.p-security__list {
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
}
@media screen and (max-width: 768px) {
	.p-security__list {
		gap: 10px;
	}
}
.p-security__col3 {
	width: calc(33.3333333333% - 20px);
}
@media screen and (max-width: 768px) {
	.p-security__col3 {
		width: 100%;
	}
}
.p-security__col2 {
	width: calc(50% - 15px);
}
@media screen and (max-width: 768px) {
	.p-security__col2 {
		width: 100%;
	}
}
.p-security__col3, .p-security__col2 {
	padding: 15px;
	background-color: #eaf5fc;
	border-radius: 10px;
}
.p-security__col3 dt, .p-security__col2 dt {
	font-weight: bold;
	text-align: center;
	color: #CC0033;
	font-size: 18px;
	margin-bottom: 0.5em;
}
.p-security__copy {
	text-align: center;
	font-size: 20px;
}
@media screen and (max-width: 768px) {
	.p-security__copy {
		font-size: 16px;
	}
}
.p-security__copy strong {
	display: block;
	color: #CC0033;
	font-weight: bold;
}

/******************************************************************
project - analysis
******************************************************************/
@media print, screen and (min-width: 769px) {
	.p-analysis {
		position: relative;
		position: relative;
	}
	.p-analysis::after {
		transition-property: top, right, bottom, left, opacity;
		transition-duration: 0.2s;
		position: absolute;
		content: "";
		margin: auto;
		box-sizing: border-box;
		vertical-align: middle;
		width: 20px;
		height: 36px;
		border-color: #CC0033;
		border-style: solid;
		border-top: 18px solid transparent !important;
		border-right-width: 0;
		border-bottom: 18px solid transparent !important;
		border-left-width: 20px;
		top: 8px;
		right: -28px;
	}
	.p-analysis::before {
		position: absolute;
		content: "";
		margin: auto;
		box-sizing: border-box;
		vertical-align: middle;
		top: 17px;
		left: 0;
		width: calc(100% + 10px);
		height: 17px;
		background: linear-gradient(to right, #fad5df 0%, #CC0033 100%);
	}
}
.p-analysis {
	display: flex;
	gap: 15px;
}
@media screen and (max-width: 768px) {
	.p-analysis {
		flex-direction: column;
		gap: 25px;
	}
}
.p-analysis > li {
	display: flex;
	flex-direction: column;
	gap: 8px;
	width: 24%;
}
@media screen and (max-width: 768px) {
	.p-analysis > li {
		width: 100%;
	}
}
.p-analysis h5 {
	background-color: #CC0033;
	color: #fff;
	font-weight: bold;
	text-align: center;
	line-height: 1.4;
	padding: 0.3em 0.2em 0.2em 0.2em;
	font-size: 14px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	margin-block: 0;
	height: 50px;
	border-inline: 2px solid #fff;
}
.p-analysis h5 strong {
	display: block;
	color: #fff;
}
.p-analysis img {
	margin-inline: auto;
	display: block;
	width: 100%;
	max-width: 400px;
	border-inline: 2px solid #fff;
}
.p-analysis__body {
	flex-grow: 1;
	font-size: 11px;
	padding-inline: 2px;
}
.p-analysis__body dl > *:not(:last-child) {
	margin-bottom: 8px;
}
.p-analysis__body p {
	margin-top: 0.5em;
	font-size: 11px;
}
.p-analysis__period {
	background-color: #fad5df;
	border-radius: 100vw;
	text-align: center;
	padding: 0.3em 0.2em 0.2em 0.2em;
	font-size: 13px;
	color: #CC0033;
}
/******************************************************************
utility - mediaquery
******************************************************************/
.u-portrait-media {
	display: none;
}

@media screen and (max-width: 1024px) {
	.u-landscape-media {
		display: none;
	}
	.u-portrait-media {
		display: block;
	}
	img.u-portrait-media {
		display: inline-block;
	}
	br.u-portrait-media {
		display: inline-block;
	}
	table.u-portrait-media {
		display: table;
	}
}
.u-sp-media {
	display: none;
}

@media screen and (max-width: 768px) {
	.u-pc-media {
		display: none;
	}
	.u-sp-media {
		display: block;
	}
	img.u-sp-media {
		display: inline-block;
	}
	br.u-sp-media {
		display: inline-block;
	}
	table.u-sp-media {
		display: table;
	}
}
/******************************************************************
utility - u-gutter
******************************************************************/
.u-gutter > *:not(:last-child):not(.h2__title) {
	margin-bottom: 1rem;
}

.u-gutter-2s > *:not(:last-child):not(.h2__title) {
	margin-bottom: 0.5rem;
}

.u-gutter-s > *:not(:last-child):not(.h2__title) {
	margin-bottom: 0.75rem;
}

.u-gutter-2x > *:not(:last-child):not(.h2__title) {
	margin-bottom: 2rem;
}

@media screen and (max-width: 768px) {
	.u-gutter > *:not(:last-child):not(.h2__title) {
		margin-bottom: 0.9rem;
	}
	.u-gutter-2s > *:not(:last-child):not(.h2__title) {
		margin-bottom: 0.45rem;
	}
	.u-gutter-s > *:not(:last-child):not(.h2__title) {
		margin-bottom: 0.675rem;
	}
	.u-gutter-2x > *:not(:last-child):not(.h2__title) {
		margin-bottom: 1.8rem;
	}
	.u-sp-gutter > *:not(:last-child):not(.h2__title) {
		margin-bottom: 0.9rem;
	}
	.u-sp-gutter-2s > *:not(:last-child):not(.h2__title) {
		margin-bottom: 0.45rem;
	}
	.u-sp-gutter-s > *:not(:last-child):not(.h2__title) {
		margin-bottom: 0.675rem;
	}
	.u-sp-gutter-2x > *:not(:last-child):not(.h2__title) {
		margin-bottom: 1.8rem;
	}
}
/******************************************************************
utility - margin
******************************************************************/
.u-margin-s {
	margin-block: 0 !important;
	height: 30px;
}
@media screen and (max-width: 768px) {
	.u-margin-s {
		height: 20px;
	}
}
.u-margin-m {
	margin-block: 0 !important;
	height: 60px;
}
@media screen and (max-width: 768px) {
	.u-margin-m {
		height: 40px;
	}
}
.u-margin-l {
	margin-block: 0 !important;
	height: 80px;
}
@media screen and (max-width: 768px) {
	.u-margin-l {
		height: 60px;
	}
}

/******************************************************************
utility - display-off
******************************************************************/
.u-display-off {
	position: absolute;
	width: 1px;
	height: 1px;
	margin: -1px;
	border: 0;
	overflow: hidden;
	padding: 0;
	clip: rect(0, 0, 0, 0);
}

/******************************************************************
utility - text-align
******************************************************************/
.u-center {
	text-align: center !important;
}

.u-right {
	text-align: right !important;
}

.u-left {
	text-align: left !important;
}