@charset "UTF-8";

/* ==========================================================
[ Layout CSS - Contents ]

**サイト全体に共通するレイアウトを記述**

base setting
print_logo
wrapper
header
hnav
main
modal
footer

========================================================== */



@font-face {
	font-family: "YuGothic M";
	src: local(Yu Gothic Medium);
}



/* ---------------------------------------------
*   base setting
--------------------------------------------- */

body {
	line-height: 1.5;
	font-size: 14px;
	/*
	font-family: Helvetica, Roboto, "YuGothic M", "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
	*/
	/*font-family: Helvetica, Roboto, Avenir, "YuGothic M", "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;*/
	font-family: Roboto, Helvetica, Avenir, "YuGothic M", "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-weight: bolder;
	font-weight: 500;
	/*
	font-weight: normal !important;
	font-weight: 400 !important;
	*/
	color: #222;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-text-size-adjust: 100%;
}
body.skin_spmenu_opened,
body.skin_modal_open,
body.no-scroll {
	overflow: hidden;
}


/*  link
--------------------------------------------- */
a {
	color: inherit;
	text-decoration: none;
}
a:hover {
	text-decoration: underline;
}


/*  img
--------------------------------------------- */
img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}


/*  clearfix
--------------------------------------------- */
.clearfix:after {
	content: "";
	display: block;
	clear: both;
}


/*  responsive
--------------------------------------------- */

/* -- general -- */
.pc_only {
	display: block;
}
.sp_only {
	display: none;
}
@media screen and (max-width: 640px) {
	.pc_only {
		display: none;
	}
	.sp_only {
		display: block;
	}
}

/* -- inline -- */
br.pc_only,
a.pc_only,
span.pc_only {
	display: inline;
}
br.sp_only,
a.sp_only,
span.sp_only {
	display: none;
}
@media screen and (max-width: 640px) {
	br.pc_only,
	a.pc_only,
	span.pc_only {
		display: none;
	}
	br.sp_only,
	a.sp_only,
	span.sp_only {
		display: inline;
	}
}


/*  other
--------------------------------------------- */

/* -- hover_opacity -- */
.hover_opacity {
	transition: opacity .3s;
}
.hover_opacity:hover {
	opacity: .7;
}

/* -- hover_fc_red -- */
.hover_fc_red:hover {
	color: #fc0010 !important;
}
.hover_fc_red.visited {
	color: purple;
}
.hover_fc_red.visited img {
	opacity: 0.75;
}
.hover_fc_red.visited:hover img {
	opacity: 1;
}
#archive_thumbnail .hover_fc_red.visited .item_thumbnail_year {
	color: purple;
}
#archive_thumbnail a.hover_fc_red.visited:hover .item_thumbnail_year {
	color: #fc0010;
}
/* -- bg_filler -- */
.bg_filler {
	display: block;
	height: 0;
	overflow: hidden;
	background-position: center top;
	background-repeat: no-repeat;
	background-size: 100% auto;
}



/* ---------------------------------------------
*   print_logo
--------------------------------------------- */
#print_logo {
	display: none !important;
}



/* ---------------------------------------------
*   wrapper
--------------------------------------------- */
#wrapper {
	position: relative;
	overflow: hidden;
	padding: 0 0 81px 150px; /* padding (bottom, left): height of footer, width of header */
	background-color: #f6f6f6;
}
@media screen and (max-width: 640px) {
	#wrapper {
		padding: 84px 0 0 0; /* padding-top: height of logo_header */
	}
}



/* ---------------------------------------------
*   wrapper (skin)
--------------------------------------------- */
.skin_current_home #wrapper {
	height: 100vh;
	padding: 0 0 0 150px; /* padding-left: width of header */
}
@media screen and (max-width: 640px) {
	.skin_current_home #wrapper {
		height: auto;
		padding: 69px 0 0 0; /* padding-top: height of logo_header */
	}
}



/* ---------------------------------------------
*   header
--------------------------------------------- */
#header {
	position: fixed;
	top: 0;
	left: 0;
	box-sizing: border-box;
	width: 150px; /* width: padding-left of wrapper */
	height: 100vh;
	background-color: #fff;
}
@media screen and (max-width: 640px) {
	#header {
		z-index: 9999;
		right: 0;
		width: 100%;
		height: auto;
		max-height: 100vh;
	}
}


/*  header_logo
--------------------------------------------- */
#header_logo {
	padding: 48px 0 30px 0;
	border-bottom: 1px solid #ccc;
	margin: 0 16px;
}
@media screen and (max-width: 640px) {
	#header_logo {
		position: relative;
		padding: 9px 0;
		margin: 0 auto;
	}
}

/* -- item_logo -- */
@media screen and (max-width: 640px) {
	#header_logo .item_logo {
		padding-top: 4px;
	}
	#header_logo .item_logo02 {
		padding-top: 4px;
	}
}

/* item_logo_inner */
#header_logo .item_logo_inner {
	width: 98px;
	padding-top: 30px;
	background-image: url(../img/common/logo_kajima_header.png);
	margin: 0 auto;
}
@media screen and (max-width: 640px) {
	#header_logo .item_logo_inner {
		width: 53px;
		padding-top: 16px;
		background-image: url(../img/common/logo_kajima_header_sp.png);
	}
}
#header_logo .item_logo02_inner {
	width: 121px;
	padding-top: 28px;
	background-image: url(../img/common/logo_kajima_header_02.png);
	margin: 0 auto;
}
@media screen and (max-width: 640px) {
	#header_logo .item_logo02_inner {
		width: 89px;
		padding-top: 15px;
		background-image: url(../img/common/logo_kajima_header_02_sp.png);
	}
}

/* -- item_text_eng -- */
@media screen and (max-width: 640px) {
	#header_logo .item_text_eng {
		width: 180px;
		padding-top: 15px;
		background-image: url(../img/common/text_major_projects_sp.png);
		margin: 10px auto 0;
	}
}

/* -- item_text_jpn -- */
@media screen and (max-width: 640px) {
	#header_logo .item_text_jpn {
		text-align: center;
		line-height: 1.25;
		font-weight: bold;
		margin: 7px auto 0;
	}
}

/* -- hnav_trigger -- */
@media screen and (max-width: 640px) {
	#hnav_trigger {
		position: absolute;
		top: 50%;
		right: 8px;
		display: block;
		width: 20px;
		padding-top: 20px;
		background-image: url(../img/common/btn_menu_sp.png);
		margin-top: -10px;
		cursor: pointer;
	}
}

/* -- hnav_trigger (skin) -- */
@media screen and (max-width: 640px) {
	.skin_spmenu_opened #hnav_trigger {
		background-position: center bottom;
	}
}



/* ---------------------------------------------
*   hnav
--------------------------------------------- */
#hnav {
	width: 100%;
	height: calc(100% - 91px);/* height: header - header_logo */
}
@media screen and (max-width: 640px) {
	#hnav {
		height: 0;
		overflow: hidden;
	}
}


/*  hnav_inner
--------------------------------------------- */
.hnav_inner {
/*	height: calc(100% - 84px);*//* height: hnav - header_search */
	height: 100%;
	overflow: hidden;
}
@media screen and (max-width: 640px) {
	.hnav_inner {
/*		height: calc(100% - 65px);*/
	}
}

/* -- malihu-custom-scrollbar-plugin (override) -- */
#hnav .mCSB_scrollTools .mCSB_draggerRail {
	background: none;
}
#hnav .mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar {
	background-color: #ccc;
	margin: 0 2px 0 10px;
}
#hnav .mCSB_inside > .mCSB_container {
	margin-right: 0;
}
#hnav .mCSB_scrollTools .mCSB_dragger {
	cursor: default;
}

/*  hnav_scroll
--------------------------------------------- */
.hnav_scroll {
	height: 100%;
	overflow: hidden;
	/*
	height: calc(100% - 195px);
	height: 200px;
	*/
}

/*  hnav_scroll_content
--------------------------------------------- */
.hnav_scroll_content {
	padding: 20px 16px 22px;
}
@media screen and (max-width: 640px) {
	.hnav_scroll_content {
		padding: 0;
	}
}


/*  item_search
--------------------------------------------- */
#hnav .item_search {
	padding-top: 20px;
}
@media screen and (max-width: 640px) {
	#hnav .item_search {
		padding-top: 0;
	}
}

/*  item_searches_wrapper
--------------------------------------------- */
#hnav .item_searches_wrapper {
	display: block;
	height: calc(100% - 195px - 75px);
}
@media screen and (max-width: 640px) {
	#hnav .item_searches_wrapper {
		height: calc(100% - 225px);
	}
}
#hnav .item_triggers {
	position: absolute;
	bottom: 0;
		bottom: 25px;
	height: 175px;
		height: auto;
	width: 100%;
}
@media screen and (max-width: 640px) {
	#hnav .item_triggers {
		position: relative;
		bottom: auto;
		height: auto;
		width: auto;
	}
}

/*  item_search (skin)
--------------------------------------------- */
#hnav .item_search.skin_top {
	padding-top: 0;
}


/*  item_search_head
--------------------------------------------- */
#hnav .item_search_head {
	position: relative;
	text-align: center;
}
@media screen and (max-width: 640px) {
	#hnav .item_search_head {
		text-align: left;
	}
}

/* -- item_search_title -- */
#hnav .item_search_title {
	display: inline-block;
}
#hnav .item_search_title:hover {
	text-decoration: none;
}
@media screen and (max-width: 640px) {
	#hnav .item_search_title {
		position: relative;
		display: block;
		padding: 12px 62px;
		border-bottom: 1px solid #ccc;

		white-space: nowrap;
	}
}

/* -- item_search_title (skin) -- */
@media screen and (max-width: 640px) {
	#hnav .item_search.skin_latest .item_search_title {
	}
	#hnav .item_search.skin_keyword .item_search_title {
		border-bottom-width: 0;
	}
}

/* -- item_search_title_text -- */
#hnav .item_search_title_text {
	display: block;
	font-size: 92.8%;
	background-position: center top;
	background-repeat: no-repeat;
}
#hnav .item_search_title_text:after {
	content: "";
	position: absolute;
	bottom: 3px;
	right: 6px;
	display: block;
	width: 10px;
	height: 0;
	padding-top: 10px;
	overflow: hidden;
	background: url(../img/common/icon_accordion.png) center top no-repeat;
	background-size: 100% auto;
}
#hnav .item_search_title_text.skin_multi:after {
	bottom: 11px;
}
@media screen and (max-width: 640px) {
	#hnav .item_search_title_text {
		position: static;
		display: inline-block;
		vertical-align: top;
		font-size: 114.2%;
		background-position: left center;
	}
	#hnav .item_search_title_text:after {
		top: 50%;
		right: 14px;
		margin-top: -5px;
	}
}

/* -- item_search_title (skin) -- */
#hnav .item_search.skin_top .item_search_title_text {
	padding-top: 32px;
	background-image: url(../img/common/icon_top.png);
}
#hnav .item_search.skin_latest .item_search_title_text {
	padding-top: 25px;
	background-image: url(../img/common/icon_latest.png);
}
#hnav .item_search.skin_category .item_search_title_text {
	padding-top: 22px;
	background-image: url(../img/common/icon_category.png);
}
#hnav .item_search.skin_area .item_search_title_text {
	padding-top: 26px;
	background-image: url(../img/common/icon_area.png);
}
#hnav .item_search.skin_year .item_search_title_text {
	padding-top: 24px;
	background-image: url(../img/common/icon_year.png);
}
#hnav .item_search.skin_dictionary .item_search_title_text {
	padding-top: 22px;
	background-image: url(../img/common/icon_dictionary.png);
}
#hnav .item_search.skin_keyword .item_search_title_text {
	padding-top: 24px;
	background-image: url(../img/common/icon_keyword.png);
}
#hnav .item_search.skin_opened .item_search_title_text:after {
	background-position: center bottom;
}
#hnav .item_search.skin_top .item_search_title_text:after,
#hnav .item_search.skin_latest .item_search_title_text:after,
#hnav .item_search.skin_dictionary .item_search_title_text:after {
	display: none;
}
@media screen and (max-width: 640px) {
	#hnav .item_search.skin_top .item_search_title_text,
	#hnav .item_search.skin_latest .item_search_title_text,
	#hnav .item_search.skin_category .item_search_title_text,
	#hnav .item_search.skin_area .item_search_title_text,
	#hnav .item_search.skin_year .item_search_title_text,
	#hnav .item_search.skin_dictionary .item_search_title_text,
	#hnav .item_search.skin_keyword .item_search_title_text {
		padding: 0 0 0 50px;
	}
	#hnav .item_search.skin_opened .item_search_title_text:after {
		background-position: center bottom;
	}
	#hnav .item_search.skin_latest .item_search_title_text:after,
	#hnav .item_search.skin_dictionary .item_search_title_text:after {
		display: none;
	}
}


/*  item_search_body
--------------------------------------------- */
#hnav .item_search_body {
	display: none;
}
#hnav .item_search_body:before {
	content: "";
	display: block;
	width: 100%;
	height: 0;
	padding-top: 13px;
	overflow: hidden;
	background: url(../img/common/icon_accordion_top.png) center bottom no-repeat;
	background-size: 100% auto;
}
@media screen and (max-width: 640px) {
	#hnav .item_search_body:before {
		display: none;
	}
}


/*  item_search_body (skin)
--------------------------------------------- */
#hnav .item_search.skin_keyword .item_search_body:before {
	display: none;
}


/*  item_search_body_inner
--------------------------------------------- */
#hnav .item_search_body_inner {
	padding-bottom: 10px;
	border: 1px solid #ccc;
	border-top-width: 0;
}
@media screen and (max-width: 640px) {
	#hnav .item_search_body_inner {
		padding-bottom: 0;
		border: 0;
	}
}


/*  item_search_body_inner (skin)
--------------------------------------------- */
#hnav .item_search.skin_keyword .item_search_body_inner {
	padding: 5px 0 0;
	border: 0;
}
@media screen and (max-width: 640px) {
	#hnav .item_search.skin_keyword .item_search_body_inner {
		padding: 5px;
	}
	#hnav .item_search.skin_keyword.skin_opened .item_search_body_inner {
		border-top: 1px solid #ccc;
	}
}


/*  item_search_close
--------------------------------------------- */
#hnav .item_search_close {
	display: none;
	width: 20px;
	height: 0;
	padding-top: 20px;
	background: url(../img/common/icon_accordion_bottom.png) center top no-repeat;
	margin: -11px auto 0;
}


/*  item_search_close (skin)
--------------------------------------------- */
#hnav .item_search.skin_opened .item_search_close {
	display: block;
	cursor: pointer;
}
@media screen and (max-width: 640px) {
	#hnav .item_search.skin_opened .item_search_close {
		display: none;
	}
}


/* -- item_accordion -- */
/*#hnav .item_accordion {}*/

/* -- item_accordion_head -- */
#hnav .item_accordion_head {
	position: relative;
	font-size: 85.7%;
	padding: 12px;
	border-bottom: 1px solid #ccc;
	cursor: pointer
}
#hnav .item_accordion_head:after {
	content: "";
	position: absolute;
	top: 50%;
	right: 15px;
	width: 8px;
	padding-top: 8px;
	background-image: url(../img/common/icon_accordion_small.png);
	margin-top: -4px;
	cursor: pointer;
}
@media screen and (max-width: 640px) {
	#hnav .item_accordion_head {
		text-align: center;
	}
}

/* -- item_accordion_head (skin) -- */
#hnav .item_accordion:last-child .item_accordion_head {
	border-bottom-width: 0;
}
#hnav .item_accordion.skin_opened .item_accordion_head:after {
	background-position: center bottom;
}
#hnav .item_accordion.skin_opened:last-child .item_accordion_head {
	border-bottom-width: 1px;
}
@media screen and (max-width: 640px) {
	#hnav .item_accordion:last-child .item_accordion_head {
		border-bottom-width: 1px;
	}
}

/* -- item_accordion_body / item_years -- */
#hnav .item_accordion_body,
#hnav .item_years {
	padding: 22px 13px 24px;
	overflow: hidden;
}

/* -- item_accordion_body -- */
#hnav .item_accordion_body {
	display: none;
	border-bottom: 1px solid #ccc;
}

/* -- item_accordion_body (skin) -- */
#hnav .item_accordion:last-child .item_accordion_body {
	border-bottom-width: 0;
}

/* item_checkbox */
#hnav .item_checkbox {
	position: relative;
	margin-top: 15px;
}

/* item_checkbox (skin) */
#hnav .item_checkbox:first-child {
	margin-top: 0;
}
#hnav .item_accordion.skin_checkbox_float .item_checkbox,
#hnav .item_years.skin_checkbox_float .item_checkbox {
	float: left;
	width: 50%;
}
#hnav .item_accordion.skin_checkbox_float .item_checkbox:nth-child(2),
#hnav .item_years.skin_checkbox_float .item_checkbox:nth-child(2) {
	margin-top: 0;
}

/* item_checkbox - input */
#hnav .item_checkbox > input {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	position: absolute;
	top: 0;
	left: 0;
	width: 0;
	height: 0;
	padding: 0;
	border: 0;
	border-radius: 0;
	background: 0;
	margin: 0;
	opacity: 0;
	visibility: hidden;
	outline: none;
}

/* item_checkbox - label */
#hnav .item_checkbox > label {
	position: relative;
	display: inline-block;
	color: #aaa;
	padding-left: 24px;
	cursor: pointer;
}
#hnav .item_checkbox > label:before {
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	display: block;
	width: 16px;
	height: 0;
	padding-top: 11px;
	overflow: hidden;
	background: url(../img/common/icon_checkbox.png) center top no-repeat;
	background-size: 100% auto;
	margin-top: -5.5px;
}
@media screen and (max-width: 640px) {
	#hnav .item_checkbox > label {
		font-size: 114.2%;
	}
}

/* item_checkbox - label (skin) */
#hnav .item_checkbox > input:checked + label {
	color: inherit;
	font-weight: bold;
}
#hnav .item_checkbox > input:checked + label:before {
	background-position: center bottom;
}

/* -- item_years -- */
/*#hnav .item_years {}*/

/* item_year */
/*#hnav .item_year {}*/

/* -- item_gsearch -- */
#hnav .item_gsearch {
	letter-spacing: -.4em;
}
/* item_textfield / item_textfield_button */
#hnav .item_gsearch .item_textfield,
#hnav .item_gsearch .item_textfield_button {
	display: inline-block;
	vertical-align: middle;
	letter-spacing: normal;
	line-height: 1;
}

/* item_textfield */
#hnav .item_gsearch .item_textfield {
	width: calc(100% - 50px);
}

/* item_textfield_button */
#hnav .item_gsearch .item_textfield_button {
	width: 44px;
	margin-left: 6px;
}

/* input */
#hnav .item_gsearch .item_textfield > input,
#hnav .item_gsearch .item_textfield_button > input {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	box-sizing: border-box;
	display: block;
	width: 100%;
	height: 38px;
	line-height: 38px;
	border-radius: 0;
	margin: 0;
	outline: none;
}

/* input */
#hnav .item_gsearch .item_textfield > input {
	padding: 0 5px;
	font-size: 85%;
	border: 1px solid #ccc;
}
#hnav .item_gsearch .item_textfield_button > input {
	display: block;
	width: 100%;
	text-align: center;
	font-size: 100%;
	color: #fff;
	background: #444;
	border: 0;
	cursor: pointer;
}


/*  item_textlinks
--------------------------------------------- */
#hnav .item_textlinks {
	border-top: 1px solid #ccc;
	margin: 12px 16px 0;
	padding-top: 12px;
}
@media screen and (max-width: 640px) {
	#hnav .item_textlinks {
		border-top-color: #222;
		padding: 14px;
		margin: 0;
	}
}

/* -- item_textlink -- */
#hnav .item_textlink {
	margin-top: 7px;
	line-height: 1;
}

/* -- item_textlink (skin) -- */
#hnav .item_textlink:first-child {
	margin-top: 0;
}

/* item_textlink_inner */
#hnav .item_textlink_inner {
	display: inline-block;
	/*font-size: 85.7%;*/
	font-size: 71.428%;

	white-space: nowrap;
	line-height: 1.3;
}
#hnav .item_textlink_inner:active {
	outline: 0;
}
#hnav .item_textlink_inner:hover {
	text-decoration: none;
}

/* item_textlink_inner (skin) */
#hnav .item_textlink.skin_target_blank .item_textlink_inner {
	padding-right: 18px;
	background: url(../img/common/icon_new_window.png) right center no-repeat;
}

.windows #hnav .item_textlink.skin_target_blank .item_textlink_inner {
	padding-right: 14px;
}

@media screen and (max-width: 640px) {
	#hnav .item_textlink_inner {
		font-size: 100%;
	}
}

/*  header_search
--------------------------------------------- */
#header_search {
	box-sizing: border-box;
	background-color: #fff;
	padding: 0 16px;
	position: relative;
}
#header_search:before {
	display: block;
	position: absolute;
	content: '';
	left: 0;
	top: -20px;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0.50, rgba(255,255,255,0)), color-stop(0.00, rgba(255,255,255,1)));
	background: -webkit-linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 50%);
	background: -moz-linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 50%);
	background: -o-linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 50%);
	background: -ms-linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 50%);
	background: linear-gradient(to bottom, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 50%);
	width: 100%;
	height: 20px;
}
/* -- item_button -- */
#header_search .item_button {
	display: block;
	width: 100%;
	text-align: center;
	color: #fff;
	font-size: 121.4%;
	line-height: 1;
	/*
	padding: 5.5px 0;
	*/
	padding: 10px 0 9px;
	background: #444;
	border: 0;
	border-radius: 0;
	margin: 0;
	outline: 0;
	cursor: pointer;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
.ie11 #header_search .item_button ,
.edge #header_search .item_button {
	padding: 9px 0 10px;
}
#header_search .item_button:hover {
	text-decoration: none;
}
#header_search .item_button-clear {
	background: #808080;
	/*font-size: 90%;*/
	/*
	padding: 3px 0 2px;
	padding: 8px 0 7px;
	*/
	padding: 9px 0 8px;
	margin-top: 10px;
}
.ie11 #header_search .item_button-clear ,
.edge #header_search .item_button-clear {
	padding: 8px 0 9px;
}
@media screen and (max-width: 640px) {
	#header_search {
		padding: 14px;
	}
	#header_search::after {
		content: "";
		display: block;
		clear: both;
	}
	#header_search .item_button {
		float: right;
		width: 55%;
	}
	#header_search .item_button-clear {
		float: left;
		width: 40%;
		padding: 10px 0 9px;
		margin-top: 0;
		font-size: 121.4%;
	}
	.ie11 #header_search .item_button-clear ,
	.edge #header_search .item_button-clear {
		padding: 9px 0 10px;
	}
}



/* ---------------------------------------------
*   main
--------------------------------------------- */
#main {
	position: relative;
	min-height: 100vh;
}
@media screen and (max-width: 640px) {
	#main {
		min-height: 0;
	}
}


/*  view
--------------------------------------------- */
#main > .view {
	z-index: -1;
	box-sizing: border-box;
	display: none;
	width: 92.686567164%;
	height: 100%;
	margin: 0 auto;
	opacity: 0;
}
@media screen and (max-width: 640px) {
	#main > .view {
		width: auto;
		height: auto;
	}
}


/*  view (skin)
--------------------------------------------- */
#main > .view.skin_current {
	z-index: 1;
	display: block;
	opacity: 1;
}



/* ---------------------------------------------
*   main (skin)
--------------------------------------------- */
.current_home #main {
	width: calc(100% - 150px); /* width: wrapper - header */
}


/* ---------------------------------------------
*   modal
--------------------------------------------- */
#modal {
	height: 100%;
	background-color: #fff;
	overflow: hidden;
}


/*  item_modal
--------------------------------------------- */
#modal .item_modal {
	position: relative;
	box-sizing: border-box;
	height: 100%;
	padding: 20px;
	overflow: hidden;
}
@media screen and (max-width: 640px) {
	#modal .item_modal {
		padding: 3.125%;
	}
}


/*  item_modal_inner
--------------------------------------------- */
#modal .item_modal_inner {
	position: relative;
	height: 100%;
	overflow: hidden;
}

/* -- malihu-custom-scrollbar-plugin (override) -- */
#modal .mCSB_scrollTools .mCSB_draggerRail {
	background: none;
}
#modal .mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar {
	background-color: #ccc;
	margin: 0 2px 0 10px;
}
#modal .mCSB_inside > .mCSB_container {
	margin-right: 0;
}
#modal .mCSB_scrollTools .mCSB_dragger {
	cursor: default;
}

/* -- item_closebutton -- */
#modal .item_closebutton {
	position: absolute;
	top: 0;
	right: 0;
	width: 20px;
	padding-top: 20px;
	background-image: url(../img/common/btn_close.png);
	cursor: pointer;
}

/* -- item_title -- */
#modal .item_title {
	padding-top: 20px;
	letter-spacing: -.4em;
	margin-bottom: 15px;
}
@media screen and (max-width: 640px) {
	#modal .item_title {
		padding-top: 5px;
	}
}

/* item_title_eng / item_title_jpn */
#modal .item_title_eng,
#modal .item_title_jpn {
	display: inline-block;
	vertical-align: bottom;
	letter-spacing: normal;
	line-height: 1;
}

/* item_title_eng */
#modal .item_title_eng {
	width: 132px;
	padding-top: 41px;
	background-image: url(../img/common/text_modal_title.png);
}
@media screen and (max-width: 640px) {
	#modal .item_title_eng {
		width: 75px;
		padding-top: 24px;
	}
}

/* item_title_jpn */
#modal .item_title_jpn {
	font-size: 171.4%;
	font-weight: bold;
	margin-left: 26px;
}
@media screen and (max-width: 640px) {
	#modal .item_title_jpn {
		font-size: 100%;
		margin-left: 13px;
	}
}

/* -- item_lead -- */
#modal .item_lead {
	margin-bottom: 10px;
}

/* -- item_panel -- */
#modal .item_panel {

}

/* -- item_panel_inner -- */
#modal .item_panel_inner {
	padding: 20px 20px 10.094339622%;
	overflow: hidden;
	background-color: #f1f1f1;
}
@media screen and (max-width: 640px) {
	#modal .item_panel_inner {
		padding: 3.125%;
	}
}

/* item_panel_left / item_panel_center / item_panel_right */
#modal .item_panel_left,
#modal .item_panel_center,
#modal .item_panel_right {
	float: left;
	box-sizing: border-box;
	width: 31.372549019%;
}
#modal .item_panel_center,
#modal .item_panel_right {
	margin-left: 2.884615384%;
}
@media screen and (max-width: 640px) {
	#modal .item_panel_left,
	#modal .item_panel_center,
	#modal .item_panel_right {
		float: none;
		width: auto;
	}
	#modal .item_panel_center,
	#modal .item_panel_right {
		margin: 35px 0 0;
	}
}

/* item_links */
#modal .item_links {
	margin-top: 50px;
}
@media screen and (max-width: 640px) {
	#modal .item_links {
		margin-top: 35px;
	}
}

/* item_links */
#modal .item_links:first-child {
	margin-top: 0;
}

/* item_links_title */
#modal .item_links_title {
	font-size: 171.4%;
	font-weight: bold;
	margin-bottom: 11px;
}
@media screen and (max-width: 640px) {
	#modal .item_links_title {
		font-size: 128%;
		margin-bottom: 5px;
	}
}

/* item_link */
#modal .item_link {
	padding: 12px 10px 0;
}
@media screen and (max-width: 640px) {
	#modal .item_link {
		padding: 5px;
	}
}

/* item_link (skin) */
#modal .item_link:nth-child(2) {
	border-top: 1px solid #797979;
}

/* item_link_inner */
#modal .item_link_inner {
	display: block;
}

/* item_link_text */
#modal .item_link_text {
	font-size: 114.2%;
}
#modal .item_link_text:hover {
	text-decoration: none;
}
@media screen and (max-width: 640px) {
	#modal .item_link_text {
		font-size: 100%;
	}
}

/* ---------------------------------------------
*   faq
--------------------------------------------- */
#faq {
	height: 100%;
	background-color: #fff;
	overflow: hidden;
}


/*  item_faq
--------------------------------------------- */
#faq .item_faq {
	position: relative;
	box-sizing: border-box;
	height: 100%;
	padding: 20px;
	overflow: hidden;
}
@media screen and (max-width: 640px) {
	#faq .item_faq {
		padding: 3.125%;
	}
}


/*  item_faq_inner
--------------------------------------------- */
#faq .item_faq_inner {
	position: relative;
	height: 100%;
	overflow: hidden;
}

/* -- malihu-custom-scrollbar-plugin (override) -- */
#faq .mCSB_scrollTools .mCSB_draggerRail {
	background: none;
}
#faq .mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar {
	background-color: #ccc;
	margin: 0 2px 0 10px;
}
#faq .mCSB_inside > .mCSB_container {
	margin-right: 0;
}
#faq .mCSB_scrollTools .mCSB_dragger {
	cursor: default;
}

/* -- item_closebutton -- */
#faq .item_closebutton {
	position: absolute;
	top: 0;
	right: 0;
	width: 20px;
	padding-top: 20px;
	background-image: url(../img/common/btn_close.png);
	cursor: pointer;
}

/* -- item_title -- */
#faq .item_title {
	padding-top: 20px;
	letter-spacing: -.4em;
	margin-bottom: 15px;
}
@media screen and (max-width: 640px) {
	#faq .item_title {
		padding-top: 5px;
	}
}

/* item_title_eng / item_title_jpn */
#faq .item_title_eng,
#faq .item_title_jpn {
	display: inline-block;
	vertical-align: bottom;
	letter-spacing: normal;
	line-height: 1;
}

/* item_title_eng */
#faq .item_title_eng {
	width: 108px;
	padding-top: 46px;
	margin-bottom: -5px;
	background-image: url(../img/common/text_faq_title.png);
}
@media screen and (max-width: 640px) {
	#faq .item_title_eng {
		width: 75px;
		padding-top: 35px;
	}
}

/* item_title_jpn */
#faq .item_title_jpn {
	font-size: 171.4%;
	font-weight: bold;
	margin-left: 26px;
}
@media screen and (max-width: 640px) {
	#faq .item_title_jpn {
		font-size: 100%;
		margin-left: 13px;
	}
}

/* -- item_link -- */
#faq .item_link {
	margin-top: 2.4em;
	margin-bottom: 1em;
}
#faq .item_link li {
	display: inline-block;
	margin-right: 2em;
}

/* -- item_panel -- */
#faq .item_panel {
}

/* -- item_panel_inner -- */
#faq .item_panel_inner {
	padding: 20px 20px 40px;
	overflow: hidden;
	background-color: #f1f1f1;
}
@media screen and (max-width: 640px) {
	#faq .item_panel_inner {
		padding: 3.125%;
	}
}
/* -- item_block -- */
#faq .item_block {
	margin-bottom: 3.5em;
}
#faq .item_block:last-child {
	margin-bottom: 0;
}
@media screen and (max-width: 640px) {
	#faq .item_block {

	}
}
/* -- item_heading -- */
#faq .item_heading {
	font-size: 121.4%;
	font-weight: bold;
	margin-bottom: 1em;
}
@media screen and (max-width: 640px) {
	#faq .item_heading {
		font-size: 100%;
	}
}
/* item_content */
#faq .item_content {
	font-size: 100%;
}
@media screen and (max-width: 640px) {
	#faq .item_content {
		font-size: 100%;
	}
}
#faq .item_content p {
	margin-bottom: 1.0em;
	line-height: 1.9;
}
#faq .item_content ol {
	margin-bottom: 1.0em;
	list-style-type: decimal;
	margin-left: 1.5em;
	line-height: 1.75;
}
#faq .item_content ol li {
	margin-bottom: 1.0em;
}
#faq .item_content ol li:last-child {
	margin-bottom: 0;
}
#faq .item_content>*:last-child {
	margin-bottom: 0;
}
@media screen and (max-width: 640px) {
	#faq .item_content {

	}
	#faq .item_content p {

	}
}


/* item_link_inner */
#faq .item_link_inner {
	display: block;
}



/*  colorbox (override)
--------------------------------------------- */
#cboxOverlay {
	z-index: 99999;
	background-color: #000;
}
#colorbox {
	z-index: 99999;
}
#cboxContent {
	margin-top: 0;
}
#cboxLoadedContent {
	padding: 0;
}
#cboxTopLeft,
#cboxTopCenter,
#cboxTopRight,
#cboxMiddleLeft,
#cboxMiddleRight,
#cboxBottomLeft,
#cboxBottomCenter,
#cboxBottomRight {
	display: none !important;
	width: 0 !important;
	height: 0 !important;
}



/* ---------------------------------------------
*   footer
--------------------------------------------- */
#footer {
	position: fixed;
	right: 0;
	bottom: 0;
	z-index: 10000;
	width: calc(100% - 150px); /* width: 100% - width of header; */
	padding: 30px 0;
	background-color: #f6f6f6;
}
@media screen and (max-width: 640px) {
	#footer {
		position: static;
		box-sizing: border-box;
		width: 100%;
		padding: 10px 7.5% 15px;
		background-color: #fff;
	}
}



/* ---------------------------------------------
*   footer (skin)
--------------------------------------------- */
.skin_current_home #footer {
	right: 150px;
	width: calc(100% - 300px); /* width: 100% - width of header; */
	padding: 2px 0;
	background-color: #fff;
}
@media screen and (max-width: 640px) {
	.skin_current_home #footer {
		box-sizing: border-box;
		width: 100%;
		padding: 10px 7.5% 15px;
	}
}


/*  item_textlinks
--------------------------------------------- */
/*#footer .item_textlinks {}*/

/* -- item_textlink -- */
#footer .item_textlink {
	border-top: 1px solid #ccc;
}
@media screen and (max-width: 640px) {
	#footer .item_textlink:first-child {
		border-top-width: 0;
	}
}

/* item_textlink_inner */
#footer .item_textlink_inner {
	display: block;
	text-align: center;
	font-size: 114.2%;
	padding: 10.5px 0;
}
#footer .item_textlink_inner:focus {
	outline: 0;
}
#footer .item_textlink_inner:hover {
	text-decoration: none;
}


/*  pagetop
--------------------------------------------- */
.footer_pagetop {
	position: absolute;
	top: 50%;
	right: 25px;
	width: 50px;
	margin-top: -24px;
}
@media screen and (max-width: 640px) {
	.footer_pagetop {
		position: static;
		width: auto;
		margin-top: 0;
	}
}


/*  pagetop
--------------------------------------------- */
.skin_current_home #footer .footer_pagetop {
	display: none;
}
@media screen and (max-width: 640px) {
	.skin_current_home #footer .footer_pagetop {
		display: block;
		margin-top: 8px;
	}
}

/* -- item_pagetop -- */
#pagetop {
	padding-top: 50px;
	background-image: url(../img/common/btn_pagetop.png);
}
#pagetop:hover {
	text-decoration: none;
}
@media screen and (max-width: 640px) {
	#pagetop {
		height: auto;
		text-align: center;
		font-size: 114.2%;
		padding: 4px 0 5px;
		border: 1px solid #222;
		background: #fff;
	}
}


/*  footer_copyright
--------------------------------------------- */
.footer_copyright {
	text-align: center;
}
@media screen and (max-width: 640px) {
	.footer_copyright {
		margin-top: 17px;
	}
}

/* -- item_copyright -- */
.footer_copyright .item_copyright {
	font-size: 85.7%;
}
@media screen and (min-width: 641px) and (max-width: 750px) {
	.footer_copyright .item_copyright {
		font-size: 70%;
	}
}
@media screen and (max-width: 640px) {
	.footer_copyright .item_copyright {
		display: inline-block;
		line-height: 1.75;
	}
}

/* -- item_copyright (skin) -- */
.skin_current_home #footer .item_copyright {
	font-size: 78.5%;
	font-family: 'Helvetica';
}
@media screen and (min-width: 641px) and (max-width: 750px) {
	.skin_current_home #footer .item_copyright {
		font-size: 70%;
	}
}
@media screen and (max-width: 640px) {
	.skin_current_home #footer .item_copyright {
		font-size: 85.7%;
	}
}