@charset "UTF-8";

/*　ハンバーガーボタン　*/
.hamburger {
	display: block;
	position: fixed;
	z-index: 99999;
	right: 10px;
	top: 22px;
	width: 35px;
	height: 16px;
	cursor: pointer;
	text-align: center;
	background: none;
	border: none;
}

.hamburger span {
	display: block;
	position: absolute;
	width: 100%;
	height: 1px;
	left: 0;
	background: #333;
	-webkit-transition: 0.5s ease-in-out;
	-moz-transition: 0.5s ease-in-out;
	transition: 0.5s ease-in-out;
}

.hamburger span:nth-child(1) {
	top: 0;
}

.hamburger span:nth-child(2) {
	top: 8px;
}

.hamburger span:nth-child(3) {
	top: 16px;
}

/* ナビ開いてる時のボタン */
.hamburger.active span:nth-child(1) {
	top: 7px;
	left: 0;
	-webkit-transform: rotate(315deg);
	-moz-transform: rotate(315deg);
	transform: rotate(335deg);
}

.hamburger.active span:nth-child(2),
.hamburger.active span:nth-child(3) {
	top: 7px;
	-webkit-transform: rotate(-315deg);
	-moz-transform: rotate(-315deg);
	transform: rotate(-335deg);
}

nav.globalMenuSp {
	position: fixed;
	z-index: 999;
	top: 60px;
	left: 0;
	transform: translateX(100%);
	transition: all 0.6s;
	width: 100%;
	height: 100%;
	align-items: center;
	overflow: scroll;
	padding-block: 7.69vw 29.7vw;
	background-color: #2B2018;
}

nav.globalMenuSp ul {
	margin: 0 auto;
	padding: 0;
	width: 100%;
}

nav.globalMenuSp ul li {
	list-style-type: none;
}

/* このクラスを、jQueryで付与・削除する */
nav.globalMenuSp.active {
	transform: translateX(0%);
}

.globalMenuPc.active {
	transform: translateX(0%);
}

/* PC */
/* ハンバーガーボタン */
.hamburgerPc-box {
	width: 100px;
	height: 100px;
	background-color: #F5F1E7;
	flex-shrink: 0;
	position: relative;
	z-index: 1000;
}

.hamburgerPc-box .hamburgerPc {
	background-color: transparent;
	border: none;
	width: 100%;
	height: 100%;
	100%:
		relative;
	padding: 0;
	position: relative;
}

.hamburgerPc-box .hamburgerPc span {
	display: block;
	position: absolute;
	width: 50px;
	height: 1px;
	left: 50%;
	translate: -50% 0;
	background-color: #333;
	-webkit-transition: 0.5s ease-in-out;
	-moz-transition: 0.5s ease-in-out;
	transition: 0.5s ease-in-out;
}

.hamburgerPc-box .hamburgerPc span:nth-child(2) {
	top: 39px;
}

.hamburgerPc-box .hamburgerPc span:nth-child(3) {
	top: 49px;
}

.hamburgerPc-box .hamburgerPc span:first-child {
	top: 29px;
}

.hamburgerPc-box__text {
	font-weight: 700;
	line-height: 1.4;
	letter-spacing: .01em;
}

.hamburgerPc.active span:nth-child(1) {
	top: 39px;
	-webkit-transform: rotate(325deg);
	-moz-transform: rotate(325deg);
	transform: rotate(325deg);
}

.hamburgerPc.active span:nth-child(2),
.hamburgerPc.active span:nth-child(3) {
	top: 39px;
	-webkit-transform: rotate(-325deg);
	-moz-transform: rotate(-325deg);
	transform: rotate(-325deg);
}

.globalMenuPc {
	position: fixed;
	z-index: 999;
	top: 0;
	left: 0;
	color: #000;
	transform: translateX(100%);
	transition: all 0.6s;
	width: 100%;
	height: 100vh;
	align-items: center;
	background: #2B2018;
	overflow: scroll;
	min-width: 1440px;
}

.hamburgerPc-box__text-box {
	width: fit-content;
	position: absolute;
	bottom: 20px;
	left: 50%;
	translate: -50% 0;
}

.hamburgerPc-box__text.-close {
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
	visibility: hidden;
	transition: .5s;
}

.hamburgerPc-box__text-box.active .hamburgerPc-box__text.-close {
	opacity: 1;
	visibility: visible;
}

.hamburgerPc-box__text.-open {
	visibility: visible;
	opacity: 1;
	transition: .5s;
}

.hamburgerPc-box__text-box.active .hamburgerPc-box__text.-open {
	visibility: hidden;
	opacity: 0;
}

.hamburgerPc-box__inner {
	width: fit-content;
	margin: 0 auto;
}

.globalMenuPc__flex {
	display: grid;
	grid-template-columns: 33% 67%;
	position: relative;
	height: 100%;
	z-index: 0;
}

.globalMenu__btn-area {
	background-image: url(/wp-content/themes/swell_child/image/globalMenuPc_img.webp);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	position: relative;
	z-index: 0;
	padding: 80px;
	display: grid;
	place-content: center;
}

.globalMenu__btn-area::before {
	content: "";
	position: absolute;
	inset: 0;
	background-color: #4D3123;
	opacity: .55;
	mix-blend-mode: multiply;
	z-index: -1;
}

.globalMenuPc__flex::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: url(/wp-content/themes/swell_child/image/globalMenuPc_bg.webp);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	opacity: .35;
	mix-blend-mode: lighten;
	z-index: -1;
}

.globalMenu-btn-area__en {
	font-size: 20px;
	color: #FFF;
	font-weight: 700;
	letter-spacing: .01em;
	line-height: 1.35;
	margin-bottom: 28px;
	text-align: center;
}

.globalMenuPc-nav {
	padding: 156px 150px 80px 100px;
	display: grid;
	place-content: center;
}

.globalMenuPc-nav__child-box {
	display: flex;
	gap: 0 60px;
}

.globalMenuPc-nav__top {
	display: flex;
	border-bottom: solid 1px rgba(255, 255, 255, .3);
	padding-bottom: 50px;
	margin-bottom: 44px;
	gap: 0 60px;
}

.globalMenu__btn-box .common-cta-btn+.common-cta-btn {
	margin-top: 10px;
}

.globalMenuPc-nav__item a {
	display: block;
	color: #FFF;
	width: fit-content;
	transition: .3s;
}

.globalMenuPc-nav__item-en {
	font-size: 20px;
	letter-spacing: .01em;
	font-weight: 700;
	line-height: 1.35;
	margin-bottom: 8px;
}

.globalMenuPc-nav__item-text {
	font-size: 14px;
	letter-spacing: .08em;
	line-height: 1;
}

.globalMenuPc-nav__item+.globalMenuPc-nav__item {
	margin-top: 33px;
}

.globalMenuPc-nav__child {
	padding-left: 20px;
	border-left: dashed 1px #FFF;
}

.globalMenuPc-nav__item {
	padding-left: 20px;
	border-left: solid 3px #FFF;
}

.globalMenuPc-nav__group ul+.globalMenuPc-nav__child {
	margin-top: 25px;
}

.globalMenuPc-nav__child-item a {
	display: block;
	color: #FFF;
	font-size: 14px;
	letter-spacing: .03em;
	line-height: 1;
	font-weight: 400;
	width: fit-content;
	transition: .3s;
}

.globalMenuPc-nav__child-item+.globalMenuPc-nav__child-item {
	margin-top: 16px;
}

.globalMenuPc-nav__bottom .globalMenuPc-nav__group {
	display: flex;
	gap: 0 86px;
}

/* 追加 */
@media (max-width: 750px) {
	nav.globalMenuSp::before {
		content: "";
		position: absolute;
		background-image: url(/wp-content/themes/swell_child/image/footer_bg.webp);
		background-position: center;
		background-repeat: no-repeat;
		background-size: cover;
		opacity: .2;
		mix-blend-mode: multiply;
		top: 0;
		left: 0;
		width: 100%;
		height: 165%;
		z-index: -1;
	}

	nav.globalMenuSp .globalMenuPc-nav__item-en {
		color: #FFF;
	}

	nav.globalMenuSp .globalMenuPc-nav__item-text {
		color: #FFF;
	}

	nav.globalMenuSp .copyright small {
		padding-bottom: 0;
	}

	.sp-hamburger-contact__list {
		background-color: #F7F6F4;
		padding: 8.97vw 5.12vw 5.12vw;
		margin-top: -3.7vw;
		position: relative;
		z-index: 0;
	}

	.top-contact__item.-hamburger {
		display: flex;
		align-items: center;
		gap: 0 5.12vw;
	}

	.top-contact__item.-hamburger .top-contact__item-icon {
		flex-shrink: 0;
		width: 15.38vw;
		margin: 0;
	}

	.sp-hamburger-contact__inner .top-contact__mail-btn a {
		width: 58.97vw;
	}

	.sp-hamburger-contact__inner .top-contact__calculator-btn a {
		width: 58.97vw;
	}

	.sp-hamburger-contact__inner .top-contact__item-ttl {
		font-size: 4.1vw;
		margin-bottom: 2.05vw;
	}

	.sp-hamburger-contact__inner .top-contact__item-tel a {
		font-size: 3.58vw;
	}

	.sp-hamburger-contact__inner .top-contact__item-tel-text .large {
		font-size: 7.17vw;
	}

	.sp-hamburger-contact__inner .top-contact__item-tel-note {
		font-size: 2.56vw;
	}

	.sp-hamburger-contact__list .top-contact__item+.top-contact__item {
		padding-top: 5.12vw;
		margin-top: 5.12vw;
	}

	.sp-hamburger-contact__ttl {
		padding: 1.28vw 4.48vw;
		background-color: var(--sub-color);
		width: fit-content;
		margin: 0 auto;
		position: relative;
		z-index: 1;
	}

	.sp-hamburger-contact__ttl-text {
		color: #FFF;
		font-size: 3.58vw;
		letter-spacing: .08em;
		font-weight: 700;
		line-height: 1.43;
	}

	nav.globalMenuSp .site-footer__bottom {
		padding-bottom: 0;
		border: none;
		margin-bottom: 12.56vw;
	}

	nav.globalMenuSp .site-footer__top {
		padding-bottom: 7.43vw;
		margin-bottom: 7.69vw;
	}

	.globalMenuPc-nav__item {
		padding-left: 5.12vw;
	}

	.globalMenuPc-nav__item-en {
		font-size: 4.61vw;
		margin-bottom: 1.28vw;
	}

	.globalMenuPc-nav__item-text {
		font-size: 3.07vw;
	}

	.sp-hamburger-contact {
		margin-bottom: 8.97vw;
	}

	.sp-hamburger-contact__list::after {
		content: "";
		background-image: url(/wp-content/themes/swell_child/image/sp_hamburger_contact_list_bg.svg);
		background-position: center;
		background-repeat: no-repeat;
		background-size: cover;
		position: absolute;
		bottom: 0;
		right: 0;
		width: 76.92vw;
		height: 54.08vw;
		z-index: -1;
		opacity: .1;
	}

	.globalMenuPc-nav__item a:hover {
		opacity: 1;
	}

	.globalMenuPc-nav__child-item a:hover {
		opacity: 1;
	}
}