﻿html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    vertical-align: baseline;
    background: rgba(0, 0, 0, 0)
  }
  
  body {
    line-height: 1;
    -webkit-text-size-adjust: 100%
  }
  
  article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
    display: block
  }
  
  ul, ol {
    list-style: none
  }
  
  blockquote, q {
    quotes: none
  }
  
  blockquote:before, blockquote:after, q:before, q:after {
    content: "";
    content: none
  }
  
  a {
    margin: 0;
    padding: 0;
    vertical-align: baseline;
    background: rgba(0, 0, 0, 0);
    text-decoration: none;
    color: inherit
  }
  
  ins {
    background-color: #ff9;
    color: #ada3a3;
    text-decoration: none
  }
  
  mark {
    background-color: #ff9;
    color: #000;
    font-style: italic;
    font-weight: bold
  }
  
  del {
    text-decoration: line-through
  }
  
  abbr[title], dfn[title] {
    border-bottom: 1px dotted;
    cursor: help
  }
  
  table {
    border-collapse: collapse;
    border-spacing: 0
  }
  
  hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #ccc;
    margin: 1em 0;
    padding: 0
  }
  
  input, textarea, button {
    padding: 0;
    border: none;
    border-radius: 0;
    outline: none;
    background: none
  }
  
  select {
    outline: none;
    background: none rgba(0, 0, 0, 0);
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none
  }
  
  input::-ms-clear {
    visibility: hidden
  }
  
  select:disabled, select:disabled::-ms-value {
    background: none;
    color: #333
  }
  
  select::-ms-expand {
    display: none
  }
  
  select:-moz-focusring {
    color: rgba(0, 0, 0, 0);
    text-shadow: 0 0 0 #828c9a
  }
  
  button, input[typr=submit] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
  }
  
  input[type=search]::-webkit-search-cancel-button, input[type=search]::-webkit-search-decoration, input[type=submit], input[type=button] {
    -webkit-appearance: none
  }
  
  * {
    box-sizing: border-box
  }
  
  *::before, *::after {
    box-sizing: inherit
  }
  
  html {
    width: 100%
  }
  
  body {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
  }
  
  img {
    width: 100%;
    max-width: 100%;
    height: auto
  }
  
  @media print, screen and (min-width: 768px) {
    img {
      width: auto
    }
  }
  
  html {
    font-size: 62.5%;
    text-size-adjust: 100%
  }
  
  body {
    font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
    font-weight: 400;
    min-width: 320px;
    overflow-x: hidden;
    overflow-y: scroll;
    font-size: 1.4rem;
    color: #333;
    letter-spacing: .04em;
    -webkit-overflow-scrolling: touch;
    word-break: break-word
  }
  
  main {
    display: block;
    line-height: 1.57
  }
  
  .no-scroll {
    width: 100%;
    height: 100vh;
    overflow: hidden
  }
  
  @media screen and (min-width: 767px), print {
    .no-scroll {
      width: auto;
      height: auto;
      overflow: scroll
    }
  }
  
  * {
    background-repeat: no-repeat
  }
  
  *::before, *::after {
    background-repeat: no-repeat
  }
  
  img {
    width: auto;
    max-width: 100%;
    height: auto;
    max-height: 100%;
    vertical-align: middle;
    border: none
  }
  
  a {
    color: inherit;
    text-decoration: none;
    word-break: break-word
  }
  
  input, button, textarea {
    padding: 0;
    margin: 0;
    font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
    font-weight: 400;
    color: #333
  }
  
  address {
    font-style: normal
  }
  
  pre, code {
    font-family: inherit
  }
  
  pre {
    word-break: break-word;
    white-space: pre-wrap
  }
  
  button::-moz-focus-inner {
    border: 0
  }
  
  button:hover {
    cursor: pointer
  }
  
  @page {
    size: a4;
    margin: 12.7mm 9.7mm
  }
  
  @media print {
    body {
      top: 0 !important;
      left: 0 !important;
      width: 200mm !important;
      height: 251mm !important;
      padding: 0 !important;
      margin: 0 !important;
      overflow: visible !important;
      -webkit-print-color-adjust: exact;
      size: a4 portrait;
      page-break-before: auto;
      page-break-after: auto
    }
    main {
      margin-top: 0 !important;
      overflow: visible !important
    }
    .header, .footer, .pagetop, .container--col2__aside {
      display: none !important
    }
    .container--m, .container--col2 {
      padding-right: 0 !important;
      padding-left: 0 !important
    }
    .container--col2__main {
      width: 100% !important;
      margin-right: 0 !important
    }
    table {
      max-width: 100% !important
    }
  }
  
  .container {
    margin-top: 2rem;
    margin-bottom: 6rem
  }
  
  @media screen and (min-width: 767px), print {
    .container {
      margin-top: 3rem;
      margin-bottom: 10rem
    }
  }
  
  .container>*:first-child {
    margin-top: 0
  }
  
  .container--l {
    max-width: 100%;
    padding-right: 20px;
    padding-left: 20px
  }
  
  @media screen and (min-width: 767px), print {
    .container--l {
      max-width: 1464px;
      padding-right: 32px;
      padding-left: 32px;
      margin: 0 auto
    }
  }
  
  .container--m {
    max-width: 100%;
    padding-right: 20px;
    padding-left: 20px
  }
  
  @media screen and (min-width: 767px), print {
    .container--m {
      max-width: 1264px;
      padding-right: 32px;
      padding-left: 32px;
      margin: 0 auto
    }
  }
  
  .container--m>.ttl:first-child {
    margin-top: 0
  }
  
  .container--s {
    max-width: 100%;
    padding-right: 20px;
    padding-left: 20px
  }
  
  @media screen and (min-width: 767px), print {
    .container--s {
      max-width: 1024px;
      padding-right: 32px;
      padding-left: 32px;
      margin: 0 auto
    }
  }
  
  .container--s>.ttl:first-child {
    margin-top: 0
  }
  
  .container--col2 {
    max-width: 100%;
    padding-right: 20px;
    padding-left: 20px;
    margin-top: 2rem
  }
  
  @media screen and (min-width: 767px), print {
    .container--col2 {
      display: flex;
      max-width: 1264px;
      padding-right: 32px;
      padding-left: 32px;
      margin: 4rem auto 0
    }
  }
  
  @media screen and (min-width: 767px), print {
    .container--col2__main {
      width: calc(100% - 32rem)
    }
  }
  
  .container--col2__main>.ttl:first-child {
    margin-top: 0
  }
  
  .container--col2__aside .localnav {
    display: none
  }
  
  .container--col2__aside .side-bnr:first-of-type {
    margin-top: 6rem
  }
  
  @media screen and (min-width: 767px), print {
    .container--col2__aside {
      display: block;
      flex-shrink: 0;
      width: 28rem;
      margin-left: 4rem
    }
    .container--col2__aside .localnav {
      display: block
    }
    .container--col2__aside .side-bnr:first-of-type {
      margin-top: 1.6rem
    }
  }
  
  .pagetop {
    display: block;
    width: 100%;
    color: #fff;
    background: #d83320;
    border: 2px solid #d83320
  }
  
  @media screen and (min-width: 1060px) {
    .pagetop {
      position: fixed;
      right: 2rem;
      bottom: 2rem;
      z-index: 99;
      width: 8rem;
      height: 8rem;
      transition: all .2s
    }
    .pagetop.fixed {
      position: absolute;
      top: -4rem;
      bottom: auto
    }
    .pagetop:hover, .pagetop:focus-visible {
      color: #d83320;
      text-decoration: underline;
      background: #fff
    }
    .pagetop:hover .pagetop__txt::before, .pagetop:focus-visible .pagetop__txt::before {
      border-top: 2px solid #d83320;
      border-right: 2px solid #d83320
    }
  }
  
  .pagetop__txt {
    position: relative;
    display: block;
    padding-top: 2.8rem;
    padding-bottom: 1.4rem;
    text-align: center;
    letter-spacing: .08em
  }
  
  @media screen and (min-width: 1060px) {
    .pagetop__txt {
      padding-top: 2.2rem;
      padding-bottom: 0;
      margin-top: 1rem;
      font-size: 1.4rem;
      line-height: 1.35;
      letter-spacing: 0
    }
  }
  
  .pagetop__txt::before {
    position: absolute;
    top: 1.2rem;
    left: 50%;
    display: block;
    width: 1rem;
    height: 1rem;
    content: "";
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(-45deg) translateX(-50%)
  }
  
  @media screen and (min-width: 1060px) {
    .pagetop__txt::before {
      top: 0;
      width: 1.6rem;
      height: 1.6rem
    }
  }
  
  .footer {
    position: relative
  }
  
  .footer-bnr__inner {
    position: relative
  }
  
  .footer-bnr__inner.--tab, .footer-bnr__inner.--pc {
    display: none
  }
  
  @media screen and (min-width: 767px), print {
    .footer-bnr__inner.--sp {
      display: none
    }
    .footer-bnr__inner.--tab {
      display: flex
    }
  }
  
  @media screen and (min-width: 1060px) {
    .footer-bnr__inner.--sp-tab {
      display: none
    }
    .footer-bnr__inner.--pc {
      display: flex
    }
  }
  
  @media screen and (min-width: 767px), print {
    .footer-bnr__inner.--no-slide .footer-bnr__item {
      width: 50%
    }
  }
  
  @media screen and (min-width: 1060px) {
    .footer-bnr__inner.--no-slide .footer-bnr__item {
      width: 33.3333333333%
    }
  }
  
  @media screen and (min-width: 767px), print {
    .footer-bnr__item {
      padding: 0 2.1rem
    }
  }
  
  .footer-bnr__item a {
    display: block
  }
  
  .footer-bnr__item a img {
    transition: all .2s
  }
  
  .footer-bnr__item a:hover img, .footer-bnr__item a:focus-visible img {
    box-shadow: 2px 2px #fff, 6px 6px 0 #707070
  }
  
  .footer-bnr__item a:hover .icon-target, .footer-bnr__item a:focus-visible .icon-target {
    text-decoration: none
  }
  
  .footer-bnr__item a.icon--pdf::after {
    content: none
  }
  
  .footer-bnr__item a.icon--pdf .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("/en/common/img/icon-pdf.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .footer-bnr__item a.icon--pdf .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .footer-bnr__item a.icon--doc::after {
    content: none
  }
  
  .footer-bnr__item a.icon--doc .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("/en/common/img/icon-doc.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .footer-bnr__item a.icon--doc .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .footer-bnr__item a.icon--xls::after {
    content: none
  }
  
  .footer-bnr__item a.icon--xls .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("/en/common/img/icon-xls.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .footer-bnr__item a.icon--xls .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .footer-bnr__item a.icon--zip::after {
    content: none
  }
  
  .footer-bnr__item a.icon--zip .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("/en/common/img/icon-zip.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .footer-bnr__item a.icon--zip .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .footer-bnr__item a.icon--file::after {
    content: none
  }
  
  .footer-bnr__item a.icon--file .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("/en/common/img/icon-file.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .footer-bnr__item a.icon--file .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .footer-bnr__item a.icon--out::after {
    content: none
  }
  
  .footer-bnr__item a.icon--out .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.2rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("/en/common/img/icon-out.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .footer-bnr__item a.icon--out .icon-target::after {
      width: 1.5rem;
      height: 1.5rem
    }
  }
  
  @media screen and (min-width: 767px), print {
    .footer-bnr .swiper {
      width: calc(100% + 4.2rem);
      margin-left: -2.1rem
    }
  }
  
  @media screen and (min-width: 767px), print {
    .footer-bnr .swiper-button-prev, .footer-bnr .swiper-button-next {
      top: calc((100% - 4.6rem)*.5 - 2rem);
      width: 4rem;
      height: 4rem;
      background: #134798
    }
  }
  
  .footer-bnr .swiper-button-prev::after, .footer-bnr .swiper-button-next::after {
    right: 1.4rem;
    width: 1.2rem;
    height: 1.2rem;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff
  }
  
  @media screen and (min-width: 767px), print {
    .footer-bnr .swiper-button-prev {
      left: 0
    }
  }
  
  @media screen and (min-width: 767px), print {
    .footer-bnr .swiper-button-next {
      right: 0
    }
  }
  
  .footer-bnr .swiper-horizontal>.swiper-pagination-bullets, .footer-bnr .swiper-pagination-bullets.swiper-pagination-horizontal, .footer-bnr .swiper-pagination-custom, .footer-bnr .swiper-pagination-fraction {
    bottom: 5rem
  }
  
  .footer-bnr+.footer__main {
    margin-top: 2.7rem;
    padding-top: 3rem;
    border-top: 1px solid #bbb
  }
  
  @media screen and (min-width: 767px), print {
    .footer-bnr+.footer__main {
      margin-top: 4.8rem
    }
  }
  
  .footer__main {
    display: flex;
    flex-direction: column;
    gap: 3rem 0
  }
  
  @media screen and (min-width: 767px), print {
    .footer__main {
      flex-direction: row
    }
  }
  
  @media screen and (min-width: 767px), print {
    .footer-info {
      width: 42%;
      padding-right: 2.5em
    }
  }
  
  .footer-logo {
    text-align: center
  }
  
  @media screen and (min-width: 767px), print {
    .footer-logo {
      text-align: left
    }
  }
  
  .footer-logo a {
    display: inline-block;
    position: relative;
    transition: all .2s
  }
  
  .footer-logo a:hover::after, .footer-logo a:focus-visible::after {
    display: block;
    pointer-events: none;
    content: "";
    border: 3px solid #3d67a9;
    width: calc(100% + 2rem);
    height: calc(100% + 2rem);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%)
  }
  
  .footer-logo img {
    width: 30rem
  }
  
  @media screen and (min-width: 767px), print {
    .footer-logo img {
      width: 37.5rem
    }
  }
  
  .footer-contact__btn {
    display: none
  }
  
  @media screen and (min-width: 767px), print {
    .footer-contact__btn {
      justify-content: space-between;
      width: 15.6rem;
      min-height: 4.2rem;
      padding: 1rem 1rem 1rem 1.6rem;
      margin-top: 2.4rem;
      color: #fff;
      background: #134798;
      display: flex;
      align-items: center
    }
    .footer-contact__btn:hover, .footer-contact__btn:focus-visible {
      text-decoration: underline
    }
    .footer-contact__btn::after {
      display: block;
      width: 1.2rem;
      height: 1.2rem;
      content: "";
      border-top: 2px solid #fff;
      border-right: 2px solid #fff;
      transform: rotate(45deg)
    }
  }
  
  .footer-add {
    margin-top: 3rem;
    line-height: 1.83
  }
  
  @media screen and (min-width: 767px), print {
    .footer-add {
      line-height: 1.56
    }
  }
  
  @media screen and (min-width: 767px), print {
    .footer-list {
      width: 27.75%;
      padding-right: 2em
    }
  }
  
  .footer-list__item {
    position: relative;
    padding-left: 2.2rem;
    margin-top: 1.4rem;
    font-size: 1.2rem;
    line-height: 1.4
  }
  
  @media screen and (min-width: 767px), print {
    .footer-list__item {
      padding-left: 1.7rem;
      margin-top: 1.5rem;
      font-size: 1.6rem
    }
  }
  
  .footer-list__item a:hover, .footer-list__item a:focus-visible {
    text-decoration: underline
  }
  
  .footer-list__item:first-of-type {
    margin-top: 0
  }
  
  .footer-list__item::before {
    position: absolute;
    top: .8rem;
    left: 0;
    display: block;
    width: .7rem;
    height: .1rem;
    content: "";
    background: #333
  }
  
  @media screen and (min-width: 767px), print {
    .footer-list__item::before {
      top: 1rem;
      width: 1rem
    }
  }
  
  .footer-list__item .pc {
    display: none
  }
  
  @media screen and (min-width: 767px), print {
    .footer-list__item .pc {
      display: block
    }
  }
  
  @media screen and (min-width: 767px), print {
    .footer-nav {
      width: 30%
    }
  }
  
  .footer-nav__item {
    position: relative;
    padding-left: 2.2rem;
    margin-top: 1.4rem;
    line-height: 1.4
  }
  
  @media screen and (min-width: 767px), print {
    .footer-nav__item {
      padding-left: 3.2rem;
      margin-top: 2.4rem;
      font-size: 1.8rem
    }
  }
  
  .footer-nav__item a:hover, .footer-nav__item a:focus-visible {
    text-decoration: underline
  }
  
  .footer-nav__item:first-of-type {
    margin-top: 0
  }
  
  .footer-nav__item::before {
    position: absolute;
    top: .5rem;
    left: 0;
    display: block;
    width: .7rem;
    height: .7rem;
    content: "";
    border-top: 1.5px solid #333;
    border-right: 1.5px solid #333;
    transform: rotate(45deg)
  }
  
  @media screen and (min-width: 767px), print {
    .footer-nav__item::before {
      top: .7rem;
      width: .8rem;
      height: .8rem
    }
  }
  
  .footer-sns {
    display: flex;
    justify-content: center;
    gap: 1rem 2rem;
    margin-top: 3rem
  }
  
  @media screen and (min-width: 767px), print {
    .footer-sns {
      justify-content: flex-start;
      margin-top: 1rem
    }
  }
  
  .footer-sns__item {
    width: 4rem
  }
  
  .footer-sns__item a {
    display: block;
    position: relative;
    transition: all .2s
  }
  
  .footer-sns__item a:hover::after, .footer-sns__item a:focus-visible::after {
    display: block;
    pointer-events: none;
    content: "";
    border: 3px solid #3d67a9;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%)
  }
  
  .footer__bar {
    padding: .7rem calc(50vw - 50%) 2rem;
    margin: 0 calc(50% - 50vw);
    background: #3d67a9
  }
  
  @media screen and (min-width: 767px), print {
    .footer__bar {
      margin-top: 4rem
    }
  }
  
  @media screen and (min-width: 767px), print {
    .footer-link {
      display: flex;
      align-items: center;
      justify-content: center;
      flex-wrap: wrap
    }
  }
  
  .footer-link__item {
    display: inline-block;
    margin-top: 1.3rem;
    margin-right: 2.6rem;
    line-height: 1.43;
    color: #fff
  }
  
  @media screen and (min-width: 767px), print {
    .footer-link__item {
      margin-right: 0;
      margin-left: 1.6rem;
      font-size: 1.4rem
    }
    .footer-link__item:first-of-type {
      margin-left: 0
    }
  }
  
  .footer-link__item a:hover, .footer-link__item a:focus-visible {
    text-decoration: underline
  }
  
  @media screen and (min-width: 767px), print {
    .footer-link__item a.icon--pdf::after {
      width: 1.4rem;
      height: 1.5rem;
      margin-bottom: -0.2rem
    }
  }
  
  @media screen and (min-width: 767px), print {
    .footer-link__item a.icon--doc::after {
      width: 1.4rem;
      height: 1.5rem;
      margin-bottom: -0.2rem
    }
  }
  
  @media screen and (min-width: 767px), print {
    .footer-link__item a.icon--xls::after {
      width: 1.4rem;
      height: 1.5rem;
      margin-bottom: -0.2rem
    }
  }
  
  @media screen and (min-width: 767px), print {
    .footer-link__item a.icon--zip::after {
      width: 1.4rem;
      height: 1.5rem;
      margin-bottom: -0.2rem
    }
  }
  
  @media screen and (min-width: 767px), print {
    .footer-link__item a.icon--file::after {
      width: 1.4rem;
      height: 1.5rem;
      margin-bottom: -0.2rem
    }
  }
  
  .footer-link__item a.icon--out::after {
    background: url(../img/icon-out-w.png) no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .footer-link__item a.icon--out::after {
      width: 1.2rem;
      height: 1.2rem
    }
  }
  
  .footer-link__item:last-of-type {
    margin-right: 0
  }
  
  @media screen and (min-width: 767px), print {
    .footer-link__item:last-of-type::after {
      content: none
    }
  }
  
  .footer-link__item::before {
    display: inline-block;
    width: 0;
    height: 0;
    margin: 0 4px 2px 0;
    content: "";
    border-color: rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) #fff;
    border-style: solid;
    border-width: 3px 0 3px 4px
  }
  
  @media screen and (min-width: 767px), print {
    .footer-link__item::after {
      display: inline-block;
      width: .1rem;
      height: 1.2rem;
      margin-left: 1.6rem;
      content: "";
      background: #fff
    }
  }
  
  .footer-copyright {
    padding: 1.4rem 2rem 1.2rem;
    background: #fff
  }
  
  @media screen and (min-width: 767px), print {
    .footer-copyright {
      padding: 2rem
    }
  }
  
  .footer-copyright__txt {
    font-size: 1rem;
    line-height: 1.6;
    text-align: center
  }
  
  @media screen and (min-width: 767px), print {
    .footer-copyright__txt {
      font-size: 1.4rem
    }
  }
  
  .footer-copyright__txt span {
    display: inline-block
  }
  
  .skip-link__item {
    position: absolute
  }
  
  .skip-link__item a {
    position: absolute;
    top: 0;
    left: -1000em;
    z-index: 1000;
    display: inline;
    width: 26.4rem;
    padding: .5rem;
    font-size: 1.4rem;
    text-align: center;
    text-decoration: none
  }
  
  .skip-link__item a:focus-visible {
    position: absolute;
    top: -3rem;
    left: 34.5rem;
    background: none repeat scroll 0 0 #fff !important;
    border: 2px solid #000
  }
  
  .header {
    width: 100%;
    height: 4rem
  }
  
  @media screen and (min-width: 1060px) {
    .header {
      position: fixed;
      top: 0;
      left: 0;
      z-index: 999;
      height: 10rem
    }
  }
  
  .header__inner {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    padding-left: 2rem;
    padding-right: 3rem;
    background: #fff;
    box-shadow: 0 .3rem .6rem rgba(0, 0, 0, .16);
    transition-duration: .2s
  }
  
  @media screen and (min-width: 1060px) {
    .header__inner {
      justify-content: space-between;
      padding: 0 1.4rem 0 3.5rem;
      padding: 0 1.4rem 0 3.5rem
    }
  }
  
  .header-logo {
    width: 11.6rem
  }
  
  @media screen and (min-width: 1060px) {
    .header-logo {
      width: 18.21%;
      max-width: 25.5rem
    }
  }
  
  .header-logo a {
    display: block;
    position: relative;
    transition: all .2s
  }
  
  .header-logo a:hover::after, .header-logo a:focus-visible::after {
    display: block;
    pointer-events: none;
    content: "";
    border: 3px solid #3d67a9;
    width: calc(100% + 2rem);
    height: calc(100% + 2rem);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%)
  }
  
  .header-logo img {
    width: 100%
  }
  
  .header-link__wrap {
    position: fixed;
    bottom: 0;
    left: 0;
    z-index: 999;
    display: flex;
    width: 100%
  }
  
  @media screen and (min-width: 1060px) {
    .header-link__wrap {
      position: static;
      justify-content: flex-end
    }
  }
  
  .header-link__list {
    display: flex;
    flex-grow: 1;
    background: #fbfbf7;
    border-top: 1px solid #c2c2c2;
    border-bottom: 1px solid #c2c2c2;
    border-left: 1px solid #c2c2c2
  }
  
  @media screen and (min-width: 1060px) {
    .header-link__list {
      flex-grow: 0;
      background: none;
      border: none
    }
  }
  
  .header-link__item {
    position: relative;
    width: 100%
  }
  
  @media screen and (min-width: 1060px) {
    .header-link__item {
      width: auto;
      margin-right: 2rem
    }
  }
  
  .header-link__item::after {
    right: 0;
    display: block;
    width: .1rem;
    height: 5rem;
    content: "";
    background: #bbb;
    position: absolute;
    top: 50%;
    transform: translateY(-50%)
  }
  
  @media screen and (min-width: 1060px) {
    .header-link__item::after {
      content: none
    }
  }
  
  @media screen and (min-width: 1060px) {
    .header-link__item:last-of-type {
      margin-right: 0
    }
  }
  
  .header-link__item:last-of-type::after {
    content: none
  }
  
  .header-link__item.--about, .header-link__item.--lang, .header-link__item.--sns {
    display: none
  }
  
  @media screen and (min-width: 1060px) {
    .header-link__item.--about, .header-link__item.--lang, .header-link__item.--sns {
      display: block
    }
  }
  
  @media screen and (min-width: 1060px) {
    .header-link__item.--about a, .header-link__item.--contact a, .header-link__item.--lang a, .header-link__item.--sns a {
      position: relative
    }
    .header-link__item.--about a::before, .header-link__item.--contact a::before, .header-link__item.--lang a::before, .header-link__item.--sns a::before {
      position: absolute;
      bottom: 0;
      left: .6rem;
      width: calc(100% - 1.2rem);
      height: .2rem;
      content: "";
      background-color: #134798;
      transition: transform .2s;
      transform: scale(0, 1);
      transform-origin: right top
    }
    .header-link__item.--about a:hover::before, .header-link__item.--about a:focus-visible::before, .header-link__item.--contact a:hover::before, .header-link__item.--contact a:focus-visible::before, .header-link__item.--lang a:hover::before, .header-link__item.--lang a:focus-visible::before, .header-link__item.--sns a:hover::before, .header-link__item.--sns a:focus-visible::before {
      transform: scale(1, 1);
      transform-origin: left top
    }
    .header-link__item.--about a.icon--out::after, .header-link__item.--contact a.icon--out::after, .header-link__item.--lang a.icon--out::after, .header-link__item.--sns a.icon--out::after {
      width: 1.2rem;
      height: 1.2rem
    }
  }
  
  .header-link__item.--pagetop {
    background: #fff
  }
  
  .header-link__item.--pagetop svg {
    width: 2.5rem;
    height: 1.6rem;
    margin-bottom: .1rem
  }
  
  @media screen and (min-width: 1060px) {
    .header-link__item.--pagetop {
      display: none
    }
  }
  
  @media screen and (min-width: 1060px) {
    .header-link__item.--about svg {
      width: 1.4rem;
      height: 1.8rem;
      margin-bottom: .1rem
    }
  }
  
  .header-link__item.--contact svg {
    width: 2.3rem;
    height: 1.7rem
  }
  
  @media screen and (min-width: 1060px) {
    .header-link__item.--contact svg {
      width: 1.8rem;
      height: 1.4rem
    }
  }
  
  @media screen and (min-width: 1060px) {
    .header-link__item.--lang svg {
      width: 1.6rem;
      height: 1.6rem
    }
  }
  
  @media screen and (min-width: 1060px) {
    .header-link__item.--sns svg {
      width: 2rem;
      height: 1.6rem
    }
  }
  
  .header-link__item.--search .header-search__trigger.is-open {
    background: #134798
  }
  
  .header-link__item.--search .header-search__trigger.is-open .header-link__txt {
    color: #fbfbf7;
    text-decoration: underline
  }
  
  .header-link__item.--search .header-search__trigger.is-open path {
    fill: #fbfbf7
  }
  
  @media screen and (min-width: 1060px) {
    .header-link__item.--search .header-search__trigger {
      width: 11rem;
      padding: .7rem 1rem .6rem;
      border: 1px solid #333;
      border-radius: 50vh;
      transition: all .2s;
      position: relative
    }
    .header-link__item.--search .header-search__trigger::after {
      width: .6rem;
      height: .6rem;
      content: "";
      border-top: .1rem solid #333;
      border-right: .1rem solid #333;
      display: block;
      position: absolute;
      content: "";
      transform: rotate(135deg);
      top: calc(50% - .3rem);
      right: 1.4rem
    }
    .header-link__item.--search .header-search__trigger .header-link__txt {
      margin-left: 1.7rem
    }
    .header-link__item.--search .header-search__trigger:hover, .header-link__item.--search .header-search__trigger:focus-visible, .header-link__item.--search .header-search__trigger.is-open {
      background: #333
    }
    .header-link__item.--search .header-search__trigger:hover::after, .header-link__item.--search .header-search__trigger:focus-visible::after, .header-link__item.--search .header-search__trigger.is-open::after {
      border-top: .1rem solid #fff;
      border-right: .1rem solid #fff
    }
    .header-link__item.--search .header-search__trigger:hover .header-link__txt, .header-link__item.--search .header-search__trigger:focus-visible .header-link__txt, .header-link__item.--search .header-search__trigger.is-open .header-link__txt {
      color: #fff;
      text-decoration: underline
    }
    .header-link__item.--search .header-search__trigger:hover path, .header-link__item.--search .header-search__trigger:focus-visible path, .header-link__item.--search .header-search__trigger.is-open path {
      fill: #fff
    }
  }
  
  .header-link__item.--search .header-search__trigger:focus-visible {
    outline: auto
  }
  
  .header-link__item.--search svg {
    width: 2.5rem;
    height: 2.5rem
  }
  
  @media screen and (min-width: 1060px) {
    .header-link__item.--search svg {
      width: 1.6rem;
      height: 1.6rem
    }
  }
  
  @media screen and (min-width: 1060px) {
    .header-link__item.--purpose a {
      padding: .8rem 1.5rem .7rem 1.1rem;
      background: #d83320;
      border: 1px solid #d83320;
      transition: all .2s
    }
    .header-link__item.--purpose a .header-link__txt {
      font-size: 1.4rem;
      color: #fff
    }
    .header-link__item.--purpose a:hover, .header-link__item.--purpose a:focus-visible {
      color: #d83320;
      text-decoration: underline;
      background: #fff
    }
    .header-link__item.--purpose a:hover .header-link__txt, .header-link__item.--purpose a:focus-visible .header-link__txt {
      color: #d83320
    }
    .header-link__item.--purpose a:hover rect, .header-link__item.--purpose a:focus-visible rect {
      fill: #d83320
    }
  }
  
  .header-link__item.--purpose svg {
    width: 2.1rem;
    height: 2.1rem
  }
  
  @media screen and (min-width: 1060px) {
    .header-link__item.--purpose svg {
      width: 1.3rem;
      height: 1.3rem
    }
    .header-link__item.--purpose svg rect {
      fill: #fff
    }
  }
  
  .header-link__item>a, .header-link__item>button {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    align-items: flex-end;
    width: 100%;
    height: 100%;
    padding-bottom: .8rem
  }
  
  @media screen and (min-width: 1060px) {
    .header-link__item>a, .header-link__item>button {
      align-items: center;
      justify-content: flex-start;
      padding: .6rem
    }
  }
  
  .header-link__item path, .header-link__item rect {
    fill: #134798
  }
  
  @media screen and (min-width: 1060px) {
    .header-link__item path, .header-link__item rect {
      fill: #333
    }
  }
  
  .header-link__txt {
    width: 100%;
    font-size: 1.2rem;
    line-height: 1;
    color: #333;
    text-align: center
  }
  
  @media screen and (min-width: 1060px) {
    .header-link__txt {
      width: auto;
      margin-left: .6rem
    }
  }
  
  .header-menu {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 20;
    width: 100%;
    height: 100%;
    overflow-y: scroll;
    background: #fff;
    transition: all .2s cubic-bezier(0, 0, 0.2, 1) 0ms;
    transform: translateY(100vh);
    -webkit-overflow-scrolling: touch
  }
  
  @media screen and (min-width: 1060px) {
    .header-menu {
      position: static;
      display: block;
      width: auto;
      height: auto;
      overflow-y: visible;
      background: none;
      transform: none
    }
  }
  
  .header-menu.is-open {
    transition: all .2s cubic-bezier(0, 0, 0.2, 1) 0ms;
    transform: translateY(0)
  }
  
  .header-menu__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    flex-wrap: wrap;
    width: 6.5rem;
    height: 6.5rem;
    padding: 1.2rem 0 .6rem;
    background: #d83320
  }
  
  @media screen and (min-width: 1060px) {
    .header-menu__btn {
      display: none
    }
  }
  
  .header-menu__btn__inner span {
    display: block;
    height: .2rem;
    margin-top: .7rem;
    margin-left: auto;
    background: #fff
  }
  
  .header-menu__btn__inner span:first-of-type {
    width: 3rem;
    margin-top: 0
  }
  
  .header-menu__btn__inner span:nth-of-type(2) {
    width: 2.5rem
  }
  
  .header-menu__btn__inner span:nth-of-type(3) {
    width: 1.8rem
  }
  
  .header-menu__btn.is-open .header-menu__btn__inner span:nth-child(1) {
    width: 2.5rem;
    transform: rotate(45deg) translate(0.4rem, 0.4rem)
  }
  
  .header-menu__btn.is-open .header-menu__btn__inner span:nth-child(2) {
    opacity: 0
  }
  
  .header-menu__btn.is-open .header-menu__btn__inner span:nth-child(3) {
    width: 2.5rem;
    margin-top: 0;
    transform: rotate(-45deg) translate(0.4rem, -0.4rem)
  }
  
  .header-menu__btn__txt {
    width: 100%;
    font-size: 1.2rem;
    line-height: 1;
    color: #fff;
    text-align: center
  }
  
  @media screen and (min-width: 1060px) {
    .header-nav__wrap {
      padding-top: .6rem
    }
  }
  
  @media screen and (min-width: 1060px) {
    .header-nav__lists {
      display: flex;
      justify-content: flex-end;
      margin-right: -1rem
    }
  }
  
  @media screen and (min-width: 1060px) {
    .header-nav__list {
      margin-right: 2.8rem
    }
    .header-nav__list.sp {
      display: none
    }
    .header-nav__list:nth-last-of-type(2) {
      margin-right: 0
    }
  }
  
  .header-nav__btn {
    position: relative;
    display: block;
    width: 100%;
    padding: 1.6rem 4rem 1.7rem 2rem;
    font-size: 1.4rem;
    font-weight: 600;
    color: #134798;
    text-align: left;
    background: #d0e3f1;
    border-bottom: 1px solid #707070
  }
  
  @media screen and (min-width: 1060px) {
    .header-nav__btn {
      width: auto;
      padding: 0;
      font-size: 1.6rem;
      line-height: 1.2;
      color: #333;
      background: none;
      border-bottom: none
    }
    .header-nav__btn:hover .header-nav__txt::after, .header-nav__btn:focus-visible .header-nav__txt::after {
      transform: scale(1, 1);
      transform-origin: left top
    }
  }
  
  .header-nav__btn::before, .header-nav__btn::after {
    display: block;
    content: "";
    background: #363636;
    position: absolute;
    top: 50%;
    transform: translateY(-50%)
  }
  
  @media screen and (min-width: 1060px) {
    .header-nav__btn::before, .header-nav__btn::after {
      content: none
    }
  }
  
  .header-nav__btn::before {
    right: 2rem;
    width: 1.4rem;
    height: .2rem
  }
  
  .header-nav__btn::after {
    right: 2.6rem;
    width: .2rem;
    height: 1.4rem;
    transition: all .3s
  }
  
  .header-nav__btn.is-open::after {
    right: 2rem;
    opacity: 0;
    transform: rotate(90deg);
    transform-origin: center top
  }
  
  .header-nav__btn.is-open .header-nav__txt::after, .header-nav__btn.current .header-nav__txt::after {
    transform: scale(1, 1)
  }
  
  .header-nav__btn:focus-visible {
    outline: auto
  }
  
  @media screen and (min-width: 1060px) {
    .header-nav__txt {
      display: block;
      position: relative;
      padding: .6rem 1.4rem;
      font-size: 1.6rem
    }
    .header-nav__txt::after {
      position: absolute;
      bottom: 0;
      left: 1.4rem;
      width: calc(100% - 2.8rem);
      height: .2rem;
      content: "";
      background-color: #134798;
      transition: transform .2s;
      transform: scale(0, 1);
      transform-origin: right top
    }
  }
  
  .header-nav__txt .pc {
    display: none
  }
  
  @media screen and (min-width: 1060px) {
    .header-nav__txt .pc {
      display: block
    }
  }
  
  .header-nav__heading {
    display: none
  }
  
  @media screen and (min-width: 1060px) {
    .header-nav__heading {
      display: block;
      font-size: 3rem;
      font-weight: 600;
      padding-bottom: 2.4rem;
      position: relative
    }
    .header-nav__heading::before {
      content: "";
      display: block;
      width: 8rem;
      height: 4px;
      background: #d83320;
      position: absolute;
      left: 0;
      bottom: 0
    }
  }
  
  .header-nav__child {
    display: none
  }
  
  @media screen and (min-width: 1060px) {
    .header-nav__child {
      display: none !important
    }
  }
  
  .header-nav__child__content .btn-list__item {
    display: none
  }
  
  .header-nav__child__item {
    background: #f3f3f3;
    border-bottom: 1px solid #707070;
    font-weight: 600;
    line-height: 1.4
  }
  
  .header-nav__child__item a {
    width: 100%;
    position: relative;
    display: block;
    padding: 1.7rem 4rem 1.6rem 2rem;
    position: relative
  }
  
  .header-nav__child__item a::after {
    width: 1rem;
    height: 1rem;
    content: "";
    border-top: .2rem solid #363636;
    border-right: .2rem solid #363636;
    display: block;
    position: absolute;
    transform: rotate(45deg);
    top: 0;
    right: 2rem;
    bottom: 0;
    margin: auto
  }
  
  .header-search {
    position: fixed;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: calc(100% - 6.5rem);
    padding-top: 4rem;
    overflow-y: scroll;
    background: #e7f3fc;
    transition: all .2s cubic-bezier(0, 0, 0.2, 1) 0ms;
    transform: translateY(100vh);
    -webkit-overflow-scrolling: touch
  }
  
  @media screen and (min-width: 1060px) {
    .header-search {
      top: 9.6rem;
      display: none;
      height: auto;
      padding: 8rem 0;
      overflow-y: visible;
      transform: translateY(-100vh)
    }
  }
  
  .header-search.is-open {
    display: block;
    transition: all .2s cubic-bezier(0, 0, 0.2, 1) 0ms;
    transform: translateY(0)
  }
  
  .header-search__form.search__form {
    max-width: none;
    height: 5.8rem
  }
  
  @media screen and (min-width: 1060px) {
    .header-search__form.search__form {
      width: calc(100% - 12rem);
      height: 8rem
    }
  }
  
  .header-search__form__txt.search__form__txt {
    width: calc(100% - 5.8rem);
    padding: 1.5rem;
    font-size: 1.6rem
  }
  
  @media screen and (min-width: 1060px) {
    .header-search__form__txt.search__form__txt {
      width: calc(100% - 7.6rem);
      padding: 2.6rem 3rem;
      font-size: 2rem
    }
  }
  
  .header-search__form__btn.search__form__btn {
    width: 5.8rem;
    background: url(../img/icon-search_w.png) center center/2.3rem 2.3rem no-repeat #134798
  }
  
  @media screen and (min-width: 1060px) {
    .header-search__form__btn.search__form__btn {
      width: 7.6rem;
      background-size: 3rem 3rem
    }
  }
  
  .header-search__form__btn.search__form__btn:hover, .header-search__form__btn.search__form__btn:focus-visible {
    background: url(../img/icon-search_b.png) center center/2.3rem 2.3rem no-repeat #fff
  }
  
  @media screen and (min-width: 1060px) {
    .header-search__form__btn.search__form__btn:hover, .header-search__form__btn.search__form__btn:focus-visible {
      width: 7.6rem;
      background-size: 3rem 3rem
    }
  }
  
  .header-search__close {
    position: fixed;
    right: 1.6rem;
    bottom: 2.4rem
  }
  
  @media screen and (min-width: 1060px) {
    .header-search__close {
      top: 2.4rem;
      right: 3rem;
      bottom: auto
    }
  }
  
  .header-search__close::before, .header-search__close::after {
    position: absolute;
    top: 1.5rem;
    left: .5rem;
    display: block;
    width: 2.5rem;
    height: .2rem;
    pointer-events: none;
    content: "";
    background: #333
  }
  
  @media screen and (min-width: 1060px) {
    .header-search__close::before, .header-search__close::after {
      left: .2rem;
      width: 3.8rem
    }
  }
  
  .header-search__close::before {
    transform: rotate(45deg)
  }
  
  .header-search__close::after {
    transform: rotate(-45deg)
  }
  
  .header-search__close .txt {
    display: block;
    padding-top: 3.2rem;
    font-size: 1.2rem
  }
  
  @media screen and (min-width: 1060px) {
    .header-search__close .txt {
      font-size: 1.6rem
    }
  }
  
  .header-search__close:hover .txt, .header-search__close:focus-visible .txt {
    text-decoration: underline
  }
  
  .header-search__close:focus-visible {
    outline: auto
  }
  
  .header-search .keyword {
    margin-top: 3.4rem
  }
  
  @media screen and (min-width: 1060px) {
    .header-search .keyword {
      display: flex;
      align-items: center;
      margin-top: 4.8rem
    }
  }
  
  .header-search .keyword__ttl {
    display: flex;
    align-items: center;
    margin-bottom: 2rem;
    font-size: 2rem;
    font-weight: 500
  }
  
  @media screen and (min-width: 1060px) {
    .header-search .keyword__ttl {
      flex-shrink: 0;
      margin-right: 8rem;
      margin-bottom: 0
    }
  }
  
  .header-search .keyword__ttl::after {
    display: block;
    flex-grow: 1;
    height: .1rem;
    margin-left: 4rem;
    content: "";
    background: #333
  }
  
  @media screen and (min-width: 1060px) {
    .header-search .keyword__ttl::after {
      content: none
    }
  }
  
  @media screen and (min-width: 1060px) {
    .header-search .keyword__list {
      gap: 1.7rem 1rem;
      padding: 0 6rem;
      border-left: 1px solid #333
    }
  }
  
  .localnav {
    line-height: 1.4
  }
  
  .localnav a:hover, .localnav a:focus-visible {
    text-decoration: underline
  }
  
  .localnav__heading {
    display: flex;
    align-items: center;
    min-height: 7.2rem;
    padding: 2rem 4.4rem 1.8rem 1.6rem;
    font-size: 1.8rem;
    line-height: 1.4;
    color: #fff;
    background: #3d67a9;
    position: relative
  }
  
  .localnav__heading::after {
    width: 1.2rem;
    height: 1.2rem;
    content: "";
    border-top: .2rem solid #fff;
    border-right: .2rem solid #fff;
    display: block;
    position: absolute;
    transform: rotate(45deg);
    top: 0;
    right: 1.5rem;
    bottom: 0;
    margin: auto
  }
  
  .localnav__list {
    padding: 0 1.6rem;
    border: 1px solid #bbb
  }
  
  .localnav__list__item {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    font-weight: 600;
    border-bottom: 1px solid #bbb
  }
  
  .localnav__list__item.is-open {
    border-bottom: none
  }
  
  .localnav__list__item>a {
    display: block;
    width: calc(100% - 2.1rem);
    padding: 2rem 1.1rem 2rem 0
  }
  
  .localnav__list__item>a.current {
    color: #134798
  }
  
  .localnav__list__item:last-of-type {
    border-bottom: none
  }
  
  .localnav__list__item:last-of-type .localnav__child-list {
    margin-bottom: 1.6rem
  }
  
  .localnav__list__btn {
    flex-shrink: 0;
    width: 2.1rem;
    height: 2.1rem;
    background: url(../img/arw-down.png) center right/1.4rem .8rem no-repeat;
    transition: all .2s
  }
  
  .localnav__list__btn.active {
    background-position: center left;
    transform: rotate(180deg)
  }
  
  .localnav__child-list {
    display: none;
    width: 100%;
    padding: 1rem 1.3rem 1rem 1.6rem;
    font-weight: 400;
    background: #e7f3fc
  }
  
  .localnav__child-list.current {
    display: block
  }
  
  .localnav__child-list__item {
    display: flex;
    align-items: center;
    flex-wrap: wrap
  }
  
  .localnav__child-list__item>a {
    position: relative;
    display: block;
    width: 100%;
    padding: .6rem 3rem .6rem 0
  }
  
  .localnav__child-list__item>a.current {
    font-weight: 600
  }
  
  .localnav__child-list__item>a::after {
    position: absolute;
    top: 50%;
    right: 0;
    display: block;
    width: 1.4rem;
    height: .8rem;
    content: "";
    background: url(../img/arw-down.png) no-repeat;
    background-size: contain;
    transform: rotate(-90deg) translateX(50%);
    margin: 0
  }
  
  .localnav__child-list__item>a.icon--pdf .localnav__child-list__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-pdf.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .localnav__child-list__item>a.icon--pdf .localnav__child-list__txt::after {
      width: 16px;
      height: 18px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .localnav__child-list__item>a.icon--doc .localnav__child-list__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-doc.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .localnav__child-list__item>a.icon--doc .localnav__child-list__txt::after {
      width: 16px;
      height: 18px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .localnav__child-list__item>a.icon--xls .localnav__child-list__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-xls.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .localnav__child-list__item>a.icon--xls .localnav__child-list__txt::after {
      width: 16px;
      height: 18px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .localnav__child-list__item>a.icon--zip .localnav__child-list__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-zip.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .localnav__child-list__item>a.icon--zip .localnav__child-list__txt::after {
      width: 16px;
      height: 18px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .localnav__child-list__item>a.icon--file .localnav__child-list__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-file.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .localnav__child-list__item>a.icon--file .localnav__child-list__txt::after {
      width: 16px;
      height: 18px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .localnav__child-list__item>a.icon--out .localnav__child-list__txt::after {
    display: inline-block;
    width: 12px;
    height: 12px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-out.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .localnav__child-list__item>a.icon--out .localnav__child-list__txt::after {
      width: 14px;
      height: 14px
    }
  }
  
  .localnav__child-list__item.has-child>a {
    width: calc(100% - 2rem);
    padding-right: 1rem
  }
  
  .localnav__child-list__item.has-child>a::after {
    content: none
  }
  
  .localnav__child-list__btn {
    position: relative;
    flex-shrink: 0;
    width: 2rem;
    height: 2rem
  }
  
  .localnav__child-list__btn::before, .localnav__child-list__btn::after {
    display: block;
    content: "";
    background: #363636;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: all .2s
  }
  
  .localnav__child-list__btn::before {
    width: 1.4rem;
    height: .1rem
  }
  
  .localnav__child-list__btn::after {
    width: .1rem;
    height: 1.4rem
  }
  
  .localnav__child-list__btn.active::after {
    opacity: 0;
    transform: rotate(90deg) translateX(-0.7rem)
  }
  
  .localnav__lower-list {
    display: none;
    width: 100%;
    padding: .7rem 1rem;
    margin-bottom: .6rem;
    font-weight: 400;
    background: #fff
  }
  
  .localnav__lower-list.current {
    display: block
  }
  
  .localnav__lower-list__item {
    position: relative;
    padding-left: 1.2rem
  }
  
  .localnav__lower-list__item::before {
    position: absolute;
    top: 1.1rem;
    left: 0;
    display: block;
    width: .6rem;
    height: .2rem;
    content: "";
    background: #134798
  }
  
  .localnav__lower-list__item>a {
    display: block;
    padding: .3rem 0
  }
  
  .localnav__lower-list__item>a.current {
    font-weight: 600
  }
  
  .localnav button:focus-visible {
    outline: auto
  }
  
  .side-bnr {
    margin-top: 1.6rem
  }
  
  .side-bnr__img {
    width: 100%
  }
  
  .side-bnr>a {
    display: block
  }
  
  .side-bnr>a img {
    transition: all .2s
  }
  
  .side-bnr>a:hover img, .side-bnr>a:focus-visible img {
    box-shadow: 2px 2px #fff, 6px 6px 0 #707070
  }
  
  .side-bnr>a.icon--pdf::after {
    content: none
  }
  
  .side-bnr>a.icon--pdf .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("/en/common/img/icon-pdf.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .side-bnr>a.icon--pdf .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .side-bnr>a.icon--doc::after {
    content: none
  }
  
  .side-bnr>a.icon--doc .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("/en/common/img/icon-doc.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .side-bnr>a.icon--doc .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .side-bnr>a.icon--xls::after {
    content: none
  }
  
  .side-bnr>a.icon--xls .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("/en/common/img/icon-xls.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .side-bnr>a.icon--xls .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .side-bnr>a.icon--zip::after {
    content: none
  }
  
  .side-bnr>a.icon--zip .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("/en/common/img/icon-zip.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .side-bnr>a.icon--zip .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .side-bnr>a.icon--file::after {
    content: none
  }
  
  .side-bnr>a.icon--file .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("/en/common/img/icon-file.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .side-bnr>a.icon--file .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .side-bnr>a.icon--out::after {
    content: none
  }
  
  .side-bnr>a.icon--out .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.2rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("/en/common/img/icon-out.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .side-bnr>a.icon--out .icon-target::after {
      width: 1.5rem;
      height: 1.5rem
    }
  }
  
  .side-bnr iframe {
    max-width: 100%
  }
  
  .ttl+* {
    margin-top: 0 !important
  }
  
  .category-mv {
    width: 100%;
    position: relative
  }
  
  @media screen and (min-width: 1060px) {
    .category-mv {
      margin-top: 9.6rem
    }
  }
  
  .category-mv img {
    width: 100%
  }
  
  .category-mv+.breadcrumb {
    margin-top: 1.2rem
  }
  
  .category-ttl {
    width: 100%;
    padding: 0 20px;
    text-align: center;
    font-size: 2rem;
    font-weight: 600;
    color: #fff;
    text-shadow: 0 .3rem .4rem #033057;
    position: absolute;
    top: 50%;
    transform: translateY(-50%)
  }
  
  @media screen and (min-width: 767px), print {
    .category-ttl {
      font-size: 4rem
    }
  }
  
  .ttl {
    font-weight: 600
  }
  
  .ttl.--lv1 {
    margin-top: 2rem;
    margin-bottom: 2rem;
    padding-bottom: .7rem;
    font-size: 2.1rem;
    line-height: 1.33;
    position: relative
  }
  
  @media screen and (min-width: 767px), print {
    .ttl.--lv1 {
      margin-top: 4rem;
      margin-bottom: 2rem;
      padding-bottom: 1.2rem;
      font-size: 2rem
    }
  }
  
  .ttl.--lv1::after {
    content: "";
    display: block;
    width: 100%;
    height: .2rem;
    background: linear-gradient(to right, #3d67a9 0, #3d67a9 6rem, #bbb 6rem, #bbb 100%);
    position: absolute;
    left: 0;
    bottom: 0
  }
  
  @media screen and (min-width: 767px), print {
    .ttl.--lv1::after {
      height: .4rem;
      background: linear-gradient(to right, #3d67a9 0, #3d67a9 15rem, #bbb 15rem, #bbb 100%)
    }
  }
  
  .ttl.--lv2 {
    margin-top: 3rem;
    margin-bottom: 1.4rem;
    padding: .9rem 1rem .7rem 1.1rem;
    background: #f3f3f3;
    border-left: 3px solid #3d67a9;
    font-size: 1.8rem;
    line-height: 1.33
  }
  
  @media screen and (min-width: 767px), print {
    .ttl.--lv2 {
      margin-top: 4rem;
      margin-bottom: 1.5rem;
      padding: .7rem 1.8rem .6rem;
      border-left: 4px solid #3d67a9;
      font-size: 1.8rem
    }
  }
  
  .ttl.--lv3 {
    margin-top: 2rem;
    margin-bottom: 1.4rem;
    padding-bottom: .5rem;
    border-bottom: 1px solid #707070;
    font-size: 1.6rem;
    line-height: 1.38
  }
  
  @media screen and (min-width: 767px), print {
    .ttl.--lv3 {
      margin-top: 3rem;
      margin-bottom: 1.6rem;
      padding-bottom: .7rem;
      border-bottom: 2px solid #707070;
      font-size: 1.7rem
    }
  }
  
  .ttl.--lv4 {
    margin-top: 2rem;
    margin-bottom: 1.4rem;
    padding-left: 1.1rem;
    font-size: 1.5rem;
    line-height: 1.4;
    position: relative
  }
  
  @media screen and (min-width: 767px), print {
    .ttl.--lv4 {
      margin-top: 4rem;
      margin-bottom: 1.6rem;
      padding-left: 1.2rem;
      font-size: 1.6rem
    }
  }
  
  .ttl.--lv4::before {
    content: "";
    display: block;
    width: .3rem;
    height: calc(100% - .4rem);
    background: #3d67a9;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 0
  }
  
  @media screen and (min-width: 767px), print {
    .ttl.--lv4::before {
      width: .4rem
    }
  }
  
  .ttl.--lv5 {
    margin-top: 1.4rem;
    margin-bottom: 1.4rem;
    padding-left: 1.4rem;
    font-size: 1.4rem;
    color: #333;
    line-height: 1.39;
    position: relative
  }
  
  @media screen and (min-width: 767px), print {
    .ttl.--lv5 {
      margin-top: 2.4rem;
      margin-bottom: 1.6rem;
      padding-left: 1.8rem;
      font-size: 1.6rem
    }
  }
  
  .ttl.--lv5::before {
    content: "";
    display: block;
    width: .8rem;
    height: .8rem;
    background: #d83320;
    position: absolute;
    top: .4rem;
    left: 0
  }
  
  @media screen and (min-width: 767px), print {
    .ttl.--lv5::before {
      width: 1rem;
      height: 1rem;
      top: .6rem
    }
  }
  
  .ttl.--border-red {
    margin-top: 2rem;
    margin-bottom: 1.5rem;
    padding-bottom: .5rem;
    border-bottom: 1px solid #d83320;
    font-size: 1.4rem
  }
  
  @media screen and (min-width: 767px), print {
    .ttl.--border-red {
      margin-top: 4rem;
      margin-bottom: 2.4rem;
      border-bottom: 2px solid #d83320;
      font-size: 1.8rem
    }
  }
  
  .ttl.--border-red.--lv1 {
    font-size: 2rem
  }
  
  .ttl.--border-red.--lv1::after {
    display: none
  }
  
  @media screen and (min-width: 767px), print {
    .ttl.--border-red.--lv1 {
      font-size: 2.6rem
    }
  }
  
  .ttl.--triangle {
    margin-top: 1.4rem;
    margin-bottom: 1.4rem;
    padding-left: 1.4rem;
    text-align: left;
    font-size: 1.4rem;
    position: relative
  }
  
  @media screen and (min-width: 767px), print {
    .ttl.--triangle {
      margin-bottom: 2rem;
      padding-left: 1.8rem;
      font-size: 1.6rem
    }
  }
  
  .ttl.--triangle::before {
    content: "";
    display: block;
    width: .8rem;
    height: .8rem;
    background: linear-gradient(135deg, transparent 0, transparent 50%, #3d67a9 50%, #3d67a9 100%);
    position: absolute;
    top: .6rem;
    left: 0
  }
  
  @media screen and (min-width: 767px), print {
    .ttl.--triangle::before {
      width: 1rem;
      height: 1rem;
      top: .7rem
    }
  }
  
  .breadcrumb {
    width: 100%;
    margin-top: 1.2rem
  }
  
  @media screen and (min-width: 1060px) {
    .breadcrumb {
      margin-top: 11.3rem
    }
  }
  
  .breadcrumb__item {
    display: inline-block;
    margin-top: .4rem;
    font-size: 1.2rem;
    line-height: 1.46
  }
  
  @media screen and (min-width: 767px), print {
    .breadcrumb__item {
      font-size: 1.3rem
    }
  }
  
  .breadcrumb__item::after {
    display: inline-block;
    width: .5rem;
    height: .5rem;
    margin: 0 .3rem .2rem 0;
    content: "";
    border-right: 1px solid #363636;
    border-bottom: 1px solid #363636;
    transform: rotate(-45deg)
  }
  
  @media screen and (min-width: 767px), print {
    .breadcrumb__item::after {
      width: .6rem;
      height: .6rem;
      margin: 0 1rem .2rem 0
    }
  }
  
  .breadcrumb__item a {
    display: inline;
    margin-right: .4rem;
    color: #006cba;
    text-decoration: underline
  }
  
  .breadcrumb__item a:hover, .breadcrumb__item a:focus-visible {
    text-decoration: none
  }
  
  @media screen and (min-width: 767px), print {
    .breadcrumb__item a {
      margin-right: .9rem
    }
  }
  
  .breadcrumb__item:last-child::after {
    content: none
  }
  
  .acc-box {
    display: flex;
    flex-wrap: wrap;
    gap: 1.2rem 0;
    margin-top: 3rem
  }
  
  @media screen and (min-width: 767px), print {
    .acc-box {
      gap: 2rem 0;
      margin-top: 4rem
    }
  }
  
  .acc-box__item {
    width: 100%;
    border: 1px solid #707070
  }
  
  .acc-box__trigger {
    width: 100%
  }
  
  .acc-box__trigger:hover .acc-box__trigger__txt, .acc-box__trigger:focus-visible .acc-box__trigger__txt {
    text-decoration: underline
  }
  
  .acc-box__trigger:focus-visible {
    outline: auto
  }
  
  .acc-box__trigger__heading {
    position: relative;
    display: block;
    width: 100%;
    padding: 1.7rem 3.8rem 1.6rem 1.5rem;
    text-align: left
  }
  
  @media screen and (min-width: 767px), print {
    .acc-box__trigger__heading {
      padding: 1rem 6rem 1rem 2rem
    }
  }
  
  .acc-box__trigger__heading::before {
    right: 1rem;
    display: block;
    width: 1.6rem;
    height: .2rem;
    content: "";
    background: #134798;
    position: absolute;
    top: 50%;
    transform: translateY(-50%)
  }
  
  @media screen and (min-width: 767px), print {
    .acc-box__trigger__heading::before {
      right: 1.6rem;
      width: 2.8rem;
      height: .3rem
    }
  }
  
  .acc-box__trigger__heading::after {
    position: absolute;
    top: calc(50% - .8rem);
    right: 1.7rem;
    display: block;
    width: .2rem;
    height: 1.6rem;
    content: "";
    background: #134798;
    transition: all .2s
  }
  
  @media screen and (min-width: 767px), print {
    .acc-box__trigger__heading::after {
      top: calc(50% - 1.4rem);
      right: 2.8rem;
      width: .3rem;
      height: 2.8rem
    }
  }
  
  .acc-box__trigger.is-open .acc-box__trigger__heading::after {
    opacity: 0;
    transform: rotate(-90deg)
  }
  
  .acc-box__trigger__txt {
    font-size: 1.5rem;
    font-weight: 600
  }
  
  @media screen and (min-width: 767px), print {
    .acc-box__trigger__txt {
      font-size: 1.6rem
    }
  }
  
  .acc-box__trigger__txt::before {
    left: 0;
    display: block;
    width: .2rem;
    height: 3rem;
    content: "";
    background: #d83320;
    position: absolute;
    top: 50%;
    transform: translateY(-50%)
  }
  
  @media screen and (min-width: 767px), print {
    .acc-box__trigger__txt::before {
      width: .4rem;
      height: 3.6rem
    }
  }
  
  .acc-box__trigger__wrap .img-list {
    width: calc(100% - 2.4rem);
    margin: 0 auto 1.6rem
  }
  
  @media screen and (min-width: 767px), print {
    .acc-box__trigger__wrap .img-list {
      width: calc(100% - 6rem);
      margin-top: 0 auto 1.8rem
    }
  }
  
  .acc-box__child {
    display: none;
    padding: 0 1.2rem 1rem
  }
  
  @media screen and (min-width: 767px), print {
    .acc-box__child {
      padding: .4rem 2rem 1rem
    }
  }
  
  .acc-box__child__txt-wrap>*:first-child {
    margin-top: 0
  }
  
  .acc-box__close {
    position: relative;
    display: block;
    padding: .6rem 0 .6rem 3.8rem;
    margin: 3.6rem 0 0 auto;
    font-size: 1.4rem
  }
  
  .acc-box__close:hover, .acc-box__close:focus-visible {
    text-decoration: underline
  }
  
  @media screen and (min-width: 767px), print {
    .acc-box__close {
      margin-top: 3rem;
      font-size: 1.6rem
    }
  }
  
  .acc-box__close::before, .acc-box__close::after {
    position: absolute;
    top: 1.7rem;
    left: 0;
    display: block;
    width: 1.8rem;
    height: .1rem;
    content: "";
    background: #333
  }
  
  @media screen and (min-width: 767px), print {
    .acc-box__close::before, .acc-box__close::after {
      width: 2.4rem
    }
  }
  
  .acc-box__close::before {
    transform: rotate(45deg)
  }
  
  .acc-box__close::after {
    transform: rotate(-45deg)
  }
  
  .acc-box__close:focus-visible {
    outline: auto
  }
  
  .acc-box.--faq .acc-box__trigger__heading {
    display: flex;
    align-items: center;
    padding-left: 0
  }
  
  .acc-box.--faq .acc-box__trigger__label {
    flex-shrink: 0;
    height: 3rem;
    padding-right: .8rem;
    padding-left: 1rem;
    margin-right: 1rem;
    font-size: 1.7rem;
    font-weight: 600;
    color: #d83320;
    background: #f3f3f3;
    display: flex;
    align-items: center
  }
  
  @media screen and (min-width: 767px), print {
    .acc-box.--faq .acc-box__trigger__label {
      height: 3.6rem;
      padding-left: 1.2rem;
      font-size: 2rem
    }
  }
  
  .acc-box.--faq .acc-box__child__label {
    display: inline-block;
    height: 3rem;
    margin-left: -1.2rem;
    padding-right: .8rem;
    padding-left: 1rem;
    font-size: 1.7rem;
    font-weight: 600;
    line-height: 3rem;
    color: #3d67a9;
    background: #e7f3fc
  }
  
  @media screen and (min-width: 767px), print {
    .acc-box.--faq .acc-box__child__label {
      height: 3.6rem;
      margin-left: -2rem;
      padding-left: 1.2rem;
      font-size: 2rem;
      line-height: 3.6rem
    }
  }
  
  .acc-box.--faq .acc-box__child__txt-wrap {
    margin-top: 1rem
  }
  
  .list {
    margin-top: 1.5rem
  }
  
  .list__item {
    margin-top: .5rem
  }
  
  .list__item:first-child {
    margin-top: 0
  }
  
  .list__item::before {
    display: table-cell;
    vertical-align: top
  }
  
  .list__item__txt {
    display: table-cell
  }
  
  .list__item__txt strong {
    color: #e90000;
    font-weight: 400
  }
  
  .list__item__txt a {
    color: #006cba;
    text-decoration: underline
  }
  
  .list__item__txt a:hover, .list__item__txt a:focus-visible {
    text-decoration: none
  }
  
  .list__item__txt .img-list.--col1 {
    margin-top: 2rem
  }
  
  @media screen and (min-width: 767px), print {
    .list__item__txt .img-list.--col1 {
      margin-top: 3rem
    }
  }
  
  .list__item__txt .img-list.--col1:last-child {
    margin-bottom: 1.5rem
  }
  
  @media screen and (min-width: 767px), print {
    .list__item__txt .img-list.--col1:last-child {
      margin-bottom: 2rem
    }
  }
  
  .list__item__txt .table__wrap:last-child {
    margin-bottom: 1.5rem
  }
  
  @media screen and (min-width: 767px), print {
    .list__item__txt .table__wrap:last-child {
      margin-bottom: 2rem
    }
  }
  
  .list__item__txt>*:first-child {
    margin-top: 0
  }
  
  .list__item>.list {
    margin-top: 0;
    margin-left: 1em
  }
  
  .list__item>.list>.list__item {
    margin-top: .4rem
  }
  
  .list.--disc>.list__item::before {
    width: 1em;
    content: "・"
  }
  
  .list.--disc>.list__item>.list {
    margin-left: 2em
  }
  
  .list.--decimal {
    counter-reset: list-cnt
  }
  
  .list.--decimal>.list__item::before {
    width: 2.5rem;
    content: counter(list-cnt) ".";
    counter-increment: list-cnt;
    white-space: nowrap
  }
  
  @media screen and (min-width: 767px), print {
    .list.--decimal>.list__item::before {
      width: 2.8rem;
      padding-top: 0.3rem;
    }
  }
  
  .list.--decimal>.list__item>.list {
    margin-left: 2.5em
  }
  
  .list.--note {
    margin-top: 1rem;
    border-spacing: 0 .8rem;
    border-collapse: separate
  }
  
  @media screen and (min-width: 767px), print {
    .list.--note {
      border-spacing: 0 1.4rem
    }
  }
  
  .list.--note>.list__item {
    display: table-row
  }
  
  .list.--note>.list__item>.list__item__ttl {
    white-space: nowrap
  }
  
  .list.--note>.list__item>.list__item__txt {
    padding-left: 1.2rem
  }
  
  @media screen and (min-width: 767px), print {
    .list.--note>.list__item>.list__item__txt {
      padding-left: 1rem
    }
  }
  
  .list.--note>.list__item>.list__item__txt>.list {
    border-collapse: collapse;
    margin-top: 0;
    margin-left: 1em
  }
  
  .list.--note>.list__item>.list__item__txt>.list>.list__item {
    margin-top: .4rem;
    padding-left: 0
  }
  
  @media screen and (min-width: 767px), print {
    .list.--col2 {
      display: flex;
      flex-wrap: wrap;
      gap: 1rem 3.2rem
    }
    .list.--col2>.list__item {
      width: calc((100% - 3.2rem)/2);
      margin-top: 0
    }
    .list.--col2>.list__item>.list {
      margin-bottom: 0
    }
    .list.--col3 {
      display: flex;
      flex-wrap: wrap;
      gap: 1rem 1.4rem
    }
    .list.--col3>.list__item {
      width: calc((100% - 2.8rem)/3);
      margin-top: 0
    }
    .list.--col3>.list__item>.list {
      margin-bottom: 0
    }
  }
  
  .list+.article-txt {
    margin-top: 2rem
  }
  
  .book-list {
    display: flex;
    flex-wrap: wrap;
    gap: 2.8rem 2.2rem;
    margin-top: 3rem
  }
  
  @media screen and (min-width: 767px), print {
    .book-list {
      gap: 3rem 3.2rem
    }
  }
  
  .book-list__item {
    width: calc((100% - 2.2rem)/2)
  }
  
  @media screen and (min-width: 767px), print {
    .book-list__item {
      width: calc((100% - 9.6rem)/4)
    }
  }
  
  .book-list__item .img-box__inner {
    max-width: 16rem;
    margin: 0 auto
  }
  
  .book-list__item .img-box__inner::before {
    padding-top: 141.35%
  }
  
  .book-list__item a {
    display: block
  }
  
  .book-list__item a .book-list__ttl {
    color: #006cba;
    text-decoration: underline
  }
  
  .book-list__item a:hover .book-list__ttl, .book-list__item a:focus-visible .book-list__ttl {
    text-decoration: none
  }
  
  .book-list__item a.icon--pdf::after {
    content: none
  }
  
  .book-list__item a.icon--pdf .book-list__ttl::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-pdf.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .book-list__item a.icon--pdf .book-list__ttl::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .book-list__item a.icon--doc::after {
    content: none
  }
  
  .book-list__item a.icon--doc .book-list__ttl::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-doc.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .book-list__item a.icon--doc .book-list__ttl::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .book-list__item a.icon--xls::after {
    content: none
  }
  
  .book-list__item a.icon--xls .book-list__ttl::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-xls.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .book-list__item a.icon--xls .book-list__ttl::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .book-list__item a.icon--zip::after {
    content: none
  }
  
  .book-list__item a.icon--zip .book-list__ttl::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-zip.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .book-list__item a.icon--zip .book-list__ttl::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .book-list__item a.icon--file::after {
    content: none
  }
  
  .book-list__item a.icon--file .book-list__ttl::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-file.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .book-list__item a.icon--file .book-list__ttl::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .book-list__item a.icon--out::after {
    content: none
  }
  
  .book-list__item a.icon--out .book-list__ttl::after {
    display: inline-block;
    width: 12px;
    height: 12px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-out.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .book-list__item a.icon--out .book-list__ttl::after {
      width: 15px;
      height: 15px
    }
  }
  
  .book-list__ttl {
    margin-top: .5rem;
    margin-bottom: 1rem
  }
  
  @media screen and (min-width: 767px), print {
    .container--col2__main .book-list__item, .container--s .book-list__item {
      width: calc((100% - 6.4rem)/3)
    }
  }
  
  .data-list {
    display: flex;
    gap: 1rem 1.5rem;
    flex-wrap: wrap;
    font-size: 1.4rem;
    width: 100%
  }
  
  .data-list__ttl {
    width: 12rem
  }
  
  .data-list__ttl__inner {
    background-color: #ecf6ff;
    border: 1px solid #d0e3f1;
    color: #333;
    display: block;
    text-align: center;
    padding: .1rem .2rem 0
  }
  
  .data-list__data {
    width: calc(100% - 13.5rem)
  }
  
  @media screen and (min-width: 767px), print {
    .data-list {
      font-size: 1.6rem;
      gap: 1.2rem 1.5rem
    }
    .data-list__ttl {
      width: 15rem
    }
    .data-list__data {
      width: calc(100% - 16.5rem)
    }
  }
  
  .schedule-tbl__item {
    margin-top: 1.5rem
  }
  
  @media screen and (min-width: 767px), print {
    .schedule-tbl__item {
      display: flex
    }
  }
  
  .schedule-tbl__item__name {
    display: flex;
    align-items: center;
    min-height: 4.2rem;
    padding: 1.2rem;
    font-weight: 600;
    color: #fff;
    background: #3d67a9
  }
  
  @media screen and (min-width: 767px), print {
    .schedule-tbl__item__name {
      flex-shrink: 0;
      align-items: flex-start;
      width: 14rem;
      padding: 1rem
    }
  }
  
  .schedule-tbl__item__detail {
    padding: 2rem 1.2rem;
    border-right: 1px solid #bbb;
    border-bottom: 1px solid #bbb;
    border-left: 1px solid #bbb
  }
  
  @media screen and (min-width: 767px), print {
    .schedule-tbl__item__detail {
      flex-grow: 1;
      padding: 1.5rem 2rem;
      border-top: 1px solid #bbb;
      border-left: none
    }
  }
  
  @media screen and (min-width: 767px), print {
    .schedule-tbl__item__detail .profile-list {
      gap: 4rem 8.1rem
    }
    .schedule-tbl__item__detail .profile-list__item {
      width: calc((100% - 24.3rem)/4)
    }
  }
  
  .schedule-tbl__item__detail>*:first-child {
    margin-top: 0
  }
  
  .schedule-tbl__item__detail>.def-list__wrap:first-child .def-list:first-of-type {
    margin-top: 0
  }
  
  .schedule-tbl__heading {
    font-size: 1.6rem;
    font-weight: 600;
    margin-top: 2rem
  }
  
  .schedule-tbl__heading::after {
    content: "";
    display: block;
    height: .2rem;
    background: linear-gradient(to right, #d83320 0, #d83320 2.6rem, transparent 2.6rem, transparent 100%);
    margin-top: .4rem
  }
  
  @media screen and (min-width: 767px), print {
    .schedule-tbl__heading {
      font-size: 1.8rem
    }
  }
  
  .schedule-tbl__subheading {
    margin-top: .6rem;
    font-size: 1.4rem;
    font-weight: 500
  }
  
  @media screen and (min-width: 767px), print {
    .schedule-tbl__subheading {
      font-size: 1.5rem;
      margin-top: 1rem
    }
  }
  
  .schedule-tbl__note {
    margin-top: .8rem;
    font-size: 1.4rem
  }
  
  @media screen and (min-width: 767px), print {
    .container--col2__main .schedule-tbl__item__detail .profile-list, .container--s .schedule-tbl__item__detail .profile-list {
      gap: 4rem 6.8rem
    }
    .container--col2__main .schedule-tbl__item__detail .profile-list__item, .container--s .schedule-tbl__item__detail .profile-list__item {
      width: calc((100% - 13.6rem)/3)
    }
  }
  
  @media screen and (min-width: 1060px) {
    .container--col2__main .schedule-tbl__item__detail .profile-list, .container--s .schedule-tbl__item__detail .profile-list {
      gap: 4rem 8.1rem
    }
    .container--col2__main .schedule-tbl__item__detail .profile-list__item, .container--s .schedule-tbl__item__detail .profile-list__item {
      width: calc((100% - 16.2rem)/3)
    }
  }
  
  .list-box {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem 0;
    margin-top: 3rem
  }
  
  @media screen and (min-width: 767px), print {
    .list-box {
      gap: 3.2rem
    }
  }
  
  .list-box__item {
    width: 100%;
    border: 1px solid #bbb;
    position: relative
  }
  
  @media screen and (min-width: 767px), print {
    .list-box__item {
      width: calc((100% - 3.2rem)/2)
    }
  }
  
  .list-box__item::before {
    content: "";
    display: block;
    width: .2rem;
    height: calc(100% - 2rem);
    background: #134798;
    position: absolute;
    top: 0;
    left: 1.5rem;
    z-index: 1
  }
  
  @media screen and (min-width: 767px), print {
    .list-box__item::before {
      height: calc(100% - 2.4rem);
      left: 3rem
    }
  }
  
  @media screen and (min-width: 767px), print {
    .list-box__heading {
      font-weight: 600
    }
  }
  
  .list-box__heading__inner {
    display: block;
    padding: 1rem 1.2rem 1rem 3rem;
    background: #e7f3fc
  }
  
  @media screen and (min-width: 767px), print {
    .list-box__heading__inner {
      padding: 2rem 3rem 2rem 6rem
    }
  }
  
  .list-box__heading a {
    padding-right: 2.4rem;
    position: relative
  }
  
  .list-box__heading a::after {
    width: 1rem;
    height: 1rem;
    content: "";
    border-top: .2rem solid #363636;
    border-right: .2rem solid #363636;
    display: block;
    position: absolute;
    transform: rotate(45deg);
    top: 0;
    right: 1.2rem;
    bottom: 0;
    margin: auto
  }
  
  .list-box__heading a:hover, .list-box__heading a:focus-visible {
    text-decoration: underline
  }
  
  @media screen and (min-width: 767px), print {
    .list-box__heading a {
      padding-right: 4.6rem
    }
    .list-box__heading a::after {
      width: 1.2rem;
      height: 1.2rem;
      right: 3rem
    }
  }
  
  .list-box__heading a.icon--pdf::after {
    background: 0 0
  }
  
  .list-box__heading a.icon--pdf .list-box__heading__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-pdf.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .list-box__heading a.icon--pdf .list-box__heading__txt::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .list-box__heading a.icon--doc::after {
    background: 0 0
  }
  
  .list-box__heading a.icon--doc .list-box__heading__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-doc.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .list-box__heading a.icon--doc .list-box__heading__txt::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .list-box__heading a.icon--xls::after {
    background: 0 0
  }
  
  .list-box__heading a.icon--xls .list-box__heading__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-xls.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .list-box__heading a.icon--xls .list-box__heading__txt::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .list-box__heading a.icon--zip::after {
    background: 0 0
  }
  
  .list-box__heading a.icon--zip .list-box__heading__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-zip.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .list-box__heading a.icon--zip .list-box__heading__txt::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .list-box__heading a.icon--file::after {
    background: 0 0
  }
  
  .list-box__heading a.icon--file .list-box__heading__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-file.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .list-box__heading a.icon--file .list-box__heading__txt::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .list-box__heading a.icon--out::after {
    background: 0 0
  }
  
  .list-box__heading a.icon--out .list-box__heading__txt::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.2rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url(../img/icon-out.png) no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .list-box__heading a.icon--out .list-box__heading__txt::after {
      width: 1.5rem;
      height: 1.5rem
    }
  }
  
  .list-box__inner {
    padding: 2.4rem 1.3rem 2.9rem 3.1rem
  }
  
  @media screen and (min-width: 767px), print {
    .list-box__inner {
      padding: 2.2rem 3rem 4rem 6.2rem
    }
  }
  
  .list-box__inner>*:first-child {
    margin-top: 0
  }
  
  @media screen and (min-width: 767px), print {
    .list-box__mid-area {
      display: flex
    }
    .list-box__mid-area .article-txt {
      flex-grow: 1;
      margin-top: 0
    }
  }
  
  .list-box__mid-area>*:first-child {
    margin-top: 0
  }
  
  .list-box__img .img-box {
    width: 10rem
  }
  
  @media screen and (min-width: 767px), print {
    .list-box__img .img-box {
      flex-shrink: 0;
      margin-right: 2rem
    }
  }
  
  .list-box__img .img-box__inner::before {
    padding-top: 100%
  }
  
  .def-list {
    margin-top: 1.5rem;
    position: relative
  }
  
  .def-list__wrap+.def-list__wrap, .def-list__wrap+.anchor+.def-list__wrap {
    margin-top: 2.5rem;
    padding-top: 1rem;
    border-top: .1rem solid #bbb
  }
  
  @media screen and (min-width: 767px), print {
    .def-list__wrap+.def-list__wrap, .def-list__wrap+.anchor+.def-list__wrap {
      margin-top: 3rem
    }
  }
  
  .def-list__ttl {
    font-size: 1.5rem;
    font-weight: 600
  }
  
  .def-list__desc {
    margin-top: .5rem
  }
  
  .def-list__desc>*:first-child {
    margin-top: 0
  }
  
  .def-list.--side+.def-list.--side {
    padding-top: 2rem
  }
  
  @media screen and (min-width: 767px), print {
    .def-list.--side+.def-list.--side {
      padding-top: 1.5rem
    }
  }
  
  .def-list.--side+.def-list.--side::before {
    content: "";
    display: block;
    width: 100%;
    height: .1rem;
    background: linear-gradient(to right, #bbb 0, #bbb 2px, transparent 2px, transparent 5px) repeat-x;
    background-size: .5rem .1rem;
    position: absolute;
    top: 0;
    left: 0
  }
  
  @media screen and (min-width: 767px), print {
    .def-list.--side+.def-list.--side::before {
      background: linear-gradient(to right, #bbb 0, #bbb 3px, transparent 3px, transparent 6px) repeat-x;
      background-size: .6rem .1rem
    }
  }
  
  .def-list.--side .def-list__ttl {
    padding-bottom: 1rem;
    border-bottom: 1px solid #bbb;
    font-weight: 500
  }
  
  .def-list.--side .def-list__desc {
    margin-top: 1rem
  }
  
  @media screen and (min-width: 767px), print {
    .def-list.--side {
      display: flex;
      flex-wrap: wrap;
      gap: 2rem
    }
    .def-list.--side .def-list__ttl {
      width: 18.8rem;
      padding-right: 2rem;
      padding-bottom: 0;
      font-size: 1.5rem;
      border-bottom: none;
      border-right: 1px solid #bbb
    }
    .def-list.--side .def-list__desc {
      width: calc(100% - 20.8rem);
      margin-top: 0
    }
    .def-list.--side.--wide .def-list__ttl {
      width: 26.1rem
    }
    .def-list.--side.--wide .def-list__desc {
      width: calc(100% - 28.1rem)
    }
  }
  
  .cattop-link {
    padding: 3.4rem calc(50vw - 50%) 0;
    margin: 0 calc(50% - 50vw);
    background: url(../img/cattop_link_bg_sp.png) center top/100% auto no-repeat
  }
  
  @media screen and (min-width: 767px), print {
    .cattop-link {
      padding-top: 8rem;
      background: url(../img/cattop_link_bg_pc.png) center top/100% auto no-repeat
    }
  }
  
  .cattop-link>*:first-child {
    margin-top: 0
  }
  
  .cattop-link__ttl {
    position: relative;
    padding-bottom: 1rem;
    margin-top: 2.4rem;
    margin-bottom: 2rem;
    font-size: 1.6rem
  }
  
  @media screen and (min-width: 767px), print {
    .cattop-link__ttl {
      margin-top: 4rem;
      margin-bottom: 3rem;
      font-size: 2.4rem
    }
  }
  
  .cattop-link__ttl::after {
    position: absolute;
    bottom: 0;
    left: 0;
    display: block;
    width: 100%;
    height: .2rem;
    content: "";
    background: linear-gradient(to right, #d83320 0, #d83320 6rem, #bbb 6rem, #bbb 100%)
  }
  
  @media screen and (min-width: 767px), print {
    .cattop-link__ttl::after {
      height: .4rem;
      background: linear-gradient(to right, #d83320 0, #d83320 15rem, #bbb 15rem, #bbb 100%)
    }
  }
  
  .cattop-link__ttl+.btn-list.--thin {
    margin-top: -0.5rem !important
  }
  
  @media screen and (min-width: 767px), print {
    .cattop-link__ttl+.btn-list.--thin {
      margin-top: -1rem !important
    }
  }
  
  .news-filter {
    padding: 1.4rem 1.2rem
  }
  
  .news-filter.--year {
    background: #f5f6f8;
    border: 1px solid #bbb;
    margin-top: 2rem
  }
  
  @media screen and (min-width: 767px), print {
    .news-filter.--year {
      margin-top: 4rem
    }
  }
  
  .news-filter.--info-cat {
    margin-top: 2.5rem
  }
  
  .news-filter.--info-cat input[type=radio] {
    display: none
  }
  
  @media screen and (min-width: 767px), print {
    .news-filter {
      padding: 2.4rem 2rem 1.6rem 2.4rem
    }
  }
  
  .news-filter>*:first-child {
    margin-top: 0
  }
  
  .news-filter__ttl.ttl.--lv4 {
    margin-bottom: .6rem
  }
  
  @media screen and (min-width: 767px), print {
    .news-filter__ttl.ttl.--lv4 {
      margin-bottom: 1rem
    }
  }
  
  .news-filter__link {
    margin-top: 1.5rem;
    text-align: right;
    position: relative
  }
  
  .news-filter__link::after {
    width: 1.2rem;
    height: 1.2rem;
    content: "";
    border-top: .2rem solid #333;
    border-right: .2rem solid #333;
    display: block;
    position: absolute;
    transform: rotate(45deg);
    top: 0;
    right: 0;
    bottom: 0;
    margin: auto
  }
  
  @media screen and (min-width: 767px), print {
    .news-filter__link {
      margin-top: .5rem
    }
  }
  
  .news-filter__link a {
    padding: .5rem 2.4rem .5rem 0
  }
  
  .news-filter__link a:hover, .news-filter__link a:focus-visible {
    text-decoration: underline
  }
  
  .news-filter__select__wrap {
    position: relative;
    width: 100%
  }
  
  .news-filter__select__trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    height: 4.7rem;
    padding: 0 1.6rem;
    font-size: 1.4rem;
    font-weight: 600;
    text-align: left;
    letter-spacing: .04em;
    background: #fff;
    border: 1px solid #bbb
  }
  
  @media screen and (min-width: 767px), print {
    .news-filter__select__trigger {
      display: none
    }
  }
  
  .news-filter__select__trigger::after {
    display: block;
    width: 1rem;
    height: .6rem;
    content: "";
    background: url(/en/common/img/news-arw.png) no-repeat;
    background-size: contain;
    transition: all .2s
  }
  
  .news-filter__select__trigger.is-open::after {
    transform: rotate(180deg)
  }
  
  .news-filter__select__list {
    position: absolute;
    top: 4.7rem;
    left: 0;
    z-index: 1;
    display: none;
    width: 100%
  }
  
  @media screen and (min-width: 767px), print {
    .news-filter__select__list {
      display: flex;
      flex-wrap: wrap;
      position: static;
      gap: 1.2rem
    }
  }
  
  .news-filter__select__item {
    width: 100%
  }
  
  @media screen and (min-width: 767px), print {
    .news-filter__select__item {
      width: auto;
      min-width: 18.2rem
    }
  }
  
  .news-filter__select__item:focus-visible {
    outline: auto
  }
  
  .news-filter__select__item__txt {
    display: block;
    padding: 1.4rem 1.4rem 1.2rem;
    background: #fff;
    border-right: 1px solid #bbb;
    border-bottom: 1px solid #bbb;
    border-left: 1px solid #bbb
  }
  
  @media screen and (min-width: 767px), print {
    .news-filter__select__item__txt {
      padding: 1rem;
      color: #134798;
      text-align: center;
      text-decoration: underline;
      border: 1px solid #707070
    }
  }
  
  .news-filter__select__item:hover .news-filter__select__item__txt, .news-filter__select__item:focus .news-filter__select__item__txt, .news-filter__select__item.current .news-filter__select__item__txt {
    color: #134798;
    text-decoration: underline
  }
  
  @media screen and (min-width: 767px), print {
    .news-filter__select__item:hover .news-filter__select__item__txt, .news-filter__select__item:focus .news-filter__select__item__txt, .news-filter__select__item.current .news-filter__select__item__txt {
      color: #fff;
      text-decoration: none;
      background: #134798;
      border: 1px solid #134798
    }
  }
  
  .news-list__box {
    margin-top: 3rem;
    padding: 2rem 1.4rem 1.5rem;
    border: 1px solid #bbb
  }
  
  @media screen and (min-width: 767px), print {
    .news-list__box {
      margin-top: 4rem;
      padding: 3rem 3rem 2.5rem
    }
  }
  
  .news-list__box>*:first-child {
    margin-top: 0
  }
  
  .news-list__box .news-list__item:last-of-type {
    border-bottom: none
  }
  
  .news-list__box .news-list__item:last-of-type .news-list__inner {
    padding-bottom: .5rem
  }
  
  .news-list__box__link {
    margin-top: 1rem;
    text-align: right;
    position: relative
  }
  
  .news-list__box__link::after {
    width: .8rem;
    height: .8rem;
    content: "";
    border-top: .2rem solid #333;
    border-right: .2rem solid #333;
    display: block;
    position: absolute;
    transform: rotate(45deg);
    top: 0;
    right: 0;
    bottom: 0;
    margin: auto
  }
  
  .news-list__box__link a {
    display: inline-block;
    padding: .5rem 1.6rem .5rem 0
  }
  
  .news-list__box__link a:hover, .news-list__box__link a:focus-visible {
    text-decoration: underline
  }
  
  .news-list__wrap {
    min-height: 20rem;
    margin-top: 1.6rem
  }
  
  @media screen and (min-width: 767px), print {
    .news-list__wrap {
      margin-top: 5.4rem
    }
  }
  
  .news-list__wrap .--no-news {
    margin-top: 2em
  }
  
  .news-list__item {
    border-bottom: 1px solid #bbb
  }
  
  .news-list__item:first-of-type .news-list__inner {
    padding-top: .6rem
  }
  
  .news-list__item:hover .news-list__ttl, .news-list__item:focus-visible .news-list__ttl {
    display: block;
    overflow: auto
  }
  
  .news-list__item a .news-list__ttl {
    text-decoration: underline
  }
  
  @media screen and (min-width: 767px), print {
    .news-list__item a:hover .news-list__ttl, .news-list__item a:focus-visible .news-list__ttl {
      text-decoration: none
    }
  }
  
  .news-list__item a.icon--pdf::after {
    content: none
  }
  
  .news-list__item a.icon--pdf .news-list__ttl::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-pdf.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .news-list__item a.icon--pdf .news-list__ttl::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .news-list__item a.icon--doc::after {
    content: none
  }
  
  .news-list__item a.icon--doc .news-list__ttl::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-doc.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .news-list__item a.icon--doc .news-list__ttl::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .news-list__item a.icon--xls::after {
    content: none
  }
  
  .news-list__item a.icon--xls .news-list__ttl::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-xls.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .news-list__item a.icon--xls .news-list__ttl::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .news-list__item a.icon--zip::after {
    content: none
  }
  
  .news-list__item a.icon--zip .news-list__ttl::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-zip.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .news-list__item a.icon--zip .news-list__ttl::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .news-list__item a.icon--file::after {
    content: none
  }
  
  .news-list__item a.icon--file .news-list__ttl::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-file.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .news-list__item a.icon--file .news-list__ttl::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .news-list__item a.icon--out::after {
    content: none
  }
  
  .news-list__item a.icon--out .news-list__ttl::after {
    display: inline-block;
    width: 12px;
    height: 12px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-out.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .news-list__item a.icon--out .news-list__ttl::after {
      width: 15px;
      height: 15px
    }
  }
  
  .news-list__inner {
    display: block;
    padding: 1.4rem 0
  }
  
  @media screen and (min-width: 767px), print {
    .news-list__inner {
      display: flex;
      align-items: center;
      padding: 2rem 0
    }
  }
  
  .news-list__data-box {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem 1.5rem;
    align-items: center;
    margin-bottom: 1rem
  }
  
  @media screen and (min-width: 767px), print {
    .news-list__data-box {
      gap: 2.4rem;
      margin-bottom: 0
    }
  }
  
  .news-list__data-box .news-list__date {
    margin-top: .1rem
  }
  
  @media screen and (min-width: 767px), print {
    .news-list__date {
      flex-shrink: 0;
      width: 16.4rem
    }
  }
  
  .news-list__ttl {
    margin-top: 4px;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
    overflow: hidden
  }
  
  @media screen and (min-width: 767px), print {
    .news-list__ttl {
      flex-grow: 1;
      margin-top: 0
    }
  }
  
  .news-detail__ttl.ttl.--lv1 {
    margin-bottom: 1rem
  }
  
  @media screen and (min-width: 767px), print {
    .news-detail__ttl.ttl.--lv1 {
      margin-bottom: 2rem
    }
  }
  
  .news-detail__update-info {
    margin-top: 1.6rem
  }
  
  @media screen and (min-width: 767px), print {
    .news-detail__update-info {
      margin-top: 3.5rem
    }
  }
  
  .news-detail__update-info .article-txt {
    margin-top: 0
  }
  
  .news-detail__update-info+* {
    margin-top: 1.6rem !important
  }
  
  @media screen and (min-width: 767px), print {
    .news-detail__update-info+* {
      margin-top: 3.5rem !important
    }
  }
  
  .img-box {
    width: 100%;
    margin-right: auto;
    margin-left: auto;
    text-align: center
  }
  
  .img-box__inner {
    position: relative;
    width: 100%;
    transition: all .2s
  }
  
  .img-box__inner::before {
    display: block;
    width: 100%;
    padding-top: 75%;
    content: ""
  }
  
  .img-box__inner img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    object-fit: scale-down
  }
  
  .img-box.--border .img-box__inner {
    overflow: hidden;
    border: 1px solid #bbb
  }
  
  .img-box figcaption {
    margin-top: .6rem;
    font-size: 1.2rem;
    line-height: 1.5;
    text-align: left
  }
  
  @media screen and (min-width: 767px), print {
    .img-box figcaption {
      margin-top: .8rem;
      font-size: 1.4rem
    }
  }
  
  .img-list {
    display: flex;
    flex-wrap: wrap;
    gap: 3rem 0;
    margin-top: 3rem
  }
  
  @media screen and (min-width: 767px), print {
    .img-list {
      margin-top: 6rem
    }
  }
  
  .img-list__item {
    width: 100%
  }
  
  .img-list__item a {
    display: block
  }
  
  .img-list__item a.icon--pdf::after {
    content: none
  }
  
  .img-list__item a.icon--pdf figcaption::after, .img-list__item a.icon--pdf .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("../img/icon-pdf.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .img-list__item a.icon--pdf figcaption::after, .img-list__item a.icon--pdf .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .img-list__item a.icon--doc::after {
    content: none
  }
  
  .img-list__item a.icon--doc figcaption::after, .img-list__item a.icon--doc .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("../img/icon-doc.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .img-list__item a.icon--doc figcaption::after, .img-list__item a.icon--doc .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .img-list__item a.icon--xls::after {
    content: none
  }
  
  .img-list__item a.icon--xls figcaption::after, .img-list__item a.icon--xls .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("../img/icon-xls.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .img-list__item a.icon--xls figcaption::after, .img-list__item a.icon--xls .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .img-list__item a.icon--zip::after {
    content: none
  }
  
  .img-list__item a.icon--zip figcaption::after, .img-list__item a.icon--zip .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("../img/icon-zip.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .img-list__item a.icon--zip figcaption::after, .img-list__item a.icon--zip .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .img-list__item a.icon--file::after {
    content: none
  }
  
  .img-list__item a.icon--file figcaption::after, .img-list__item a.icon--file .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("../img/icon-file.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .img-list__item a.icon--file figcaption::after, .img-list__item a.icon--file .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .img-list__item a.icon--out::after {
    content: none
  }
  
  .img-list__item a.icon--out figcaption::after, .img-list__item a.icon--out .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.2rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("../img/icon-out.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .img-list__item a.icon--out figcaption::after, .img-list__item a.icon--out .icon-target::after {
      width: 1.5rem;
      height: 1.5rem
    }
  }
  
  .img-list__item a.icon--zoom::after {
    content: none
  }
  
  .img-list__item a.icon--zoom figcaption::after, .img-list__item a.icon--zoom .icon-target::after {
    display: inline-block;
    width: 1.5rem;
    height: 1.5rem;
    margin-right: .3rem;
    margin-bottom: -0.2rem;
    margin-left: .4rem;
    content: "";
    background: url("../img/icon-zoom.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .img-list__item a.icon--zoom figcaption::after, .img-list__item a.icon--zoom .icon-target::after {
      width: 1.8rem;
      height: 1.8rem;
      margin-bottom: -0.3rem
    }
  }
  
  .img-list__item a figcaption {
    color: #006cba;
    text-decoration: underline
  }
  
  .img-list__item a:hover figcaption, .img-list__item a:hover .icon-target, .img-list__item a:focus-visible figcaption, .img-list__item a:focus-visible .icon-target {
    text-decoration: none
  }
  
  .img-list__item a:hover .img-box__inner, .img-list__item a:focus-visible .img-box__inner {
    box-shadow: 2px 2px #fff, 6px 6px 0 #707070
  }
  
  .img-list.--col1 {
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: center
  }
  
  .img-list.--col1 .img-list__item {
    width: fit-content
  }
  
  .img-list.--col1 .img-list__item.--left {
    align-self: flex-start
  }
  
  .img-list.--col1 .img-list__item.--left .img-box>img {
    margin-left: 0
  }
  
  .img-list.--col1 .img-list__item.--right {
    align-self: flex-end
  }
  
  .img-list.--col1 .img-list__item.--right .img-box>img {
    margin-right: 0
  }
  
  .img-list.--col1 .img-box {
    text-align: revert
  }
  
  .img-list.--col1 .img-box>img {
    display: block;
    margin-left: auto;
    margin-right: auto
  }
  
  .img-list.--col1 .img-box figcaption {
    transition: all .2s;
    opacity: 0
  }
  
  .img-list.--col1 .img-box figcaption.active {
    opacity: 1
  }
  
  @media screen and (min-width: 767px), print {
    .img-list.--col2 {
      gap: 2.4rem 3.2rem;
      max-width: 88rem;
      margin-right: auto;
      margin-left: auto
    }
    .img-list.--col2 .img-list__item {
      width: calc((100% - 3.2rem)/2)
    }
    .img-list.--col3 {
      gap: 2.4rem 3.2rem;
      margin-right: auto;
      margin-left: auto
    }
    .img-list.--col3 .img-list__item {
      width: calc((100% - 6.4rem)/3)
    }
  }
  
  .img-list+.article-txt {
    margin-top: 3rem
  }
  
  @media screen and (min-width: 767px), print {
    .img-list+.article-txt {
      margin-top: 6rem
    }
  }
  
  .img-txt {
    margin-top: 2rem
  }
  
  @media screen and (min-width: 767px), print {
    .img-txt {
      margin-top: 3rem
    }
  }
  
  .img-txt__img {
    width: 100%;
    max-width: 424px;
    margin: 0 auto
  }
  
  .img-txt__img.--vertical {
    max-width: 254px
  }
  
  @media screen and (min-width: 767px), print {
    .img-txt__img.--vertical {
      max-width: 318px
    }
  }
  
  .img-txt__img.--vertical .img-box__inner::before {
    padding-top: 133.33%
  }
  
  .img-txt__img.--vertical.--small {
    max-width: 198px
  }
  
  .img-txt__img.--small {
    max-width: 264px
  }
  
  @media screen and (min-width: 767px), print {
    .img-txt__img {
      width: 48.18%;
      margin-top: .6rem;
      margin-bottom: 1.8rem
    }
    .img-txt__img.--small {
      width: 30.9%
    }
  }
  
  .img-txt__txt {
    width: 100%;
    margin-top: 1.5rem
  }
  
  @media screen and (min-width: 767px), print {
    .img-txt__txt {
      margin-top: 0
    }
  }
  
  .img-txt__txt>*:first-child {
    margin-top: 0
  }
  
  @media screen and (min-width: 767px), print {
    .img-txt.--right {
      display: block
    }
    .img-txt.--right::after {
      display: block;
      clear: both;
      content: ""
    }
  }
  
  @media screen and (min-width: 767px), print {
    .img-txt.--right .img-txt__img {
      float: right;
      margin-left: 3.2rem
    }
  }
  
  @media screen and (min-width: 767px), print {
    .img-txt.--left {
      display: flex
    }
  }
  
  @media screen and (min-width: 767px), print {
    .img-txt.--left .img-txt__img {
      flex-shrink: 0;
      margin-right: 3.2rem;
      margin-left: 0
    }
  }
  
  @media screen and (min-width: 767px), print {
    .img-txt.--left .img-txt__txt {
      flex-grow: 1
    }
  }
  
  .mov {
    margin-top: 3rem
  }
  
  @media screen and (min-width: 767px), print {
    .mov {
      max-width: 88rem;
      margin: 4rem auto 0
    }
  }
  
  .mov__inner {
    position: relative;
    width: 100%;
    padding-top: 56.25%
  }
  
  .mov__inner iframe {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important
  }
  
  .bnr-list {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    margin-top: 3rem
  }
  
  @media screen and (min-width: 767px), print {
    .bnr-list {
      gap: 1rem 3rem
    }
  }
  
  .bnr-list__item {
    width: 100%
  }
  
  .bnr-list__item a {
    display: inline-block;
    text-align: right
  }
  
  .bnr-list__item a.icon--pdf::after {
    content: none
  }
  
  .bnr-list__item a.icon--pdf .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("/en/common/img/icon-pdf.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .bnr-list__item a.icon--pdf .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .bnr-list__item a.icon--doc::after {
    content: none
  }
  
  .bnr-list__item a.icon--doc .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("/en/common/img/icon-doc.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .bnr-list__item a.icon--doc .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .bnr-list__item a.icon--xls::after {
    content: none
  }
  
  .bnr-list__item a.icon--xls .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("/en/common/img/icon-xls.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .bnr-list__item a.icon--xls .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .bnr-list__item a.icon--zip::after {
    content: none
  }
  
  .bnr-list__item a.icon--zip .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("/en/common/img/icon-zip.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .bnr-list__item a.icon--zip .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .bnr-list__item a.icon--file::after {
    content: none
  }
  
  .bnr-list__item a.icon--file .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("/en/common/img/icon-file.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .bnr-list__item a.icon--file .icon-target::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .bnr-list__item a.icon--out::after {
    content: none
  }
  
  .bnr-list__item a.icon--out .icon-target::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.2rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url("/en/common/img/icon-out.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .bnr-list__item a.icon--out .icon-target::after {
      width: 1.5rem;
      height: 1.5rem
    }
  }
  
  .bnr-list__item a img {
    transition: all .2s
  }
  
  .bnr-list__item a:hover img, .bnr-list__item a:focus-visible img {
    box-shadow: 2px 2px #fff, 6px 6px 0 #707070
  }
  
  .bnr-list__item a:hover .icon-target, .bnr-list__item a:focus-visible .icon-target {
    text-decoration: none
  }
  
  .bnr-list.--side .bnr-list__item {
    width: auto
  }
  
  .bnr-list.--col4, .bnr-list.--col3 {
    max-width: 56rem;
    margin: 4rem auto 0
  }
  
  @media screen and (min-width: 767px), print {
    .bnr-list.--col4, .bnr-list.--col3 {
      gap: 2rem 3.2rem;
      max-width: 88rem;
      margin: 8rem auto 0
    }
  }
  
  @media screen and (min-width: 1060px) {
    .bnr-list.--col4, .bnr-list.--col3 {
      max-width: none
    }
  }
  
  .bnr-list.--col4 .bnr-list__item, .bnr-list.--col3 .bnr-list__item {
    width: calc((100% - 1.5rem)/2)
  }
  
  @media screen and (min-width: 767px), print {
    .bnr-list.--col4 .bnr-list__item, .bnr-list.--col3 .bnr-list__item {
      width: calc((100% - 6.4rem)/3)
    }
  }
  
  @media screen and (min-width: 1060px) {
    .bnr-list.--col4 .bnr-list__item, .bnr-list.--col3 .bnr-list__item {
      width: calc((100% - 9.6rem)/4)
    }
  }
  
  @media screen and (min-width: 767px), print {
    .bnr-list.--col3 {
      align-items: unset;
      justify-content: flex-start
    }
    .bnr-list.--col3 .bnr-list__item {
      width: calc((100% - 6.4rem)/3);
      min-height: 6.4rem;
      padding-top: .6rem;
      padding-bottom: .4rem
    }
  }
  
  .icon-target {
    display: block;
    margin-top: .6rem;
    font-size: 1.2rem;
    line-height: 1.5;
    color: #006cba;
    text-align: right;
    text-decoration: underline
  }
  
  @media screen and (min-width: 767px), print {
    .icon-target {
      margin-top: .8rem;
      font-size: 1.4rem
    }
  }
  
  a[target=_blank] {
    position: relative
  }
  
  a[target=_blank] .reader-txt {
    position: absolute;
    left: -9000px;
    width: 0;
    overflow: hidden;
    pointer-events: none
  }
  
  @media screen and (min-width: 767px), print {
    a[target=_blank]:hover .reader-txt, a[target=_blank]:focus-visible .reader-txt {
      position: absolute;
      right: -3rem;
      bottom: -1.5em;
      left: auto;
      z-index: 5;
      display: block;
      width: auto;
      min-width: 150px;
      padding: 4px .5em;
      margin-top: 0;
      overflow: auto;
      font-size: 1.4rem;
      letter-spacing: 0;
      line-height: 1;
      color: #333;
      text-align: center;
      text-indent: 0;
      white-space: nowrap;
      background-color: #eef5fe;
      border: 1px solid #0058ac;
      opacity: 1 !important
    }
  }
  
  @media screen and (min-width: 767px), print {
    a[href^="tel:"] {
      pointer-events: none;
      cursor: default
    }
  }
  
  .article-txt {
    margin-top: 1em
  }
  
  .article-txt strong {
    font-weight: 400;
    color: #e90000
  }
  
  .article-txt a {
    color: #006cba;
    text-decoration: underline
  }
  
  .article-txt a:hover, .article-txt a:focus-visible {
    text-decoration: none
  }
  
  .article-txt--center {
    text-align: center
  }
  
  .article-txt--right {
    text-align: right
  }
  
  .article-txt+.img-list {
    margin-top: 1rem
  }
  
  .link__txt {
    color: #006cba;
    text-decoration: underline
  }
  
  .icon--pdf::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url(../img/icon-pdf.png) no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .icon--pdf::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .icon--doc::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url(../img/icon-doc.png) no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .icon--doc::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .icon--xls::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url(../img/icon-xls.png) no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .icon--xls::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .icon--zip::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url(../img/icon-zip.png) no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .icon--zip::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .icon--file::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url(../img/icon-file.png) no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .icon--file::after {
      width: 2rem;
      height: 2.2rem;
      margin-bottom: -0.4rem;
      margin-left: .4rem
    }
  }
  
  .icon--out::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.2rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url(../img/icon-out.png) no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .icon--out::after {
      width: 1.5rem;
      height: 1.5rem
    }
  }
  
  .code-block {
    padding: 1.6rem 2rem;
    margin-top: 3rem;
    word-break: break-word;
    border: 2px solid #707070
  }
  
  .article-txt+.code-block {
    margin-top: .8rem
  }
  
  .line {
    height: 1px;
    margin: 4rem 0;
    background: #707070
  }
  
  .line+* {
    margin-top: 0 !important
  }
  
  .mail-address {
    display: flex
  }
  
  .mail-address__ttl {
    flex-shrink: 0;
    margin-right: 1em
  }
  
  .btn {
    display: inline-block
  }
  
  .btn[href]:hover, .btn[href]:focus-visible {
    text-decoration: underline
  }
  
  .btn-lang {
    display: flex;
    align-items: center;
    gap: .5rem;
    color: #fff;
    margin-left: auto
  }
  
  @media screen and (min-width: 767px), print {
    .btn-lang {
      display: none
    }
  }
  
  .btn-lang svg {
    width: 1.2rem
  }
  
  .btn-lang svg path {
    fill: #fff
  }
  
  .btn-lang__txt {
    font-size: 1.2rem;
    text-decoration: underline
  }
  
  p+.btn-lang {
    color: #333
  }
  
  p+.btn-lang svg path {
    fill: #333
  }
  
  .btn-list {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 2rem 0;
    margin-top: 2rem
  }
  
  .btn-list__item {
    display: flex;
    align-items: center;
    width: 40rem;
    padding: 1.8rem 3.4rem 1.6rem 1.5rem;
    position: relative
  }
  
  .btn-list__item::after {
    width: 1rem;
    height: 1rem;
    content: "";
    border-top: .2rem solid #fff;
    border-right: .2rem solid #fff;
    display: block;
    position: absolute;
    transform: rotate(45deg);
    top: 0;
    right: 1.4rem;
    bottom: 0;
    margin: auto
  }
  
  .btn-list__item:not([href]):after {
    content: none
  }
  
  @media screen and (min-width: 767px), print {
    .btn-list__item {
      padding: 2rem 4rem 2rem 2rem
    }
    .btn-list__item::after {
      right: 2rem
    }
  }
  
  .btn-list__item.--white {
    background: #fff;
    border: 1px solid #134798
  }
  
  .btn-list__item.--white::after {
    border-color: #363636
  }
  
  .btn-list__item.--blue {
    color: #fff;
    background: #134798
  }
  
  .btn-list__item.--light-blue {
    border: 1px solid #123068;
    color: #333;
    background: #eef4f9
  }
  
  .btn-list__item.--light-blue::after {
    border-color: #333
  }
  
  .btn-list__item.--gray {
    background: #f3f3f3;
    border: 1px solid #bbb
  }
  
  .btn-list__item.--gray::after {
    border-color: #333
  }
  
  .btn-list__item:last-of-type {
    margin-bottom: 0
  }
  
  .btn-list__item.icon--pdf::after {
    background: 0 0
  }
  
  .btn-list__item.icon--pdf .btn__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("/en/common/img/icon-pdf.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .btn-list__item.icon--pdf .btn__txt::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .btn-list__item.icon--doc::after {
    background: 0 0
  }
  
  .btn-list__item.icon--doc .btn__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("/en/common/img/icon-doc.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .btn-list__item.icon--doc .btn__txt::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .btn-list__item.icon--xls::after {
    background: 0 0
  }
  
  .btn-list__item.icon--xls .btn__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("/en/common/img/icon-xls.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .btn-list__item.icon--xls .btn__txt::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .btn-list__item.icon--zip::after {
    background: 0 0
  }
  
  .btn-list__item.icon--zip .btn__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("/en/common/img/icon-zip.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .btn-list__item.icon--zip .btn__txt::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .btn-list__item.icon--file::after {
    background: 0 0
  }
  
  .btn-list__item.icon--file .btn__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("/en/common/img/icon-file.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .btn-list__item.icon--file .btn__txt::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .btn-list__item.icon--out::after {
    background: 0 0
  }
  
  .btn-list__item.icon--out .btn__txt::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.2rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem;
    margin-left: .3rem;
    content: "";
    background: url(../img/icon-out.png) no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .btn-list__item.icon--out .btn__txt::after {
      width: 1.5rem;
      height: 1.5rem
    }
  }
  
  .btn-list__item.icon--out.--blue .btn__txt::after {
    background: url(../img/icon-out-w.png) no-repeat;
    background-size: contain
  }
  
  .btn-list.--year {
    flex-wrap: nowrap;
    justify-content: flex-start;
    margin-top: 1.4rem
  }
  
  @media screen and (min-width: 767px), print {
    .btn-list.--year {
      margin-top: 2rem
    }
  }
  
  .btn-list.--year .btn-list__item {
    width: auto;
    max-width: 44%;
    min-height: 5.3rem;
    padding-top: .7em;
    padding-bottom: .5em;
    margin-left: auto
  }
  
  @media screen and (min-width: 767px), print {
    .btn-list.--year .btn-list__item {
      min-height: 4rem;
      padding-right: 4rem;
      padding-left: 2rem
    }
  }
  
  .btn-list.--year .btn-list__item.--left {
    padding-right: 1.5rem;
    padding-left: 3.4rem;
    margin-left: 0
  }
  
  @media screen and (min-width: 767px), print {
    .btn-list.--year .btn-list__item.--left {
      padding-right: 2rem;
      padding-left: 4rem
    }
  }
  
  .btn-list.--year .btn-list__item.--left::after {
    right: auto;
    left: 1.4rem;
    transform: rotate(-135deg)
  }
  
  @media screen and (min-width: 767px), print {
    .btn-list.--year .btn-list__item.--left::after {
      left: 2rem
    }
  }
  
  @media screen and (min-width: 767px), print {
    .btn-list {
      margin-top: 4rem
    }
    .btn-list.--col1 {
      flex-direction: column;
      gap: 2rem 0;
      align-items: center
    }
    .btn-list.--col2 {
      gap: 2rem 6rem;
      justify-content: flex-start;
      max-width: 78rem;
      margin-right: auto;
      margin-left: auto
    }
    .btn-list.--col2 .btn-list__item {
      width: calc(50% - 3rem)
    }
    .btn-list.--col3 {
      gap: 2rem;
      justify-content: flex-start
    }
    .btn-list.--col3 .btn-list__item {
      width: calc(33.3333333333% - 1.333rem)
    }
    .btn-list.--col4 {
      gap: 2rem 6rem;
      justify-content: flex-start
    }
    .btn-list.--col4 .btn-list__item {
      width: calc(50% - 3rem);
      min-height: 6.4rem;
      padding-top: .6rem;
      padding-bottom: .4rem
    }
  }
  
  @media screen and (min-width: 767px)and (min-width: 767px), print {
    .btn-list.--right {
      justify-content: flex-end
    }
  }
  
  @media screen and (min-width: 1060px) {
    .btn-list.--col4 {
      gap: 2rem 3.2rem
    }
    .btn-list.--col4 .btn-list__item {
      width: calc((100% - 9.6rem)/4)
    }
  }
  
  .btn-list+.article-txt {
    margin-top: 3rem
  }
  
  @media screen and (min-width: 767px), print {
    .btn-list+.article-txt {
      margin-top: 4rem
    }
  }
  
  .article-txt+.btn-list {
    margin-top: 1em
  }
  
  @media screen and (min-width: 767px), print {
    .article-txt+.btn-list {
      margin-top: 1.5em
    }
  }
  
  .anchorlink-list {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem 3rem;
    margin-top: 2rem
  }
  
  @media screen and (min-width: 767px), print {
    .anchorlink-list {
      margin-top: 4rem
    }
  }
  
  .anchorlink-list__item {
    flex: 1 0 auto;
    max-width: 100%;
    padding: .2rem 2rem .9rem 0;
    border-bottom: .1rem solid #134798;
    position: relative
  }
  
  .anchorlink-list__item::after {
    width: 1rem;
    height: 1rem;
    content: "";
    border-top: .2rem solid #000;
    border-right: .2rem solid #000;
    display: block;
    position: absolute;
    content: "";
    transform: rotate(135deg);
    top: 20%;
    right: .5rem;
    bottom: 0
  }
  
  .ttl+.anchorlink-list {
    margin-top: 2rem !important
  }
  
  .book-outline__btns {
    margin-top: 1.5rem
  }
  
  .book-outline__btns__item:not(:first-child) {
    margin-top: 1rem
  }
  
  .book-outline__btns__link {
    display: block;
    padding: 1.8rem 3.4rem 1.6rem 1.5rem
  }
  
  .book-outline__btns__link:hover, .book-outline__btns__link:focus-visible {
    text-decoration: underline
  }
  
  .book-outline__btns__link.--anchor {
    background: #134798;
    color: #fff;
    width: 100%;
    position: relative
  }
  
  .book-outline__btns__link.--anchor::after {
    width: 1rem;
    height: 1rem;
    content: "";
    border-top: .2rem solid #fff;
    border-right: .2rem solid #fff;
    display: block;
    position: absolute;
    transform: rotate(45deg);
    top: 0;
    right: 1.4rem;
    bottom: 0;
    transform: rotate(135deg);
    margin: auto
  }
  
  .book-outline__btns__link.--download {
    border: 1px solid #d83320;
    background-color: #fff3f1;
    font-weight: 500
  }
  
  @media screen and (min-width: 767px), print {
    .book-outline__btns {
      display: flex;
      justify-content: flex-end;
      gap: 0 1rem;
      margin-top: 0;
      width: 100%
    }
    .book-outline__btns__item:not(:first-child) {
      margin-top: auto
    }
    .book-outline__btns__link {
      padding: .7rem 1rem
    }
    .book-outline__btns__link.--anchor {
      width: 12rem
    }
    .book-outline__btns__link.--anchor::after {
      top: 30%;
      bottom: auto
    }
  }
  
  .wysiwyg_box {
    font-size: 1.4rem
  }
  
  @media screen and (min-width: 767px), print {
    .wysiwyg_box {
      font-size: 1.6rem
    }
  }
  
  .box {
    padding: 2rem 1.2rem;
    margin-top: 2rem
  }
  
  @media screen and (min-width: 767px), print {
    .box {
      padding: 3rem;
      margin-top: 4rem
    }
  }
  
  .box>*:first-child {
    margin-top: 0
  }
  
  .box.--gray {
    background: #fff;
    border: 1px solid #707070
  }
  
  .box.--orange {
    background: #fffdf8;
    border: 1px solid #dc8d40
  }
  
  @media screen and (min-width: 767px), print {
    .box.--orange {
      border: 2px solid #dc8d40
    }
  }
  
  .box.--blue {
    position: relative;
    border: 1px solid #3d67a9
  }
  
  @media screen and (min-width: 767px), print {
    .box.--blue {
      border: 2px solid #3d67a9
    }
  }
  
  .box.--blue::before {
    position: absolute;
    top: 0;
    left: .3rem;
    display: block;
    width: .4rem;
    height: 100%;
    content: "";
    background: #d0e3f1
  }
  
  @media screen and (min-width: 767px), print {
    .box.--blue::before {
      left: .7rem;
      width: .8rem
    }
  }
  
  .box.--red {
    position: relative;
    background: #fff9f8;
    border: 1px solid #d83320
  }
  
  @media screen and (min-width: 767px), print {
    .box.--red {
      border: 2px solid #d83320
    }
  }
  
  .box.--red::before {
    display: block;
    width: calc(100% - 6px);
    height: calc(100% - 6px);
    pointer-events: none;
    content: "";
    border: 1px solid rgba(216, 51, 32, .5);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%)
  }
  
  @media screen and (min-width: 767px), print {
    .box.--red::before {
      width: calc(100% - 10px);
      height: calc(100% - 10px);
      border: 1px solid #d83320
    }
  }
  
  .book-detail {
    padding: 2rem 1.2rem;
    margin-top: 2rem;
    border: 1px solid #bbb
  }
  
  @media screen and (min-width: 767px), print {
    .book-detail {
      display: flex;
      padding: 2rem;
      margin-top: 3rem
    }
  }
  
  .book-detail__img {
    width: 100%;
    max-width: 16.2rem;
    margin: 0 auto
  }
  
  @media screen and (min-width: 767px), print {
    .book-detail__img {
      flex-shrink: 0;
      width: 16rem;
      margin-right: 2rem;
      margin-left: 0
    }
  }
  
  .book-detail__img .img-box__inner::before {
    padding-top: 141.35%
  }
  
  .book-detail__txt {
    width: 100%;
    margin-top: 2rem
  }
  
  @media screen and (min-width: 767px), print {
    .book-detail__txt {
      flex-grow: 1;
      width: auto;
      margin-top: 0
    }
  }
  
  .book-detail__txt>*:first-child {
    margin-top: 0
  }
  
  @media screen and (min-width: 767px), print {
    .book-detail__ttl {
      margin-bottom: 2rem
    }
  }
  
  .book-outline {
    padding: 2rem 1.2rem;
    margin-top: 2rem;
    border: 1px solid #bbb
  }
  
  .book-outline .ttl {
    margin-top: 0;
    width: 100%
  }
  
  @media screen and (min-width: 767px), print {
    .book-outline {
      display: flex;
      flex-wrap: wrap;
      padding: 2rem;
      margin-top: 3rem
    }
  }
  
  .book-outline__img {
    width: 100%;
    max-width: 16.2rem;
    margin: 0 auto
  }
  
  @media screen and (min-width: 767px), print {
    .book-outline__img {
      flex-shrink: 0;
      width: 16rem;
      margin-right: 2rem;
      margin-left: 0
    }
  }
  
  .book-outline__img .img-box__inner::before {
    padding-top: 141.35%
  }
  
  .book-outline__txt {
    width: 100%;
    margin-top: 2rem
  }
  
  @media screen and (min-width: 767px), print {
    .book-outline__txt {
      width: calc(100% - 18rem);
      margin-top: 0
    }
  }
  
  .book-outline__txt>*:first-child {
    margin-top: 0
  }
  
  .profile-box {
    padding: 2rem 1.2rem;
    margin-top: 2rem;
    border: 1px solid #bbb
  }
  
  @media screen and (min-width: 767px), print {
    .profile-box {
      display: flex;
      padding: 2rem 2rem 2rem 1.5rem
    }
  }
  
  .profile-box__img {
    width: 100%;
    max-width: 16.2rem;
    margin: 0 auto
  }
  
  @media screen and (min-width: 767px), print {
    .profile-box__img {
      flex-shrink: 0;
      width: 16.8rem;
      margin-right: 1.5rem;
      margin-left: 0
    }
  }
  
  .profile-box__img .img-box__inner::before {
    padding-top: 141.35%
  }
  
  .profile-box__txt {
    width: 100%;
    margin-top: 2rem
  }
  
  @media screen and (min-width: 767px), print {
    .profile-box__txt {
      flex-grow: 1;
      width: auto;
      margin-top: 1rem
    }
  }
  
  .profile-box__txt .article-txt {
    margin-top: .6rem
  }
  
  .profile-box__txt>*:first-child {
    margin-top: 0
  }
  
  .profile-box__name {
    font-size: 1.6rem;
    font-weight: 600
  }
  
  @media screen and (min-width: 767px), print {
    .profile-box__name {
      font-size: 2rem
    }
  }
  
  .profile-box__name.--kana {
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 1.3
  }
  
  .profile-box__position {
    margin-top: 8px
  }
  
  .profile-box__ttl {
    position: relative;
    padding-left: 1.6rem;
    margin: 1.5rem 0;
    font-size: 1.4rem
  }
  
  @media screen and (min-width: 767px), print {
    .profile-box__ttl {
      padding-left: 2rem;
      margin: 1.9rem 0 .5rem;
      font-size: 1.6rem
    }
  }
  
  .profile-box__ttl::before {
    position: absolute;
    top: .6rem;
    left: 0;
    display: block;
    width: .8rem;
    height: .8rem;
    content: "";
    background: #3d67a9;
    transform: rotate(45deg)
  }
  
  @media screen and (min-width: 767px), print {
    .profile-box__ttl::before {
      top: .7rem;
      width: 1rem;
      height: 1rem
    }
  }
  
  .profile-list {
    display: flex;
    flex-direction: column;
    gap: 2rem;
    margin-top: 2rem
  }
  
  @media screen and (min-width: 767px), print {
    .profile-list {
      flex-direction: row;
      flex-wrap: wrap;
      gap: 4rem 9rem;
      margin-top: 4rem
    }
  }
  
  @media screen and (min-width: 767px), print {
    .profile-list__item {
      width: calc((100% - 27rem)/4)
    }
    .profile-list__item .profile-box__img {
      width: 100%;
      margin-right: 0
    }
  }
  
  @media screen and (min-width: 1060px) {
    .profile-list__item {
      width: calc((100% - 36rem)/5)
    }
  }
  
  @media screen and (min-width: 767px), print {
    .container--col2__main .profile-list, .container--s .profile-list {
      gap: 4rem 6.8rem
    }
    .container--col2__main .profile-list__item, .container--s .profile-list__item {
      width: calc((100% - 13.6rem)/3)
    }
  }
  
  @media screen and (min-width: 1060px) {
    .container--col2__main .profile-list, .container--s .profile-list {
      gap: 4rem 6.8rem
    }
    .container--col2__main .profile-list__item, .container--s .profile-list__item {
      width: calc((100% - 20.4rem)/4)
    }
  }
  
  .inquiry-box {
    padding: 1.5rem 1.5rem 3.6rem;
    margin-top: 2rem;
    background: #f3f3f3
  }
  
  @media screen and (min-width: 767px), print {
    .inquiry-box {
      padding: 2.5rem 3rem 3rem
    }
  }
  
  .inquiry-box__heading {
    padding-bottom: .6rem;
    font-size: 1.8rem;
    border-bottom: .1rem solid #707070
  }
  
  .inquiry-box__subheading {
    margin-top: 1.5rem;
    padding-left: .8rem;
    font-size: 1.5rem;
    border-left: .3rem solid #3d67a9
  }
  
  @media screen and (min-width: 767px), print {
    .inquiry-box__subheading {
      font-size: 1.6rem
    }
  }
  
  .inquiry-box__heading, .inquiry-box__subheading {
    margin-bottom: 1.5rem
  }
  
  .inquiry-box__inner+* {
    margin-top: 3rem
  }
  
  .inquiry-box__inner .ttl.--lv5 {
    margin-top: 1.4rem;
    margin-bottom: 1rem
  }
  
  .inquiry-box__data__item {
    display: flex;
    gap: 1rem
  }
  
  .inquiry-box__data__item .heading {
    width: 6rem;
    flex-shrink: 0
  }
  
  .inquiry-box__data__item .detail {
    flex-grow: 1
  }
  
  .inquiry-box__data__item .detail a {
    color: #006cba;
    text-decoration: underline
  }
  
  .inquiry-box__data__item .detail a:hover, .inquiry-box__data__item .detail a:focus-visible {
    text-decoration: none
  }
  
  @media screen and (min-width: 767px), print {
    .inquiry-box__data__item .detail a[href^="tel:"] {
      color: #333;
      text-decoration: none
    }
  }
  
  .inquiry-box__btn {
    display: block;
    margin-top: 1.4rem;
    padding: 1.5rem;
    padding-right: 3rem;
    background: #fff;
    border: 1px solid #134798;
    position: relative
  }
  
  .inquiry-box__btn::after {
    width: 1rem;
    height: 1rem;
    content: "";
    border-top: .2rem solid #000;
    border-right: .2rem solid #000;
    display: block;
    position: absolute;
    transform: rotate(45deg);
    top: 0;
    right: 1rem;
    bottom: 0;
    margin: auto
  }
  
  .inquiry-box__btn.icon--pdf::after {
    background: 0 0
  }
  
  .inquiry-box__btn.icon--pdf .btn__txt::after {
    content: "";
    display: inline-block;
    width: 12px;
    height: 13px;
    background: url("../img/icon-pdf.png") no-repeat;
    background-size: contain;
    margin-left: 3px;
    margin-right: 3px;
    margin-bottom: -1px
  }
  
  @media screen and (min-width: 767px), print {
    .inquiry-box__btn.icon--pdf .btn__txt::after {
      width: 20px;
      height: 22px;
      margin-left: 4px;
      margin-bottom: -4px
    }
  }
  
  .inquiry-box__btn.icon--doc::after {
    background: 0 0
  }
  
  .inquiry-box__btn.icon--doc .btn__txt::after {
    content: "";
    display: inline-block;
    width: 12px;
    height: 13px;
    background: url("../img/icon-doc.png") no-repeat;
    background-size: contain;
    margin-left: 3px;
    margin-right: 3px;
    margin-bottom: -1px
  }
  
  @media screen and (min-width: 767px), print {
    .inquiry-box__btn.icon--doc .btn__txt::after {
      width: 20px;
      height: 22px;
      margin-left: 4px;
      margin-bottom: -4px
    }
  }
  
  .inquiry-box__btn.icon--xls::after {
    background: 0 0
  }
  
  .inquiry-box__btn.icon--xls .btn__txt::after {
    content: "";
    display: inline-block;
    width: 12px;
    height: 13px;
    background: url("../img/icon-xls.png") no-repeat;
    background-size: contain;
    margin-left: 3px;
    margin-right: 3px;
    margin-bottom: -1px
  }
  
  @media screen and (min-width: 767px), print {
    .inquiry-box__btn.icon--xls .btn__txt::after {
      width: 20px;
      height: 22px;
      margin-left: 4px;
      margin-bottom: -4px
    }
  }
  
  .inquiry-box__btn.icon--zip::after {
    background: 0 0
  }
  
  .inquiry-box__btn.icon--zip .btn__txt::after {
    content: "";
    display: inline-block;
    width: 12px;
    height: 13px;
    background: url("../img/icon-zip.png") no-repeat;
    background-size: contain;
    margin-left: 3px;
    margin-right: 3px;
    margin-bottom: -1px
  }
  
  @media screen and (min-width: 767px), print {
    .inquiry-box__btn.icon--zip .btn__txt::after {
      width: 20px;
      height: 22px;
      margin-left: 4px;
      margin-bottom: -4px
    }
  }
  
  .inquiry-box__btn.icon--file::after {
    background: 0 0
  }
  
  .inquiry-box__btn.icon--file .btn__txt::after {
    content: "";
    display: inline-block;
    width: 12px;
    height: 13px;
    background: url("../img/icon-file.png") no-repeat;
    background-size: contain;
    margin-left: 3px;
    margin-right: 3px;
    margin-bottom: -1px
  }
  
  @media screen and (min-width: 767px), print {
    .inquiry-box__btn.icon--file .btn__txt::after {
      width: 20px;
      height: 22px;
      margin-left: 4px;
      margin-bottom: -4px
    }
  }
  
  .inquiry-box__btn.icon--out::after {
    background: 0 0
  }
  
  .inquiry-box__btn.icon--out .btn__txt::after {
    content: "";
    display: inline-block;
    width: 1.2rem;
    height: 1.2rem;
    background: url(../img/icon-out.png) no-repeat;
    background-size: contain;
    margin-left: .3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem
  }
  
  @media screen and (min-width: 767px), print {
    .inquiry-box__btn.icon--out .btn__txt::after {
      width: 1.5rem;
      height: 1.5rem
    }
  }
  
  .inquiry-box__btn:hover, .inquiry-box__btn:focus-visible {
    text-decoration: underline
  }
  
  @media screen and (min-width: 767px), print {
    .inquiry-box__btn {
      width: 40rem;
      margin-top: 2rem
    }
    .inquiry-box__btn::after {
      right: 2rem
    }
  }
  
  .related-link-box {
    padding: 1.5rem;
    margin-top: 4rem;
    border: 1px solid #bbb
  }
  
  @media screen and (min-width: 767px), print {
    .related-link-box {
      padding: 2rem
    }
  }
  
  .related-link-box__heading {
    font-size: 2rem;
    font-weight: 600
  }
  
  @media screen and (min-width: 767px), print {
    .related-link-box__heading {
      font-weight: 700
    }
  }
  
  .change-log-box {
    padding: 1.5rem;
    margin-top: 2rem;
    border: 1px solid #bbb
  }
  
  @media screen and (min-width: 767px), print {
    .change-log-box {
      padding: 2rem 2rem .5rem
    }
  }
  
  .change-log-box__heading {
    padding-left: .8rem;
    margin-bottom: .5rem;
    border-left: .3rem solid #3d67a9;
    font-size: 2rem;
    font-weight: 600
  }
  
  @media screen and (min-width: 767px), print {
    .change-log-box__heading {
      padding-left: 1rem;
      font-weight: 700
    }
  }
  
  .change-log-box__list__item {
    padding: 1.5rem 0;
    border-bottom: .1rem solid #bbb
  }
  
  .change-log-box__list__item:last-of-type {
    border: none
  }
  
  .change-log-box__list__item .date {
    margin-bottom: .7rem
  }
  
  @media screen and (min-width: 767px), print {
    .change-log-box__list__item {
      display: flex;
      padding: 1.5rem 0
    }
    .change-log-box__list__item .date {
      flex-shrink: 0;
      width: 15.6rem;
      margin-bottom: 0
    }
  }
  
  .change-log-box__list__item .txt>*:first-child {
    margin-top: 0
  }
  
  .change-log-box__list__item .list {
    margin-top: .7rem
  }
  
  .important-info {
    background-color: #fff;
    width: calc(100% + 4rem);
    margin-left: -2rem;
    padding: 1.5rem 2rem;
    border: 1px solid #bbb
  }
  
  @media screen and (min-width: 767px), print {
    .important-info {
      display: flex;
      width: 100%;
      min-height: 7rem;
      margin-left: 0;
      padding: 0
    }
  }
  
  .important-info+* {
    margin-top: 2rem
  }
  
  @media screen and (min-width: 767px), print {
    .important-info+* {
      margin-top: 4rem
    }
  }
  
  .important-info+.category-lead {
    margin-top: 0
  }
  
  @media screen and (min-width: 767px), print {
    .important-info+.category-lead {
      margin-top: 3rem
    }
  }
  
  .important-info__heading {
    display: inline-block;
    padding: .4rem 1.2rem;
    background: #000;
    color: #fff;
    font-weight: 600
  }
  
  @media screen and (min-width: 767px), print {
    .important-info__heading {
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
      width: 18rem
    }
  }
  
  .important-info__list {
    margin-top: 1rem
  }
  
  @media screen and (min-width: 767px), print {
    .important-info__list {
      display: flex;
      align-items: center;
      flex-wrap: wrap;
      margin-top: 0;
      padding: 2rem
    }
  }
  
  .important-info__item {
    margin-top: 1em;
    line-height: 1.57
  }
  
  @media screen and (min-width: 767px), print {
    .important-info__item {
      width: 100%;
      margin-top: .5em
    }
  }
  
  .important-info__item:first-of-type {
    margin-top: 0
  }
  
  @media screen and (min-width: 767px), print {
    .important-info__item__inner {
      display: flex;
      align-items: baseline
    }
  }
  
  .important-info__item a .important-info__ttl {
    text-decoration: underline
  }
  
  .important-info__item a:hover .important-info__ttl, .important-info__item a:focus-visible .important-info__ttl {
    text-decoration: none
  }
  
  .important-info__item a.icon--pdf::after {
    content: none
  }
  
  .important-info__item a.icon--pdf .important-info__ttl::after {
    content: "";
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    background: url("../img/icon-pdf.png") no-repeat;
    background-size: contain;
    margin-left: .3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem
  }
  
  @media screen and (min-width: 767px), print {
    .important-info__item a.icon--pdf .important-info__ttl::after {
      width: 2rem;
      height: 2.2rem;
      margin-left: .4rem;
      margin-bottom: -0.4rem
    }
  }
  
  .important-info__item a.icon--doc::after {
    content: none
  }
  
  .important-info__item a.icon--doc .important-info__ttl::after {
    content: "";
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    background: url("../img/icon-doc.png") no-repeat;
    background-size: contain;
    margin-left: .3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem
  }
  
  @media screen and (min-width: 767px), print {
    .important-info__item a.icon--doc .important-info__ttl::after {
      width: 2rem;
      height: 2.2rem;
      margin-left: .4rem;
      margin-bottom: -0.4rem
    }
  }
  
  .important-info__item a.icon--xls::after {
    content: none
  }
  
  .important-info__item a.icon--xls .important-info__ttl::after {
    content: "";
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    background: url("../img/icon-xls.png") no-repeat;
    background-size: contain;
    margin-left: .3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem
  }
  
  @media screen and (min-width: 767px), print {
    .important-info__item a.icon--xls .important-info__ttl::after {
      width: 2rem;
      height: 2.2rem;
      margin-left: .4rem;
      margin-bottom: -0.4rem
    }
  }
  
  .important-info__item a.icon--zip::after {
    content: none
  }
  
  .important-info__item a.icon--zip .important-info__ttl::after {
    content: "";
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    background: url("../img/icon-zip.png") no-repeat;
    background-size: contain;
    margin-left: .3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem
  }
  
  @media screen and (min-width: 767px), print {
    .important-info__item a.icon--zip .important-info__ttl::after {
      width: 2rem;
      height: 2.2rem;
      margin-left: .4rem;
      margin-bottom: -0.4rem
    }
  }
  
  .important-info__item a.icon--file::after {
    content: none
  }
  
  .important-info__item a.icon--file .important-info__ttl::after {
    content: "";
    display: inline-block;
    width: 1.2rem;
    height: 1.3rem;
    background: url("../img/icon-file.png") no-repeat;
    background-size: contain;
    margin-left: .3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem
  }
  
  @media screen and (min-width: 767px), print {
    .important-info__item a.icon--file .important-info__ttl::after {
      width: 2rem;
      height: 2.2rem;
      margin-left: .4rem;
      margin-bottom: -0.4rem
    }
  }
  
  .important-info__item a.icon--out::after {
    content: none
  }
  
  .important-info__item a.icon--out .important-info__ttl::after {
    content: "";
    display: inline-block;
    width: 1.2rem;
    height: 1.2rem;
    background: url("../img/icon-out.png") no-repeat;
    background-size: contain;
    margin-left: .3rem;
    margin-right: .3rem;
    margin-bottom: -0.1rem
  }
  
  @media screen and (min-width: 767px), print {
    .important-info__item a.icon--out .important-info__ttl::after {
      width: 1.5rem;
      height: 1.5rem
    }
  }
  
  @media screen and (min-width: 767px), print {
    .important-info__date {
      width: 12.6rem;
      padding-right: .5em;
      flex-shrink: 0
    }
  }
  
  .important-info__ttl {
    margin-top: .3rem
  }
  
  @media screen and (min-width: 767px), print {
    .important-info__ttl {
      margin-top: 0
    }
  }
  
  .category-lead {
    margin: 0 calc(50% - 50vw);
    padding: 2rem calc(50vw - 50%);
    background: #f3f3f3
  }
  
  @media screen and (min-width: 767px), print {
    .category-lead {
      width: 100%;
      margin: 0;
      padding: 2rem 2rem 1.8rem
    }
  }
  
  table tr>*:first-child {
    border-left: 1px solid #bbb !important
  }
  
  table th, table td {
    vertical-align: middle !important;
    border-top: 1px solid #bbb !important;
    border-right: 1px solid #bbb !important
  }
  
  table th>*:first-child, table td>*:first-child {
    margin-top: 0
  }
  
  table th {
    padding: 1.2rem 1.2rem 1rem !important;
    font-weight: 500;
    background: #e0eef9 !important
  }
  
  table td {
    padding: 1.2rem 1.2rem 1rem !important;
    background: #fff
  }
  
  table strong {
    color: #e90000;
    font-weight: 400
  }
  
  .table__wrap {
    margin-top: 1.4rem
  }
  
  @media screen and (min-width: 767px), print {
    .table__wrap {
      margin-top: 2rem
    }
  }
  
  .table__caption {
    margin-top: 1rem;
    font-size: 1.4rem
  }
  
  @media screen and (min-width: 767px), print {
    .table__caption {
      margin-top: 2rem
    }
  }
  
  .table table>caption {
    margin-bottom: 1.4rem;
    padding-left: 1.4rem;
    text-align: left;
    font-size: 1.4rem;
    font-weight: 600;
    position: relative
  }
  
  @media screen and (min-width: 767px), print {
    .table table>caption {
      margin-bottom: 2rem;
      padding-left: 1.8rem;
      font-size: 1.5rem
    }
  }
  
  .table table>caption::before {
    content: "";
    display: block;
    width: .8rem;
    height: .8rem;
    background: linear-gradient(135deg, transparent 0, transparent 50%, #3d67a9 50%, #3d67a9 100%);
    position: absolute;
    top: .6rem;
    left: 0
  }
  
  @media screen and (min-width: 767px), print {
    .table table>caption::before {
      width: 1rem;
      height: 1rem;
      top: .7rem
    }
  }
  
  .table table td>.def-list__wrap:first-child .def-list:first-child {
    margin-top: 0
  }
  
  .table.--fixed table {
    width: 100%;
    table-layout: fixed;
    border-bottom: 1px solid #bbb !important
  }
  
  .table.--fixed table>.table__ttl {
    margin-top: 0
  }
  
  @media screen and (min-width: 767px), print {
    .table.--fixed table tr>*:first-child {
      border-left: 1px solid #bbb !important
    }
  }
  
  .table.--fixed table th, .table.--fixed table td {
    display: block;
    width: 100%;
    border-left: 1px solid #bbb !important
  }
  
  @media screen and (min-width: 767px), print {
    .table.--fixed table th, .table.--fixed table td {
      display: table-cell;
      border-left: none !important
    }
  }
  
  @media screen and (min-width: 767px), print {
    .table.--fixed table th {
      width: 52%;
      max-width: 300px
    }
  }
  
  .table.--scroll {
    height: auto;
    overflow-x: auto;
    overflow-y: hidden
  }
  
  @media screen and (min-width: 767px), print {
    .table.--scroll {
      overflow: inherit
    }
  }
  
  .table.--scroll table {
    width: auto;
    margin-bottom: 20px;
    table-layout: fixed
  }
  
  @media screen and (min-width: 767px), print {
    .table.--scroll table {
      max-width: 100% !important;
      table-layout: inherit
    }
  }
  
  .table.--scroll table tr>*:first-child {
    border-left: 1px solid #ccc !important
  }
  
  .table.--scroll table th, .table.--scroll table td {
    font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif !important;
    font-size: 1.4rem !important;
    border: 1px solid #ccc !important
  }
  
  @media screen and (min-width: 767px), print {
    .table.--scroll table th, .table.--scroll table td {
      font-size: 1.5rem !important
    }
  }
  
  .table.--scroll table th *, .table.--scroll table td * {
    font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif !important;
    font-size: 1.4rem !important
  }
  
  @media screen and (min-width: 767px), print {
    .table.--scroll table th *, .table.--scroll table td * {
      font-size: 1.5rem !important
    }
  }
  
  .table.--scroll table a {
    color: #006cba !important;
    text-decoration: underline !important
  }
  
  .table.--scroll .simplebar-track.simplebar-horizontal {
    height: 4px;
    background: #ddd;
    border-radius: 50vh
  }
  
  .table.--scroll .simplebar-track.simplebar-horizontal .simplebar-scrollbar {
    top: 0;
    height: 4px
  }
  
  .table.--scroll .simplebar-track.simplebar-horizontal .simplebar-scrollbar::before {
    height: 4px;
    background: #134798;
    border-radius: 50vh;
    opacity: 1
  }
  
  .table.--scroll .scroll-note {
    margin-bottom: .5rem
  }
  
  .gsc-above-wrapper-area table tr>*:first-child {
    border-left: none !important
  }
  
  .gsc-above-wrapper-area table th, .gsc-above-wrapper-area table td {
    border-top: none !important;
    border-right: none !important
  }
  
  .gsc-above-wrapper-area table td {
    padding: 0 !important
  }
  
  @media screen and (min-width: 767px), print {
    .gsc-above-wrapper-area table td {
      padding: 0 !important
    }
  }
  
  .gsc-refinementsArea {
    display: none
  }
  
  .card-link {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem 0;
    margin-top: 3rem
  }
  
  @media screen and (min-width: 767px), print {
    .card-link {
      gap: 3.2rem
    }
  }
  
  @media screen and (min-width: 1060px) {
    .card-link {
      gap: 3.2rem 4.2rem
    }
  }
  
  .card-link__item {
    width: 100%
  }
  
  @media screen and (min-width: 767px), print {
    .card-link__item {
      width: calc((100% - 3.2rem)/2)
    }
  }
  
  @media screen and (min-width: 1060px) {
    .card-link__item {
      width: calc((100% - 8.4rem)/3)
    }
  }
  
  .card-link__item a {
    display: flex;
    flex-direction: column-reverse;
    height: 100%
  }
  
  .card-link__item a:hover .card-link__ttl__txt, .card-link__item a:focus-visible .card-link__ttl__txt {
    text-decoration: none
  }
  
  .card-link__item a.icon--pdf::after {
    content: none
  }
  
  .card-link__item a.icon--pdf .card-link__ttl__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-pdf.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .card-link__item a.icon--pdf .card-link__ttl__txt::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .card-link__item a.icon--doc::after {
    content: none
  }
  
  .card-link__item a.icon--doc .card-link__ttl__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-doc.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .card-link__item a.icon--doc .card-link__ttl__txt::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .card-link__item a.icon--xls::after {
    content: none
  }
  
  .card-link__item a.icon--xls .card-link__ttl__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-xls.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .card-link__item a.icon--xls .card-link__ttl__txt::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .card-link__item a.icon--zip::after {
    content: none
  }
  
  .card-link__item a.icon--zip .card-link__ttl__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-zip.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .card-link__item a.icon--zip .card-link__ttl__txt::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .card-link__item a.icon--file::after {
    content: none
  }
  
  .card-link__item a.icon--file .card-link__ttl__txt::after {
    display: inline-block;
    width: 12px;
    height: 13px;
    margin-right: 3px;
    margin-bottom: -1px;
    margin-left: 3px;
    content: "";
    background: url("../img/icon-file.png") no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .card-link__item a.icon--file .card-link__ttl__txt::after {
      width: 20px;
      height: 22px;
      margin-bottom: -4px;
      margin-left: 4px
    }
  }
  
  .card-link__item a.icon--out::after {
    content: none
  }
  
  .card-link__item a.icon--out .card-link__ttl__txt::after {
    display: inline-block;
    width: 1.2rem;
    height: 1.2rem;
    margin-right: .3rem;
    margin-left: .3rem;
    content: "";
    background: url(../img/icon-out.png) no-repeat;
    background-size: contain
  }
  
  @media screen and (min-width: 767px), print {
    .card-link__item a.icon--out .card-link__ttl__txt::after {
      width: 1.5rem;
      height: 1.5rem
    }
  }
  
  .card-link__img {
    width: 100%
  }
  
  .card-link__img .img-box__inner {
    overflow: hidden;
    border-top: 1px solid #707070;
    border-left: 1px solid #707070;
    border-right: 1px solid #707070
  }
  
  .card-link__img .img-box__inner::before {
    padding-top: 44.77%
  }
  
  .card-link__box {
    flex-grow: 1;
    width: 100%;
    padding: 1.5rem;
    border-top: 1px solid #707070;
    border-right: 1px solid #707070;
    border-bottom: 4px solid #3d67a9;
    border-left: 1px solid #707070
  }
  
  .card-link__label {
    font-size: 1.3rem;
    text-align: right
  }
  
  @media screen and (min-width: 767px), print {
    .card-link__label {
      font-size: 1.4rem
    }
  }
  
  .card-link__ttl {
    font-size: 2rem;
    color: #134798
  }
  
  @media screen and (min-width: 767px), print {
    .card-link__ttl {
      font-size: 1.6rem;
      margin: 0
    }
  }
  
  .card-link__ttl__txt {
    text-decoration: underline;
    text-decoration-thickness: .1rem
  }
  
  .card-link__ttl+.article-txt {
    position: relative;
    padding-top: 1rem;
    margin-top: 1rem !important
  }
  
  @media screen and (min-width: 767px), print {
    .card-link__ttl+.article-txt {
      padding-top: 1.6rem;
      margin-top: 1.6rem !important
    }
  }
  
  .card-link__ttl+.article-txt::before {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 3rem;
    height: .1rem;
    content: "";
    background: #134798
  }
  
  @media screen and (min-width: 767px), print {
    .card-link__ttl+.article-txt::before {
      height: .2rem
    }
  }
  
  @media screen and (min-width: 767px), print {
    .card-link.--col3 .card-link__item {
      width: calc((100% - 6.4rem)/3)
    }
  }
  
  @media screen and (min-width: 1060px) {
    .container--col2__main .card-link, .container--s .card-link {
      gap: 3.2rem
    }
    .container--col2__main .card-link__item, .container--s .card-link__item {
      width: calc((100% - 3.2rem)/2)
    }
  }
  
  .label {
    width: 13.5rem;
    min-width: 4.4rem;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: .2em .5em 0;
    line-height: 1.3
  }
  
  @media screen and (min-width: 767px), print {
    .label {
      width: 15.2rem
    }
  }
  
  .label.--info-cat {
    color: #fff
  }
  
  .label.--info-cat.--security {
    background: #0026a4
  }
  
  .label.--info-cat.--digital {
    background: #852797
  }
  
  .label.--info-cat.--exam {
    background: #ae004c
  }
  
  .label.--info-cat.--news {
    background: #197ea4
  }
  
  .label.--info-cat.--employee-development {
    background: #007e53
  }
  
  .label.--info-cat.--ipa-all {
    background: #7d6f11
  }
  
  .label.--info-cat.--urgent {
    width: 5.9rem;
    background: #d83320
  }
  
  .label.--info-cat.--attention {
    width: 5.9rem;
    background: #0e3278
  }
  
  .label.--info-cat.--warning {
    width: 5.9rem;
    color: #000;
    background: #ffea07
  }
  
  .label.--info-cat.--risk {
    width: 5.9rem;
    background: #9a0e9a
  }
  
  .label.--event-cat.--seminar {
    background: #ecf6ff;
    border: 1px solid #bbb
  }
  
  .label.--event-cat.--event {
    background: #e9f8f3;
    border: 1px solid #bbb
  }
  
  .label.--event-cat.--conference {
    background: #fffbe4;
    border: 1px solid #bbb
  }
  
  .swiper {
    padding-bottom: 7.4rem;
    opacity: 0
  }
  
  .swiper.swiper-initialized {
    opacity: 1
  }
  
  @media screen and (min-width: 767px), print {
    .swiper {
      padding-bottom: 0
    }
  }
  
  .swiper-slide {
    height: auto
  }
  
  .swiper-slide a {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%
  }
  
  .swiper-button-prev, .swiper-button-next {
    top: auto;
    bottom: 0;
    width: 3rem;
    height: 3rem;
    margin: 0;
    background: url(../img/slide-arw.png) center center/0.8rem 1.4rem no-repeat #134798
  }
  
  @media screen and (min-width: 767px), print {
    .swiper-button-prev, .swiper-button-next {
      top: calc((100% - 4.6rem)*.5 - 2rem);
      bottom: auto;
      width: 6.8rem;
      height: 6.8rem;
      background: #134798;
      border: 3px solid #134798;
      transition: all .2s
    }
  }
  
  .swiper-button-prev::after, .swiper-button-next::after {
    content: none
  }
  
  @media screen and (min-width: 767px), print {
    .swiper-button-prev::after, .swiper-button-next::after {
      position: absolute;
      top: 0;
      right: 2.8rem;
      bottom: 0;
      display: block;
      width: 2rem;
      height: 2rem;
      margin: auto;
      pointer-events: none;
      content: "";
      border-top: 3px solid #fff;
      border-right: 3px solid #fff;
      transform: rotate(45deg)
    }
  }
  
  .swiper-button-prev:focus-visible, .swiper-button-next:focus-visible {
    outline: auto
  }
  
  @media screen and (min-width: 767px), print {
    .swiper-button-prev:hover, .swiper-button-next:hover, .swiper-button-prev:focus-visible, .swiper-button-next:focus-visible {
      background: #fff
    }
    .swiper-button-prev:hover::after, .swiper-button-next:hover::after, .swiper-button-prev:focus-visible::after, .swiper-button-next:focus-visible::after {
      border-top: 3px solid #134798;
      border-right: 3px solid #134798
    }
  }
  
  .swiper-button-prev {
    left: calc(50% - 7.5rem);
    transform: rotate(180deg)
  }
  
  @media screen and (min-width: 767px), print {
    .swiper-button-prev {
      left: -3rem
    }
  }
  
  .swiper-button-next {
    right: calc(50% - 7.5rem)
  }
  
  @media screen and (min-width: 767px), print {
    .swiper-button-next {
      right: -3rem
    }
  }
  
  .swiper-pagination-bullet {
    width: .9rem;
    height: .9rem;
    background: #363636;
    border: 3px solid #363636 !important;
    border-radius: 0;
    opacity: 1
  }
  
  @media screen and (min-width: 767px), print {
    .swiper-pagination-bullet {
      width: 1.4rem;
      height: 1.4rem;
      transition: all .2s
    }
    .swiper-pagination-bullet:hover, .swiper-pagination-bullet:focus-visible {
      background: #fff
    }
  }
  
  .swiper-pagination-bullet-active {
    background: #d83320;
    border: 3px solid #d83320 !important
  }
  
  @media screen and (min-width: 767px), print {
    .swiper-pagination-bullet-active:hover, .swiper-pagination-bullet-active:focus-visible {
      background: #fff
    }
  }
  
  .swiper-pagination-bullet:focus-visible {
    outline: auto
  }
  
  .swiper-btn {
    bottom: 0;
    width: 6rem;
    height: 3rem;
    background: #363636;
    border: 3px solid #363636;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    align-items: center;
    justify-content: center
  }
  
  @media screen and (min-width: 767px), print {
    .swiper-btn {
      position: static;
      margin-left: 1rem;
      transform: none;
      transition: all .2s
    }
  }
  
  .swiper-btn.stop::before, .swiper-btn.stop::after {
    display: block;
    width: .4rem;
    height: 1.2rem;
    pointer-events: none;
    content: "";
    background: #fff
  }
  
  .swiper-btn.stop::before {
    margin-right: .2rem
  }
  
  .swiper-btn.play::before {
    display: block;
    width: 0;
    height: 0;
    margin-left: .3rem;
    pointer-events: none;
    content: "";
    border-color: rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) #fff;
    border-style: solid;
    border-width: 6px 0 6px 12px
  }
  
  .swiper-btn:focus-visible {
    outline: auto
  }
  
  @media screen and (min-width: 767px), print {
    .swiper-btn:hover, .swiper-btn:focus-visible {
      background: #fff
    }
    .swiper-btn:hover.stop::before, .swiper-btn:hover.stop::after, .swiper-btn:focus-visible.stop::before, .swiper-btn:focus-visible.stop::after {
      background: #363636
    }
    .swiper-btn:hover.play::before, .swiper-btn:focus-visible.play::before {
      border-color: rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) #363636
    }
  }
  
  @media screen and (min-width: 767px), print {
    .swiper-btn-wrap {
      display: flex;
      align-items: center;
      justify-content: center;
      margin-top: 1.6rem
    }
    .swiper-btn-wrap .swiper-pagination {
      position: static;
      width: auto
    }
  }
  
  .swiper-horizontal>.swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
    bottom: 4.5rem
  }
  
  .swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 .6rem
  }
  
  @media screen and (min-width: 767px), print {
    .swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
      margin: 0 1rem
    }
  }
  
  .basic-slide {
    padding: 3rem 0;
    margin: 4rem calc(50% - 50vw) 0;
    background: #d0e3f1
  }
  
  @media screen and (min-width: 767px), print {
    .basic-slide {
      padding: 6rem calc(50vw - 50%) 3rem;
      margin-top: 8rem
    }
  }
  
  .basic-slide__inner {
    position: relative
  }
  
  .basic-slide__inner.--tab, .basic-slide__inner.--pc {
    display: none
  }
  
  @media screen and (min-width: 767px), print {
    .basic-slide__inner.--sp {
      display: none
    }
    .basic-slide__inner.--tab {
      display: flex
    }
  }
  
  @media screen and (min-width: 1060px) {
    .basic-slide__inner.--sp-tab {
      display: none
    }
    .basic-slide__inner.--pc {
      display: flex
    }
  }
  
  @media screen and (min-width: 767px), print {
    .basic-slide .swiper {
      margin: 0 3.6rem
    }
  }
  
  .basic-slide .swiper-wrapper {
    padding-left: 8.5vw
  }
  
  @media screen and (min-width: 767px), print {
    .basic-slide .swiper-wrapper {
      padding-left: 0
    }
  }
  
  .basic-slide__card {
    height: 100%;
    margin: 0 1.5rem
  }
  
  @media screen and (min-width: 767px), print {
    .basic-slide__card {
      margin: 0 1.4rem
    }
  }
  
  .basic-slide__card.--no-data {
    padding: 3rem;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center
  }
  
  .basic-slide__card.--no-data img {
    max-width: 28.8rem
  }
  
  .basic-slide__card a:hover .basic-slide__ttl, .basic-slide__card a:focus-visible .basic-slide__ttl {
    text-decoration: underline
  }
  
  .basic-slide__img {
    position: relative;
    width: 100%
  }
  
  .basic-slide__img .img-box__inner {
    overflow: hidden;
    border: 1px solid #bbb;
    background: #fff
  }
  
  .basic-slide__img .img-box__inner::before {
    padding-top: 54.45%;
    background: #fff
  }
  
  .basic-slide__label {
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    bottom: 0;
    left: 0;
    padding: .5em 1.5rem .4em;
    font-size: 1.2rem;
    color: #fff;
    background: #3d67a9
  }
  
  @media screen and (min-width: 767px), print {
    .basic-slide__label {
      min-width: 13rem;
      min-height: 3.2rem;
      font-size: 1.4rem
    }
  }
  
  .basic-slide__box {
    flex-grow: 1;
    padding: 1.6rem 1.3rem 2rem;
    background: #fff;
    border-right: 1px solid #bbb;
    border-bottom: 1px solid #bbb;
    border-left: 1px solid #bbb
  }
  
  @media screen and (min-width: 767px), print {
    .basic-slide__box {
      padding: 1.4rem 1.6rem 3.8rem
    }
  }
  
  .basic-slide__ttl {
    margin-bottom: 1rem;
    font-size: 1.7rem;
    color: #134798
  }
  
  @media screen and (min-width: 767px), print {
    .basic-slide__ttl {
      margin-bottom: .8rem;
      font-size: 2rem
    }
  }
  
  .basic-slide__date {
    font-weight: 700
  }
  
  .basic-slide__txt {
    margin-top: 1rem
  }
  
  .--no-slide {
    display: flex;
    justify-content: center
  }
  
  .--no-slide .basic-slide__card {
    height: auto
  }
  
  .--no-slide .basic-slide__card>a {
    display: flex;
    flex-direction: column;
    height: 100%
  }
  
  @media screen and (min-width: 767px), print {
    .--no-slide .basic-slide__card {
      width: calc((100% - 12.8rem)/2)
    }
  }
  
  @media screen and (min-width: 1060px) {
    .--no-slide .basic-slide__card {
      width: calc((100% - 15.6rem)/3)
    }
  }
  
  .keyword__list {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem 1.2rem
  }
  
  @media screen and (min-width: 767px), print {
    .keyword__list {
      gap: 1.4rem
    }
  }
  
  .keyword__item a {
    display: block;
    padding: .8rem 1.8rem .8rem 1.5rem;
    font-weight: bold;
    line-height: 1;
    background: #fff;
    border: 3px solid #3d67a9;
    border-radius: 50vh
  }
  
  .keyword__item a:hover, .keyword__item a:focus-visible {
    text-decoration: underline
  }
  
  .keyword__item a:hover, .keyword__item a:focus-visible {
    background: #e7f3fc
  }
  
  @media screen and (min-width: 1060px) {
    .keyword__item a {
      padding: .8rem 4.2rem .6rem 3.6rem
    }
  }
  
  .search__form {
    display: flex;
    width: 100%;
    max-width: 57rem;
    height: 4rem;
    margin: 0 auto;
    border: 1px solid #ccc
  }
  
  @media screen and (min-width: 767px), print {
    .search__form {
      height: 6rem;
      border: 2px solid #ccc
    }
  }
  
  .search__form__txt {
    width: calc(100% - 3.8rem);
    padding: 1rem 1.5rem;
    background: #fff
  }
  
  @media screen and (min-width: 767px), print {
    .search__form__txt {
      width: calc(100% - 5.8rem);
      padding: 1.5rem 3rem;
      font-size: 2rem
    }
    .search__form__txt:focus-visible {
      outline: auto
    }
  }
  
  .search__form__btn {
    width: 3.8rem;
    height: 100%;
    cursor: pointer;
    background: url(../img/icon-search_w.png) center center/1.5rem 1.5rem no-repeat #134798;
    border: 3px solid #134798
  }
  
  @media screen and (min-width: 767px), print {
    .search__form__btn {
      width: 5.8rem;
      background-size: 3rem 3rem;
      transition: all .2s
    }
  }
  
  .search__form__btn:hover, .search__form__btn:focus-visible {
    background: url(../img/icon-search_b.png) center center/1.5rem 1.5rem no-repeat #fff
  }
  
  @media screen and (min-width: 767px), print {
    .search__form__btn:hover, .search__form__btn:focus-visible {
      width: 5.8rem;
      background-size: 3rem 3rem
    }
  }