@charset "utf-8";

.spFootUtility,
.spFootLang {
	display: none;
}
.gSearch iframe {
    width: 100%;
}

/********************************************************* hamburger menu*/
#hamburger {
	display: none;
	width: 32px;
	float: right;
}
#hamburger-icon {
	margin-top: 5px;
    width: 32px;
    height: 20px;
    position: relative;
    display: block;
    line-height: 1;
	cursor: pointer;
}
#hamburger-icon .line {
	display: block;
	background: #b7190c;
	width: 32px;
	height: 4px;
	position: absolute;
	left: 0;
	transition: all 0.4s;
	-webkit-transition: all 0.4s;
	-moz-transition: all 0.4s;
}
#hamburger-icon .line.line-1 {
	top: 0;
}
#hamburger-icon .line.line-2 {
	top: 50%;
}
#hamburger-icon .line.line-3 {
	top: 100%;
}
#hamburger-icon.active .line-1 {
	transform: translateY(10px) translateX(0) rotate(45deg);
	-webkit-transform: translateY(10px) translateX(0) rotate(45deg);
	-moz-transform: translateY(10px) translateX(0) rotate(45deg);
}
#hamburger-icon.active .line-2 {
	opacity: 0;
}
#hamburger-icon.active .line-3 {
	transform: translateY(-10px) translateX(0) rotate(-45deg);
	-webkit-transform: translateY(-10px) translateX(0) rotate(-45deg);
	-moz-transform: translateY(-10px) translateX(0) rotate(-45deg);
}

@media screen and (max-width: 1004px) {
/*共通 --------------------------------------------------------*/
html {
	background-color: #fff;
}
body {
	background-image: none;
}
#hamburger {
	display: block;
}
.section-inSide {
	width: auto;
}
.utilityNav {
	padding: 5px 10px;
    background: #f1f1f1;
	margin: 0;
	width: auto;
}
.utilityNav .print {
	display: none;
}
.breadcrumbs {
	float: none;
	width: auto;
	height: auto;
	overflow: hidden;
}
.breadcrumbs li {
	font-size: 10px;
}
#main h1 {
	margin-top: 15px;
	font-size: 24px;
}
#main h2 {
	padding-left: 10px;
	font-size: 18px;
}
#main .box_b {
	padding: 0 0 15px 0;
}
#main img {
	max-width: 100%;
	height: auto;
}
.galleryNav {
	text-align: center;
}
.galleryItem > div {
	float: none !important;
	text-align: center;
	margin-bottom: 20px;
	width: auto !important;
}
.galleryItem > div h3 {
	text-align: left;
}
#main .fr,
#main .fl {
	float: none;
}
img.fl {
	margin: 0 0 20px 0;
}
.overFlow {
	overflow-x: scroll;
}
.onePhoto {
	float: none !important;
	width: auto !important;
	text-align: center !important;
	margin: 0 0 20px 0 !important;
}
.manyPhoto {
	text-align: center;
}
.manyPhoto img {
	margin: 0 0 20px 0 !important;
}

/*ヘッダー --------------------------------------------------------*/
#header {
	position: relative;
	box-sizing: border-box;
	height: auto;
	background: none;
	border-top: 2px solid #ae945b;
	border-bottom: 1px solid #b7190c;
	padding: 5px 10px;
	background-color: #F8F8F8;
}
#header .section-inSide {
	height: auto;
	position: static;
}
#header .section-inSide h1 {
	position: static;
	float: left;
}
#header .section-inSide h1 img {
	width: auto;
    height: 35px;
}
#header .section-inSide .utility-Nav,
#header .section-inSide .language-Nav,
#header .section-inSide form {
	display: none;
}
#navWrap {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    z-index: 100;
}
.navopen #navWrap {
	display: block;
}
#header .section-inSide .gNav_sub,
#header .section-inSide .gNav {
    width: auto;
    position: static;
    left: auto;
    top: auto;
}
#header .section-inSide .gNav_sub li,
#header .section-inSide .gNav > li {
	float: none;
	display: block;
    border-bottom: 1px solid #fff;
}
#header .section-inSide .gNav_sub li a,
#header .section-inSide .gNav > li a {
    display: block !important;
    width: auto !important;
	height: auto !important;
    text-align: left;
    font-weight: normal !important;
	text-indent: 0 !important;
	
	color: #fff !important;
    float: none !important;
    background: #b7190c !important;
    padding: 12px 15px;
    position: relative;
	font-family: Trajan Pro, Georgia, "Times New Roman", Times, serif;
	font-variant: small-caps;
    font-size: 15px;
    letter-spacing: 1px;
}
#header .section-inSide .gNav_sub li a {
	color: #333 !important;
	background: #ccc !important;
}
#header .section-inSide .gNav_sub li a:after,
#header .section-inSide .gNav > li a:after {
    position: absolute;
    content: '';
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg);
    width: 8px;
    height: 8px;
    top: 0;
    bottom: 0;
    right: 15px;
    margin: auto;
}
#header .section-inSide .gNav_sub li a:after {
	border-color: #333;
}
#header .section-inSide .gNav > li > ul {
	display: none !important;
	width: auto;
	position: static;
	padding: 0 !important;
}
#header .section-inSide .gNav > li > ul li {
	margin-bottom: 0;
}

/*コンテンツ --------------------------------------------------------*/
.derivationContents {
	background: none;
}
#contents, #content {
	width: auto;
    padding: 0 !important;
	margin: 0;
}
#contents #mainColumn, #contents #main, #content #main,
#contents #subColumn, #contents #sub, #content #sub {
	float: none;
	width: auto;
	margin: 0;
}
#main {
	padding: 15px;
	min-height: 0 !important;
}
#sub {
	padding: 40px 15px 15px 15px;
}
ul#subMenu {
	margin-bottom: 20px;
}

/*ページトップ --------------------------------------------------------*/
.pageTop {
    width: auto;
    margin: 0;
	padding: 0;
	text-align: center;
	background-color: transparent;
	position: fixed;
	right: 5px;
	bottom: 5px;
	z-index: 1000;
}
.pageTop a {
	float: none;
	display: block;
	width: 25px;
	height: 25px;
	background-color: #b7190c;
	border-radius: 50%;
	border: 1px solid #fff;
}
.pageTop a img {
	display: none;
}
.pageTop a:after {
    position: absolute;
    content: '';
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    transform: rotate(-45deg);
    width: 8px;
    height: 8px;
    top: 10px;
	left: 0;
    right: 0;
    margin: auto;
}

/*Utility --------------------------------------------------------*/
.spFootUtility {
	border-top: 1px solid #ccc;
	display: block;
	padding: 15px;
	overflow: hidden;
}
.spFootUtility input {
	-webkit-appearance: none;
	padding: 5px;
	display: block;
	float: left;
	box-sizing: border-box;
	border-radius: 0;
}
.spFootUtility input[type="search"] {
	width: 70%;
	height: 30px;
	border: 1px solid #ccc;
}

.spFootUtility input.searchtext {
	width: 70%;
	height: 30px;
	border: 1px solid #ccc;
}

.spFootUtility input[type="submit"] {
	width: 30%;
	height: 30px;
	color: #fff;
	background-color: #b7190c;
	border: none;
}

.spFootLang {
	display: block;
	padding: 15px;
	background-color: #fff;
}
.spFootLang h2 {
	text-align: center;
	margin-bottom: 10px;
	font-size: 13px;
	font-weight: normal;
	letter-spacing: 1px;
	font-family: Trajan Pro, Georgia, "Times New Roman", Times, serif;
}

.listLang {
	text-align: center;
}
.listLang li {
	display: inline-block;
	vertical-align: middle;
	margin: 0 5px;
}
.listLang a {
	display: inline-block;
	color: #000;
}
.listLang .ja a {
	background: url(/global/images/icon_lang_ja.png) no-repeat left center;
	padding-left: 20px;
	line-height: 20px;
}
.listLang .en a {
	background: url(/global/images/icon_lang_en.gif) no-repeat left center;
	padding-left: 20px;
	line-height: 20px;
}
.listLang .cn a {
	background: url(/global/images/icon_lang_cn.gif) no-repeat left center;
	padding-left: 20px;
	line-height: 20px;
}
.listLang .ko a {
	background: url(/global/images/icon_lang_ko.gif) no-repeat left center;
	padding-left: 20px;
	line-height: 20px;
}

/*フッター --------------------------------------------------------*/
#footer {
	margin-top: 0;
	height: auto;
	position: static;
	text-align: center;
}
#footer .section-inSide .infomation {
	height: auto;
	padding: 30px 15px;
}
#footer .section-inSide .infomation .socialGroup {
	float: none;
	padding-top: 0;
	margin-bottom: 20px;
}
#footer .section-inSide .infomation .socialGroup li {
	display: inline-block;
	margin: 0 5px 5px 5px;
}
#footer .section-inSide .infomation p {
}
#footer .section-inSide .infomation .logo {
	margin-bottom: 20px;
	float: none;
}
#footer .section-inSide .infomation .logo img {
	max-width: 250px;
	height: auto;
}
#footer .section-inSide .infomation .center {
	margin: 0;
	float: none;
	width: auto;
}
#footer .section-inSide .infomation .center img {
	max-width: 250px;
	height: auto;
}
#footer .section-inSide .infomation .center span {
	font-size: 22px;
}
#footer .section-inSide .infomation .copy {
	padding-top: 20px;
}
#footer .section-inSide .footerNav,
#footer .section-inSide .footerNav-secondStage {
	width: auto;
    margin: 0;
    padding: 0;
	display: flex;
    display: -webkit-flex;
    flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    border-top: 1px solid #fff;
    margin-bottom: -1px;
	background-color: #eee;
}
#footer .section-inSide .footerNav li,
#footer .section-inSide .footerNav-secondStage li {
    border-left: none !important;
	border-right: none !important;
    padding: 0 !important;
    float: none;
	border-bottom: 1px solid #fff;
    margin: 0;
    width: 50%;
    box-sizing: border-box;
	display: block;
}
#footer .section-inSide .footerNav li:nth-child(odd),
#footer .section-inSide .footerNav-secondStage li:nth-child(odd) {
	border-right: 1px solid #fff !important;
}
#footer .section-inSide .footerNav li a,
#footer .section-inSide .footerNav-secondStage li a {
	display: block;
    padding: 10px 20px 10px 10px;
    background-color: #eee;
    font-weight: normal !important;
    font-size: 12px;
    text-align: left;
    position: relative;
	color: #000;
}
#footer .section-inSide .footerNav li a:before,
#footer .section-inSide .footerNav-secondStage li a:before {
    content: '';
    border-top: 1px solid #333;
    border-right: 1px solid #333;
    width: 6px;
    height: 6px;
    transform: rotate(45deg);
    position: absolute;
    top: 13px;
    right: 10px;
}
#footer .section-inSide {
	height: auto;
}

/*シェアボタン --------------------------------------------------------*/
.home #shareon {
	margin-top: 0;
}
#shareon {
	margin: 0;
	width: auto;
	position: static;
	height: auto !important;
	background: #fff;
	border-top: 1px solid #ccc;
	padding-top: 15px;
	z-index: auto;
}
#shareon h3 {
	background: none;
	width: auto;
	height: auto;
	text-align: center;
	text-indent: 0;
	font-family: Trajan Pro, Georgia, "Times New Roman", Times, serif;
	font-variant: small-caps;
	letter-spacing: 1px;
	font-size: 14px;
	font-weight: normal;
	z-index: auto;
	line-height: 1.3;
}
#shareon #shareon_inner {
	position: static;
	width: auto;
	height: auto;
	padding: 15px;
	background-color: transparent;
}
#shareon #shareon_inner ul {
	padding: 0;
	margin: 0 -2px;
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
}
#shareon #shareon_inner ul li {
	width: 50%;
	padding: 0 2px;
	box-sizing: border-box;
}
#shareon #shareon_inner ul li a {
	position: static !important;
	width: auto !important;
	height: auto !important;
	color: #fff !important;
	text-align: center;
	margin: 0 !important;
	display: block;
	float: none;
	padding: 10px 15px;
	text-indent: 0;
	font-size: 13px;
}
#shareon #shareon_inner ul li#facebook a {
	background-image: none !important;
	background: rgb(0, 0, 51);
}
#shareon #shareon_inner ul li#twitter a {
	background-image: none !important;
	background: rgb(51, 102, 204);
}

/*CMS --------------------------------------------------------*/
.articleDetail #main div {
	width: auto !important;
}
.articleDetail #main img {
	box-sizing: border-box;
}
}
