@charset "UTF-8";
/*========================*/

/* Component */

/*========================*/
/*========================
SVG */
/* arrow */
.arrow {
	fill: none;
	stroke: var(--color-main-pale);
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-width: 2;
}

/*========================
hoerスタイル */
/* タッチデバイスでタップ時にhover.jsによりis-hoverクラスを付与するオブジェクトから、タップ時のハイライトを非表示にする */
@media (any-hover: none) {
	.is-hover,
	.tap-highlight-white.is-hover {
		cursor: pointer;

		-webkit-tap-highlight-color: rgba(255, 255, 255, 0);
	}
}

/* ====================
/* ------------------
テキスト */
.txt {
	font-size: var(--txt-reg);
	font-weight: normal;
	letter-spacing: .07em;
	line-height: 1.88;
	text-align: justify;
}
/* ------------------
リード */
.lead {
	font-size: calc(var(--txt-xl) * 0.857);
	font-weight: bold;
	letter-spacing: .18em;
	line-height: 1.57;
}
/* ------------------
見出し */
.headline {
	padding-bottom: 2.2em;
	position: relative;

	--headline-border: 2.5em;
}
.headline::before,
.headline::after {
	content: "";
	display: block;
	width: var(--headline-border);
	height: 5px;

	position: absolute;
}
.headline::before {
	background-color: var(--color-main);
	left: 0;
	bottom: 0;
}
.headline::after {
	background-color: var(--color-accent);
	left: var(--headline-border);
	bottom: 5px;
}
.headline__alphabet {
	font-family: var(--alphabet);
	font-size: var(--txt-4x);
	font-weight: 800;
	color: var(--color-bk);
	line-height: 1.35;
}
.headline__alphabet::first-letter {
	color: var(--color-main);
}
.headline__jp {
	font-size: var(--txt-sm);
	font-weight: 700;
	letter-spacing: 0.125em;
	color: var(--color-bk);
	line-height: 1.25;
}
/* 中央揃え */
.headline--center {
	text-align: center;
}
.headline--center.headline::before {
	left: calc(50% - calc(var(--headline-border) / 2));
	-webkit-transform: translateX(-50%);
	        transform: translateX(-50%);
}
.headline--center.headline::after {
	left: calc(50% + calc(var(--headline-border) / 2));
	-webkit-transform: translateX(-50%);
	        transform: translateX(-50%);
}
/* ------------------
テキストリンク */
.txt--link {
	color: var(--color-link);
	text-decoration: underline;
}
@media (any-hover: hover) {
	.txt--link {
		-webkit-transition: color .2s ease-in-out;
		transition: color .2s ease-in-out;
	}
	.txt--link:hover,
	.txt--link:focus {
		color: var(--color-link--hover);
	}
}


/* ====================
ボタン */
.button__container {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
	-webkit-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
}
.button {
	--button-gup: min(10vw, var(--txt-md));
	display: -webkit-inline-box;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	-webkit-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
	gap: 0 var(--button-gup);

	font-size: var(--txt-md);
	line-height: 1.1;

	width: calc(336rem / 16);
	max-width: 100%;
	min-height: calc(60rem / 16);
	padding-block: 0.5em;
	padding-inline: var(--button-gup);

	text-align: center;
	position: relative;
	z-index: 1;
}
.button .arrow {
	position: absolute;
	right: var(--button-gup);
}
/* ------------------------
大きいボタン */
.button--lg {
	--button-gup: min(10vw, var(--txt-md));
	display: -webkit-inline-box;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	-webkit-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
	gap: 0 var(--button-gup);

	font-size: var(--txt-md);
	line-height: 1.1;

	width: calc(448rem / 16);
	max-width: 100%;
	min-height: calc(60rem / 16);
	padding-block: 0.5em;
	padding-inline: var(--button-gup);

	position: relative;
	z-index: 1;
}
/* ------------------------
カラーの制御 */
.button--main-c,
.button--accent-c,
.button--white-c {
	background-color: transparent;
}
.button--main-c {
	color: var(--color-white);
}
.button--accent-c {
	color: var(--color-white);
}
.button--white-c {
	color: var(--color-main);
}
.button--main-c::before,
.button--accent-c::before,
.button--white-c::before,
.button--main-c::after,
.button--accent-c::after,
.button--white-c::after {
	content: "";
	display: inline-block;
	position: absolute;
	width: 100%;
	left: 0;
}
.button--main-c::before,
.button--accent-c::before,
.button--white-c::before {
	top: 0;
	height: 100%;
	z-index: -1;
}
.button--main-c::after,
.button--accent-c::after,
.button--white-c::after {
	bottom: 0;
	height: 2px;
	z-index: -2;
}
.button--main-c::before,
.button--main-c::after {
	background-color: var(--color-main);
}
.button--accent-c::before,
.button--accent-c::after {
	background-color: var(--color-accent);
}
.button--white-c::before {
	background-color: var(--color-white);
}
.button--white-c::after {
	background-color: var(--color-main);
}
.button svg,
.button--lg svg {
	stroke: currentColor;
}
@media(any-hover: hover) {
	.button--main-c,
	.button--accent-c,
	.button--white-c {
		-webkit-transition: color .2s var(--easeInSine),
		border-color .1s var(--easeInExpo);
		transition: color .2s var(--easeInSine),
		border-color .1s var(--easeInExpo);
	}
	.button--main-c::before,
	.button--accent-c::before,
	.button--white-c::before {
		-webkit-transition: -webkit-transform .2s var(--easeInQuad);
		transition: -webkit-transform .2s var(--easeInQuad);
		transition: transform .2s var(--easeInQuad);
		transition: transform .2s var(--easeInQuad), -webkit-transform .2s var(--easeInQuad);
		-webkit-transform-origin: left top;
		        transform-origin: left top;
	}
	.button--main-c:hover::before,
	.button--main-c:focus-visible::before,
	.button--accent-c:hover::before,
	.button--accent-c:focus-visible::before,
	.button--white-c:hover::before,
	.button--white-c:focus-visible::before {
		-webkit-transform: scaleX(0);
		        transform: scaleX(0);
		-webkit-transform-origin: right bottom;
		        transform-origin: right bottom;
	}
	.button--main-c:hover,
	.button--main-c:focus-visible {
		color: var(--color-main);
	}
	.button--accent-c:hover,
	.button--accent-c:focus-visible {
		color: var(--color-accent);
	}
	.button--white-c:hover,
	.button--white-c:focus-visible {
		color: var(--color-main);
	}
	.button svg,
	.button--lg svg {
		-webkit-transition: -webkit-transform .2s var(--easeInQuad);
		transition: -webkit-transform .2s var(--easeInQuad);
		transition: transform .2s var(--easeInQuad);
		transition: transform .2s var(--easeInQuad), -webkit-transform .2s var(--easeInQuad);
	}
	.button:hover svg,
	.button--lg:hover svg,
	.button:focus-visible svg,
	.button--lg:focus-visible svg {
		-webkit-animation-name: hover-arrow;
		        animation-name: hover-arrow;
		-webkit-animation-timing-function: var(--easeInQuad);
		        animation-timing-function: var(--easeInQuad);
		-webkit-animation-duration: .3s;
		        animation-duration: .3s;
		-webkit-animation-delay: .05s;
		        animation-delay: .05s;
		-webkit-animation-fill-mode: both;
		        animation-fill-mode: both;
	}
	@-webkit-keyframes hover-arrow {
		0% {
			-webkit-transform: translateX(0);
			        transform: translateX(0);
			opacity: 1;
		}
		50% {
			-webkit-transform: translateX(100%);
			        transform: translateX(100%);
			opacity: 0;
		}
		51% {
			-webkit-transform: translateX(-100%);
			        transform: translateX(-100%);
			opacity: 0;
		}
		100% {
			-webkit-transform: translateX(0);
			        transform: translateX(0);
			opacity: 1;
		}
	}
	@keyframes hover-arrow {
		0% {
			-webkit-transform: translateX(0);
			        transform: translateX(0);
			opacity: 1;
		}
		50% {
			-webkit-transform: translateX(100%);
			        transform: translateX(100%);
			opacity: 0;
		}
		51% {
			-webkit-transform: translateX(-100%);
			        transform: translateX(-100%);
			opacity: 0;
		}
		100% {
			-webkit-transform: translateX(0);
			        transform: translateX(0);
			opacity: 1;
		}
	}
}

/* ====================
共通テーブル */
.common-table {
	width: 100%;
	--table-th-gutter : min(5vw,1em);
	--table-th-width : 4.5em;
}
.common-table tr {
	border-top: 1px solid var(--color-main-pale);
	border-bottom: 1px solid var(--color-main-pale);
}
.common-table th ,
.common-table td {
	-webkit-font-feature-settings: "palt";
	        font-feature-settings: "palt";
	letter-spacing: 0.05em;
	padding-block: 1em;
	padding-inline: var(--table-th-gutter);
}
.common-table th {
	font-weight: 700;
	text-align: center;
	width: calc(var(--table-th-width) + calc(var(--table-th-gutter) * 2));
	max-width: 168px;
}
/* テーブル内リスト */
.table-list li {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
}
.table-list li::before {
	content: "・";
}
.common-table ul + p {
	margin-top: 1em;
}
@media (max-width: 559px) {
	.common-table tr {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		    -ms-flex-direction: column;
		        flex-direction: column;
		border: none;
	}
	.common-table tr:first-child {
		border-top: 1px solid var(--color-main-pale);
	}
	.common-table tr:last-child {
		border-bottom: 1px solid var(--color-main-pale);
	}
	.common-table tr + tr {
		border-top: 1px solid var(--color-main-pale);
	}
	.common-table th {
		width: 100%;
		max-width: none;
		text-align: left;
		background-color: var(--color-main-thin);
	}
	.common-table td {
		padding-inline: var(--table-th-gutter);
	}
}


/* ====================
下層イメージ */
#lower-hero {
	display: grid;

	height: max(
		560px,
		35vw
	);

	background-color: var(--color-main-pale);
	background-repeat: no-repeat;
	background-size: cover;

	place-items: center;
}
body:is(#works-list,.post-type-archive-works-list,#blog-list,.post-type-archive-blog-list,#privacy) #lower-hero {
	height: max(
		460px,
		28.7vw
	);
}
@media (max-width: 959px) {
	#lower-hero {
		height: max(
			336px,
			35vw
		);
		margin-top: var(--header-height);
	}
	body:is(#works-list,.post-type-archive-works-list,#blog-list,.post-type-archive-blog-list,#privacy) #lower-hero {
		height: max(
			224px,
			28.7vw
		);
	}
}
/* 個別指定 */
#business #lower-hero {
	background-image: url(../../images/business/lower_business.jpg);
	background-position: center center;
}
#company #lower-hero {
	background-image: url(../../images/company/lower_company.jpg);
	background-position: center center;
}
/* ページネーム */
.page-name {
	color: var(--color-white);
	text-align: center;

	margin-top: calc(var(--header-height) / 1.5);
	margin-inline: var(--gutter-var-8x);
}
body:not(:is(#works-list,.post-type-archive-works-list,#blog-list,.post-type-archive-blog-list,#privacy)) .page-name {
	text-shadow: 0px 0px 20px rgba(17, 46, 92, 0.7);
}
.page-name__en {
	font-family: var(--alphabet);
	font-weight: 800;
	font-size: var(--txt-4x);
	text-transform: uppercase;
	line-height: 1.1;
}
.page-name__jp {
	font-weight: 700;
	font-size: var(--txt-md);
	letter-spacing: 0.2em;
	line-height: 1.25;
	margin-top: 0.3em;
}
/* サファリ対応 */
_::-webkit-full-page-media, _:future, :root body:not(:is(#works-list,.post-type-archive-works-list,#blog-list,.post-type-archive-blog-list,#privacy)) .page-name {
	text-shadow: none;
	-webkit-filter: drop-shadow(0px 0px 20px rgba(17, 46, 92, 0.7));
	filter: drop-shadow(0px 0px 20px rgba(17, 46, 92, 0.7));
}



/* ====================
PHPのindex.php用 */
.php-index__headline {
	font-size: var(--txt-md);
	font-weight: 700;
}
.php-index__headline::before {
	content: "";
	display: block;
	padding-top: var(--header-height);
}
.php-index__lead {
	margin-block: 1.5em;
}
.php-index__item {
	color: var(--color-main-soft);

	display: -webkit-box;

	display: -ms-flexbox;

	display: flex;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}
.php-index__item::before {
	content: "・";
}
.php-index__item + .php-index__item {
	margin-top: 0.5em;
}
.php-index__item a {
	display: -webkit-inline-box;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}
.php-index__item a[target="_blank"]::after {
    content: "";
    display: inline-block;
	line-height: 1;
    vertical-align: middle;
    margin-left: 0.3em;

	width: 0.7em;
	height: 0.7em;

	background-color: var(--color-main-soft);

	-webkit-mask-image: url(../../svg/icon_exlink.svg);
	        mask-image: url(../../svg/icon_exlink.svg);
	-webkit-mask-position: center;
	        mask-position: center;
	-webkit-mask-repeat: no-repeat;
	        mask-repeat: no-repeat;
	-webkit-mask-size: cover;
	        mask-size: cover;
}
@media (any-hover: hover) {
	.php-index__item a,
	.php-index__item a[target="_blank"]::after {
		-webkit-transition: color .2s ease-in-out, background-color .2s ease-in-out;
		transition: color .2s ease-in-out, background-color .2s ease-in-out;
	}
	.php-index__item a:hover,
	.php-index__item a:focus-visible {
		color: var(--color-accent);
	}
	.php-index__item a:hover[target="_blank"]::after,
	.php-index__item a:focus-visible[target="_blank"]::after {
		background-color: var(--color-accent);
	}
}