@charset "utf-8";

/* 足跡を非表示 */
#footstep_wrap {
	display: none !important;
}

/* 画像 */
a:hover img {
	opacity: 1;
}

/* 背景 */
body {
	background: #000;
	color: #fff;
}

#container {
	min-height: 100vh;
	overflow: hidden;
}
#container a {
	color: inherit;
}

/* ヘッダ */
#header {
	position: relative;
	z-index: 40;
}

#top_search {
	display: none;
}

#front_header_link {
	position: fixed;
	top: 10px;
	right: 20px;
	z-index: 42;
	width: 680px;
	text-align: right;
}

#header_link > li > a,
#header_link > li > #readspeaker_button1 > a {
	color: inherit;
	text-shadow: 0px 0px 3px #000, 0px 0px 3px #000, 0px 0px 3px #000, 0px 0px 3px #000, 0px 0px 3px #000;
}
#header_link > li#hl_support > a {
	background-image: url(/img/front/icon_h_support.png);
}
#header_link > li#hl_voice > a,
#header_link > li#hl_voice > #readspeaker_button1 > a {
	background-image: url(/img/front/icon_h_voice.png);
}
#header_link > li#hl_lang > a {
	background-image: url(/img/front/icon_h_lang.png);
}
#header_link > li#hl_mypage > a {
	background-image: url(/img/front/icon_h_mypage.png);
}

.box_hl {
	color: #333;
}

/* ロゴ */
#front_header {
	position: fixed;
	left: 50%;
	top: calc(50% - 30px);
	-webkit-transform: translate(-50%,-50%);
		-ms-transform: translate(-50%,-50%);
			transform: translate(-50%,-50%);
	z-index: 41;
	width: 950px;
	min-height: 226px;
	background: rgba(0,0,0,0.6);
	color: #fff;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
	padding-left: 200px;
}

#logo {
	width: 200px;
	height: 100%;
	background: #fff;
	color: #333;
	margin: 0px;
	position: absolute;
	top: 0px;
	left: 0px;
}
#logo a {
	display: block;
}
#logo img {
	width: 100%;
	height: auto;
}

/* 検索 */
#front_search_open {
	position: fixed;
	left: 20px;
	bottom: 70px;
	z-index: 43;
	border: none;
	background: url(/img/front/logo2.png) no-repeat left center rgba(0,0,0,0.6);
	border-radius: 0px 5px 5px 0px;
	color: #fff;
	font-weight: bold;
	margin: 0px;
	padding: 8px 20px 8px 78px;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
	min-height: 50px;
}
#front_search_open span {
	display: block;
	background: url(/img/common/icon_search.png) no-repeat right center transparent;
	color: inherit;
	padding: 5px 35px 5px 0px;
}

#front_search_close {
	position: absolute;
	top: -10px;
	right: 0px;
	width: 20px;
	height: 20px;
	border: none;
	background: url(/img/front/icon_close.png) no-repeat center center #fff;
	color: #333;
	border-radius: 100%;
	text-align: left;
	text-indent: -9999em;
	overflow: hidden;
	margin: 0px;
	padding: 0px;
}

#top_search_form {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: nowrap;
		flex-wrap: nowrap;
	-webkit-box-pack: justify;
		-ms-flex-pack: justify;
			justify-content: space-between;
	padding: 25px 30px 20px;
	min-height: 111px;
}
#top_search_form > div {
	display: inline-block;
	vertical-align: top;
}

#top_search_keyword {
	width: calc(100% - 300px);
	padding: 0px;
}
#cse-search-box label {
	color: inherit;
	font-size: 1.8rem;
	margin-bottom: 10px;
}
#cse-search-box .cse_select_cat {
	display: inline-block;
	vertical-align: middle;
	width: 118px;
	margin-right: 2px;
}
#cse-search-box .cse_select_cat label {
	display: none;
}

#google_category {
	display: inline-block;
	vertical-align: middle;
	width: 118px;
	height: 40px;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
	border: none;
	border-radius: 5px 0px 0px 5px;
	padding-left: 5px;
}
#tmp_query {
	width: calc(100% - 170px) !important;
	border-radius: 0px;
}
#submit {
	width: 51px;
}

#cse_filetype fieldset {
	margin: 10px 0px 0px;
	font-size: 1.5rem;
}
#cse_filetype fieldset span input {
	margin-top: -1px;
}

#top_search_page_id_wrap {
	width: 280px;
	padding: 0px;
}
#top_search_page_id_wrap label {
	color: inherit;
	font-size: 1.8rem;
	margin-bottom: 10px;
}

#open_page_id {
	width: calc(100% - 50px);
}
#open_page_id_submit {
	width: 51px;
}

/* よくあるワード */
#search_trend_word {
	background: #000;
	color: #fff;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: nowrap;
		flex-wrap: nowrap;
	-webkit-box-pack: justify;
		-ms-flex-pack: justify;
			justify-content: space-between;
	-webkit-box-align: center;
		-ms-flex-align: center;
			align-items: center;
	padding: 15px 30px;
	min-height: 40px;
	position: relative;
}
#search_trend_word:after {
	content: '';
	display: block;
	width: 0px;
	height: 0px;
	border: 15px solid transparent;
	border-top-width: 0px;
	border-bottom-color: #000;
	position: absolute;
	top: -15px;
	left: 155px;
}

#search_trend_word_ttl {
	display: inline-block;
	vertical-align: middle;
	width: 140px;
	font-size: 1.5rem;
}

#search_trend_word p {
	display: inline-block;
	vertical-align: middle;
	width: calc(100% - 140px);
	margin: 0px;
	max-height: calc(1em + 26px);
	overflow: hidden;
}
#search_trend_word p a {
	display: inline-block;
	vertical-align: middle;
	margin: 5px;
	border: 1px solid #8ea1ab;
	background: #fff;
	border-radius: 5px;
	color: #069;
	font-size: 1.5rem;
	text-decoration: none;
	padding: 3px 10px;
	cursor: pointer;
}
#search_trend_word p a:hover {
	color: #333;
	text-decoration: underline;
}

/* メイン */
#mymainback {
	position: relative;
	z-index: 30;
	width: auto;
	max-width: none;
	margin: 0px;
}

/* 重要なお知らせ */
#top_important {
	position: fixed;
	top: 20px;
	left: 20px;
	z-index: 31;
	width: calc(100vw - 740px);
	min-width: 540px;
	max-width: 880px;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
	padding: 12px 27px;
	border: 3px solid #bd0000;
	background: #fff;
	color: #b41f1d;
}
#top_important h2 {
	margin: 0px;
	padding: 1px 0px 7px;
	font-size: 1.8rem;
}

#top_important .link_box {
	position: absolute;
	top: 7px;
	right: 27px;
}
#top_important .link_box > span {
	display: inline-block;
	vertical-align: middle;
	margin-left: 20px;
}
#top_important .link_box > span a {
	display: inline-block;
	color: #333;
	padding: 3px 0px 3px 20px;
	position: relative;
}
#top_important .link_box > span a:after {
	content: '';
	display: block;
	width: 10px;
	height: 10px;
	border: 2px solid #841d23;
	border-left: none;
	border-bottom: none;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
	position: absolute;
	left: 0px;
	top: 50%;
	-webkit-transform: translateY(-50%) rotate(45deg);
		-ms-transform: translateY(-50%) rotate(45deg);
			transform: translateY(-50%) rotate(45deg);
}

#top_important ul {
	margin: 0px;
	padding: 0px;
	list-style: none;
	max-height: 80px;
	overflow: auto;
}
#top_important ul li {
	padding: 3px 0px;
	width: 100%;
	display: table;
}
#top_important ul li > span {
	display: table-cell;
	vertical-align: top;
}
#top_important ul li > span.article_date {
	width: 11em;
}
#top_important ul li a {
	color: #b41f1d;
}

/* メニュー */
#front_menu {
	position: fixed;
	right: 20px;
	left: 20px;
	bottom: 70px;
	z-index: 32;
	text-align: right;
}
#front_menu ul {
	margin: 0px;
	padding: 0px;
	list-style: none;
}
#front_menu ul li {
	display: inline-block;
	vertical-align: bottom;
	width: 200px;
	margin-left: 10px;
}
#front_menu ul li a {
	display: block;
}
#front_menu ul li a img {
	width: 100%;
	height: auto;
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	transition: 0.5s;
}
#front_menu ul li a:hover img {
	-webkit-transform: scale(1.1, 1.1);
		-ms-transform: scale(1.1, 1.1);
			transform: scale(1.1, 1.1);
}
#front_menu ul li img {
	width: 100%;
	height: auto;
}
/* フッタ */
#footer {
	position: fixed;
	right: 20px;
	bottom: 20px;
	z-index: 10;
	margin-top: 0px;
	width: 500px;
	text-align: right;
}
#copyright p {
	margin: 0px;
	text-shadow: 0px 0px 3px #000, 0px 0px 3px #000, 0px 0px 3px #000, 0px 0px 3px #000, 0px 0px 3px #000;
}

/* スライドコントロールボタン */
#slide_control_box {
	position: fixed;
	left: 20px;
	bottom: 20px;
	z-index: 20;
}
#slide_control_box button[id^="slide_control_"] {
	display: inline-block;
	vertical-align: middle;
	width: 26px;
	height: 26px;
	border: none;
	background-color: transparent;
	background-repeat: no-repeat;
	background-position: center center;
	color: inherit;
	margin: 0px 5px 0px 0px;
	padding: 0px;
	text-align: left;
	text-indent: -9999em;
	overflow: hidden;
}
#slide_control_box button#slide_control_prev {
	background-image: url(/img/front/btn_slide_prev.png);
}
#slide_control_box button#slide_control_next {
	background-image: url(/img/front/btn_slide_next.png);
}
#slide_control_box button#slide_control_pause {
	width: 57px;
	background-image: url(/img/front/btn_slide_stop.png);
}
#slide_control_box button#slide_control_play {
	display: none;
	width: 57px;
	background-image: url(/img/front/btn_slide_start.png);
}

/* スライド */
#front_photo {
	position: fixed;
	top: 0px;
	left: 0px;
	z-index: -1;
	width: 100%;
	height: 100vh;
	overflow: hidden;
}
#front_photo img {
	width: auto;
	height: auto;
	min-width: 100%;
	min-height: 100%;
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%,-50%);
		-ms-transform: translate(-50%,-50%);
			transform: translate(-50%,-50%);
}
#front_photo .photo_caption {
	display: block;
	position: absolute;
	bottom: 20px;
	left: 150px;
	text-shadow: 0px 0px 3px #000, 0px 0px 3px #000, 0px 0px 3px #000, 0px 0px 3px #000, 0px 0px 3px #000;
	width: calc(100vw - 700px);
}
.slick-slider,
.slick-list,
.slick-track {
	height: 100vh;
}


/* 背景色変更時 */
.color_change #front_photo {
	z-index: auto !important;
}


/* タブレット */
/* 横1279px以下 */
@media screen and (max-width: 1279px) {

	#front_header {
		top: calc(50% - 80px);
	}
	#front_header_link {
		position: relative;
		top: 0px;
		right: 0px;
		width: auto;
		padding: 10px 20px 10px 100px;
	}

	#top_important {
		position: relative;
		width: calc(100% - 40px);
		top: 0px;
	}

	#front_menu {
		bottom: 120px;
	}

	#footer {
		width: calc(100% - 40px);
		bottom: 60px;
	}
	#copyright {
		margin-left: 200px;
		margin-right: 0px;
	}

	#front_photo .photo_caption {
		width: calc(100% - 175px);
	}

}
/* 横949px以下 */
@media screen and (max-width: 949px) {

	#front_header {
		width: calc(100% - 40px);
	}

	#top_search_form {
		display: block;
		min-height: 1px;
	}
	#top_search_form > div {
		display: block;
	}
	#top_search_keyword {
		width: auto;
	}

	#front_menu {
		bottom: 150px;
	}
	#front_menu ul {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: nowrap;
			flex-wrap: nowrap;
		-webkit-box-pack: center;
			-ms-flex-pack: center;
				justify-content: center;
		-webkit-box-align: end;
			-ms-flex-align: end;
				align-items: flex-end;
	}
	#front_menu ul li {
		width: calc(25% - 10px);
		margin: 0px 5px;
	}
}
/* 縦760px以下 */
@media screen and (max-height: 760px) {

	#container {
		min-height: 760px;
		position: relative;
	}
	#mymainback {
		position: static;
	}

	#front_header {
		position: absolute;
	}

	#front_header_link {
		position: absolute;
	}

	#top_important {
		position: absolute;
	}

	#front_menu {
		position: absolute;
	}

	#footer {
		position: absolute;
	}

}
/* 横1280px以上、縦760px以下 */
@media screen and (min-width: 1280px) and (max-height: 760px) {

	#front_header {
		position: absolute;
		top: 180px;
		-webkit-transform: translateX(-50%);
			-ms-transform: translateX(-50%);
				transform: translateX(-50%);
	}

}
/* 横1279px以下、縦760px以下 */
@media screen and (max-width: 1279px) and (max-height: 760px) {

	#front_header {
		top: 200px;
		-webkit-transform: translateX(-50%);
			-ms-transform: translateX(-50%);
				transform: translateX(-50%);
	}

	#front_header_link {
		position: relative;
	}

	#top_important {
		position: relative;
	}
	#top_important ul {
		max-height: 55px;
	}

}
/* 横949px以下、縦760px以下 */
@media screen and (max-width: 949px) and (max-height: 760px) {

	#front_header {
		top: 180px;
		-webkit-transform: translateX(-50%);
			-ms-transform: translateX(-50%);
				transform: translateX(-50%);
	}

	#top_important {
		position: relative;
	}
	#top_important ul {
		max-height: 30px;
	}

	#front_menu {
		bottom: 90px;
	}

	#footer {
		bottom: 50px;
	}

}
/* タブレット ここまで */