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

/* ナビゲーション */

/*-----------------------*/
@media(min-width: 960px) {
	/* ==================
	コンテナ */
	#nav__wrapper {
		-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 var(--gutter-var-reg);

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

		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%;
	}
	#index .nav__current {
		color: var(--color-white);
	}
	.nav__addr {
		display: none;
	}
	/* ==================
	current */
	.nav__current div {
		position: relative;
	}
	.nav__current div::after {
		content: "";
		display: inline-block;
		width: 100%;
		height: 2px;
		background-color: var(--color-main);

		position: absolute;
		left: 0;
		bottom: -0.5em;

		-webkit-transform: scaleX(0);

		        transform: scaleX(0);
		-webkit-transform-origin: right top;
		        transform-origin: right top;
	}
	.nav__current.is-current {
		color: var(--color-main);
	}
	#index .nav__current div::after {
		background-color: var(--color-white);
	}
	.nav__current.is-current div::after {
		-webkit-transform: scaleX(1);
		        transform: scaleX(1);
	}
	/* ==================
	スクロール後の処理 */
	#index #header.is-change .nav__current:not(.is-current) {
		color: var(--color-sub);
	}
	#index #header.is-change .nav__current.is-current {
		color: var(--color-main);
	}
	#index #header.is-change .nav__current div::after {
		background-color: var(--color-main);
	}
}
/* hover設定 */
@media(any-hover: hover) {
	#index .nav__current:not(.is-current) ,
	.nav__current:not(.is-current) {
		-webkit-transition: color .2s var(--easeInQuad);
		transition: color .2s var(--easeInQuad);
	}
	.nav__current:not(.is-current) div::after {
		-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);
	}
	#index #header.is-change .nav__current:not(.is-current):hover,
	#index #header.is-change .nav__current:not(.is-current):focus,
	.nav__current:hover,
	.nav__current:focus {
		color: var(--color-main);
	}
	.nav__current:not(.is-current):hover div::after,
	.nav__current:not(.is-current):hover div:focus {
		-webkit-transform: scaleX(1);
		        transform: scaleX(1);
		-webkit-transform-origin: left top;
		        transform-origin: left top;
	}
}



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

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

	border-radius: calc(var(--header-height) / 2);
	background-color: var(--color-sub-soft);
	background-color: rgba(234, 238, 241, 0.5);
	-webkit-backdrop-filter: blur(4px) saturate(120%);
	        backdrop-filter: blur(4px) saturate(120%);
	/* opacity: .7; */

	position: fixed;
	top: 10px;
	right: min(10px , 1.25vw);
}
#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%;
}
.nav-open-button__line {
	display: block;

	width: 40%;
	height: 2px;

	background-color: var(--color-sub);
}
/* クローズボタン */
#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: 2px;

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

	-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-top: 80px;
		padding-bottom: 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(234, 238, 241, 0.2);

		cursor: pointer;

		z-index: 0;

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

		display: block;

		padding: 1em min(4.5vw, var(--gutter-reg));
	}
	/* ----------------
	住所など */
	.nav__addr {
		font-size: var(--txt-sm);
		margin-left: min(4.5vw, var(--gutter-reg));
		margin-right: min(4.5vw, var(--gutter-reg));
		margin-top: calc(3em - 1em);
		padding-top: 3em;

		border-top: 1px solid var(--color-gray);
	}
	/* 会社名 */
	.nav__addr .company-name {
		width: 200px;
		max-width: 100%;
	}
	.nav__addr .company-name img {
		width: 100%;
		height: auto;
	}
	/* 住所 */
	.header-addr {
		margin-top: 1.25em;
	}
	.header-addr .add {
		line-height: 1.35;
	}
	/* 電話 */
	.nav__addr .tel {
		font-family: var(--number);
		font-size: var(--txt-reg);
		font-weight: 700;
		line-height: 1.1;
		color: var(--color-bk);

		display: inline-block;
	}
	.nav__addr .tel .number {
		font-size: var(--txt-xl);
	}
	.nav__addr .fax {
		font-family: var(--number);
		font-size: var(--txt-reg);
	}
	/* ==================
	current */
	.nav__current::before {
		content: "";
		display: block;
		width: 4px;
		height: calc(100% - 1.5em);
		background-color: var(--color-main);
		position: absolute;
		top: 50%;
		left: 0;
		-webkit-transform: scaleX(0) translateY(-50%);
		        transform: scaleX(0) translateY(-50%);
		-webkit-transform-origin: right top;
		        transform-origin: right top;
	}
	.nav__current.is-current {
		color: var(--color-main);
	}
	.nav__current.is-current::before {
		-webkit-transform: scaleX(1) translateY(-50%);
		        transform: scaleX(1) translateY(-50%);
	}


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

	オープン時の挙動

	============================== */
	/* ---------------------
	スクロール禁止 */
	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__addr {
		-webkit-animation-delay: .48s;
		        animation-delay: .48s;
	}
	@-webkit-keyframes navItemSlide {
		from {
			opacity: 0;

			-webkit-transform: translateX(-2em);

			        transform: translateX(-2em);

			-webkit-filter: blur(8px);

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

			-webkit-transform: translateX(0);

			        transform: translateX(0);

			-webkit-filter: none;

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

			-webkit-transform: translateX(-2em);

			        transform: translateX(-2em);

			-webkit-filter: blur(8px);

			        filter: blur(8px);
		}
		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: .3em;
	}
	.nav__current {
		padding: 1em min(7vw, var(--gutter-reg));
	}
	/* ----------------
	住所など */
	.nav__addr {
		margin-left: min(7vw, var(--gutter-reg));
		margin-right: min(7vw, var(--gutter-reg));
		margin-top: calc(3em - 1em);
		padding-top: 3em;
	}
	/* 会社名 */
	.nav__addr .company-name {
		width: 180px;
	}
}