@charset "UTF-8";
/* ------------------------------------ Reset Style ------------------------------------ */
* { box-sizing: border-box; }

* > p:first-child { margin-top: 0; }

body { margin: 0; font-size: 0.88rem; font-family: -apple-system, "ヒラギノ角ゴ Pro", "メイリオ", Meiryo, Arial, sans-serif; color: #333; -webkit-text-size-adjust: 100%; }

h1, h2, h3, h4, h5 { margin: 0; }

a { color: #039; text-decoration: underline; }

a:visited { color: #60c; }

a:hover { color: #f63; }

p { margin: 10px 0 0; }

img { width: 100%; vertical-align: bottom; }

ul { margin: 0; padding: 15px; }

sup { vertical-align: text-top; }

sub { vertical-align: text-bottom; }

@media (min-width: 768px) { img { width: auto; } }

fieldset { margin: 0; padding: 0; border: 0; }

input, textarea, select, button { padding: 2px 5px; margin: 0; background: #fff; border: 1px solid #ccc; border-radius: 0; font-family: -apple-system, "ヒラギノ角ゴ Pro", "メイリオ", Meiryo, Arial, sans-serif; font-size: inherit; appearance: none; -webkit-appearance: none; }

caption { font-size: 0; }

/* ------------------------------------ Global Contents Style ------------------------------------ */
.g-inner { width: 100%; max-width: 960px; margin: 0 auto; }

.g-inner ul { margin: 0; padding: 0; }

.g-inner ul li { list-style-type: none; }

.overlay { width: 100vw; height: 100vh; display: none; position: fixed; top: 0; left: 0; background: rgba(255, 255, 255, 0.8); z-index: 1; }

.overlay.is-active { display: block; }

/* .global-header --------------------------- */
.global-header { position: relative; background: #fff; border-bottom: 1px solid #d1d1d1; z-index: 2; }

.global-header .g-inner { height: 44px; position: relative; overflow: hidden; }

.global-header .l-logo { height: 110px; padding: 7px 8px 5px 7px; }

.global-header .l-logo a { width: 150px; height: 60px; display: inline-block; }

.global-header .g-head-logo { width: auto; height: 100%; padding: 8px 8px 5px 8px; position: absolute; top: 50%; left: 0; transform: translate(0, -50%); }

.global-header .g-head-identifier, .global-header .head-nav { display: none; }

.global-header .menu-btn { width: 44px; height: 44px; padding: 2px 5px 6px; position: absolute; top: 0; right: 0; font-size: 2.38rem; text-align: center; }

.global-header .menu-btn.is-active { padding: 11px; background: #666; font-size: 1.38rem; }

.global-header .menu-btn.is-active.fa { color: #fff; }

.global-header .menu-btn.is-active.fa:before { content: "\f00d"; }

@media (min-width: 768px) { .global-header { border-bottom: none; }
  .global-header .g-inner { height: 100px; }
  .global-header .l-logo { width: 65%; height: 100px; padding: 0; position: relative; float: left; }
  .global-header .g-head-logo { width: auto; height: 100%; padding: 14px 12px 12px; top: 0; transform: translate(0, 0); }
  .global-header .g-head-identifier { display: block; position: absolute; top: 50%; left: 210px; transform: translate(0, -50%); height: 18px;}
  .global-header .head-nav { width: 35%; display: block; float: right; }
  .global-header .menu-btn { display: none; } }

/* .head-nav --------------------------- */
.head-nav .list-utility { margin-top: 7px; margin-bottom: 7px; font-size: .70rem; text-align: right; }

.head-nav .list-utility li { margin-left: 3px; display: inline-block; background-repeat: no-repeat; background-position: left center; }

.head-nav .language { padding-left: 8px; background-image: url(../images/global/icon-arrow.gif); }

.head-nav .sitemap { padding-left: 15px; background-image: url(../images/global/icon-sitemap.gif); }

.head-nav .contact { padding-left: 15px; background-image: url(../images/global/icon-contact.gif); }

/* .global-navi --------------------------- */
.global-navi { width: 100%; height: auto; padding: 0; display: none; position: absolute; top: 45px; left: 0; background-color: #f5f5f5; z-index: 100; }

@media (max-width: 767px) { .global-navi.is-menu-open { display: block; } }

@media (min-width: 768px) { .global-navi { display: block; position: static; background: #fff; } }

/* .block-search --------------------------- */
.search-block { overflow: hidden; }

.block-search { float: right; }

.block-search fieldset { overflow: hidden; }

.block-search fieldset > * { vertical-align: text-bottom; float: left; }

.block-search input[type=text] { padding: 2px 5px; border-radius: 3px 0 0 3px; box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.1) inset; font-size: 0.63rem; overflow: hidden; }

.block-search .roll { padding: 0; border: none; }

.block-search .roll:hover { cursor: pointer; }

.block-search .help { margin-top: 0; }

.block-search .help img { width: auto; vertical-align: text-top; }

@media (max-width: 767px) { .block-search { float: none; }
  .block-search fieldset { padding: 20px 20px; position: relative; text-align: center; }
  .block-search fieldset:before { width: 54px; height: 24px; padding: 6px 5px; position: absolute; top: 20px; right: 20px; background: #1a3369; color: #fff; content: "検索"; }
  .block-search input[type=text] { width: calc(100% - 64px); padding: 6px 6px 7px; border-radius: 0; box-shadow: none; font-size: 0.88rem; }
  .block-search input[type="image"] { width: 64px; height: 36px; position: absolute; top: 20px; right: 20px; opacity: 0; }
  .block-search .help { display: none; } }

/* .g-menu --------------------------- */
.g-menu .menu-close { padding: 20px 20px; background: #808080; cursor: pointer; text-align: center; color: #fff; }

.g-menu .menu-close .fa { padding-right: 10px; position: static; font-size: 1rem; vertical-align: 1px; transform: translate(0, 0); }

@media (max-width: 767px) { .g-menu { font-size: 1rem; font-weight: bold; }
  .g-menu a { width: 100%; padding: 13px 20px; display: block; color: #fff; text-decoration: none; }
  .g-menu li { padding: 0; position: relative; border-bottom: 1px solid #fff; }
  .g-menu li.is-active { padding: 13px 20px; color: rgba(255, 255, 255, 0.5); }
  .g-menu li.is-active.is-links { padding: 0; }
  .g-menu li .fa { position: absolute; top: 50%; right: 20px; transform: translate(0, -50%); font-size: 0.88rem; font-weight: normal; }
  .g-menu > li { background: #4d4d4d; }
  .g-menu > li.l-bg-gray { background: #666; }
  .g-menu > li.l-bg-light-gray { background: #f3f4f6; font-weight: normal; }
  .g-menu > li.l-bg-light-gray li { border-bottom: 1px solid #b3b3b3; }
  .g-menu > li.l-bg-light-gray li:last-child { border-bottom: none; }
  .g-menu > li.l-bg-light-gray li.is-active { color: rgba(0, 0, 0, 0.4); }
  .g-menu > li.l-bg-light-gray a { color: #333; }
  .g-menu > li.l-bg-light-gray .fa { color: #999; } }

@media (min-width: 768px) { .g-menu { overflow: hidden; }
  .g-menu .fa { display: none; }
  .g-menu li { width: auto; margin: 0 15px; padding: 9px 0; float: left; background: none; border: none; }
  .g-menu li.is-active:before { margin-left: -14px; width: 14px; display: inline-block; vertical-align: 1px; line-height: 1.0; content: "●"; }
  .g-menu li.is-active a { text-decoration: none; color: #333; }
  .g-menu li.is-active a:hover { text-decoration: underline; }
  .g-menu a { display: inline; padding: 0; }
  .g-menu .menu-close { display: none; } }

.no-script-menu { display: block; }

.no-script-menu .g-menu { display: flex; flex-wrap: wrap; background: #4d4d4d; }

.no-script-menu .g-menu li { width: 50%; }

.no-script-menu .g-menu li:nth-child(odd) { border-right: 1px solid #fff; }

.no-script-menu .g-menu li a { padding: 13px 10px; padding-right: 25px; }

.no-script-menu .g-menu li:after { display: inline-block; text-rendering: auto; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; position: absolute; top: 50%; right: 10px; transform: translate(0, -50%); font: normal normal normal 14px/1 FontAwesome; font-size: 0.88rem; font-weight: normal; color: #fff; content: "\f054"; }

.no-script-menu .g-menu li.is-active { padding: 13px 10px; padding-right: 25px; }

.no-script-menu .g-menu li.is-active:after { display: none; }

.no-script-menu .g-menu li.is-active.is-links { padding: 0; }

.no-script-menu .g-menu li.is-active.is-links:after { display: inline-block; }

/* .global-footer-navi --------------------------- */
.global-foot-navi-sp { background: #666; color: #fff; }

.global-foot-navi-sp a, .global-foot-navi-sp span { padding: 10px; display: block; color: #fff; text-decoration: none; text-align: center; }

.global-foot-navi-sp ul { overflow: hidden; }

.global-foot-navi-sp li { width: 50%; float: left; border: 1px solid #fff; }

.global-foot-navi-sp li:nth-child(odd) { border-left: none; }

.global-foot-navi-sp li:nth-child(even) { border-right: none; }

.global-foot-navi-sp li.l-wide { width: 100%; float: none; border-left: none; border-right: none; }

.global-foot-navi-sp li.is-active { background: #1a3369; }

@media (min-width: 768px) { .global-foot-navi-sp { display: none; } }

.global-foot-navi { background: #666; color: #fff; font-size: 0.75rem; }

.global-foot-navi a, .global-foot-navi span { padding-left: 12px; display: inline-block; text-indent: -4px; text-decoration: none; color: #fff; }

.global-foot-navi a:before, .global-foot-navi span:before { padding-right: 5px; display: inline-block; font: normal normal normal 14px/1 FontAwesome; font-size: 0.75rem; text-rendering: auto; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

.global-foot-navi a:hover { text-decoration: underline; }

.global-foot-navi a:before { content: "\f105"; }

.global-foot-navi span { padding-left: 8px; }

.global-foot-navi span:before { padding-right: 2px; content: "●"; }

.global-foot-navi h2 { padding-bottom: 5px; border-bottom: 1px solid #fff; font-size: 0.815rem; font-weight: bold; }

.global-foot-navi h2 a { padding-left: 0; text-indent: 0; }

.global-foot-navi h3 { margin-top: 15px; font-size: 0.75rem; font-weight: normal; }

.global-foot-navi h3 a:before { font-size: 0.63rem; content: "\f054"; }

.global-foot-navi li { margin-top: 5px; }

.global-foot-navi .g-inner { padding: 50px 0 0 0; overflow: hidden; }

.global-foot-navi .g-inner > *:not(.close-btn) { margin-bottom: 30px; }

.global-foot-navi .contaner { overflow: hidden; }

.global-foot-navi .contaner > div { float: left; }

.global-foot-navi .product { width: 70%; padding-right: 15px; float: left; overflow: hidden; }

.global-foot-navi .product ul { padding-left: 8px; }

.global-foot-navi .product .l-block { width: 20%; float: right; }

.global-foot-navi .product .l-wide { width: 80%; float: left; }

.global-foot-navi .product .l-wide > ul { width: 50%; float: left; }

.global-foot-navi .product .l-wide > ul > li { margin-top: 10px; padding-right: 10px; }

.global-foot-navi .company { width: 15%; padding-right: 15px; }

.global-foot-navi .other { width: 15%; }

.global-foot-navi .other > ul { margin-top: 15px; }

.global-foot-navi .other > ul:first-child { margin-top: 0; }

.global-foot-navi .close-btn { width: 12rem; margin: 0 auto; padding: 5px; display: block; clear: both; background: #666; border: 1px solid #fff; font-size: 0.75rem; text-align: center; cursor: pointer; }

.global-foot-navi .close-btn:after { content: "を閉じる"; }

.global-foot-navi .close-btn .fa { width: 12px; height: 12px; margin-right: 8px; padding: 0; display: inline-block; background: #fff; text-align: center; font-size: 10px; color: #666; vertical-align: 1px; }

.global-foot-navi .close-btn.is-menu-close:after { content: "を開く"; }

.global-foot-navi .close-btn.is-menu-close .fa:before { display: inline-block; vertical-align: 1px; color: #666; content: "\f078"; }

.global-foot-navi .close-btn.is-en:after { content: "Close"; }

.global-foot-navi .close-btn.is-en.is-menu-close:after { content: "Open"; }

@media (max-width: 767px) { .global-foot-navi { display: none; } }

/* .global-footer  --------------------------- */
.global-footer { background: #fff; }

.global-footer .copyright { padding: 15px 20px 20px; display: block; text-align: center; font-size: 0.63rem; }

.global-footer .copyright a { color: #333; text-decoration: none; }

.global-footer .copyright a:hover { text-decoration: underline; }

@media (min-width: 768px) { .global-footer .g-inner { padding: 15px 0; overflow: hidden; }
  .global-footer .copyright { padding: 2px 0; float: right; } }

.g-foot-menu { overflow: hidden; }

.g-foot-menu li { width: 50%; padding: 10px 20px; float: left; }

.g-foot-menu li:nth-child(odd) { text-align: right; }

.g-foot-menu li:nth-child(even) { text-align: left; }

@media (min-width: 768px) { .g-foot-menu { width: 50%; float: left; font-size: 0.75rem; }
  .g-foot-menu li { width: auto; padding: 0 15px 0 0; }
  .g-foot-menu li:nth-child(odd) { text-align: left; }
  .g-foot-menu li:nth-child(even) { text-align: left; } }

.g-foot-identifier { max-width: 226px; margin: 0 auto; display: block; text-align: center; }

@media (min-width: 768px) { .g-foot-identifier { display: none; } }
