@charset "UTF-8";

/*　ハンバーガーボタン　*/
.hamburger {
	display: block;
	position: fixed;
	z-index: 99999;
	right: 13px;
	top: 12px;
	width: 42px;
	height: 42px;
	cursor: pointer;
	text-align: center;
}

.hamburger span {
	display: block;
	position: absolute;
	width: 30px;
	height: 2px;
	left: 6px;
	background: #555;
	-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: 10px;
}

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

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

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

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

nav.globalMenuSp {
	position: fixed;
	z-index: 999;
	top: 0;
	left: 0;
	color: #000;
	text-align: center;
	transform: translateX(100%);
	transition: all 0.6s;
	width: 100%;
	height: 100vh;
	align-items: center;
	background: #ccc;
	overflow: scroll;
}

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

/* nav.globalMenuSp ul li {
	list-style-type: none;
	padding: 0;
	width: 100%;
	border-bottom: 1px solid #fff;
} */

/* nav.globalMenuSp ul li:last-child {
	padding-bottom: 0;
	border-bottom: none;
} */

/* nav.globalMenuSp ul li a {
	display: block;
	color: #000;
	padding: 1em 0;
	text-decoration: none;
} */

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

/* ===================================================
追加
=================================================== */
/* バーガー調整 */
.hamburger {
	top: 24px;
	right: 5.13vw;
	width: 46px;
	height: 46px;
	background: #1A1A1A;
	border-radius: 6px;
	border: none;
}

.hamburger span {
	display: block;
	position: absolute;
	width: 25.5px;
	height: 2.5px;
	left: 10px;
	background: #fff;
	border-radius: 6px;
}

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

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

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

.hamburger.active span:nth-child(1) {
	top: 22px;
	left: 10px;
}

.hamburger.active span:nth-child(2),
.hamburger.active span:nth-child(3) {
	top: 22px;
}

/* SPメインメニュー */
nav.globalMenuSp {
	position: fixed;
	width: 71.79vw;
	left: auto;
	right: 0;
	color: #fff;
	background: -webkit-gradient(linear, left top, left bottom, from(#2b4f9f), color-stop(40%, #204089), to(#10285c));
	background: -webkit-linear-gradient(top, #2b4f9f 0%, #204089 40%, #10285c 100%);
	background: linear-gradient(to bottom, #2b4f9f 0%, #204089 40%, #10285c 100%);
	padding: 0 5.13vw 7.69vw;
	padding-top: calc(99px + 2vw);
	z-index: 999;
}

nav.globalMenuSp .menus {
	height: 99.5vw;
	overflow-y: scroll;
}

nav.globalMenuSp .menu:not(:first-of-type) {
	margin-top: 5.13vw;
}

nav.globalMenuSp .menu.accordion:not(:first-of-type) {
	margin-top: 7.69vw;
	margin-bottom: 7.69vw;
}

nav.globalMenuSp .menu_title a {
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	align-items: center;
	gap: 2.56vw;
	color: #fff;
	padding-right: 2.56vw;
	padding-bottom: 2.56vw;
	border-bottom: 1px solid #fff;
}

nav.globalMenuSp .menu_title .en {
	font-family: "Montserrat", sans-serif;
	font-size: 4.62vw;
	font-weight: 500;
	line-height: 1;
	letter-spacing: 0em;
	text-align: left;
}

nav.globalMenuSp .menu_title .icon {
	-ms-flex-negative: 0;
	flex-shrink: 0;
	position: relative;
	display: inline-block;
	top: -0.5vw;
	width: 3.08vw;
	height: 3.08vw;
	width: 2.56vw;
	height: 2.56vw;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	-webkit-transform-origin: center center;
	transform-origin: center center;
	border-right: 2px solid #fff;
	border-bottom: 2px solid #fff;
	-webkit-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
}

nav.globalMenuSp .accordion.is-open .menu_title .icon {
	top: 0.5vw;
	-webkit-transform: rotate(225deg);
	transform: rotate(225deg);
}

nav.globalMenuSp .menu_title .arrow {
	-ms-flex-negative: 0;
	flex-shrink: 0;
}

nav.globalMenuSp .menu_title .arrow img {
	position: relative;
	right: -1vw;
	width: 5.64vw;
	height: 5.38vw;
	-o-object-fit: contain;
	object-fit: contain;
}

nav.globalMenuSp .sub_menus {
	overflow: hidden;
	max-height: 0;
	margin-top: 0;
	padding-bottom: 0;
	transition: max-height 0.3s ease, margin-top 0.3s ease, padding-bottom 0.3s ease;
}

.accordion.is-open .sub_menus {
	margin-top: 4.1vw;
}

nav.globalMenuSp .sub_menu {
	text-align: left;
}

nav.globalMenuSp .sub_menu:not(:first-of-type) {
	margin-top: 2vw;
}

nav.globalMenuSp .sub_menu a {
	font-size: 3.59vw;
	font-weight: 500;
	line-height: 1;
	letter-spacing: 0.05em;
	color: #fff;
}

/* 下部コンテンツ */
.globalMenuSp .contents {
	margin-top: 11.03vw;
}

.globalMenuSp .text {
	font-size: 3.33vw;
	font-weight: 500;
	line-height: 1.5692307692;
	letter-spacing: 0.05em;
	text-align: left;
}

.globalMenuSp .copyright {
	display: block;
	font-size: 3.08vw;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.01em;
	margin-top: 10.26vw;
	text-align: center;
}