/* ヘッダー関連 */
.globalHeader {
  position: fixed;
  top: 10px;
  width: 96%;
  height: 80px;
  border-radius: 10px;
  background-image: linear-gradient(to top, #d5d4d0 0%, #d5d4d0 1%, #eeeeec 31%, #efeeec 75%, #e9e9e7 100%);
  margin: 0 2%;
  transition: all 0.1s ease-in-out;
  z-index: 1000;
}
.globalHeader.scroll {
  top: 0;
  width: 100%;
  border-radius: 0;
  margin: 0;
}
.globalHeader.subsite {
  top: 0 !important;
  width: 100% !important;
  border-radius: 0 !important;
  margin: 0 !important;
}

.globalHeader.showMenu {
  border-bottom-left-radius: 0; 
  border-bottom-right-radius: 0;
}

.globalHeader-logo {
  position: absolute;
  left: 10px;
  height: 60px;
  padding: 10px;
}
.globalHeader-menu {
  position: absolute;
  display: flex;
  justify-content: flex-end;
  height: 100%;
  right: 10px;
}
.globalHeader-menu > li {
  display: inline;
  font-size:20px;
  line-height: 80px;
  padding: 0 5px;
  border-right: 1px solid black;
  cursor: pointer;
}
.globalHeader-menu > li:first-child {
  border-left: 1px solid black;
}

.globalHeader-icon {
  padding-top: 25px;
  height: 30px;
}

.globalHeader-menuToggle {
  display: block;
  position: absolute;
  height: 40px;
  width: 40px;
}

.globalHeader-menuToggle > span {
  position: absolute;
  top: 25px;
  width: 100%;
  height: 2px;
  border-radius: 4px;
  background-color: black;
  transition: all 0.2s ease-in-out;
}
.globalHeader-menuToggle > span:nth-of-type(2) {
  top: 38px;
}
.globalHeader-menuToggle > span:nth-of-type(3) {
  top: 51px;
}

.globalHeader-menuToggle.active span:nth-of-type(1) {
  transform: translateY(13px) rotate(-45deg);
}
.globalHeader-menuToggle.active span:nth-of-type(2) {
  opacity: 0;
}
.globalHeader-menuToggle.active span:nth-of-type(3) {
  transform: translateY(-13px) rotate(45deg);
}

.globalHeader-subMenu {
  position:relative;
  width: 100%;
  background-image: linear-gradient(to top, #dfe9f3 0%, white 100%);
  margin-top: 80px;
  border-radius: 0 0 10px 10px;
  max-height: 70vh;
  overflow-y: auto;
  padding-bottom: 10px;
}

.globalHeader-subMenu-button {
  border: 1px solid white;
  width: 100px;
  height: 40px;
  top: 10px;
  position: absolute;
  line-height: 40px;
  cursor: pointer;
}

.globalHeader-subMenu-contents {
  margin: 10px 10px 0;
  text-align: left;
  padding-top: 5px;
  border-top: 1px solid blue;
  line-height: 20px;
}

.inner-header-menu-contents:not([type="last"]) {
  padding-left: 10px; 
}

.inner-header-menu-link {
  padding-left: 10px;
  display: inline-block;
  padding-bottom: 10px;
}
.inner-header-menu-link:hover, .inner-header-menu-language-link:hover,
.globalFooter-menu a:hover, globalFooter-otherMenu a:hover,
.main-service-list a:hover, .view-all-service a:hover,view-all-service a:hover{
  text-decoration: underline;
/*  color: red;*/
}

.inner-header-menu-contents:not([type="last"]) > ul {
  padding-left: 15px; 
}

.inner-header-menu-contents[type="last"] {
  border-right: 1px solid blue;
  display: inline;
  padding-right: 10px;
}

.inner-header-menu-contents[type="last"] > a {
  padding-bottom: 10px;
  display: inline-block;
}

.table-ul {
  display: table;
  table-layout: fixed;
  text-align: center;
  width: 100%;
}
.table-ul li {
  display: table-cell;
}

.table-ul2 {
  display: table;
  table-layout: fixed;
  text-align: left;
  width: 60%;
}
.table-ul2 li {
  display: table-cell;
}

.close-button {
  right: 10px;
}

.en-button {
  border: none;
  left: 10px;
}

.jp-button {
  border: none;
  left: 120px;
}

.en-button.active, .jp-button.active {
  border: 1px solid blue;
}

.globalHeader-subMenu-search-text {
  height: 30px;
}
.globalHeader-subMenu-search-button {
  width: 50px;
  height: 30px;
}

.activeMenu {
  background-color: white;
/* color:blue; */
  text-decoration: underline;
  font-weight: bold;
}

.none-border {
  border-right: none !important;
}



/* フッター */
.globalFooter {
  position: relative;
  left: 0px;
  right: 0px;
  margin: auto;
  max-width: 1280px;
}

.globalFooter-latestNews {
  display: flex;
  flex-wrap: wrap;
  background-color: #E3E2DF;
}

.globalFooter-latestNews > div {
  font-size:14px;
  padding: 20px 0px;
  background-color: #E3E2DF;
}

.globalFooter-latestNews > div:nth-of-type(1) {
  background-color: #E3E2DF;
  color: #39454B;
  width: 125px;
  text-align: center;
 }
/*
.globalFooter-latestNews > div:nth-of-type(2) {
  width: 125px;
  text-align: center;
}
*/
.globalFooter-latestNews > div:nth-of-type(2) {
  /*border-left: 1px dashed black;*/
  padding-left: 20px;
}

.globalFooter-menu {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  background-image: linear-gradient(to bottom, #d5d4d0 0%, #d5d4d0 1%, #eeeeec 31%, #efeeec 75%, #e9e9e7 100%);
  border-top: lightgray solid 2px;
  color: #5f5f5f;
}

.globalFooter-menu strong{
/*color: #39454B; */
  color: #39454B;
}

.globalFooter-menu > div {
  box-sizing: border-box;
  padding: 10px;
  max-width: 220px;
}

.globalFooter-menu > div:last-child {
  vertical-align: middle;
  text-align: center;
  width: 280px !important;
}

.globalFooter-menu > div > div {
  box-sizing: border-box;
  padding: 5px 0;
  word-break: keep-all;
}

.globalFooter-menu a:hover, .globalFooter-otherMenu a:hover {
  /*text-decoration: underline;*/
/*  color: orange;*/
}

.globalFooter-otherMenu {
  font-size: 0;
  text-align: center;
  background-image: linear-gradient(to top, #d5d4d0 0%, #d5d4d0 1%, #eeeeec 31%, #efeeec 75%, #e9e9e7 100%);
  padding: 5px 0;
  color: #5f5f5f;
  font-size: 14px;
  padding-bottom: 30px;
}

.globalFooter-otherMenu > li {
  display: inline-block;
  padding: 0 10px;
  border-right: 1px solid black;
}

.globalFooter-otherMenu > li:last-child{
  border: none;
}

.page_top {
  width: 150px;
  height: 60px;
  right: 0;
  bottom: -100px;
  position: fixed;
  opacity: 0.6px;
  background:rgba(30,144,255,0.7); 
  border-radius: 10px 0px 0px 10px;
  cursor: pointer;
}

.page_top a {
  position: relative;
  display: block;
  width: 150px;
  text-decoration: none;
}

.page_top a:after {
  content: 'TOP PAGE';
  font-size: 18px;
  color: #fff;
  position: absolute;
  margin: 20px 25px 25px 25px;
}

/* 各コンテンツのベーススタイル */
.breadcrumbsList {
  padding: 10px;
  font-size: 12px;
}

.breadcrumbsList li {
  display: inline;
}

.breadcrumbsList li::after {
  content: '>';
  display: inline-block;
  padding: 0 10px;
}

.breadcrumbsList li:last-child {
  font-weight: bold;
}
.breadcrumbsList li:last-child::after {
  display: none;
}

.main-contents-cover > div:first-child {
  background-image: url(/assets/img/Blue.png);
  background-repeat : no-repeat;
  background-position : top center;
  position: relative;
  text-align: center;
  background-size:cover;
  height: 300px;
}

.main-contents-cover > div > p {
  position: absolute;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  color: white;
  text-shadow: 1px 1px 0 black, -1px -1px 0 black,
              -1px 1px 0 black, 1px -1px 0 black,
              0px 1px 0 black,  0-1px 0 black,
              -1px 0 0 black, 1px 0 0 black;
}

.main-contents-cover > div > p:nth-child(1)  {
  display: block;
  top: 50%;
  font-size: 2vw;
  white-space: nowrap;
  font-weight: bold;
}

.main-contents-cover > div > p:nth-child(2)  {
  top: 70%;
  font-size: 1vw;
}

.main-contents-title {
  text-align: center;
  padding: 10px 5px;
}

.main-contents-title > p {
  color: #0676B2;
}

.main-contents-title > p:first-child {
  font-size: 30px;
}

.main-contents {
  position: relative;
  max-width: 1280px;
  left: 0;
  right: 0;
  margin: auto;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-bottom: 10px;
}

.main-contents > div {
  padding: 10px 20px 10px 20px;
  width: 100%;
}

.main-contentsList {
  position: relative;
  max-width: 1280px;
  left: 0;
  right: 0;
  margin: auto;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  border: none !important;
  padding: 10px;
  box-sizing:border-box
}

.main-contentsList > h1 {
  position: relative;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  padding-top: 20px;
  font-size: 22px;
  width: 100%;
}
.main-contentsList > h2 {
  position: relative;
  top: 0;
  right: 0;
  bottom: 0;
  left: 5px;
  margin: auto;
  font-size: 18px;
  font-weight: initial;
  width: 100%;
  color: dimgrey;
}
.main-contentsList > div {

  border-top: gray solid 1px;
  width: 100%;
}
.main-contentsList > nav {
  position: relative;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  padding: 5px 25px 5px;
  width: 80%;
}
.main-contentsList > nav > ul {
  list-style: circle;
  padding-left: 25px;
}

.main-contents th {
  background-color: #f5f5f5;
  border: solid 1px #f5f5f5;
  padding: 10px;
  vertical-align: middle;
}

.main-contents td {
  border: solid 1px #f5f5f5;
  padding: 10px;
  vertical-align: middle;
}

.main-contentsList > span {
  width: 48%;
  margin: 0 5px 10px 5px;
}

.card {
  width: 100%;
  border: black solid 1px;
  border-radius: 5px;
  cursor: pointer;
}
.card > div:nth-child(1){
  padding: 10px;
  border-top-left-radius: 5px;
  border-top-right-radius: 5px;
  background-color: cornflowerblue;
  color: white;
  font-weight: bold;
  text-align: center;
}
.card > div:nth-child(2){
  padding: 10px;
  color: dimgrey;
  word-break: break-all;
}

.breadcrumbsListMobile {
  display: none;
}

.QA article {
  max-height: 0;
  overflow-y: hidden;
  color: gray;
  padding-left: 15px;
  margin: 5px;
}
.QA li {
  border-bottom: gray solid 1px;
  padding: 5px;
  cursor: pointer;
}

.QA label {
  cursor: pointer;
}

.QA input {
  display: none;
}

.QA input:checked + article {
  max-height: 100vh;
  opacity: 1;
}

* {
  font-family: "Noto Sans Japanese", "Helvetica Neue", Arial, Helvetica, sans-serif;
}

html {
  height: 100%;
}

body {
  text-align: left;
  color: black;
  height: 100%;
}

a {
  color: inherit;
  text-decoration: none;
}

table {
  border-collapse:separate;
}

.printLogo {
  display: none;
  height: 50px;
}
.printTitle {
  display: none;
  text-align: center;
  font-size: 40px;
}

.mobileMenu {
  display: none;
}

/* Newsのarrow */
.arrow_r_b {
  position: relative;
  display: inline-block;
  padding-left: 20px;
  color: green;
  text-decoration: none;
  left: 5px;
  top: -5px;
}
.arrow_r_b:before {
  content: '';
  width: 18px;
  height: 18px;
  background: green;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: -3px;
  margin-top: -9px;
}
.arrow_r_b:after {
  content: '';
  width: 6px;
  height: 6px;
  border: 0;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  position: absolute;
  top: 50%;
  left: 0;
  margin-top: -4px;
  transform: rotate(45deg);
}

/* 印刷時 
@media print {
  #globalHeader {
    display: none;
  }

  #globalFooter {
    display: none;
  }

  .no_print {
    display: none;
  }

  .printLogo {
    display: block !important;
  }

  .printTitle {
    text-align: center;
    display: block !important;
  }

  .main-contents > div:nth-child(1) {
    width: 100%;
  }
}*/

@media print {
  body {
    -webkit-print-color-adjust: exact;
    top:0 !IMPORTANT;
    left:0 !IMPORTANT;
    width:200mm !IMPORTANT;
    height:290mm !IMPORTANT;
  }

  #globalHeader {
    display: none;
  }
}