@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);
		font-weight: 500;
		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 */
	.nav__current.is-current {
		color: var(--color-main);
	}
}
/* hover設定 */
@media(any-hover: hover) {
	.nav__current {
		-webkit-transition: color .2s var(--easeInQuad);
		transition: color .2s var(--easeInQuad);
	}
	.nav__current:hover,
	.nav__current:focus-visible {
		color: var(--color-main);
	}
	/* ------------
	お問い合わせ */
	.nav__contact-inner:hover ,
	.nav__contact-inner:focus-visible {
		background-color: var(--color-main-hover);
	}
	.nav__contact-inner .arrow {
		-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);
	}
	.nav__contact-inner:hover .arrow,
	.nav__contact-inner:focus-visible .arrow {
		-webkit-animation-name: hover-arrow;
		        animation-name: hover-arrow;
		-webkit-animation-timing-function: var(--easeInExpo);
		        animation-timing-function: var(--easeInExpo);
		-webkit-animation-duration: .5s;
		        animation-duration: .5s;
		-webkit-animation-delay: .03s;
		        animation-delay: .03s;
		-webkit-animation-fill-mode: both;
		        animation-fill-mode: both;
	}
}


/* ==================
お問い合わせボタン */
.nav__contact {
	-ms-flex-item-align: center;
	    align-self: center;
}
.nav__contact-inner {
	font-size: var(--txt-xs);
	font-weight: 500;
	color: var(--color-white);

	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;
	gap: 0.3em;

	background-color: var(--color-main);
	border-radius: 8px;
	padding: 1em calc(1.5em + 10px);
	width: min(calc(224rem / 16), 240px);
	max-width: 100%;
	min-height: 56px;

	position: relative;
	-webkit-transition: min-height .3s var(--linear), padding .3s var(--linear), background-color .2s var(--easeInQuad);
	transition: min-height .3s var(--linear), padding .3s var(--linear), background-color .2s var(--easeInQuad);
}
#header.is-change .nav__contact-inner {
	-webkit-transition: min-height .3s var(--linear), padding .3s var(--linear), background-color .2s var(--easeInQuad);
	transition: min-height .3s var(--linear), padding .3s var(--linear), background-color .2s var(--easeInQuad);
	min-height: 42px;
	padding: 0.5em calc(1.5em + 10px);
}
.nav__contact-inner svg {
	position: absolute;
	right: 20px;
	width: 0.7em;
	height: 0.7em;
	stroke-width: 3;
}


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

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

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

	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);
}
body:not(#index) #header:not(.is-change) #nav-open-button {
	background-color: transparent;
}
body#index #nav-open-button ,
#header.is-change #nav-open-button {
	background-color: rgba(244, 245, 245, 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: 5px 0;

	width: 100%;
	height: 100%;
}
.nav-open-button__line {
	display: block;

	width: 40%;
	height: 1px;
	background-color: var(--color-main-soft);
}
/* クローズボタン */
#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(111, 131, 181, .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-family: var(--alphabet);
		font-size: var(--txt-xs);
		color: var(--color-main-soft);

		display: block;

		padding: 1em var(--gutter-var-reg);
	}
	/* ----------------
	お問い合わせボタン */
	.nav__contact {
		padding-inline: var(--gutter-var-reg);
		margin-top: 2em;
	}
	.nav__contact-inner {
		width: 100%;
	}
	/* ----------------
	住所など */
	.nav__addr {
		margin-inline: var(--gutter-var-reg);
		margin-top: 3em;
		padding-top: 3em;

		border-top: 1px solid var(--color-main-pale);
	}
	/* 会社名 */
	.nav__addr .company-name {
		width: calc(160rem / 16);
		max-width: 100%;
	}
	.nav__addr .company-name img {
		width: 100%;
		height: auto;
	}
	/* 住所 */
	.header-addr {
		font-size: var(--txt-sm);
		margin-top: 1.25em;
	}
	/* 電話 */
	.nav__addr .tel {
		font-family: var(--alphabet);
		font-weight: 700;
		font-size: var(--txt-xs);
		color: var(--color-bk);
		line-height: 1.1;
		margin-top: 0.5em;

		display: inline-block;
	}
	.nav__addr .tel .number {
		font-size: var(--txt-lg);
	}
	.nav__addr .fax {
		line-height: 1.1;
		margin-top: 0.15em;
	}
	/* ==================
	current */
	.nav__current.is-current {
		color: var(--color-main);
	}


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

	オープン時の挙動

	============================== */
	/* ---------------------
	スクロール禁止 */
	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__contact,
	#nav__wrapper .nav__addr {
		will-change: transform;
	}
	#nav__wrapper.is-open[aria-hidden="false"] .nav__item,
	#nav__wrapper.is-open[aria-hidden="false"] .nav__contact,
	#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__contact {
		-webkit-animation-delay: .39s;
		        animation-delay: .39s;
	}
	#nav__wrapper.is-open[aria-hidden="false"] .nav__addr {
		-webkit-animation-delay: .42s;
		        animation-delay: .42s;
	}
	@-webkit-keyframes navItemSlide {
		from {
			opacity: 0;

			-webkit-transform: translateY(12px);

			        transform: translateY(12px);

			-webkit-filter: blur(4px);

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

			-webkit-transform: translateY(0);

			        transform: translateY(0);

			-webkit-filter: none;

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

			-webkit-transform: translateY(12px);

			        transform: translateY(12px);

			-webkit-filter: blur(4px);

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

			-webkit-transform: translateY(0);

			        transform: translateY(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.7em;
	}
	.nav__current {
		padding: 0.7em min(10vw, calc(30rem / 16));
	}
	.nav__contact {
		padding-inline: min(10vw, calc(30rem / 16));
		margin-top: 2.3em;
	}
	/* ----------------
	住所など */
	.nav__addr {
		margin-inline: min(10vw, calc(30rem / 16));
	}
}