@charset "utf-8";

/* ======================================================
 * layout_pc.css
 * ------------------------------------------------------
 * @media print, screen and (min-width: 768px)
 
====================================================== */

@media print, screen and (min-width: 768px) {
  /* ------------------------------------------------------
   * Header
  ------------------------------------------------------ */
  .Header {
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    background: #fff;
    z-index: 1001;
  }
  
  /* ----- HeaderBody ----- */
  .HeaderBody {
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
    padding-left: 4%;
    width: 100%;
    min-width: 1200px;
    border-bottom: 1px solid #dddddd;
  }
  
  /* header-identity */
  .header-identity {width: 12%;}
  .identity_logo > a {
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
  }
  .identity_logo > a > img {width: 100%;}
  .header_serchWrap {
    display: block;
    position: relative;
    margin: 20px 0;
    padding: 0 10px 4px 20px;
    width: 100%;
    border-bottom: 1px solid #9d1f23;
  }
  .header_serchWrap:before {
    content: "";
    display: block;
    position: absolute;
  }
  .header_serchWrap:before {
    top: 14px;
    left: 10px;
    margin-top: -0.5em;
    width: 2px;
    height: 19px;
    background: #9a9a9a;
  }
  .header_serchWrap > form {
    display: -webkit-flex;
    display: flex;
  }
  .header_serch,
  .header_serch_btn {
    margin: 0;
    padding: 0;
    background: none;
    border: none;
    border-radius: 0;
    outline: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
  }
  .header_serch {
    padding-right: 5px;
    width: calc(100% - 30px);
    font-size: 1.8rem;
  }
  input.header_serch::placeholder {color: #999;}
  input.header_serch:-ms-input-placeholder {color: #999;}
  input.header_serch::-ms-input-placeholder {color: #999;}
  .header_serch_btn {
    margin-top: 4px;
    width: 28px;
    height: 28px;
    text-indent: -9999px;
    background: url(../img/com_sprite01.png) no-repeat;
    background-position: -83px 0;
    cursor: pointer;
  }
  .header_serch_btn:hover {opacity: 0.7;}
  
  /* ------------------------------------------------------
   * Gnav
  ------------------------------------------------------ */
  .Gnav {
    padding-left: 5%;
    width: 88%;
  }
  
  /* ----- GnavBody ----- */
  .GnavBody > .gnav-pc {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
  }
  .GnavBody > .gnav-sp {display: none;}
  /* gnavList */
  .gnavList {
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
  }
  
  .gnavList > li > a,
	.gnavList > li > a > span {
    text-decoration: none;
    color: #333;
  }
  .gnavList > li > a.a-blank:after {
    display: inline-block;
    margin-top: 0;
    margin-left: 4px;
    vertical-align: middle;
  }
  .gnavList-main {
    display: -webkit-flex;
    display: flex;
    width: 37%;
    color: #333;
    font-weight: 400;
  }
  .gnavList-main > li {
    margin-left: 14%;
    min-width: 2em;
  }
  .gnavList-main > li:first-of-type {margin-left: 0;}
  .gnavList-main > li > a {
    text-decoration: none;
    font-size: 1.8rem;
    line-height: 1.4;
  }
  .gnavList-main > li > a.is-current,
  .gnavList-main > li > a:hover {color: #9d1f23;}
  .gnavList-sub {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: flex-end;
    justify-content: flex-end;
    padding-left: 3%;
    width: 63%;
  }
  .gnavList-sub > li {margin-left: 7%;}
  .gnavList-sub > li:first-of-type {margin-left: 0;}
  .gnavList-sub > li > a {
    position: relative;
    text-decoration: none;
    color: #666;
    font-size: 1.6rem;
    line-height: 1.5;
  }
  .gnavList-sub > li > a > span {
    color: #666;
  }
  .gnavList-sub > li > a.is-current {
    color: #9d1f23;
    font-weight: bold;
  }
  .gnavList-sub > li > .headerUtility_btn.is-current {
    position: relative;
    color: #333;
    font-weight: normal;
    background: #f2f2f2;
  }
  .gnavList-sub > li > .headerUtility_btn.is-current:after {
    content: '';
    display: block;
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 100%;
    height: 1px;
    background: #f2f2f2;
  }
  .gnavList-sub > li > a:hover > span{text-decoration: underline;}
  .gnavList-sub > li > a > span {
    display: inline-block;
    min-width: 2em;
  }
  .headerUtility + .headerUtility {margin-left: -0px;}
  .headerUtility_body {display: none;}
  .js-headerUtility.is-current + .headerUtility_body {
    display: block;
    position: absolute;
    width: 600px;
    top: 100%;
    right: 0;
    background: #f2f2f2;
  }
  .headerUtility_bodyInner {
    margin: 0 auto;
    padding: 0 20px;
  }
  .headerUtility_link {margin: 8px 0 10px;}
  .headerUtility_link > li {
    padding-left: 10px;
    border-bottom: 1px solid #ccc;
  }
  .headerUtility_link > li:last-child {border-bottom: none;}
  .headerUtility_link > li > a {
    display: block;
    position: relative;
    padding: 12px 0 12px 28px;
    text-decoration: none;
    color: #333;
    font-size: 1.8rem;
  }
  .headerUtility_link > li > a:hover {text-decoration: underline;}
  .headerUtility_link > li > a > span:before,
  .headerUtility_link > li > a > span:after {
    content: "";
    position: absolute;
    vertical-align: middle;
    top: 50%;
    -webkit-transition: all .2s ease-out 0s;
    transition: all .2s ease-out 0s;
  }
  .headerUtility_link > li > a > span:before {
    left: 0;
    margin-top: -2px;
    width: 16px;
    height: 1px;
    background: #555555;
  }
  .headerUtility_link > li > a > span:after {
    left: 6px;
    margin-top: -6px;
    width: 9px;
    height: 9px;
    border-top: 1px solid #555555;
    border-right: 1px solid #555555;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
  }
  .headerUtility_link > li > a:hover > span:before {left: 6px;}
  .headerUtility_link > li > a:hover > span:after {left: 12px;}
  .headerUtility_btn {
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
    width: 80px;
    height: 72px;
    font-size: 1.2rem;
    text-align: center;
    border-left: 1px solid #dddddd;
  }
  .gnavList-sub > li > .headerUtility_btn {font-size: 1.2rem;}
  .headerUtility-serch,
  .headerUtility-language,
  .js-headerUtility-close {
    display: inline-block;
    margin: 0 auto;
  }
  .headerUtility-serch:before,
  .headerUtility-language:before,
  .js-headerUtility-close:before {
    content: "";
    display: block;
    margin: 4px auto 6px;
    background: url(../img/com_sprite01.png) no-repeat;
  }
  .headerUtility-serch:before {
    width: 21px;
    height: 21px;
    background-position: 0 0;
  }
  .headerUtility-language:before {
   
      width: 21px;
      height: 21px;
      background: url(../img/lanage.svg) no-repeat;
  }
  .js-headerUtility-close:before {
    width: 17px;
    height: 21px;
    background-position: -44px 0;
  }
  /* ------------------------------------------------------
   * Main
  ------------------------------------------------------ */
  .Main {
    display: block;
    margin-top: 73px;
  }
  
  /* ----- pageGuide ----- */
  .pageGuide {
    padding-top: 18px;
    margin: 0 auto;
    width: 1200px;
  }
  
  /* breadcrumbs */
  .breadcrumbs {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 20px;
  }
  .breadcrumbs > li {
    margin-right: 15px;
    font-size: 1.4rem;
  }
  .breadcrumbs > li:before {
    content: "/";
    display: inline-block;
    margin-right: 15px;
    color: #a9a9a9;
  }
  .breadcrumbs > li:last-of-type {
    margin-right: 0;
    font-weight: bold;
  }
  .breadcrumbs > li:first-of-type:before {display: none;}
  
  /* ----- pageHead ----- */
  .pageHead {
    position: relative;
    width: 100%;
    color: #fff;
  }
   
  .pageHead > .pageHead-inner {background: #9d1f23;}
  .pageHead {min-width: 1200px;}
  .pageHead .heading-lv1 {
    margin: 0 auto;
    padding: 15px 0 13px;
    width: 1200px;
    text-align: center;
  }
  .pageHead .heading-lv1 .heading_title {
    padding-bottom: 0;
    color: #e1c6c6;
    font-size: 1.6rem;
    font-weight: normal;
  }
  .pageHead .heading-lv1 > .heading_title > em {
    color: #fff;
    font-size: 3.0rem;
    font-weight: bold;
    font-style: normal;
  }
  .pageHead .heading-lv1 > .heading_title > em + span {margin-left: 14px;}
  .pageHead .heading-lv1:after {display: none;}
  
  /* ----- container ----- */
  .pktitle{font-size:1.5rem;}
  .container {
    margin: 0 auto;
    width: 1200px;
  }
  .pageHead + .container {margin-top: 50px;}
  .pageHead + .container > .contents > *:first-child {margin-top: 0;}
  /* contents */
  [data-sidebar="true"] .contents {
    margin-top: 20px;
    float: left;
    width: 912px;
    overflow: hidden;
  }
  
  /* sidebar */
  .sidebar {
    float: right;
    margin-left: 48px;
    width: 240px;
  }
  
  /* ------------------------------------------------------
   * Footer
  ------------------------------------------------------ */
  .Footer {
    position: relative;
    margin-top: 120px;
    min-width: 1200px;
  }
  /* ----- FooterBody ----- */
  .FooterBody {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    padding: 60px 4%;
    background: #f6f6f6;
  }
  
  /* footer-sitemap */
  .footer-sitemap {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    width: 100%;
  }
  .footer-sitemap > .sitemap_item {
    width: 18.4%;
    margin-left: 2%;
  }
  .footer-sitemap > .sitemap_item:nth-child(5n+1) {
    margin-left: 0;
  }
  .sitemap_item > :first-of-type {margin-top: 0;}
  .sitemap-link {
    display: block;
    width: 100%;
  }
  .sitemap-link + .sitemap-link {margin-top: 30px;}
  /* footer-link */
  .sitemap-link > li + li {margin-top: 20px;}
  .sitemap-link > li > a {
    display: inline-block;
    position: relative;
    padding-left: 28px;
    text-decoration: none;
    color: #333;
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.4;
  }
  .sitemap-link > li > a:hover {color: #9d1f23;}
  .sitemap-link > li > a > span:before,
  .sitemap-link > li > a > span:after {
    content: "";
    position: absolute;
    vertical-align: middle;
    top: 50%;
    -webkit-transition: all .2s ease-out 0s;
    transition: all .2s ease-out 0s;
  }
  .sitemap-link > li > a > span:before {
    left: 0;
    width: 16px;
    height: 1px;
    background: #555555;
  }
  .sitemap-link > li > a > span:after {
    left: 6px;
    margin-top: -4px;
    width: 9px;
    height: 9px;
    border-top: 1px solid #555555;
    border-right: 1px solid #555555;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
  }
  .sitemap-link > li > a:hover > span:before {left: 6px;}
  .sitemap-link > li > a:hover > span:after {left: 12px;}
  .sitemap-link_detail {
    margin-top: 20px;
    padding-left: 28px;
  }
  .sitemap-link_detail > li {line-height: 1.4;}
  .sitemap-link_detail > li + li {margin-top: 1em;}
  .sitemap-link_detail > li > a {
    display: inline-block;
    text-decoration: none;
    color: #333;
    font-size: 1.5rem;
  }
  .sitemap-link_detail > li > a:hover {text-decoration: underline;}
  .sitemap-banner {max-width: 264px;}
  .sitemap-banner > li + li {margin-top: 20px;}
  .sitemap-sns {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: flex-end;
    justify-content: flex-end;
    width: 100%;
    overflow: hidden;
  }
  .sitemap-sns > span {
    position: relative;
    z-index: 2;
  }
  .sitemap-snsList {
    display: -webkit-flex;
    display: flex;
  }
  .sitemap-snsList > li {
    display: -webkit-flex;
    display: flex;
    -webkit-align-items: center;
    align-items: center;
    min-width: 36px;
  }
  .sitemap-snsList > li {margin-left: 17px;}
  .sitemap-qrcode {
    text-align: center;
  }
  .sitemap-qrcode > dt {
    margin-bottom: .75em;
    font-size: 1.8rem;
    font-weight: bold;
  }
  .sitemap-qrcode > dd {
    max-width: 150px;
    margin: 0 auto;
  }
  /* footer-copyright */
  .footer-copyright {
    padding: 20px 4% 15px;
    color: #fff;
    font-size: 1.3rem;
    background: #9d1f23;
  }
  .footer-copyright > small {
    color: #fff;
  }
  
  /* ----- Pagetop ----- */
  .Pagetop {
    content: '';
    display: block;
    position: fixed;
    right: 5%;
    bottom: 150px;
    z-index: 1000;
  }
  .Pagetop > a {
    display: block;
    width: 60px;
    height: 60px;
    background: url(../img/set.svg) no-repeat;
    
  }
  /* ------------------------------------------------------
   * Other
  ------------------------------------------------------ */
  .js-headerUtility_overlay {
    display: none;
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000;
    opacity: 0.5;
    z-index: 1000;
  }
  /* marsinder css override */
  #mf_marsfinder #page-top {
    width: 0;
    height: 0;
    overflow:hidden;
  }
  /* ------------------------------------------------------
   * Clearfix
  ------------------------------------------------------ */
  .container::after {
    display: block;
    clear: both;
    content: "";
  }
}

/* ======================================================
 * Media Queries
====================================================== */
@media screen and (min-width: 768px) and (max-width: 1899px) {
  /* ------------------------------------------------------
   * Gnav
  ------------------------------------------------------ */
  .gnavList-sub > li {margin-left: 6.6%;}
  .gnavList-sub > li > a {font-size: 1.5rem;}
  
  /* ------------------------------------------------------
   * Footer
  ------------------------------------------------------ */
  .FooterBody {padding: 60px 4%;}
}
@media screen and (min-width: 768px) and (max-width: 1780px) {
  /* ------------------------------------------------------
   * Gnav
  ------------------------------------------------------ */
  /* gnavList */
  .gnavList-sub > li {margin-left: 6%;}
  .gnavList-sub > li > a {font-size: 1.4rem;}
}
@media screen and (min-width: 768px) and (max-width: 1630px) {
  /* ------------------------------------------------------
   * Gnav
  ------------------------------------------------------ */
  .HeaderBody {padding-left: 3%;}
  .Gnav {padding-left: 5%;}
  /* gnavList */
  .gnavList-main > li > a {font-size: 1.6rem;}
  .gnavList-sub > li {margin-left: 5%;}
  /* ------------------------------------------------------
   * Footer
  ------------------------------------------------------ */
  .FooterBody {padding: 60px 3%;}
  .sitemap-link > li > a {font-size: 1.6rem;}
}
@media screen and (min-width: 768px) and (max-width: 1342px) {
  /* ------------------------------------------------------
   * Gnav
  ------------------------------------------------------ */
  /* gnavList */
  .gnavList-main > li {margin-left: 14%;}
  .gnavList-main > li > a {font-size: 1.5rem;}
  .gnavList-sub > li {margin-left: 4%;}
  .gnavList-sub > li > a {font-size: 1.4rem;}
  /* ------------------------------------------------------
   * Footer
  ------------------------------------------------------ */
  .sitemap-link > li > a {font-size: 1.5rem;}
  .sitemap-link_detail > li > a {font-size: 1.3rem;}
}
@media screen and (min-width: 768px) and (max-width: 1150px) {
  /* ------------------------------------------------------
   * Gnav
  ------------------------------------------------------ */
  .HeaderBody {padding-left: 2%;}
  .Gnav {padding-left: 5%;}
  .gnavList-main > li > a {font-size: 1.4rem;}
  .gnavList-sub {padding-left: 2%;}
  .gnavList-sub > li {margin-left: 3%;}
  .gnavList-sub > li > a {font-size: 1.2rem;}
  .headerUtility_btn {
    width: 70px;
    font-size: 1.2rem;
  }
  /* ------------------------------------------------------
   * Footer
  ------------------------------------------------------ */
  .sitemap-link > li > a {font-size: 1.4rem;}
  .sitemap-link_detail > li > a {font-size: 1.2rem;}
  .footer-sitemap > .sitemap_item:last-of-type {max-width: 26%;}
}
@media screen and (min-width: 768px) and (max-width: 830px) {
  /* ------------------------------------------------------
   * Gnav
  ------------------------------------------------------ */
  .gnavList-sub > li {margin-left: 2%;}
}

/* ======================================================
 * Print
====================================================== */
@media print {
  /* ------------------------------------------------------
   * Common
  ------------------------------------------------------ */
  .Pagetop {display:none!important;}
  
  /* ------------------------------------------------------
   * Header
  ------------------------------------------------------ */
  .Header {position: relative !important;}
  .gnavList-main > li > a {font-size: 1.4rem;}
  .gnavList-sub {padding-left: 2%;}
  .gnavList-sub > li {margin-left: 3%;}
  .gnavList-sub > li > a {font-size: 1.2rem;}
  .Main {margin-top: 0 !important;}
}