@charset "UTF-8";

/*　ハンバーガーボタン　*/
.hamburger {
	display: block;
	position: fixed;
	z-index: 99999;
	right: 20px;
	top: 34px;
	width: 29px;
	height: 18px;
	cursor: pointer;
	text-align: center;
	-webkit-appearance: none;
	background-color: unset;
    border: unset;
    border-radius: 0;
    color: unset;
    padding: unset;
}

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

.hamburger.color span {
	background: #fff;
}

.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: 8px;
	left: 0;
	-webkit-transform: rotate(315deg);
	-moz-transform: rotate(315deg);
	transform: rotate(315deg);
	background-color: #fff;
}

.hamburger.active span:nth-child(2),
.hamburger.active span:nth-child(3) {
	top: 8px;
	-webkit-transform: rotate(-315deg);
	-moz-transform: rotate(-315deg);
	transform: rotate(-315deg);
	background-color: #fff;
}

.globalMenuSp {
	position: fixed;
	z-index: 999;
	top: 0;
	left: 30px;
	color: #fff;
	transform: translateX(100%);
	transition: all 0.6s;
	width: calc(100% - 30px);
	height: 100vh;
	background: #000000;
	overflow: scroll;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding: 31.28vw 7.69vw 11.79vw;
}

.globalMenuSp .logo {
	display: block;
	width: 46.15vw;
	margin-bottom: 11.7vw;
}

.globalMenuSp .logo img {
	width: 100%;
}

.globalMenuSp .ham_vav {
	margin-bottom: 24vw;
}

.globalMenuSp .ham_vav .ham_nav_block {
	padding-left: 2.5vw;
}

.globalMenuSp .ham_vav .ham_nav_block+.ham_nav_block {
	margin-top: 9.6vw;
}

.globalMenuSp .ham_vav .ham_nav_block .link {
	position: relative;
	font-size: 4.6vw;
	letter-spacing: .08em;
	font-weight: 800;
	color: #fff;
	line-height: 1;
}

.globalMenuSp .ham_vav .ham_nav_block .link::before {
	content: "";
	position: absolute;
	left: -10.19vw;
	width: 7.69vw;
	height: 1px;
	top: 50%;
	transform: translateY(-50%);
	background-color: #E3E3E3;
}

.globalMenuSp .ham_vav .ham_nav_block .link::after {
	content: "";
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: calc(-1 * (2.5vw + 5px));
	width: 5px;
	aspect-ratio: 1;
	border-radius: 50%;
	background-color: #fff;
}

.globalMenuSp .ham_vav .ham_nav_block .sub_link {
	font-size: 3.58vw;
	letter-spacing: .12em;
	line-height: 1;
	color: #E3E3E3;
	width: fit-content;
	display: flex;
	gap: 0.7em;
	align-items: center;
}

.globalMenuSp .ham_vav .ham_nav_block .sub_link .icon {
    width: .86em;
    display: flex;
    align-items: center;
    justify-content: center;
}

.globalMenuSp .ham_vav .ham_nav_block .sub_link .icon svg {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.globalMenuSp .ham_vav .ham_nav_block .sub_link .icon svg path {
    fill: #fff;
}

.globalMenuSp .ham_vav .ham_nav_block .sub_link_area {
	margin-top: 6.4vw;
}

.globalMenuSp .ham_vav .ham_nav_block .sub_link_area.grid {
	display: grid;
	grid-template-columns: repeat(3, auto);
	gap: 6.4vw 9.2vw;
}

.globalMenuSp .ham_vav .ham_nav_block .sub_link_area.flex_box {
	display: flex;
	flex-wrap: wrap;
	gap: 6.4vw 7.69vw;
}

.globalMenuSp .info_area {
	margin-top: auto;
}

.globalMenuSp .info_area .address {
	font-size: 3.58vw;
	letter-spacing: .08em;
	margin-bottom: .85em;
	line-height: 1.35;
	color: #E3E3E3;
}

.globalMenuSp .info_area .btm_link_area {
	display: flex;
	font-size: 3.07vw;
	gap: .5em;
}

.globalMenuSp .info_area .btm_link_area .btm_link {
	color: #E3E3E3;
	letter-spacing: .08em;
}

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