@charset "utf-8";


/*** MainMenu Style ***/



/* Mainmenu
------------------------------------------------------------- */

/* Common */

#main_menu_box {
	width: 100%;
	height: 55px;
	padding: 0;
	z-index: 9998;
	background-color: rgba(255,255,255,1);
	transform: translate3d(0, 0, 0);
	border-top: 3px solid #103fb4;
	padding-top: 1px;
}

#main_menu_box::before {
	content: "";
	display: block;
	width: 100%;
	height: 1px;
	background-color: #9b2c93;
	position: absolute;
	left: 0;
	top: 1px;
}

#main_menu_box::after {
	content: "";
	display: block;
	width: 100%;
	height: 1px;
	background-color: #9b2c93;
	position: absolute;
	left: 0;
	top: 52px;
}

.main_menu_inner {
	margin: 0 auto;
	width: 100%;
	position: relative;
}

.main_menu_inner:after {
	content: "";
	clear: both;
	display: block;
}

#main_menu_box nav {
	display: none;
	width: 100%;
	float: none;
	clear: both;
	height: auto;
	max-height: 90vh;
	overflow-y: auto;
	color: #000;
	background-color: rgba(255,255,255,1);
	position: relative;
	-webkit-overflow-scrolling: touch;
	box-shadow: 0px 1px 5px -3px rgba(0,0,0,0.3);
}

#main_menu_box nav > ul {
	margin: 0;
	display: block;
	height: auto;
	float: none;
	position: relative;
	list-style: none;
	border-bottom: 1px solid #ccc;
}

#main_menu_box nav li {
	display: block;
	float: none;
	height: auto;
}

#main_menu_box nav li a {
	display: block;
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 15px 8px 15px 15px;
	color: #000;
	font-size: 1.4rem;
	text-align: left;
	letter-spacing: 0.05em;
}

#main_menu_box nav li a:hover,
#main_menu_box nav li a:active {
	text-decoration: none;
	background-color: #e4ecff;
}


/* Menu Icon */

#menu_icon {
	position: absolute;
	right: 18px;
	top: 15px;
	display: inline;
	cursor: pointer;
}

#menu_icon span {
	border: 1px solid #103fb4;
	width: 30px;
	margin-bottom: 8px;
	display: block;
	transition: all 0.25s;
}

#menu_icon.active .first {
	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	margin-top: 10px;
}

#menu_icon.active .second {
	transform: rotate(135deg);
	-webkit-transform: rotate(135deg);
	position: relative;
	top: -10px;
}

#menu_icon.active .third {
	display: none
}


/* Header Title */

.header_title {
	position: relative;
}

.header_logo {
	float: left;
	margin: 3px 0 0 3px;
	width: 240px;
	height: 48px;
}

.header_logo a {
	display: block;
	width: 100%;
	height: 100%;
	font-size: 0;
	background-image: url(../img/logo.png);
	background-size: contain;
	background-position: left center;
	background-repeat: no-repeat;
}

.header_address_box {
	display: none;
	float: left;
	margin-top: 6px;
	width: calc(100% - 320px);
	min-width: 170px;
	text-align: right;
}

.header_address_box p {
	color: #103fb4;
	white-space: nowrap;
}

.header_address_box p:first-child {
	font-size: 1.1rem;
	letter-spacing: 0;
}

.header_address_box p:last-child {
	font-size: 1.8rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}

.header_address_box p:last-child a::before {
	display: inline-block;
	content: "\f095";
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	font-size: 95%;
	color: #103fb4;
	margin-right: 3px;
	transform: scaleX(-1);
}

.header_address_box p a,
.header_address_box p a:hover,
.header_address_box p a:active {
	text-decoration: none;
	color: #103fb4;
}


/*Dropdown*/

#main_menu_box nav li ul {
	margin: 0;
	display: block;
}

#main_menu_box nav > ul > li {
	border-top: 1px solid #ccc;
}

#main_menu_box nav > ul > li > a {
	font-weight: 500;
}

#main_menu_box nav > ul > li > a::before {
	display: inline-block;
	content: "\f138";
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	color: #103fb4;
	margin-right: 3px;
}

#main_menu_box nav li.dropdown ul {
	position: relative;
	top: auto;
}

#main_menu_box nav .dropdown li a {
	padding-left: 25px;
}

#main_menu_box nav ul.mega_dropdown {
	position: relative;
	top: auto;
	display: none;
}

#main_menu_box nav ul.mega_dropdown li.dropdown_title {
	display: none;
}

#main_menu_box nav li ul.mega_dropdown li.row ul li span {
	display: block;
	padding: 15px 10px 5px 15px;
	border-top: 1px dashed #ccc;
}

#main_menu_box nav li ul.mega_dropdown li.row ul li span::before {
	content: "";
	display: inline-block;
	width: 5px;
	height: 14px;
	background-color: #103fb4;
	vertical-align: text-top;
	margin-right: 3px;
}

#main_menu_box nav li.dropdown ul li a,
#main_menu_box nav li ul.mega_dropdown li a {
	text-indent: -9px;
	padding-left: 49px;
	line-height: 1.6;
}

#main_menu_box nav li.dropdown ul li a::before,
#main_menu_box nav li ul.mega_dropdown li a::before {
	display: inline-block;
	content: "\f138";
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	color: #103fb4;
	margin-right: 3px;
}

#main_menu_box nav li.menu_ext a::after,
#main_menu_box nav li.menu_blank a::after {
	display: inline-block;
	content: "";
	width: 18px;
	height: 18px;
	background-position: center bottom;
	background-repeat: no-repeat;
	background-size: contain;
	margin: 0 0 2px 2px;
	vertical-align: middle;
}

#main_menu_box nav li.menu_ext a::after {
	background-image: url(/resources/img/icon_ext_blue.png);
}

#main_menu_box nav li.menu_blank a::after {
	background-image: url(/resources/img/icon_targetlink_blue.png);
}





/* for IE 
------------------------------------------------------------- */

@media all and (-ms-high-contrast: none){

	.header_address_box {
		margin-top: 9px;
	}

}





/* for MiddleSize(480-679px)
-------------------------------------------------------------------------------- */
@media print, screen and (min-width:480px) {

	/* Header Title */

	.header_address_box {
		display: block;
	}

}





/* for MiddleSize(680-787px)
-------------------------------------------------------------------------------- */
@media print, screen and (min-width:680px) {

	/* Header Title */

	.header_address_box {
		margin-top: 14px;
	}

	.header_address_box p {
		display: inline-block;
		vertical-align: middle;
	}

	.header_address_box p:first-child {
		margin-right: 10px;
		padding-bottom: 3px;
	}

}





/* for MiddleSize
-------------------------------------------------------------------------------- */
@media print, screen and (min-width:788px) {

	/* Common */

	#main_menu_box {
		height: 100px;
	}

	#main_menu_box::after {
		top: 56px;
	}

	.main_menu_inner {
		margin: 0 auto;
		height: 60px;
		position: relative;
	}

	#main_menu_box nav {
		display: block !important;
		width: 100%;
		overflow-y: visible;
		position: relative;
		right: auto;
		left: 0;
		bottom: auto;
		background-color: #103fb4;
		border-top: 2px solid #fff;
		border-bottom: 1px solid #fff;
		box-shadow: none;
	}

	#main_menu_box nav > ul {
		margin: 0 auto;
		height: auto;
		width: 100%;
		max-width: 1260px;
		border-bottom: 0;
		display: flex;
		flex-wrap: nowrap;
	}

	#main_menu_box nav > ul > li {
		height: 40px;
		border-top: 0;
		flex-grow: 1;
		border-right: 1px solid #fff;
	}

	#main_menu_box nav > ul > li:first-child {
		border-left: 1px solid #fff;
	}

	#main_menu_box nav > ul > li a {
		display: block;
		width: 100%;
		height: 100%;
		margin: 0;
		padding: 0;
		font-size: 1.1rem;
		text-align: center;
		line-height: 40px;
		letter-spacing: 0.02em;
		color: #fff;
		white-space: nowrap;
	}

	#main_menu_box nav li a:hover,
	#main_menu_box nav li a:active {
		color: #fff;
		background-color: #9b2c93;
	}


	/* Menu Icon */

	#menu_icon {
		display: none;
	}


	/* Header Title */

	.header_title {
		margin: 0 auto;
		max-width: 1260px;
		height: 55px;
		overflow: hidden;
	}

	.header_logo {
		margin: 3px 0 0 5px;
		width: 260px;
		height: 52px;
	}

	.header_address_box {
		margin-top: 6px;
		width: calc(100% - 280px);
	}

	.header_address_box p {
		display: block;
		vertical-align: middle;
	}

	.header_address_box p:first-child {
		margin-right: 0;
		padding-bottom: 1px;
		font-size: 1.2rem;
		letter-spacing: 0.01em;
	}

	.header_address_box p:last-child {
		font-size: 2rem;
	}


	/*Dropdown*/

	#main_menu_box nav li ul {
		display: none;
	}

	#main_menu_box nav li:hover ul {
		display: inline;
	}

	#main_menu_box nav li li {
		float: none;
	}

	#main_menu_box nav li {
		position: relative;
	}

	#main_menu_box nav > ul > li {
		border-top: 0;
	}

	#main_menu_box nav > ul > li > a::before {
		display: none;
	}

	#main_menu_box nav li.dropdown > ul {
		position: absolute;
		top: 40px;
		left: 0;
		padding: 0;
		background-color: #e4ecff;
		background: -moz-linear-gradient(top, #fff, #e4ecff);
		background: -webkit-linear-gradient(top, #fff,#e4ecff);
		background: linear-gradient(to bottom, #fff,#e4ecff);
		box-shadow: 0px 1px 5px -2px rgba(0,0,0,0.3);
	}

	#main_menu_box nav li.dropdown ul li a,
	#main_menu_box nav li ul.mega_dropdown li a {
		display: inline-block;
		width: auto;
		padding: 10px 20px;
		text-align: left;
		text-indent: -8px;
		font-size: 1.2rem;
		color: #000;
		white-space: normal;
	}

	#main_menu_box nav li.dropdown ul li a:hover,
	#main_menu_box nav li.dropdown ul li a:active,
	#main_menu_box nav li ul.mega_dropdown li a:hover,
	#main_menu_box nav li ul.mega_dropdown li a:active {
		background-color: transparent;
		color: #9b2c93;
	}

	#main_menu_box nav li.dropdown ul li a:hover::before,
	#main_menu_box nav li ul.mega_dropdown li a:hover::before {
		color: #9b2c93;
	}

	#main_menu_box nav li.menu_ext a::after,
	#main_menu_box nav li.menu_blank a::after {
		background-position: center top;
		vertical-align: middle;
	}

	#main_menu_box nav li.menu_ext a:hover::after {
		background-image: url(/resources/img/icon_ext_purple.png);
	}

	#main_menu_box nav li.menu_blank a:hover::after {
		background-image: url(/resources/img/icon_targetlink_purple.png);
	}

	#main_menu_box nav .mega_dropdown_box {
		position: fixed;
		left: 0;
		top: 98px;
		width: 100%;
		background-color: #e4ecff;
		background: -moz-linear-gradient(top, #fff, #e4ecff);
		background: -webkit-linear-gradient(top, #fff,#e4ecff);
		background: linear-gradient(to bottom, #fff,#e4ecff);
		box-shadow: 0px 1px 5px -2px rgba(0,0,0,0.3);
	}

	#main_menu_box nav li:hover ul.mega_dropdown {
		display: block;
		position: relative;
		width: 100%;
		max-width: 1260px;
		margin: 0 auto;
	}

	#main_menu_box nav li:hover ul.mega_dropdown li.dropdown_title {
		display: block;
		margin: 0;
		padding-left: 5px;
		width: 220px;
		height: 30px;
		position: absolute;
		left: 10px;
		top: 35px;
		border-left: 5px solid #103fb4;
		font-weight: 500;
		font-size: 1.7rem;
		line-height: 30px;
	}

	#main_menu_box nav li ul.mega_dropdown li.row ul li span {
		padding: 10px 5px 10px 0;
		border-top: 0;
	}

	#main_menu_box nav ul.mega_dropdown li.row {
		display: flex;
		height: auto;
		margin-left: 250px;
		padding: 30px 0 27px 0;
		width: calc(100% - 280px);
	}

	#main_menu_box nav ul.mega_dropdown li.row ul.mega_col {
		width: 50%;
	}


	/*Current Mark*/

	#main_menu_box nav > ul > li > a::after {
		position: absolute;
		bottom: -3px;
		left: 0;
		right: 0;
		content: '▲';
		font-size: 12px;
		line-height: 1;
		color: #fff;
		display: none;
	}

	#main_menu_box nav > ul > li:hover > a::after {
		display: inline;
	}


}


/* for IE 
------------------------------------------------------------- */

@media all and (-ms-high-contrast: none) and (min-width:788px){

	.header_address_box {
		margin-top: 8px;
	}

	#main_menu_box nav .mega_dropdown_box {
		top: 101px;
	}

}




/* for LargeSize
-------------------------------------------------------------------------------- */
@media print, screen and (min-width:960px) {


	#main_menu_box nav > ul > li a {
		font-size: 1.3rem;
	}

	#main_menu_box nav li.dropdown ul li a,
	#main_menu_box nav li ul.mega_dropdown li a {
		font-size: 1.3rem;
	}

	#main_menu_box nav li:hover ul.mega_dropdown li.dropdown_title {
		width: 260px;
		left: 20px;
		font-size: 2rem;
	}

	#main_menu_box nav ul.mega_dropdown li.row {
		margin-left: 320px;
		width: calc(100% - 340px);
	}

}





/* for ExtraLargeSize
-------------------------------------------------------------------------------- */
@media print, screen and (min-width:1260px) {



}





/* for Print*/
@media print{

	#main_menu_box {
		padding: 0 0;
		position: relative !important;
		box-shadow: none;
		height: 65px;
	}

	#main_menu_box nav {
		display: none !important;
	}

	#menu_icon {
		display: none !important;
	}

	@supports (-ms-ime-align:auto) {

		/* Logo
		------------------------------------------------------------- */

		.menu_logo a {
			display: list-item !important;
			list-style-image: url(../img/logo_print.png) !important;
			list-style-position: inside !important;
			background-image: none !important;
		}

	}

}

