@charset "UTF-8";
/*reset.css*/
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
font,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-weight: 500;
  vertical-align: baseline;
  box-sizing: border-box;
}

ol,
ul {
  list-style: none;
}
ol li,
ul li {
  list-style: none;
}

a {
  text-decoration: none;
  color: inherit;
  transition: 0.3s ease;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 700;
}

html {
  /*rem,emの基準値を設定*/
  font-size: 16px;
  /*スクロールをスムーズに*/
  scroll-behavior: smooth;
  scroll-padding: 100px;
}

.wbr {
  display: inline-block;
}

/*言語切り替え関連（スマホのみ有効）*/
/*言語切り替えボタンの表示*/
@media screen and (max-width: 767px) {
  .lang-switcher button.active {
    background: black;
    color: white;
  }
}
/*言語コンテンツの切り替え*/
@media screen and (max-width: 767px) {
  .lang-switch-content {
    display: none;
  }
  .lang-switch-content.active {
    display: block;
  }
}
/*著作権保護
[data-copy-guard=true]の要素を、印刷時に非表示にする*/
@media print {
  [data-copy-guard=true] {
    display: none;
  }
  [data-copy-guard=true]::after {
    content: "※著作権保護のため、このコンテンツは印刷時には表示されません。";
    display: block;
    font-size: 2rem;
    color: #000;
    text-align: center;
    margin-top: 1.25rem;
  }
}
/*欧文のタイポグラフィを美しくする
- 単語の途中で折り返すならハイフネーションを有効にする
- 単語の間に大きなスペースが入らないようにする
- 右側が綺麗に揃うようにする*/
[lang=en] p,
[lang=en] div {
  word-break: break-word;
  word-wrap: break-word;
  -webkit-hyphens: auto;
  hyphens: auto;
  letter-spacing: 0.05rem;
}

/*SPのみ有効*/
.sp-only {
  display: none !important;
}

@media screen and (max-width: 767px) {
  .sp-only {
    display: block !important;
  }
}
/*PCのみ有効*/
@media screen and (max-width: 767px) {
  .pc-only {
    display: none !important;
  }
}
#content-area {
  max-width: calc(1060px + 2.5rem);
  margin-inline: auto;
  padding-inline: 1.25rem;
}

body.single-column-layout > #content-area > main {
  width: 100%;
}
@media (max-width: 767px) {
  body.single-column-layout > #content-area > main {
    margin-top: 2rem;
  }
}

body.two-column-layout #page-main {
  display: grid;
  grid-template-columns: 16.4375rem 1fr;
  gap: 3.63rem;
}
@media (max-width: 767px) {
  body.two-column-layout #page-main {
    gap: 3.5rem;
    grid-template-columns: 1fr;
    margin-top: 2rem;
  }
}
body.two-column-layout #page-main .left-side-column {
  position: relative;
}
body.two-column-layout #page-main .left-side-column .sticky-area {
  position: sticky;
  top: 6.3rem;
}
@media (max-width: 767px) {
  body.two-column-layout #page-main .left-side-column .sticky-area {
    position: static;
  }
}
#page-main .left-side-column .sticky-area {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1.38rem;
}
#page-main .left-side-column .sticky-area h1 a {
  color: #000;
  font-family: Zen Kaku Gothic Antique;
  font-size: 2.5rem;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  letter-spacing: 0.125rem;
}
@media (max-width: 767px) {
  #page-main .left-side-column .sticky-area h1 a {
    color: #000;
    font-family: Zen Kaku Gothic Antique;
    font-size: 2rem;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: 0.1rem;
  }
}
#page-main .left-side-column .sticky-area nav ul {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1.38rem;
}
@media (max-width: 767px) {
  #page-main .left-side-column .sticky-area nav ul {
    flex-direction: row;
    gap: 1rem 1.88rem;
    flex-wrap: wrap;
  }
}
#page-main .left-side-column .sticky-area nav ul div.sp-only {
  display: flex;
  flex-direction: column;
  gap: 0.56rem;
}
#page-main .left-side-column .sticky-area nav ul li.main-category {
  color: #000;
  font-family: Zen Kaku Gothic Antique;
  font-size: 1.5625rem;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  letter-spacing: 0.07813rem;
  transition: all 0.3s ease;
}
#page-main .left-side-column .sticky-area nav ul li.main-category:hover, #page-main .left-side-column .sticky-area nav ul li.main-category:active, #page-main .left-side-column .sticky-area nav ul li.main-category:focus {
  transform: translateX(0.5rem);
}
@media (max-width: 767px) {
  #page-main .left-side-column .sticky-area nav ul li.main-category {
    border-bottom: 2px solid #000;
    color: #000;
    font-family: Zen Kaku Gothic Antique;
    font-size: 1.25rem;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: 0.0625rem;
  }
}
#page-main .left-side-column .sticky-area nav ul li.sub-category {
  color: #000;
  font-family: Zen Kaku Gothic Antique;
  font-size: 1.25rem;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  letter-spacing: 0.0625rem;
}
#page-main .left-side-column .sticky-area nav ul li.sub-category a {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.44rem;
  align-items: center;
}
#page-main .left-side-column .sticky-area nav ul li.sub-category a:hover, #page-main .left-side-column .sticky-area nav ul li.sub-category a:active, #page-main .left-side-column .sticky-area nav ul li.sub-category a:focus {
  transform: translateX(0.5rem);
}
#page-main .left-side-column .sticky-area nav ul li.sub-category a::before {
  content: "";
  width: 0.875rem;
  height: 0.125rem;
  display: inline-block;
  background: #000;
  margin-right: 0.5rem;
}

/*グローバル言語切り替えボタン*/
.global-lang-switcher {
  position: fixed;
  bottom: 0.62rem;
  right: 0.62rem;
  right: auto;
  z-index: 1000;
  display: flex;
  gap: 0.5rem;
  transform: translateY(200%); /* 初期状態: 下に隠す */
  opacity: 0; /* 初期状態: 透明 */
  transition: transform 0.3s ease, opacity 0.3s ease; /* アニメーション効果 */
}
.global-lang-switcher.active {
  transform: translateY(0%); /* 表示状態: 元の位置 */
  opacity: 1; /* 表示状態: 不透明 */
}
.global-lang-switcher button {
  padding: 0.5rem 0.75rem;
  border: 1px solid #ccc;
  background-color: #f0f0f0;
  color: #333;
  cursor: pointer;
  font-size: 0.875rem;
  border-radius: 0.25rem;
  transition: background-color 0.3s ease, color 0.3s ease;
}
.global-lang-switcher button:hover {
  opacity: 0.8;
}
.global-lang-switcher button.active {
  background-color: #000;
  color: #fff;
  border-color: #000;
}/*# sourceMappingURL=common.min.css.map */