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

/* ナビゲーション */

/*-----------------------*/
@media(min-width: 960px) {
	/* ==================
	コンテナ */
	#nav__wrapper {
		-webkit-box-flex: 1;
		    -ms-flex-positive: 1;
		        flex-grow: 1;
		-ms-flex-item-align: stretch;
		    align-self: stretch;
	}
	#nav__inner {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		    flex-wrap: wrap;
		-webkit-box-pack: end;
		    -ms-flex-pack: end;
		        justify-content: flex-end;
		gap: 0 min(5%,var(--gutter-var-lg));

		height: 100%;
	}
	/* ==================
	ナビアイテム */
	.nav__current {
		font-size: var(--txt-xs);
		color: var(--color-main-soft);

		display: -webkit-box;

		display: -ms-flexbox;

		display: flex;
		-webkit-box-align: center;
		    -ms-flex-align: center;
		        align-items: center;
		-webkit-box-pack: center;
		    -ms-flex-pack: center;
		        justify-content: center;

		width: 100%;
		height: 100%;

		position: relative;
	}
	.nav__addr {
		display: none;
	}
	/* ==================
	current */
	.single-works-list .nav__current[href*="works-list"],
	.single-blog-list .nav__current[href*="blog-list"],
	.current-menu-item .nav__current {
		color: var(--color-accent);
	}
	.nav__current::before {
		content: "";
		display: block;
		width: 100%;
		height: 4px;
		background-color: var(--color-accent);

		position: absolute;
		top: 0;
		left: 0;

		-webkit-transform: scaleX(0);

		        transform: scaleX(0);
	}
	.single-works-list .nav__current[href*="works-list"]::before,
	.single-blog-list .nav__current[href*="blog-list"]::before,
	.current-menu-item .nav__current::before {
		-webkit-transform: scaleX(1);
		        transform: scaleX(1);
	}
}
/* hover設定 */
@media(any-hover: hover) {
	.nav__current {
		-webkit-transition: color .2s var(--easeInQuad);
		transition: color .2s var(--easeInQuad);
	}
	.nav__current::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: right top;
		        transform-origin: right top;
	}
	.nav__current:hover,
	.nav__current:focus-visible {
		color: var(--color-accent);
	}
	.nav__current:hover::before,
	.nav__current:focus-visible::before {
		-webkit-transform: scaleX(1);
		        transform: scaleX(1);
		-webkit-transform-origin: left bottom;
		        transform-origin: left bottom;
	}
}



/* ==================
バーガーボタン */
/* オープンボタン */
#nav-open-button {
	display: none;

	width: var(--header-height);
	height: var(--header-height);

	border-radius: calc(var(--header-height) / 2);

	position: fixed;
	top: 10px;
	right: min(10px, 1.25vw);

	-webkit-transition: background-color .3s var(--linear), -webkit-backdrop-filter .3s var(--linear);

	transition: background-color .3s var(--linear), -webkit-backdrop-filter .3s var(--linear);

	transition: background-color .3s var(--linear), backdrop-filter .3s var(--linear);

	transition: background-color .3s var(--linear), backdrop-filter .3s var(--linear), -webkit-backdrop-filter .3s var(--linear);
}
#header.is-change #nav-open-button {
	background-color: rgba(129, 152, 165, 0.8);
	-webkit-backdrop-filter: blur(4px) saturate(110%);
	        backdrop-filter: blur(4px) saturate(110%);
}
#nav-open-button:focus-visible {
	/* focus */
	outline: 2px solid var(--color-focus);
}
.nav-open-button__inner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	-webkit-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
	gap: 4px 0;

	width: 100%;
	height: 100%;
}
body:not(#index) #header:not(.is-change) .nav-open-button__line {
	background-color: var(--color-main-soft);
}
.nav-open-button__line {
	display: block;

	width: 40%;
	height: 1px;

	background-color: var(--color-main-thin);
}
/* クローズボタン */
#nav-close-button {
	display: none;

	width: var(--header-height);
	height: var(--header-height);
	margin-left: auto;

	background-color: transparent;

	position: absolute;
	top: 10px;
	right: min(10px, 1.25vw);
	z-index: 99;
}
.nav-close-button__inner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	-webkit-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;

	width: 100%;
	height: 100%;

	background-color: transparent;

	position: relative;
}
.nav-close-button__line {
	display: block;

	width: 40%;
	height: 1px;

	border-radius: 1px;
	background-color: var(--color-main-soft);

	-webkit-transform: translate(-50%,-50%);

	        transform: translate(-50%,-50%);

	position: absolute;
	top: 50%;
	left: 50%;
}
.nav-close-button__line.-top {
	-webkit-transform: translate(-50%,-50%) rotate(45deg);
	        transform: translate(-50%,-50%) rotate(45deg);
}
.nav-close-button__line.-bottom {
	-webkit-transform: translate(-50%,-50%) rotate(-45deg);
	        transform: translate(-50%,-50%) rotate(-45deg);
}



/* =====================================
ブレイクポイント
===================================== */
@media(max-width: 959px) {
	/* ==================
	バーガーボタン */
	#nav-open-button,
	#nav-close-button {
		display: block;
	}
	/* ==================
	コンテナ */
	#nav__wrapper,
	#nav__inner,
	#nav__cover {
		display: none;

		height: 100vh;
		min-height: 100vh;

		position: fixed;
		top: 0;
		right: 0;
	}
	#nav__wrapper,
	#nav__cover {
		width: 100%;
		max-width: 100%;
	}
	#nav__wrapper {
		overflow: hidden;

		z-index: 90;
	}
	#nav__inner {
		overflow-x: hidden;
		overflow-y: auto;

		width: calc(360rem/16);
		max-width: calc(100% - 12vw);
		padding-block: 80px;

		background-color: var(--color-base);
		-webkit-box-shadow: -10px 0 24px rgba(100,100,100,.2);
		        box-shadow: -10px 0 24px rgba(100,100,100,.2);

		z-index: 90;
	}
	#nav__cover {
		background-color: rgba(129, 152, 165, .5);

		cursor: pointer;

		z-index: 0;

		-webkit-backdrop-filter: blur(4px) saturate(110%);

		        backdrop-filter: blur(4px) saturate(110%);
	}
	/* ==================
	ナビアイテム */
	.nav__item + .nav__item {
		margin-top: 0.7em;
	}
	.nav__current {
		font-size: var(--txt-xs);
		color: var(--color-main-soft);

		display: block;

		padding: 0.7em var(--gutter-var-md);
	}
	/* ----------------
	住所など */
	.nav__addr {
		margin-inline: var(--gutter-var-md);
		margin-top: 3em;
		padding-top: 3em;

		border-top: 1px solid var(--color-main-pale);
	}
	/* 会社名 */
	.nav__addr .company-name {
		width: 200px;
		max-width: 100%;
	}
	.nav__addr .company-name img {
		display: inline-block;
		width: 100%;
		height: auto;
	}
	/* 住所 */
	.header-addr {
		margin-top: 1.25em;
	}
	.header-addr .addr {
		font-size: var(--txt-sm);
	}
	/* 電話 */
	.nav__addr .tel {
		font-family: var(--alphabet);
		font-size: var(--txt-xs);
		color: var(--color-bk);
		font-weight: 600;

		display: inline-block;
	}
	.nav__addr .tel .number {
		font-size: var(--txt-lg);
		font-weight: 500;
	}
	/* ==================
	current */
	.single-works-list .nav__current[href*="works-list"],
	.single-blog-list .nav__current[href*="blog-list"],
	.current-menu-item .nav__current {
		color: var(--color-accent);
	}


	/* ==============================

	オープン時の挙動

	============================== */
	/* ---------------------
	スクロール禁止 */
	body.is-open {
		overflow: hidden;
	}
	/* ---------------------
	コンテナ */
	#nav__wrapper.is-open,
	#nav__wrapper.is-open #nav__inner,
	#nav__wrapper.is-open #nav__cover {
		display: block;
	}
	/* ---------------------
	アニメーション */
	/* コンテナの動き */
	#nav__wrapper.is-open[aria-hidden="false"] #nav__inner {
		-webkit-animation-name: navOpen;
		        animation-name: navOpen;
		-webkit-animation-duration: .4s;
		        animation-duration: .4s;
		-webkit-animation-timing-function: var(--easeInOutCirc);
		        animation-timing-function: var(--easeInOutCirc);
		-webkit-animation-fill-mode: forwards;
		        animation-fill-mode: forwards;
	}
	#nav__wrapper.is-open[aria-hidden="false"] #nav__cover {
		-webkit-animation-name: navOpen--cover;
		        animation-name: navOpen--cover;
		-webkit-animation-duration: .2s;
		        animation-duration: .2s;
		-webkit-animation-timing-function: var(--easeInExpo);
		        animation-timing-function: var(--easeInExpo);
		-webkit-animation-fill-mode: forwards;
		        animation-fill-mode: forwards;
	}
	#nav__wrapper.is-open[aria-hidden="true"] #nav__inner {
		-webkit-animation-name: navClose;
		        animation-name: navClose;
		-webkit-animation-duration: .4s;
		        animation-duration: .4s;
		-webkit-animation-timing-function: var(--easeInOutCirc);
		        animation-timing-function: var(--easeInOutCirc);
		-webkit-animation-fill-mode: forwards;
		        animation-fill-mode: forwards;
	}
	#nav__wrapper.is-open[aria-hidden="true"] #nav__cover {
		-webkit-animation-name: navClose--cover;
		        animation-name: navClose--cover;
		-webkit-animation-duration: .2s;
		        animation-duration: .2s;
		-webkit-animation-timing-function: var(--easeInExpo);
		        animation-timing-function: var(--easeInExpo);
		-webkit-animation-fill-mode: forwards;
		        animation-fill-mode: forwards;
	}
	@-webkit-keyframes navOpen {
		from {
			opacity: 0;
		}
		to {
			opacity: 1;
		}
	}
	@keyframes navOpen {
		from {
			opacity: 0;
		}
		to {
			opacity: 1;
		}
	}
	@-webkit-keyframes navOpen--cover {
		from {
			opacity: 0;
		}
		to {
			opacity: 1;
		}
	}
	@keyframes navOpen--cover {
		from {
			opacity: 0;
		}
		to {
			opacity: 1;
		}
	}
	@-webkit-keyframes navClose {
		from {
			opacity: 1;
		}
		to {
			opacity: 0;
		}
	}
	@keyframes navClose {
		from {
			opacity: 1;
		}
		to {
			opacity: 0;
		}
	}
	@-webkit-keyframes navClose--cover {
		from {
			opacity: 1;
		}
		to {
			opacity: 0;
		}
	}
	@keyframes navClose--cover {
		from {
			opacity: 1;
		}
		to {
			opacity: 0;
		}
	}
	/* ナビゲーションリストのアニメーション */
	#nav__wrapper .nav__item,
	#nav__wrapper .nav__addr {
		will-change: transform;
	}
	#nav__wrapper.is-open[aria-hidden="false"] .nav__item,
	#nav__wrapper.is-open[aria-hidden="false"] .nav__addr {
		-webkit-animation-name: navItemSlide;
		        animation-name: navItemSlide;
		-webkit-animation-duration: .25s;
		        animation-duration: .25s;
		-webkit-animation-timing-function: linear;
		        animation-timing-function: linear;
		-webkit-animation-delay: .3s;
		        animation-delay: .3s;
		-webkit-animation-fill-mode: both;
		        animation-fill-mode: both;
	}
	#nav__wrapper.is-open[aria-hidden="false"] .nav__item:nth-child(2) {
		-webkit-animation-delay: .33s;
		        animation-delay: .33s;
	}
	#nav__wrapper.is-open[aria-hidden="false"] .nav__item:nth-child(3) {
		-webkit-animation-delay: .36s;
		        animation-delay: .36s;
	}
	#nav__wrapper.is-open[aria-hidden="false"] .nav__item:nth-child(4) {
		-webkit-animation-delay: .39s;
		        animation-delay: .39s;
	}
	#nav__wrapper.is-open[aria-hidden="false"] .nav__item:nth-child(5) {
		-webkit-animation-delay: .42s;
		        animation-delay: .42s;
	}
	#nav__wrapper.is-open[aria-hidden="false"] .nav__item:nth-child(6) {
		-webkit-animation-delay: .45s;
		        animation-delay: .45s;
	}
	#nav__wrapper.is-open[aria-hidden="false"] .nav__item:nth-child(7) {
		-webkit-animation-delay: .48s;
		        animation-delay: .48s;
	}
	#nav__wrapper.is-open[aria-hidden="false"] .nav__addr {
		-webkit-animation-delay: .51s;
		        animation-delay: .51s;
	}
	@-webkit-keyframes navItemSlide {
		from {
			opacity: 0;

			-webkit-transform: translateX(12px);

			        transform: translateX(12px);

			-webkit-filter: blur(4px);

			        filter: blur(4px);
		}
		to {
			opacity: 1;

			-webkit-transform: translateX(0);

			        transform: translateX(0);

			-webkit-filter: none;

			        filter: none;
		}
	}
	@keyframes navItemSlide {
		from {
			opacity: 0;

			-webkit-transform: translateX(12px);

			        transform: translateX(12px);

			-webkit-filter: blur(4px);

			        filter: blur(4px);
		}
		to {
			opacity: 1;

			-webkit-transform: translateX(0);

			        transform: translateX(0);

			-webkit-filter: none;

			        filter: none;
		}
	}
	/* オープンボタンのアニメーション */
	#nav-open-button .nav-open-button__line {
		will-change: transform;
	}
	#nav-open-button[aria-expanded="true"] .nav-open-button__line {
		background-color: var(--color-main-pale);

		-webkit-transform: scaleX(0);

		        transform: scaleX(0);
	}
	#nav-open-button[aria-expanded="false"] .nav-open-button__line {
		-webkit-transition: background-color .4s linear , -webkit-transform .4s linear;
		transition: background-color .4s linear , -webkit-transform .4s linear;
		transition: transform .4s linear , background-color .4s linear;
		transition: transform .4s linear , background-color .4s linear , -webkit-transform .4s linear;
		-webkit-transform: scaleX(1);
		        transform: scaleX(1);
		-webkit-transform-origin: right top;
		        transform-origin: right top;
	}
	#nav-open-button[aria-expanded="false"] .nav-open-button__line:nth-child(2) {
		-webkit-transition-delay: .1s;
		        transition-delay: .1s;
	}
	#nav-open-button[aria-expanded="false"] .nav-open-button__line:nth-child(3) {
		-webkit-transition-delay: .2s;
		        transition-delay: .2s;
	}
}
@media(max-width: 559px) {
	/* ==================
	ナビアイテム */
	.nav__item + .nav__item {
		margin-top: 0.5em;
	}
	.nav__current {
		padding: 0.5em min(10vw, calc(30rem / 16));
	}
	/* ----------------
	住所など */
	.nav__addr {
		margin-inline: min(10vw, calc(30rem / 16));
	}
}