@charset "UTF-8";
/* ==========================================================
  フォント
========================================================== */
/* ==========================================================
  EXTEND
========================================================== */
/* ===================================================================
CSS information
 file name  :shared.css
 style info :共通のスタイル
=================================================================== */
/* ==========================================================
  BASE
========================================================== */
@media screen and (min-width: 768px) {
  html {
    font-size: 16px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1280px) {
  html {
    font-size: 15px;
  }
}
@media screen and (min-width: 1921px) {
  html {
    font-size: 0.9vw;
  }
}
@media screen and (max-width: 767px) {
  html {
    font-size: 3.4vw;
  }
}

body {
  -webkit-text-size-adjust: 100%;
     -moz-text-size-adjust: 100%;
      -ms-text-size-adjust: 100%;
          text-size-adjust: 100%;
  font-weight: 700;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  color: #fff;
  background: #fff;
  line-height: 1.6;
  text-align: center;
}
@media screen and (min-width: 768px) {
  body {
    font-size: 1rem;
  }
}
@media screen and (max-width: 767px) {
  body {
    font-size: 3.4vw;
  }
}
:lang(ja) body {
  font-family: "Noto Sans JP", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Meiryo", sans-serif;
}
:lang(en) body {
  font-family: "Noto Sans", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Meiryo", sans-serif;
}
body:focus {
  outline: none;
}
body #wrap {
  width: 100%;
  height: 100%;
  position: relative;
}

/* ==========================================================
  LINK
========================================================== */
a,
a:visited,
a:hover {
  text-decoration: none;
}

/* ==========================================================
  ROLLOVER
========================================================== */
.expansion {
  -webkit-transition: all 0.2s 0s ease;
  transition: all 0.2s 0s ease;
}
.expansion:hover {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}

/* ==========================================================
  COMMON
========================================================== */
h2 {
  color: #b5941f;
  position: relative;
  font-weight: 700;
  letter-spacing: 0.05em;
  font-size: 1.875rem;
  margin-bottom: 5rem;
}
h2:after {
  content: "";
  display: block;
  position: absolute;
  background: #e93132;
  height: 0.125rem;
  width: 6.875rem;
  bottom: -1.25rem;
  left: calc(50% - 3.4375rem);
}

.serif {
  display: inline !important;
}
:lang(ja) .serif {
  font-family: "Noto Serif JP", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Meiryo", sans-serif;
}
:lang(en) .serif {
  font-family: "Noto Serif", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Meiryo", sans-serif;
}

/* ==========================================================
  HEADER
========================================================== */
header {
  width: 100%;
  background: #000;
}
header .inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  padding: 0 1.5rem;
  height: 2.875rem;
}
@media screen and (max-width: 767px) {
  header .inner {
    padding: 0 1rem;
  }
}
header .inner .logo {
  width: 10.625rem;
}
header .inner .logo img {
  vertical-align: baseline;
}
header .inner .rBox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
header .inner .rBox .x img {
  vertical-align: sub;
  width: 1.375rem;
}
header .inner .rBox .langBox {
  border-left: solid 0.0625rem #565454;
  padding-left: 1em;
  margin-left: 1em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  color: #fff;
  font-size: 0.875rem;
  text-align: right;
  height: 1.5rem;
}
header .inner .rBox .langBox p {
  cursor: pointer;
  background: url(../img/shared/icn_language.svg) no-repeat center left/1.4rem;
  padding-left: 1.8rem;
}
header .inner .rBox .langBox ul {
  display: none;
  position: absolute;
  width: 100%;
  z-index: 9999;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  top: 2.125rem;
  right: -0.625rem;
}
@media screen and (min-width: 1921px) {
  header .inner .rBox .langBox ul {
    top: 1.7rem;
  }
}
header .inner .rBox .langBox ul li a {
  display: block;
  color: #fff;
  background: #000;
  text-align: right;
  text-decoration: none;
  padding: 0.5rem 0.75rem 0.8rem;
}
header .inner .rBox .langBox ul li a:hover {
  background: #4b4e56;
  color: #fff;
}

/* ==========================================================
    FOOTER
  ========================================================== */
footer {
  width: 100%;
  background: #00091c;
  padding: 2.5rem 0;
}
footer .l5 {
  margin: 0 auto 2.5rem;
  width: 6.25rem;
}
footer ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin: 0 auto 2.125rem;
}
@media screen and (min-width: 768px) {
  footer ul {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 0 3%;
    width: min(96%, 58.125rem);
  }
}
@media screen and (max-width: 767px) {
  footer ul {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 4vw 0;
    width: 80%;
  }
}
footer ul li {
  border-radius: 1.25rem;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  footer ul li {
    width: 48.4%;
  }
}
footer ul li img:hover {
  -webkit-filter: brightness(110%);
          filter: brightness(110%);
}
footer .copyRight {
  color: #9599c6;
  font-size: 0.75rem;
}