@charset "utf-8";

/* ------------------------------------------------------------

	base style

------------------------------------------------------------ */

* {
	margin: 0;
	padding: 0;
}

html {
	height: 100%;
}

body {
	height: 100%;
	color: #000000;
	font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 75%;
	text-align: center;
	background: url("../images/bg_white_gray.png") repeat-y center top;
	background-color: white;
}


/* ---------- fontsize Except IE ---------- */

:root *> body {
	font-size: 12px;
}

/* ---------- for Firefox2 ---------- */

body, x:-moz-any-link {
	font-size: 12px;
}


a:link {
	color: #0000EE;
	text-decoration: none;
}

a:visited {
	color: #551A8B;
	text-decoration: none;
}

a:active {
	color: #3399CC;
	text-decoration: underline;
}

a:hover {
	color: #3399CC;
	text-decoration: underline;
}

a:focus {
	outline: none;
}

/* font default */

h1, h2, h3, h4, h5, h6 {
	font-size: 100%;
}

p, address {
	font-size: 100%;
	font-style: normal;
	line-height: 1.85em;
}
#contents p {
	font-size: 110%;
}

/* list default */

ol, ul {
	list-style: none;
}

ul, ol, dl {
	font-size: 100%;
	line-height: 1.85em;
}
#contents ul,
#contents ol,
#contents dl {
	font-size: 110%;
}

#contents ul ul, #contents ul ol, #contents ul dl,
#contents ol ul, #contents ol ol, #contents ol dl,
#contents dl ul, #contents dl ol, #contents dl dl {
	font-size: 100%;
}

ul.list_basic {
	list-style-type: disc;
	padding-left:15px;
}

ul.list_basic li {
	margin-left: 3px;
}

.sc_index .list_basic li span {
	font-weight: bold;
}

ol.list_basic {
	list-style-type: decimal;
	margin-left:20px;
}

ol.list_basic li {
	margin-left: 6px;
}

ol.list_alpha {
	list-style-type: lower-alpha;
	padding-left:15px;
}

ol.list_alpha li {
	margin-left: 6px;
}

ol.list_note li{
	list-style-type:none;
	list-style-position:inside;
	counter-increment: cnt;
	padding-left:2em;
	text-indent:-2em;
}

ol.list_note  li:before{
	display: marker;
	content: "*" counter(cnt) ") ";
}

ol.bracket > li,
ol.closing_bracket > li {
	counter-increment: cnt;
	padding-left:2em;
	text-indent:-2em;
}
ol.bracket > li:before {
	content: "("counter(cnt) ") ";
}
ol.closing_bracket > li:before {
	content: counter(cnt) ") ";
}

sub {
	vertical-align: baseline;
}

.img_head1_sup{
	line-height: 2;
}

/* sup */

*>/**/sup {
	font-size: 70%;
	vertical-align: text-top;
	line-height: 13px;
}

/* form */

input ,select {
	vertical-align: middle;
}

/* image default */

img {
	border-style: none;
}

/* ----------clear---------- */

.clr {
	clear: both;
	overflow: hidden;
	width: 1px;
	height: 1px;
	margin: 0 -1px -1px 0;
	border: 0;
	padding: 0;
	font-size: 0;
	line-height: 0;
}


/* ----------container---------- */

#container {
	position: relative;
	width: 100%;
	max-width: 1920px;
	min-width: 960px;
	min-height: 100%;
	height: auto !important;
	height: 100%;
	margin: 0 auto -359px;
	padding: 140px 0 0;
	box-sizing: border-box !important;
	text-align: left;
}


/* ----------push---------- */

#push {
	height: 420px;
}


/* ----------header---------- */

#header {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 140px;
	background: url(../images/header_bg.jpg) no-repeat center top;
}
body.fixed #header {
	position: fixed;
	top: -70px;
	z-index: 99999;
}

#logo {
	width: 100%;
	height: 70px;
	max-width: 960px;
	margin: 0 auto;
	padding: 17px 0 0 0;
	box-sizing: border-box;
}
#logo a{
	display: block;
	width: 308px;
	height: 38px;
}
#logo img{
	width: 308px;
	height: 38px;
}

/* ----------header_search---------- */

#header_search {
	position: absolute;
	left: 50%;
	top: 18px;
	z-index: 150;
	margin: 0 0 0 280px;
}
/*#header_search {
	position: absolute;
	top: 4px;
	z-index: 150;
}*/

/* ----------search---------- */

input[type="search"] {
  -webkit-appearance: auto !important;
}
input[type="search"]::-webkit-search-cancel-button {
  -webkit-appearance: auto !important;
}
#header_search .mt-site-search-filter-directories {
  margin: 0;
  display: none;
}
#header_search form {
	width: 202px;
	display: flex;
	border: 2px solid #0086d1;
	border-radius: 100px;
	overflow: hidden;
	box-sizing: border-box;
	padding: 0 5px;
}
#header_search form input{
	width: calc(100% - 32px);
 appearance:none;
 height:32px;
	line-height: 32px;
 margin:0;
	border: none;
 border-radius:0;
 padding:.5rem;
	outline: none;
}
#header_search form input:focus {
 outline: none;
}
#header_search form button {
	width: 32px;
	height:32px;
	margin-left: 0;
	border: none;
	background: #fff url("../images/icn_site_search.png") no-repeat 0 0;
	background-size: 100% 100%;
	text-indent: -9999px;
}
.mt-site-search-result-container__modal {
 top: 50%;
 left: 50%;
	transform: translate(-50%,-50%);
}

/* ----------header_btn---------- */

#btn_inquiry,
#btn_lang {
	position: absolute;
	top: 19px;
	height: 33px;
	font-size: 1px;
	line-height: 1%;
	z-index: 200;
}

#btn_inquiry {
	left: 50%;
	margin: 0 0 0 18px;
}

#btn_lang {
	left: 50%;
	margin: 0 0 0 148px;
}

#btn_inquiry img,
#btn_lang img {
	display: block;
}


/* ----------main---------- */

#main {
	width: 960px;
	margin: 0 auto;
	overflow: hidden;
}


/* ----------contents---------- */

#contents {
	float: left;
	width: 690px;
}


/* ----------index_contents---------- */

#index_contents {
	float: left;
	width: 692px;
}


/* ----------footer---------- */

#footer {
	position: relative;
	height: 420px;
	background: url(../images/footer_bg.jpg) no-repeat center bottom;
	margin: 30px auto 0;
	text-align: left;
}

ul#footer_btn {
	position: absolute;
	bottom:18px;
	left:50%;
	margin: 0 0 0 -475px;
	font-size: 1px;
	line-height: 1%;
	overflow: hidden;
	z-index: 2;
}

ul#footer_btn img {
	display: block;
}

ul#footer_btn li {
	float: left;
}

ul#footer_btn li.btn1 {
	padding-top:3px;
	padding-right: 12px;
	padding-left:12px;

}

ul#footer_btn li.btn2 {
	padding-top:3px;
	padding-right: 20px;
}

ul#footer_btn li.btn3 {
	padding-top:3px;
}

/* add */
#footer .footer_inner{
	width:950px;
	padding-top:55px;
	margin:0 auto;
}

#footer .footer_inner .footer_link_title{
	font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-weight:bold;
	border-bottom:2px solid #6E8EAD;
	padding-bottom:1px;
	margin-bottom:3px;
}
.footer_inner a,.footer_inner a:link{
	color:#333;
	font-size:13px;
}

#footer .footer_inner .footer_inner_box{
	width:200px;
	margin-right:50px;
	float:left;
	line-height: 28px;/* 2015.12.2 */
}
#footer .footer_inner .mr0{
	margin-right:0 !important;
}

/* ----------copyright---------- */

#copyright {
	padding:0 0 0 255px;
	position: absolute;
	bottom: 18px;
	left: 50%;
	z-index: 1;
}


/* ----------topcontrol---------- */

#topcontrol {
	position: absolute;
	right: 0;
	z-index: 99999;
}

#topcontrol img:hover {
	filter: alpha(opacity=60);
	-moz-opacity: 0.6;
	opacity: 0.6;
}

.bnrLeft {
    float: right;
    padding-left: 10px;
    width: 300px;
}
.clear {
	clear: both;
}

.title-block {
	display: flex;
	width: 690px;
}
.title-block .index_banner {
    width: 220px;
}
.title-block .title-right {
	margin-left: auto;
}
.title-block .title-left {
	flex-grow: 999;
	flex-shrink: 999;
	flex-basis: auto;
}
.link-catalog {
	position: relative;
	overflow: hidden;
	margin-bottom: 10px;
}
.link-catalog a {
	position: relative;
	display: inline-block;
}
.link-catalog.type-01 {
	height: 86px;
}
.link-catalog.type-02 {
	height: 86px;
}
.link-catalog.type-03 {
	width: 243px;
	height: 62px;
	margin: 0 auto;
}
.link-catalog.type-04 {
	width: 393px;
	height: 62px;
	margin: 0 auto;
}
.link-catalog.type-05 {
	width: 423px;
	height: 62px;
	margin: 0 auto;
}
.link-catalog.type-06 {
	width: 300px;
	height: 62px;
	margin: 0 auto;
}
.link-catalog .catalog-on-button {
	position: absolute;
	left: auto;
	height: auto;
	margin: auto;
	pointer-events: none;
}
.link-catalog.type-01 .catalog-on-button {
	bottom: 15px;
	right: 15px;
	width: 46px;
}
.link-catalog.type-02 .catalog-on-button {
	bottom: 15px;
	right: 25px;
	width: 46px;
}
.link-catalog.type-03 .catalog-on-button,
.link-catalog.type-04 .catalog-on-button,
.link-catalog.type-05 .catalog-on-button,
.link-catalog.type-06 .catalog-on-button {
	top: 4px;
	right: 5px;
	width: 38px;
	border: solid 1px #E0E0E0;
}
.link-catalog.type-01 p.text-on-button {
	position: absolute;
	left: 40px;
	top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    text-align: left;
	font-size: 14px !important;
	font-weight: bold;
	line-height: 1.4em;
	color: #004f86;
	pointer-events: none;
	text-indent: -1em;
	padding-left: 1em;
}
.link-catalog.type-03 p.text-on-button,
.link-catalog.type-06 p.text-on-button {
	position: absolute;
	left: 30px;
	top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    text-align: left;
	font-size: 14px !important;
	font-weight: bold;
	line-height: 1.4em;
	color: #202020;
	pointer-events: none;
}

/* ----------SNS Shere link---------- */
#sns-link {
	position: absolute;
	top: 0;
	right: 0;
	display: flex;
	padding-top: 5px;
}
#sns-link p.sns-link-name {
	font-size: 15px;
	margin-right: 5px;
	align-self: flex-end;
}
#sns-link p.sns-link-name:after {
	content: "Share";
}
#sns-link #atstbx {
    animation-name: atstbx-fadein;
    animation-duration: 0.5s;
}
@keyframes atstbx-fadein {
  from {
      transform: translateX(40px);
  }
  to {
      transform: translateX(0);
  }
}
