@charset "UTF-8";
.theme-primary, body, .theme-box, .c_attention, .c_note, ul.topics_list, .article_tile, table.spec-list, .theme-page-title, .c_theme_editor .title, #contents-title > .container, .theme-footer, #l_footer > .container, .theme-header, #l_header > .container, .theme-global-navi, .c_global_navi, .theme-global-header, #l_global_header > .container,
.theme-global-footer,
#l_global_footer > .container, .theme-tertiary,
.theme-gray,
table.spec-list th, .theme-secondary, .l_section:nth-child(even) {
  --ff-default: Noto Sans JP;
  --ff-heading: Noto Serif JP, serif;
  --ff-accent: Noto Serif JP, serif;
  --fw-normal: 400;
  --fw-bold: 700;
  --lh-heading: 1.4;
  --lh-sentence: 1.6;
  --lh-button: 1.1;
  --ls-heading: 0.05em;
  --ls-sentence: 0.05em;
  --ls-button: 0.05em;
  --fs-root: 1.6rem;
  --fs-l: 2em;
  --fs-m: 1.2em;
  --fs-n: 1em;
  --fs-s: 0.85em;
  --space-extra: 8em;
  --space-outer: 5em;
  --space-inner: 3em;
  --space-gap: 2em;
  --space-normal: 1em;
  --space-min: 0.5em;
  --color-background:#FFFFFF;
  --color-border:#CCCCCC;
  --color-font:#000000;
  --color-link:#0000EE;
  --color-note:#666666;
  --color-main: #666666;
  --color-sub: #999999;
  --color-accent: #CCCCCC;
  --color-primary: #666666;
  --color-error: #c81717;
  --color-deny: #f14668;
  --color-warning: #b58f22;
  --color-valid: #399b65;
  --color-invalid: #666666;
  --color-accept: #1878fa;
  --color-white: #FFFFFF;
  --color-black: #000000;
  --color-lgray: #FAFAFA;
  --color-gray: #EEEEEE;
  --color-dgray: #CCCCCC;
  --color-light: #FFFFFF;
  --color-dark: #000000;
  --border-radius: 0.5em;
  background-color: var(--color-background);
  color: var(--color-font);
  font-family: var(--ff-default);
  font-size: var(--fs-root);
  font-weight: var(--fw-normal);
  line-height: var(--lh-sentence);
  letter-spacing: var(--ls-sentence);
}
@media screen and (max-width: 750px) {
  .theme-primary, body, .theme-box, .c_attention, .c_note, ul.topics_list, .article_tile, table.spec-list, .theme-page-title, .c_theme_editor .title, #contents-title > .container, .theme-footer, #l_footer > .container, .theme-header, #l_header > .container, .theme-global-navi, .c_global_navi, .theme-global-header, #l_global_header > .container,
  .theme-global-footer,
  #l_global_footer > .container, .theme-tertiary,
  .theme-gray,
  table.spec-list th, .theme-secondary, .l_section:nth-child(even) {
    --lh-heading: 1.4;
    --lh-sentence: 1.6;
    --lh-button: 1.1;
  }
}
@media screen and (max-width: 750px) {
  .theme-primary, body, .theme-box, .c_attention, .c_note, ul.topics_list, .article_tile, table.spec-list, .theme-page-title, .c_theme_editor .title, #contents-title > .container, .theme-footer, #l_footer > .container, .theme-header, #l_header > .container, .theme-global-navi, .c_global_navi, .theme-global-header, #l_global_header > .container,
  .theme-global-footer,
  #l_global_footer > .container, .theme-tertiary,
  .theme-gray,
  table.spec-list th, .theme-secondary, .l_section:nth-child(even) {
    --ls-heading: 0.05em;
    --ls-sentence: 0.05em;
    --ls-button: 0.05em;
  }
}
@media screen and (max-width: 750px) {
  .theme-primary, body, .theme-box, .c_attention, .c_note, ul.topics_list, .article_tile, table.spec-list, .theme-page-title, .c_theme_editor .title, #contents-title > .container, .theme-footer, #l_footer > .container, .theme-header, #l_header > .container, .theme-global-navi, .c_global_navi, .theme-global-header, #l_global_header > .container,
  .theme-global-footer,
  #l_global_footer > .container, .theme-tertiary,
  .theme-gray,
  table.spec-list th, .theme-secondary, .l_section:nth-child(even) {
    --fs-root: 1.6rem;
    --fs-l: 2em;
    --fs-m: 1.2em;
    --fs-n: 1em;
    --fs-s: 0.85em;
  }
}
@media screen and (max-width: 750px) {
  .theme-primary, body, .theme-box, .c_attention, .c_note, ul.topics_list, .article_tile, table.spec-list, .theme-page-title, .c_theme_editor .title, #contents-title > .container, .theme-footer, #l_footer > .container, .theme-header, #l_header > .container, .theme-global-navi, .c_global_navi, .theme-global-header, #l_global_header > .container,
  .theme-global-footer,
  #l_global_footer > .container, .theme-tertiary,
  .theme-gray,
  table.spec-list th, .theme-secondary, .l_section:nth-child(even) {
    --space-extra: 6em;
    --space-outer: 4em;
    --space-inner: 2em;
    --space-gap: 1.5em;
    --space-normal: 1em;
    --space-min: 0.5em;
  }
}
.theme-primary .button, body .button, .theme-box .button, .c_attention .button, .c_note .button, ul.topics_list .button, .article_tile .button, table.spec-list .button, .theme-page-title .button, .c_theme_editor .title .button, #contents-title > .container .button, .theme-footer .button, #l_footer > .container .button, .theme-header .button, #l_header > .container .button, .theme-global-navi .button, .c_global_navi .button, .theme-global-header .button, #l_global_header > .container .button,
.theme-global-footer .button,
#l_global_footer > .container .button, .theme-tertiary .button,
.theme-gray .button, .theme-secondary .button, .l_section:nth-child(even) .button {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.theme-primary .button > *, body .button > *, .theme-box .button > *, .c_attention .button > *, .c_note .button > *, ul.topics_list .button > *, .article_tile .button > *, table.spec-list .button > *, .theme-page-title .button > *, .c_theme_editor .title .button > *, #contents-title > .container .button > *, .theme-footer .button > *, #l_footer > .container .button > *, .theme-header .button > *, #l_header > .container .button > *, .theme-global-navi .button > *, .c_global_navi .button > *, .theme-global-header .button > *, #l_global_header > .container .button > *,
.theme-global-footer .button > *,
#l_global_footer > .container .button > *, .theme-tertiary .button > *,
.theme-gray .button > *, .theme-secondary .button > *, .l_section:nth-child(even) .button > * {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.theme-primary .button.button-tertiary > .label, body .button.button-tertiary > .label, .theme-box .button.button-tertiary > .label, .c_attention .button.button-tertiary > .label, .c_note .button.button-tertiary > .label, ul.topics_list .button.button-tertiary > .label, .article_tile .button.button-tertiary > .label, table.spec-list .button.button-tertiary > .label, .theme-page-title .button.button-tertiary > .label, .c_theme_editor .title .button.button-tertiary > .label, #contents-title > .container .button.button-tertiary > .label, .theme-footer .button.button-tertiary > .label, #l_footer > .container .button.button-tertiary > .label, .theme-header .button.button-tertiary > .label, #l_header > .container .button.button-tertiary > .label, .theme-global-navi .button.button-tertiary > .label, .c_global_navi .button.button-tertiary > .label, .theme-global-header .button.button-tertiary > .label, #l_global_header > .container .button.button-tertiary > .label,
.theme-global-footer .button.button-tertiary > .label,
#l_global_footer > .container .button.button-tertiary > .label, .theme-tertiary .button.button-tertiary > .label,
.theme-gray .button.button-tertiary > .label, .theme-secondary .button.button-tertiary > .label, .l_section:nth-child(even) .button.button-tertiary > .label {
  border-bottom: 1px solid var(--button-font);
}
.theme-primary .button.button-tertiary:hover > .label, body .button.button-tertiary:hover > .label, .theme-box .button.button-tertiary:hover > .label, .c_attention .button.button-tertiary:hover > .label, .c_note .button.button-tertiary:hover > .label, ul.topics_list .button.button-tertiary:hover > .label, .article_tile .button.button-tertiary:hover > .label, table.spec-list .button.button-tertiary:hover > .label, .theme-page-title .button.button-tertiary:hover > .label, .c_theme_editor .title .button.button-tertiary:hover > .label, #contents-title > .container .button.button-tertiary:hover > .label, .theme-footer .button.button-tertiary:hover > .label, #l_footer > .container .button.button-tertiary:hover > .label, .theme-header .button.button-tertiary:hover > .label, #l_header > .container .button.button-tertiary:hover > .label, .theme-global-navi .button.button-tertiary:hover > .label, .c_global_navi .button.button-tertiary:hover > .label, .theme-global-header .button.button-tertiary:hover > .label, #l_global_header > .container .button.button-tertiary:hover > .label,
.theme-global-footer .button.button-tertiary:hover > .label,
#l_global_footer > .container .button.button-tertiary:hover > .label, .theme-tertiary .button.button-tertiary:hover > .label,
.theme-gray .button.button-tertiary:hover > .label, .theme-secondary .button.button-tertiary:hover > .label, .l_section:nth-child(even) .button.button-tertiary:hover > .label {
  border-bottom: 1px solid transparent;
}

.theme-secondary, .l_section:nth-child(even) {
  --color-background:#FAFAFA;
  background-color: var(--color-background);
  color: var(--color-font);
  font-family: var(--ff-default);
  font-size: var(--fs-root);
  font-weight: var(--fw-normal);
  line-height: var(--lh-sentence);
  letter-spacing: var(--ls-sentence);
}
.theme-secondary .button, .l_section:nth-child(even) .button {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.theme-secondary .button > *, .l_section:nth-child(even) .button > * {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.theme-secondary .button.button-tertiary > .label, .l_section:nth-child(even) .button.button-tertiary > .label {
  border-bottom: 1px solid var(--button-font);
}
.theme-secondary .button.button-tertiary:hover > .label, .l_section:nth-child(even) .button.button-tertiary:hover > .label {
  border-bottom: 1px solid transparent;
}

.theme-tertiary,
.theme-gray,
table.spec-list th {
  --color-background:#EEEEEE;
  background-color: var(--color-background);
  color: var(--color-font);
  font-family: var(--ff-default);
  font-size: var(--fs-root);
  font-weight: var(--fw-normal);
  line-height: var(--lh-sentence);
  letter-spacing: var(--ls-sentence);
}
.theme-tertiary .button,
.theme-gray .button,
table.spec-list th .button {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.theme-tertiary .button > *,
.theme-gray .button > *,
table.spec-list th .button > * {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.theme-tertiary .button.button-tertiary > .label,
.theme-gray .button.button-tertiary > .label,
table.spec-list th .button.button-tertiary > .label {
  border-bottom: 1px solid var(--button-font);
}
.theme-tertiary .button.button-tertiary:hover > .label,
.theme-gray .button.button-tertiary:hover > .label,
table.spec-list th .button.button-tertiary:hover > .label {
  border-bottom: 1px solid transparent;
}

.theme-global-header, #l_global_header > .container,
.theme-global-footer,
#l_global_footer > .container {
  --fs-root: 1rem;
  --color-background: #666666;
  --color-font: #FFFFFF;
  --space-outer: 0.5em;
  background-color: var(--color-background);
  color: var(--color-font);
  font-family: var(--ff-default);
  font-size: var(--fs-root);
  font-weight: var(--fw-normal);
  line-height: var(--lh-sentence);
  letter-spacing: var(--ls-sentence);
}
@media screen and (max-width: 750px) {
  .theme-global-header, #l_global_header > .container,
  .theme-global-footer,
  #l_global_footer > .container {
    --fs-root: 1rem;
    --space-outer: 0.5em;
  }
}
.theme-global-header .button, #l_global_header > .container .button,
.theme-global-footer .button,
#l_global_footer > .container .button {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.theme-global-header .button > *, #l_global_header > .container .button > *,
.theme-global-footer .button > *,
#l_global_footer > .container .button > * {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.theme-global-header .button.button-tertiary > .label, #l_global_header > .container .button.button-tertiary > .label,
.theme-global-footer .button.button-tertiary > .label,
#l_global_footer > .container .button.button-tertiary > .label {
  border-bottom: 1px solid var(--button-font);
}
.theme-global-header .button.button-tertiary:hover > .label, #l_global_header > .container .button.button-tertiary:hover > .label,
.theme-global-footer .button.button-tertiary:hover > .label,
#l_global_footer > .container .button.button-tertiary:hover > .label {
  border-bottom: 1px solid transparent;
}

.theme-header, #l_header > .container, .theme-global-navi, .c_global_navi {
  --space-outer: 1em;
  background-color: var(--color-background);
  color: var(--color-font);
  font-family: var(--ff-default);
  font-size: var(--fs-root);
  font-weight: var(--fw-normal);
  line-height: var(--lh-sentence);
  letter-spacing: var(--ls-sentence);
}
@media screen and (max-width: 750px) {
  .theme-header, #l_header > .container, .theme-global-navi, .c_global_navi {
    --space-outer: 1em;
  }
}
.theme-header .button, #l_header > .container .button, .theme-global-navi .button, .c_global_navi .button {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.theme-header .button > *, #l_header > .container .button > *, .theme-global-navi .button > *, .c_global_navi .button > * {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.theme-header .button.button-tertiary > .label, #l_header > .container .button.button-tertiary > .label, .theme-global-navi .button.button-tertiary > .label, .c_global_navi .button.button-tertiary > .label {
  border-bottom: 1px solid var(--button-font);
}
.theme-header .button.button-tertiary:hover > .label, #l_header > .container .button.button-tertiary:hover > .label, .theme-global-navi .button.button-tertiary:hover > .label, .c_global_navi .button.button-tertiary:hover > .label {
  border-bottom: 1px solid transparent;
}

.theme-footer, #l_footer > .container {
  --space-extra: 3.0em;
  --space-outer: 3.0em;
  --space-inner: 2.0em;
  --space-gap: 2.0em;
  --space-min: 0.5em;
  background-color: var(--color-background);
  color: var(--color-font);
  font-family: var(--ff-default);
  font-size: var(--fs-root);
  font-weight: var(--fw-normal);
  line-height: var(--lh-sentence);
  letter-spacing: var(--ls-sentence);
}
@media screen and (max-width: 750px) {
  .theme-footer, #l_footer > .container {
    --space-extra: 2.0em;
    --space-outer: 1.0em;
    --space-inner: 1.0em;
    --space-gap: 0.5em;
    --space-min: 0.5em;
  }
}
.theme-footer .button, #l_footer > .container .button {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.theme-footer .button > *, #l_footer > .container .button > * {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.theme-footer .button.button-tertiary > .label, #l_footer > .container .button.button-tertiary > .label {
  border-bottom: 1px solid var(--button-font);
}
.theme-footer .button.button-tertiary:hover > .label, #l_footer > .container .button.button-tertiary:hover > .label {
  border-bottom: 1px solid transparent;
}

.theme-global-navi, .c_global_navi {
  --space-inner: 1em;
  background-color: var(--color-background);
  color: var(--color-font);
  font-family: var(--ff-default);
  font-size: var(--fs-root);
  font-weight: var(--fw-normal);
  line-height: var(--lh-sentence);
  letter-spacing: var(--ls-sentence);
}
@media screen and (max-width: 750px) {
  .theme-global-navi, .c_global_navi {
    --space-inner: 1em;
  }
}
.theme-global-navi .button, .c_global_navi .button {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.theme-global-navi .button > *, .c_global_navi .button > * {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.theme-global-navi .button.button-tertiary > .label, .c_global_navi .button.button-tertiary > .label {
  border-bottom: 1px solid var(--button-font);
}
.theme-global-navi .button.button-tertiary:hover > .label, .c_global_navi .button.button-tertiary:hover > .label {
  border-bottom: 1px solid transparent;
}

.theme-page-title, .c_theme_editor .title, #contents-title > .container {
  --color-background: #EEEEEE;
  --space-outer: 3em;
  --space-outer-side: 3em;
  --space-inner: 2em;
  background-color: var(--color-background);
  color: var(--color-font);
  font-family: var(--ff-default);
  font-size: var(--fs-root);
  font-weight: var(--fw-normal);
  line-height: var(--lh-sentence);
  letter-spacing: var(--ls-sentence);
}
@media screen and (max-width: 750px) {
  .theme-page-title, .c_theme_editor .title, #contents-title > .container {
    --space-outer: 3em;
    --space-outer-side: 3em;
    --space-inner: 2em;
  }
}
.theme-page-title .button, .c_theme_editor .title .button, #contents-title > .container .button {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.theme-page-title .button > *, .c_theme_editor .title .button > *, #contents-title > .container .button > * {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.theme-page-title .button.button-tertiary > .label, .c_theme_editor .title .button.button-tertiary > .label, #contents-title > .container .button.button-tertiary > .label {
  border-bottom: 1px solid var(--button-font);
}
.theme-page-title .button.button-tertiary:hover > .label, .c_theme_editor .title .button.button-tertiary:hover > .label, #contents-title > .container .button.button-tertiary:hover > .label {
  border-bottom: 1px solid transparent;
}

.theme-box, .c_attention, .c_note, ul.topics_list, .article_tile, table.spec-list {
  --lh-heading: 1.4;
  --lh-sentence: 1.6;
  --lh-button: 1.1;
  --ls-heading: 0.01em;
  --ls-sentence: 0.01em;
  --ls-button: 0.01em;
  --space-outer: 1.5em;
  --space-inner: 1em;
  --space-gap: 1em;
  --space-normal: 0.5em;
  --space-min: 0.5em;
  background-color: var(--color-background);
  color: var(--color-font);
  font-family: var(--ff-default);
  font-size: var(--fs-root);
  font-weight: var(--fw-normal);
  line-height: var(--lh-sentence);
  letter-spacing: var(--ls-sentence);
}
@media screen and (max-width: 750px) {
  .theme-box, .c_attention, .c_note, ul.topics_list, .article_tile, table.spec-list {
    --lh-heading: 1.4;
    --lh-sentence: 1.6;
    --lh-button: 1.1;
    --ls-heading: 0.01em;
    --ls-sentence: 0.01em;
    --ls-button: 0.01em;
    --space-outer: 1.5em;
    --space-inner: 1em;
    --space-gap: 1em;
    --space-normal: 0.5em;
    --space-min: 0.5em;
  }
}
.theme-box .button, .c_attention .button, .c_note .button, ul.topics_list .button, .article_tile .button, table.spec-list .button {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.theme-box .button > *, .c_attention .button > *, .c_note .button > *, ul.topics_list .button > *, .article_tile .button > *, table.spec-list .button > * {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.theme-box .button.button-tertiary > .label, .c_attention .button.button-tertiary > .label, .c_note .button.button-tertiary > .label, ul.topics_list .button.button-tertiary > .label, .article_tile .button.button-tertiary > .label, table.spec-list .button.button-tertiary > .label {
  border-bottom: 1px solid var(--button-font);
}
.theme-box .button.button-tertiary:hover > .label, .c_attention .button.button-tertiary:hover > .label, .c_note .button.button-tertiary:hover > .label, ul.topics_list .button.button-tertiary:hover > .label, .article_tile .button.button-tertiary:hover > .label, table.spec-list .button.button-tertiary:hover > .label {
  border-bottom: 1px solid transparent;
}

.button {
  --button-background:#666666;
  --button-border:#666666;
  --button-font:#FFFFFF;
  --button-icon:#FFFFFF;
  --button-background-hover:#FFFFFF;
  --button-border-hover:#666666;
  --button-font-hover:#666666;
  --button-icon-hover:#666666;
}
.button.button-secondary {
  --button-background:#FFFFFF;
  --button-border:#CCCCCC;
  --button-font:#666666;
  --button-icon:#666666;
  --button-background-hover:#EEEEEE;
  --button-border-hover:#CCCCCC;
  --button-font-hover:#666666;
  --button-icon-hover:#666666;
}
.button.button-tertiary {
  --button-background:transparent;
  --button-border:transparent;
  --button-font:#666666;
  --button-icon:#666666;
  --button-background-hover:#EEEEEE;
  --button-border-hover:transparent;
  --button-font-hover:#666666;
  --button-icon-hover:#666666;
}
.button.button-deny {
  --button-background:#f14668;
  --button-border:#f14668;
  --button-font:#FFFFFF;
  --button-icon:#FFFFFF;
  --button-background-hover:#FFFFFF;
  --button-border-hover:#f14668;
  --button-font-hover:#f14668;
  --button-icon-hover:#f14668;
}

html, body {
  position: relative;
  z-index: 0;
  margin: 0;
  padding: 0;
  min-height: 100dvh;
  width: 100%;
  font-weight: normal;
  text-align: left;
  word-break: break-all;
  overflow-wrap: break-word;
}

*,
*::before,
*::after {
  position: relative;
  z-index: 0;
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-text-size-adjust: 100%;
     -moz-text-size-adjust: 100%;
      -ms-text-size-adjust: 100%;
          text-size-adjust: 100%;
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
  font-family: inherit;
  line-height: inherit;
  letter-spacing: inherit;
  vertical-align: inherit;
  border-radius: 0;
  border-color: inherit;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -moz-tap-highlight-color: rgba(0, 0, 0, 0);
  -ms-tap-highlight-color: rgba(0, 0, 0, 0);
  -o-tap-highlight-color: rgba(0, 0, 0, 0);
}

:focus {
  outline: 0;
}

ol > li,
ul > li {
  margin-left: 1.5em;
}
ol > li + li,
ul > li + li {
  margin-top: 0.75em;
}

strong {
  font-weight: var(--fw-bold);
}

img {
  max-width: 100%;
  width: 100%;
  height: auto;
  margin: 0;
  padding: 0;
  vertical-align: bottom;
}

/* フォームタグ関連のリセット */
input,
button,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
}

input[type=checkbox],
input[type=radio] {
  -moz-appearance: auto;
       appearance: auto;
  -webkit-appearance: auto;
}

textarea {
  resize: vertical;
}

input[type=submit],
input[type=button],
label,
button,
select {
  cursor: pointer;
}

/*iosのフォームボタンリセット*/
input[type=submit],
input[type=button],
input[type=reset] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  -moz-appearance: button;
       appearance: button;
  border: none;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  cursor: pointer;
}

input[type=submit]::-webkit-search-decoration,
input[type=button]::-webkit-search-decoration,
input[type=reset]::-webkit-search-decoration {
  display: none;
}

input[type=submit]:focus,
input[type=button]:focus,
input[type=reset]:focus {
  outline-offset: -2px;
}

a, button {
  text-decoration: none;
  cursor: pointer;
}

a {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
a.link {
  color: var(--color-link);
  border-bottom: 1px dashed var(--color-link);
}
a.link:hover {
  border-bottom: 1px dashed transparent;
}
a:hover {
  opacity: 0.7;
}

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

/* パソコン表示時 */
@media screen and (min-width: 1000px) {
  html {
    font-size: 10px;
  }
}
/* タブレット表示時 */
@media screen and (min-width: 750px) and (max-width: 1000px) {
  html {
    font-size: 1vw;
  }
}
/* モバイル表示時 */
@media screen and (max-width: 750px) {
  html {
    font-size: 2.6666666667vw;
  }
}
#wrapper {
  min-height: 100dvh;
  width: calc(100vw - (100vw - 100%));
  display: grid;
  grid-template: " global-header " auto " header        " auto " main          " 1fr " footer        " auto " global-footer " auto/100%;
}
#wrapper.side_left {
  grid-template: " global-header global-header " auto " header        main          " 1fr " header        footer        " auto " global-footer global-footer " auto/auto 1fr;
}
#wrapper.side_right {
  grid-template: " global-header global-header " auto " main          header        " 1fr " footer        header        " auto " global-footer global-footer " auto/1fr auto;
}

#l_global_header {
  grid-area: global-header;
  z-index: 5;
}

#l_header {
  grid-area: header;
  z-index: 4;
  position: sticky;
  top: 0;
}

#l_main {
  grid-area: main;
  z-index: 1;
}

#l_footer {
  grid-area: footer;
  z-index: 3;
}

#l_global_footer {
  grid-area: global-footer;
  z-index: 2;
}

.l_inner {
  max-width: 1000px;
  margin: 0 auto;
}
@media screen and (min-width: 750px) and (max-width: 1000px) {
  .l_inner {
    width: 100%;
  }
}
@media screen and (max-width: 750px) {
  .l_inner {
    width: 100%;
  }
}
.l_inner.fill {
  max-width: calc(100% + 2em);
  width: calc(100% + 2em);
  margin-left: -1em;
  margin-right: -1em;
}

.l_section {
  width: 100%;
  padding: var(--space-outer) 1em;
}
.l_section.no-padding {
  padding: 0 1em;
}
.l_section + .l_section {
  border-top: 1px solid var(--color-border);
}
.l_row + .l_row {
  margin-top: var(--space-inner);
}
.l_row + .l_row.no-margin {
  margin-top: 0;
}

#l_global_header > .container {
  padding: var(--space-outer);
}
#l_global_header > .container > h1 {
  display: inline-block;
}
#l_global_header > .container > p {
  display: inline-block;
  padding-left: var(--space-min);
}

#l_header {
  /* モバイル表示時 */
}
#l_header > .container {
  display: grid;
  grid-template: " logo .....              global-navi" auto/auto var(--space-inner) 1fr;
  padding: calc(var(--space-outer) / 2);
}
#l_header > .container .logo {
  grid-area: logo;
  place-self: center normal;
  padding: calc(var(--space-outer) / 2);
}
#l_header > .container .logo .main {
  font-size: var(--fs-l);
  font-weight: var(--fw-bold);
  font-family: var(--ff-heading);
}
#l_header > .container .logo img {
  height: 4em;
}
#l_header > .container .c_global_navi {
  grid-area: global-navi;
  place-self: center normal;
  padding: calc(var(--space-outer) / 2);
}
#l_header > .container .btn_mobile_menu {
  display: none;
}
@media screen and (max-width: 750px) {
  #l_header > .container {
    display: grid;
    grid-template: " logo        ........... btn_menu    " auto " global-navi global-navi global-navi " auto/auto 1fr 4em;
    padding: calc(var(--space-outer) / 2);
  }
  #l_header > .container .logo {
    place-self: normal normal;
  }
  #l_header > .container .logo img {
    height: 3em;
  }
  #l_header > .container .btn_mobile_menu {
    display: block;
    grid-area: btn_menu;
    place-self: center normal;
    width: 100%;
    aspect-ratio: 1/1;
  }
  #l_header > .container .btn_mobile_menu > * {
    -webkit-transition: all 0.3s 0s ease;
    transition: all 0.3s 0s ease;
  }
  #l_header > .container .btn_mobile_menu > span:nth-child(-n+3) {
    position: absolute;
    left: 50%;
    display: block;
    height: 1px;
    width: 60%;
    background-color: var(--color-font);
  }
  #l_header > .container .btn_mobile_menu > span:nth-child(1) {
    top: 10%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  #l_header > .container .btn_mobile_menu > span:nth-child(2) {
    top: 30%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  #l_header > .container .btn_mobile_menu > span:nth-child(3) {
    top: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  #l_header > .container .btn_mobile_menu > span:nth-child(4) {
    position: absolute;
    left: 0%;
    bottom: 0%;
    width: 100%;
  }
  #l_header > .container .btn_mobile_menu > span:nth-child(4)::after {
    content: "MENU";
  }
  #l_header > .container .c_global_navi {
    place-self: normal normal;
    display: none;
  }
  #l_header.show_menu .btn_mobile_menu span:nth-child(1) {
    top: 30%;
    -webkit-transform: translateX(-50%) rotate(45deg);
            transform: translateX(-50%) rotate(45deg);
  }
  #l_header.show_menu .btn_mobile_menu span:nth-child(2) {
    opacity: 0;
  }
  #l_header.show_menu .btn_mobile_menu span:nth-child(3) {
    top: 30%;
    -webkit-transform: translateX(-50%) rotate(-45deg);
            transform: translateX(-50%) rotate(-45deg);
  }
  #l_header.show_menu .btn_mobile_menu span:nth-child(4)::after {
    content: "CLOSE";
  }
  #l_header.show_menu .c_global_navi {
    place-self: normal normal;
    display: grid;
  }
}

#l_main {
  display: grid;
  grid-template: " title " auto " body  " 1fr/100%;
  min-height: 100%;
}

#contents-title {
  grid-area: title;
}
#contents-title > .container {
  padding: var(--space-outer) var(--space-outer-side);
  background-color: transparent;
}
#contents-title > .container.index {
  padding: 0;
}
#contents-title > .container.index .mv {
  aspect-ratio: 16/9;
  background-image: var(--main-img);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
}
#contents-title > .container > .background {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  background-color: var(--color-background);
  background-image: var(--background-img);
  background-position: var(--background-position);
  background-repeat: no-repeat;
  background-size: var(--background-size);
  -webkit-mask-image: -webkit-gradient(linear, left top, left bottom, from(rgb(0, 0, 0)), to(transparent));
  -webkit-mask-image: linear-gradient(rgb(0, 0, 0) var(--background-grd), transparent);
          mask-image: -webkit-gradient(linear, left top, left bottom, from(rgb(0, 0, 0)), to(transparent));
          mask-image: linear-gradient(rgb(0, 0, 0) var(--background-grd), transparent);
}
#contents-title > .container > .background > .background_blur {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  -webkit-backdrop-filter: blur(var(--background-blur));
          backdrop-filter: blur(var(--background-blur));
}
#contents-title > .container > .background > .background_overlay {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  background-color: var(--orverray-color);
  opacity: var(--orverray-opacity);
}
#contents-title > .container > h1 {
  line-height: var(--lh-heading);
  letter-spacing: var(--ls-heading);
}
#contents-title > .container > h1 > .main {
  display: inline-block;
  width: 100%;
  font-family: var(--ff-heading);
  font-size: var(--fs-l);
  font-weight: var(--fw-bold);
}
#contents-title > .container > h1 > .sub {
  display: inline-block;
  width: 100%;
  font-family: var(--ff-accent);
  font-size: var(--fs-m);
  font-weight: var(--fw-bold);
  color: var(--color-main);
}
#contents-title > .container > p {
  margin-top: var(--space-inner);
  color: var(--color-note);
}

#contents_body {
  grid-area: body;
}

#l_global_footer > .container {
  padding: var(--space-min);
}

#l_footer > .container {
  border-top: 1px solid var(--color-border);
}
#l_footer > .container .footer_contents {
  display: grid;
  grid-template: " sign  sitemap " auto/50% 1fr;
  gap: var(--space-gap);
}
#l_footer > .container .footer_contents .sign {
  grid-area: sign;
}
#l_footer > .container .footer_contents .sign .logo a {
  display: inline-block;
}
#l_footer > .container .footer_contents .sign .logo a .main {
  font-family: var(--ff-heading);
  font-size: var(--fs-l);
  font-weight: var(--fw-bold);
}
#l_footer > .container .footer_contents .sign .logo a img {
  height: 4.5em;
}
#l_footer > .container .footer_contents .sign .profile {
  margin-top: var(--space-normal);
  padding-top: var(--space-normal);
  border-top: 1px solid var(--color-border);
}
#l_footer > .container .footer_contents .sign .contact {
  margin-top: var(--space-min);
}
#l_footer > .container .footer_contents .sitemap {
  grid-area: sitemap;
}
#l_footer > .container .footer_contents .sitemap ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  list-style: none;
  gap: var(--space-gap);
}
#l_footer > .container .footer_contents .sitemap ul li {
  margin: 0;
  padding: 0;
}

html #InitializeLoader {
  background-color: var(--color-background);
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100dvw;
  height: 100dvh;
  -webkit-backdrop-filter: blur(2px);
          backdrop-filter: blur(2px);
  display: grid;
  place-content: center;
}
html #InitializeLoader .loader {
  --uib-size: 5em;
  --uib-color: var(--color-main);
  --uib-speed: 2s;
  position: relative;
  height: var(--uib-size);
  width: var(--uib-size);
}
html #InitializeLoader .loader::before,
html #InitializeLoader .loader::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  border-radius: 50%;
  background-color: var(--uib-color);
  -webkit-animation: pulse var(--uib-speed) linear infinite;
          animation: pulse var(--uib-speed) linear infinite;
  -webkit-transform: scale(0);
          transform: scale(0);
  opacity: 0;
  -webkit-transition: background-color 0.3s ease;
  transition: background-color 0.3s ease;
}
html #InitializeLoader .loader::after {
  -webkit-animation-delay: calc(var(--uib-speed) / -2);
          animation-delay: calc(var(--uib-speed) / -2);
}
@-webkit-keyframes pulse {
  0% {
    -webkit-transform: scale(0);
            transform: scale(0);
    opacity: 1;
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 0;
  }
}
@keyframes pulse {
  0% {
    -webkit-transform: scale(0);
            transform: scale(0);
    opacity: 1;
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 0;
  }
}
html.inited #InitializeLoader {
  -webkit-animation-name: fade;
          animation-name: fade;
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
  -webkit-animation-duration: 0.2s;
          animation-duration: 0.2s;
  -webkit-animation-timing-function: ease-in;
          animation-timing-function: ease-in;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
@-webkit-keyframes fade {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateY(-10em);
            transform: translateY(-10em);
    opacity: 0;
  }
}
@keyframes fade {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateY(-10em);
            transform: translateY(-10em);
    opacity: 0;
  }
}

html #ConnectionLoader {
  display: none;
}
html.connecting #ConnectionLoader {
  background-color: rgba(0, 0, 0, 0.2);
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100dvw;
  height: 100dvh;
  -webkit-backdrop-filter: blur(2px);
          backdrop-filter: blur(2px);
  display: grid;
  place-content: center;
}
html.connecting #ConnectionLoader .loader {
  --uib-size: 8em;
  --uib-color: var(--color-main);
  --uib-speed: 1.4s;
  --uib-stroke: 0.5em;
  --uib-bg-opacity: .1;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: var(--uib-stroke);
  width: var(--uib-size);
  border-radius: calc(var(--uib-stroke) / 2);
  overflow: hidden;
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
}
html.connecting #ConnectionLoader .loader::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: var(--uib-color);
  opacity: var(--uib-bg-opacity);
  -webkit-transition: background-color 0.3s ease;
  transition: background-color 0.3s ease;
}
html.connecting #ConnectionLoader .loader::after {
  content: "";
  height: 100%;
  width: 100%;
  border-radius: calc(var(--uib-stroke) / 2);
  -webkit-animation: zoom var(--uib-speed) ease-in-out infinite;
          animation: zoom var(--uib-speed) ease-in-out infinite;
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
  background-color: var(--uib-color);
  -webkit-transition: background-color 0.3s ease;
  transition: background-color 0.3s ease;
}
@-webkit-keyframes zoom {
  0% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  100% {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
}
@keyframes zoom {
  0% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  100% {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
}

.disabled {
  opacity: 0.6;
  pointer-events: none;
  -webkit-filter: brightness(90%);
          filter: brightness(90%);
}

.ta-left {
  text-align: left;
}

.ta-right {
  text-align: right;
}

.ta-center {
  text-align: center;
}

.ta-justify {
  text-align: justify;
}

.va-middle {
  vertical-align: middle;
}

.ff-default {
  font-family: var(--ff-default);
}

.ff-heading {
  font-family: var(--ff-heading);
}

.ff-accent {
  font-family: var(--ff-accent);
}

.fw-bold {
  font-weight: var(--fw-bold);
}

.fw-normal {
  font-weight: var(--fw-normal);
}

.fs-l {
  font-size: var(--fs-l);
}

.fs-m {
  font-size: var(--fs-m);
}

.fs-n {
  font-size: var(--fs-n);
}

.fs-s {
  font-size: var(--fs-s);
}

@media screen and (max-width: 750px) {
  .sp-fs-l {
    font-size: var(--fs-l);
  }
  .sp-fs-m {
    font-size: var(--fs-m);
  }
  .sp-fs-n {
    font-size: var(--fs-n);
  }
  .sp-fs-s {
    font-size: var(--fs-s);
  }
}
.mar-extra {
  margin: var(--space-extra);
}

.mar-outer {
  margin: var(--space-outer);
}

.mar-inner {
  margin: var(--space-inner);
}

.mar-gap {
  margin: var(--space-gap);
}

.mar-normal {
  margin: var(--space-normal);
}

.mar-min {
  margin: var(--space-min);
}

.mar-r-extra {
  margin-right: var(--space-extra);
}

.mar-r-outer {
  margin-right: var(--space-outer);
}

.mar-r-inner {
  margin-right: var(--space-inner);
}

.mar-r-gap {
  margin-right: var(--space-gap);
}

.mar-r-normal {
  margin-right: var(--space-normal);
}

.mar-r-min {
  margin-right: var(--space-min);
}

.mar-l-extra {
  margin-left: var(--space-extra);
}

.mar-l-outer {
  margin-left: var(--space-outer);
}

.mar-l-inner {
  margin-left: var(--space-inner);
}

.mar-l-gap {
  margin-left: var(--space-gap);
}

.mar-l-normal {
  margin-left: var(--space-normal);
}

.mar-l-min {
  margin-left: var(--space-min);
}

.mar-t-extra {
  margin-top: var(--space-extra);
}

.mar-t-outer {
  margin-top: var(--space-outer);
}

.mar-t-inner {
  margin-top: var(--space-inner);
}

.mar-t-gap {
  margin-top: var(--space-gap);
}

.mar-t-normal {
  margin-top: var(--space-normal);
}

.mar-t-min {
  margin-top: var(--space-min);
}

.mar-b-extra {
  margin-bottom: var(--space-extra);
}

.mar-b-outer {
  margin-bottom: var(--space-outer);
}

.mar-b-inner {
  margin-bottom: var(--space-inner);
}

.mar-b-gap {
  margin-bottom: var(--space-gap);
}

.mar-b-normal {
  margin-bottom: var(--space-normal);
}

.mar-b-min {
  margin-bottom: var(--space-min);
}

@media screen and (max-width: 750px) {
  .sp-mar-extra {
    margin: var(--space-extra);
  }
  .sp-mar-outer {
    margin: var(--space-outer);
  }
  .sp-mar-inner {
    margin: var(--space-inner);
  }
  .sp-mar-gap {
    margin: var(--space-gap);
  }
  .sp-mar-normal {
    margin: var(--space-normal);
  }
  .sp-mar-min {
    margin: var(--space-min);
  }
  .sp-mar-r-extra {
    margin-right: var(--space-extra);
  }
  .sp-mar-r-outer {
    margin-right: var(--space-outer);
  }
  .sp-mar-r-inner {
    margin-right: var(--space-inner);
  }
  .sp-mar-r-gap {
    margin-right: var(--space-gap);
  }
  .sp-mar-r-normal {
    margin-right: var(--space-normal);
  }
  .sp-mar-r-min {
    margin-right: var(--space-min);
  }
  .sp-mar-l-extra {
    margin-left: var(--space-extra);
  }
  .sp-mar-l-outer {
    margin-left: var(--space-outer);
  }
  .sp-mar-l-inner {
    margin-left: var(--space-inner);
  }
  .sp-mar-l-gap {
    margin-left: var(--space-gap);
  }
  .sp-mar-r-normal {
    margin-left: var(--space-normal);
  }
  .sp-mar-l-min {
    margin-left: var(--space-min);
  }
  .sp-mar-t-extra {
    margin-top: var(--space-extra);
  }
  .sp-mar-t-outer {
    margin-top: var(--space-outer);
  }
  .sp-mar-t-inner {
    margin-top: var(--space-inner);
  }
  .sp-mar-t-gap {
    margin-top: var(--space-gap);
  }
  .sp-mar-r-normal {
    margin-top: var(--space-normal);
  }
  .sp-mar-t-min {
    margin-top: var(--space-min);
  }
  .sp-mar-b-extra {
    margin-bottom: var(--space-extra);
  }
  .sp-mar-b-outer {
    margin-bottom: var(--space-outer);
  }
  .sp-mar-b-inner {
    margin-bottom: var(--space-inner);
  }
  .sp-mar-b-gap {
    margin-bottom: var(--space-gap);
  }
  .sp-mar-r-normal {
    margin-bottom: var(--space-normal);
  }
  .sp-mar-b-min {
    margin-bottom: var(--space-min);
  }
}
.pad-extra {
  padding: var(--space-extra);
}

.pad-outer {
  padding: var(--space-outer);
}

.pad-inner {
  padding: var(--space-inner);
}

.pad-gap {
  padding: var(--space-gap);
}

.pad-normal {
  padding: var(--space-normal);
}

.pad-min {
  padding: var(--space-min);
}

.pad-r-extra {
  padding-right: var(--space-extra);
}

.pad-r-outer {
  padding-right: var(--space-outer);
}

.pad-r-inner {
  padding-right: var(--space-inner);
}

.pad-r-gap {
  padding-right: var(--space-gap);
}

.pad-r-normal {
  padding-right: var(--space-normal);
}

.pad-r-min {
  padding-right: var(--space-min);
}

.pad-l-extra {
  padding-left: var(--space-extra);
}

.pad-l-outer {
  padding-left: var(--space-outer);
}

.pad-l-inner {
  padding-left: var(--space-inner);
}

.pad-l-gap {
  padding-left: var(--space-gap);
}

.pad-l-normal {
  padding-left: var(--space-normal);
}

.pad-l-min {
  padding-left: var(--space-min);
}

.pad-t-extra {
  padding-top: var(--space-extra);
}

.pad-t-outer {
  padding-top: var(--space-outer);
}

.pad-t-inner {
  padding-top: var(--space-inner);
}

.pad-t-gap {
  padding-top: var(--space-gap);
}

.pad-t-normal {
  padding-top: var(--space-normal);
}

.pad-t-min {
  padding-top: var(--space-min);
}

.pad-b-extra {
  padding-bottom: var(--space-extra);
}

.pad-b-outer {
  padding-bottom: var(--space-outer);
}

.pad-b-inner {
  padding-bottom: var(--space-inner);
}

.pad-b-gap {
  padding-bottom: var(--space-gap);
}

.pad-b-normal {
  padding-bottom: var(--space-normal);
}

.pad-b-min {
  padding-bottom: var(--space-min);
}

@media screen and (max-width: 750px) {
  .sp-pad-extra {
    padding: var(--space-extra);
  }
  .sp-pad-outer {
    padding: var(--space-outer);
  }
  .sp-pad-inner {
    padding: var(--space-inner);
  }
  .sp-pad-gap {
    padding: var(--space-gap);
  }
  .sp-pad-normal {
    padding: var(--space-normal);
  }
  .sp-pad-min {
    padding: var(--space-min);
  }
  .sp-pad-r-extra {
    padding-right: var(--space-extra);
  }
  .sp-pad-r-outer {
    padding-right: var(--space-outer);
  }
  .sp-pad-r-inner {
    padding-right: var(--space-inner);
  }
  .sp-pad-r-gap {
    padding-right: var(--space-gap);
  }
  .sp-pad-r-normal {
    padding-right: var(--space-normal);
  }
  .sp-pad-r-min {
    padding-right: var(--space-min);
  }
  .sp-pad-l-extra {
    padding-left: var(--space-extra);
  }
  .sp-pad-l-outer {
    padding-left: var(--space-outer);
  }
  .sp-pad-l-inner {
    padding-left: var(--space-inner);
  }
  .sp-pad-l-gap {
    padding-left: var(--space-gap);
  }
  .sp-pad-l-normal {
    padding-left: var(--space-normal);
  }
  .sp-pad-l-min {
    padding-left: var(--space-min);
  }
  .sp-pad-t-extra {
    padding-top: var(--space-extra);
  }
  .sp-pad-t-outer {
    padding-top: var(--space-outer);
  }
  .sp-pad-t-inner {
    padding-top: var(--space-inner);
  }
  .sp-pad-t-gap {
    padding-top: var(--space-gap);
  }
  .sp-pad-t-normal {
    padding-top: var(--space-normal);
  }
  .sp-pad-t-min {
    padding-top: var(--space-min);
  }
  .sp-pad-b-extra {
    padding-bottom: var(--space-extra);
  }
  .sp-pad-b-outer {
    padding-bottom: var(--space-outer);
  }
  .sp-pad-b-inner {
    padding-bottom: var(--space-inner);
  }
  .sp-pad-b-gap {
    padding-bottom: var(--space-gap);
  }
  .sp-pad-b-normal {
    padding-bottom: var(--space-normal);
  }
  .sp-pad-b-min {
    padding-bottom: var(--space-min);
  }
}
#ResponsiveCheck {
  width: 0;
  height: 0;
  opacity: 0;
  visibility: hidden;
  overflow: hidden;
}

.isPC {
  display: none;
}

.isPC-TAB {
  display: none;
}

.isTAB {
  display: none;
}

.isTAB-SP {
  display: none;
}

.isSP {
  display: none;
}

@media screen and (min-width: 1000px) {
  .isPC {
    display: block;
  }
  .isPC-TAB {
    display: block;
  }
  .isTAB {
    display: none;
  }
  .isTAB-SP {
    display: none;
  }
  .isSP {
    display: none;
  }
}
@media screen and (min-width: 750px) and (max-width: 1000px) {
  .isPC {
    display: none;
  }
  .isPC-TAB {
    display: block;
  }
  .isTAB {
    display: block;
  }
  .isTAB-SP {
    display: block;
  }
  .isSP {
    display: none;
  }
}
@media screen and (max-width: 750px) {
  .isPC {
    display: none;
  }
  .isPC-TAB {
    display: none;
  }
  .isTAB {
    display: none;
  }
  .isTAB-SP {
    display: block;
  }
  .isSP {
    display: block;
  }
}
/* Gridシステム(12 col grid) */
.grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--space-gap);
}
.grid.no-gap {
  gap: 0;
}
.grid.min-gap {
  gap: var(--space-min);
}
.grid .sub-grid {
  display: grid;
  grid-template-columns: subgrid;
}
.grid .sub-grid.no-gap {
  gap: 0;
}
.grid .grid-col-1 {
  grid-column: span 1;
}
.grid .grid-col-2 {
  grid-column: span 2;
}
.grid .grid-col-3 {
  grid-column: span 3;
}
.grid .grid-col-4 {
  grid-column: span 4;
}
.grid .grid-col-5 {
  grid-column: span 5;
}
.grid .grid-col-6 {
  grid-column: span 6;
}
.grid .grid-col-7 {
  grid-column: span 7;
}
.grid .grid-col-8 {
  grid-column: span 8;
}
.grid .grid-col-9 {
  grid-column: span 9;
}
.grid .grid-col-10 {
  grid-column: span 10;
}
.grid .grid-col-11 {
  grid-column: span 11;
}
.grid .grid-col-12 {
  grid-column: span 12;
}
.grid .place-cs {
  place-self: center start;
}

/* モバイル表示時 */
@media screen and (max-width: 750px) {
  .grid .grid-col-sp-1 {
    grid-column: span 1;
  }
  .grid .grid-col-sp-2 {
    grid-column: span 2;
  }
  .grid .grid-col-sp-3 {
    grid-column: span 3;
  }
  .grid .grid-col-sp-4 {
    grid-column: span 4;
  }
  .grid .grid-col-sp-5 {
    grid-column: span 5;
  }
  .grid .grid-col-sp-6 {
    grid-column: span 6;
  }
  .grid .grid-col-sp-7 {
    grid-column: span 7;
  }
  .grid .grid-col-sp-8 {
    grid-column: span 8;
  }
  .grid .grid-col-sp-9 {
    grid-column: span 9;
  }
  .grid .grid-col-sp-10 {
    grid-column: span 10;
  }
  .grid .grid-col-sp-11 {
    grid-column: span 11;
  }
  .grid .grid-col-sp-12 {
    grid-column: span 12;
  }
}
.icon {
  font-size: var(--fs-m);
  margin-bottom: -0.1em;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}
.icon.valid {
  color: #399b65;
}
.icon.invalid {
  color: #666666;
}

.button {
  display: inline-grid;
  grid-template: " ..... prefix label suffix ..... " auto/0.5fr auto auto auto 0.5fr;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  overflow: hidden;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0.8em 1em;
  background-color: var(--button-background);
  color: var(--button-font);
  border-radius: var(--border-radius);
  border: 1px solid var(--button-border);
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  line-height: var(--lh-button);
  letter-spacing: var(--ls-button);
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
  white-space: nowrap;
}
.button.button-small {
  font-size: var(--fs-s);
}
.button.button-large {
  font-size: var(--fs-m);
}
.button.button-wide {
  width: 100%;
}
.button .label {
  grid-area: label;
}
.button .icon {
  grid-area: prefix;
  color: var(--button-icon);
}
.button .icon + .label {
  margin-left: 0.5em;
}
.button .label + .icon {
  grid-area: suffix;
  margin-left: 0.5em;
  margin-right: 0em;
}
.button:hover, .button:active, .button.active {
  background-color: var(--button-background-hover);
  border-color: var(--button-border-hover);
  color: var(--button-font-hover);
}
.button:hover .icon, .button:active .icon, .button.active .icon {
  color: var(--button-icon-hover);
}

.button-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: var(--space-normal);
}
.button-list.nowrap {
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
}
.button-list.nowrap > span.space {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 100%;
          flex: 1 1 100%;
}
.button-list.button-list-left {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.button-list.button-list-right {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.button-list > .button {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
}
* + .button-list {
  margin-top: var(--space-gap);
}

#DaialogShield {
  display: none;
}
#DaialogShield.show {
  background-color: rgba(0, 0, 0, 0.1);
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100dvw;
  height: 100dvh;
  -webkit-backdrop-filter: blur(2px);
          backdrop-filter: blur(2px);
  display: grid;
  display: grid;
  place-content: center;
}
#DaialogShield .daialog {
  min-width: 300px;
  max-width: 80dvw;
  max-height: 80dvh;
  padding: var(--space-normal);
  border-radius: 0.5em;
  border: 1px solid var(--color-border);
  background-color: var(--color-background);
}
#DaialogShield .daialog .title {
  border-bottom: 1px solid var(--color-border);
  padding-bottom: var(--space-normal);
  margin-bottom: var(--space-normal);
  font-weight: bold;
}
#DaialogShield .daialog .message {
  max-height: 50dvh;
  overflow-y: auto;
  margin-bottom: var(--space-gap);
}
#DaialogShield .daialog .operation {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  gap: var(--space-gap);
}
#DaialogShield .daialog.warning {
  border: 1px solid #c81717;
}

label {
  display: inline-block;
}
label.full {
  width: 100%;
}
label > input:not([type=radio], [type=checkbox]),
label > textarea,
label > select,
label > .text-editor {
  width: 100%;
}
label.checkbox {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-line-pack: center;
      align-content: center;
}
label.checkbox > input + span {
  margin-left: var(--space-min);
}
label.checkbox + label.checkbox {
  margin-left: var(--space-min);
}

input, textarea, select, .text-editor {
  -webkit-appearance: auto;
  -moz-appearance: auto;
  -ms-appearance: auto;
  -o-appearance: auto;
  appearance: auto;
  line-height: 1.5;
  margin: 0px;
  padding: 0px;
  padding: 0.2em 0.4em;
  background-color: #FFFFFF;
  color: #000000;
  border-radius: 0px;
}
input:focus, textarea:focus, select:focus, .text-editor:focus {
  -webkit-appearance: auto;
  -moz-appearance: auto;
  -ms-appearance: auto;
  -o-appearance: auto;
  appearance: auto;
  -webkit-transition-delay: 0s;
          transition-delay: 0s;
  -webkit-transition-duration: 0.3s;
          transition-duration: 0.3s;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-timing-function: ease;
          transition-timing-function: ease;
}

input:not([type=radio], [type=checkbox]), textarea, select, .text-editor {
  -webkit-box-shadow: 0px 0px 0px 1px rgba(0, 0, 0, 0.1882352941);
          box-shadow: 0px 0px 0px 1px rgba(0, 0, 0, 0.1882352941);
  border: 1px solid rgba(0, 0, 0, 0);
  border-radius: 0.25em;
}
input:not([type=radio], [type=checkbox]):focus, textarea:focus, select:focus, .text-editor:focus {
  border-color: var(--color-main);
}
input:not([type=radio], [type=checkbox]).danger, textarea.danger, select.danger, .text-editor.danger {
  border-color: #c81717;
}

.c_global_navi {
  display: grid;
  grid-template: " sub-navi " auto " main-navi" auto/100%;
  /* モバイル表示時 */
}
.c_global_navi > .main_navi {
  grid-area: main-navi;
  margin: 0;
  padding: 0;
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -ms-flex-line-pack: center;
      align-content: center;
}
.c_global_navi > .main_navi li {
  margin: 0;
  padding: 0;
}
.c_global_navi > .main_navi li a {
  display: block;
  padding: var(--space-inner);
  line-height: var(--lh-button);
}
.c_global_navi > .main_navi li a .main {
  display: block;
  font-family: var(--ff-heading);
  font-weight: var(--fw-bold);
}
.c_global_navi > .main_navi li a .sub {
  display: block;
  font-family: var(--ff-accent);
  font-size: var(--fs-s);
  color: var(--color-main);
  margin-top: 0.25em;
}
.c_global_navi > .main_navi li a:hover, .c_global_navi > .main_navi li a.active {
  opacity: 1;
}
.c_global_navi > .main_navi li a:hover::after, .c_global_navi > .main_navi li a.active::after {
  content: "";
  display: block;
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: var(--color-main);
}
.c_global_navi > .sub_navi {
  grid-area: sub-navi;
  margin: 0;
  padding: 0;
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -ms-flex-line-pack: center;
      align-content: center;
  font-size: var(--fs-s);
}
.c_global_navi > .sub_navi li {
  margin: 0;
  padding: 0;
}
.c_global_navi > .sub_navi li + li {
  margin-left: var(--space-normal);
}
.c_global_navi > .sub_navi li a {
  display: block;
  line-height: var(--lh-button);
}
.c_global_navi > .sub_navi li a .main {
  display: inline-block;
  color: var(--color-note);
}
.c_global_navi > .sub_navi li a::before {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-top: 0.5em solid transparent;
  border-bottom: 0.5em solid transparent;
  border-right: 0.25em solid transparent;
  border-left: 0.5em solid var(--color-note);
}
@media screen and (max-width: 750px) {
  .c_global_navi {
    display: grid;
    grid-template: " main-navi " auto " .....     " var(--space-inner) " sub-navi  " auto/100%;
  }
  .c_global_navi > .main_navi {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .c_global_navi > .main_navi li {
    width: 100%;
  }
  .c_global_navi > .main_navi li a:hover::after, .c_global_navi > .main_navi li a.active::after {
    top: 0;
    left: 0;
    width: 2px;
    height: 100%;
  }
  .c_global_navi > .sub_navi {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .c_global_navi > .sub_navi li {
    width: 100%;
  }
  .c_global_navi > .sub_navi li + li {
    margin-left: 0;
    margin-top: var(--space-inner);
  }
}

.c_heading_section {
  display: block;
  margin-bottom: var(--space-outer);
  line-height: var(--lh-heading);
  letter-spacing: var(--ls-heading);
}
.c_heading_section > .main {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  font-family: var(--ff-heading);
  font-size: var(--fs-l);
  font-weight: var(--fw-bold);
}
.c_heading_section > .sub {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  margin-top: 1em;
  font-family: var(--ff-accent);
  font-size: var(--fs-m);
  font-weight: var(--fw-bold);
  color: var(--color-main);
}
.c_heading_section > .sub::before {
  content: "";
  position: absolute;
  top: -0.5em;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  display: block;
  width: calc(100% + 2em);
  height: 2px;
  background-color: var(--color-sub);
}

.c_heading_row {
  display: block;
  padding: var(--space-min);
  margin-bottom: 1em;
  border-left: 0.25em solid var(--color-main);
  line-height: var(--lh-heading);
  letter-spacing: var(--ls-heading);
}
.c_heading_row > .main {
  display: block;
  font-family: var(--ff-heading);
  font-size: var(--fs-m);
  font-weight: var(--fw-bold);
}

* + .c_heading_row {
  margin-top: 1em;
}

* + .c_text {
  margin-top: var(--space-gap);
}

.c_text_with_image {
  display: grid;
  grid-template: " image text " auto/35% 1fr;
  gap: var(--space-gap);
  place-items: center start;
}
.c_text_with_image > .text {
  grid-area: text;
}
.c_text_with_image > .image {
  grid-area: image;
}
.c_text_with_image.reverse {
  grid-template: " text  image " auto/1fr 35%;
}
.c_text_with_image:nth-child(even) {
  grid-template: " text  image " auto/1fr 35%;
}
@media screen and (max-width: 750px) {
  .c_text_with_image {
    grid-template: " image " auto " text  " auto/100%;
  }
  .c_text_with_image.reverse {
    grid-template: " image " auto " text  " auto/100%;
  }
  .c_text_with_image:nth-child(even) {
    grid-template: " image " auto " text  " auto/100%;
  }
}
* + .c_text_with_image {
  margin-top: var(--space-gap);
}

.c_image {
  border-radius: var(--border-radius);
  overflow: hidden;
}

.c_image_list_tile {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  margin: calc(var(--space-gap) / 2 * -1);
}
.c_image_list_tile > .item {
  margin: calc(var(--space-gap) / 2);
  -webkit-box-flex: 0;
      -ms-flex: 0 0 calc(33.33333% - var(--space-gap));
          flex: 0 0 calc(33.33333% - var(--space-gap));
}
.c_image_list_tile > .item > figcaption {
  position: absolute;
  bottom: 0;
  width: 100%;
  background: rgb(0, 0, 0);
  background: -webkit-gradient(linear, left bottom, left top, from(rgb(0, 0, 0)), to(rgba(255, 255, 255, 0)));
  background: linear-gradient(0deg, rgb(0, 0, 0) 0%, rgba(255, 255, 255, 0) 100%);
  padding: var(--space-normal);
  color: #FFFFFF;
  font-size: var(--fs-s);
}

table.spec-list {
  width: 100%;
  border-spacing: 0px;
  border-collapse: separate;
  border: 0px solid transparent;
  border-top: 1px solid var(--color-border);
}
table.spec-list th, table.spec-list td {
  padding: var(--space-outer);
  border: 0px solid transparent;
  background-color: var(--color-background);
  border-bottom: 1px solid var(--color-border);
}
table.spec-list th {
  min-width: 15em;
  white-space: nowrap;
  vertical-align: middle;
  background-color: var(--color-background);
  font-weight: var(--fw-bold);
}
* + table.spec-list {
  margin-top: var(--space-gap);
}
@media screen and (max-width: 750px) {
  table.spec-list {
    display: block;
  }
  table.spec-list tr, table.spec-list th, table.spec-list td {
    display: block;
  }
  table.spec-list th {
    border-bottom: none;
  }
}

.tile_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  margin: calc(var(--space-gap) / 2 * -1);
  --parent-gap: var(--space-gap);
}
.tile_list.col2 .tile_item {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 calc(50% - var(--parent-gap));
          flex: 0 0 calc(50% - var(--parent-gap));
  margin: calc(var(--parent-gap) / 2);
}
.tile_list.col3 .tile_item {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 calc(33.33333% - var(--parent-gap));
          flex: 0 0 calc(33.33333% - var(--parent-gap));
  margin: calc(var(--parent-gap) / 2);
}
.tile_list.col4 .tile_item {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 calc(25% - var(--parent-gap));
          flex: 0 0 calc(25% - var(--parent-gap));
  margin: calc(var(--parent-gap) / 2);
}
@media screen and (max-width: 750px) {
  .tile_list.col2 .tile_item {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 calc(100% - var(--parent-gap));
            flex: 0 0 calc(100% - var(--parent-gap));
  }
  .tile_list.col3 .tile_item {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 calc(100% - var(--parent-gap));
            flex: 0 0 calc(100% - var(--parent-gap));
  }
  .tile_list.col4 .tile_item {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 calc(100% - var(--parent-gap));
            flex: 0 0 calc(100% - var(--parent-gap));
  }
}

.article_tile {
  cursor: pointer;
  overflow: hidden;
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius);
}
.article_tile.card {
  display: grid;
  grid-template: "thumbnail" auto "description" auto/100%;
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.article_tile.card:hover {
  scale: 1.05;
}
.article_tile.card .thumbnail {
  grid-area: thumbnail;
  border-bottom: 0.5em solid var(--color-sub);
}
.article_tile.card .description {
  grid-area: description;
  display: grid;
  grid-template: "timestamp" auto "title" auto "caption" auto "tag_list" auto/100%;
  padding: var(--space-outer);
}
.article_tile.card .description .timestamp {
  grid-area: timestamp;
  font-size: var(--fs-s);
  color: var(--color-note);
  margin-bottom: var(--space-min);
}
.article_tile.card .description .title {
  grid-area: title;
  font-family: var(--ff-heading);
}
.article_tile.card .description .title .main {
  font-size: var(--fs-m);
  font-weight: var(--fw-bold);
}
.article_tile.card .description .caption {
  grid-area: caption;
  margin-bottom: var(--space-inner);
}
.article_tile.card .description .tag_list {
  grid-area: tag_list;
}
.article_tile.balloon {
  display: grid;
  grid-template: "thumbnail ..... .....      " auto "thumbnail ..... description" auto "thumbnail ..... .....      " auto/auto var(--space-gap) 1fr;
  padding: var(--space-outer);
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.article_tile.balloon:hover {
  scale: 1.05;
}
.article_tile.balloon .thumbnail {
  grid-area: thumbnail;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 1/1;
  width: 8em;
}
.article_tile.balloon .description {
  grid-area: description;
  display: grid;
  grid-template: "timestamp" auto "title" auto "caption" auto "tag_list" auto/100%;
}
.article_tile.balloon .description .timestamp {
  grid-area: timestamp;
  font-size: var(--fs-s);
  color: var(--color-note);
  margin-bottom: var(--space-min);
}
.article_tile.balloon .description .title {
  grid-area: title;
  font-family: var(--ff-heading);
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
}
.article_tile.balloon .description .title .main {
  font-size: var(--fs-m);
  font-weight: var(--fw-bold);
}
.article_tile.balloon .description .caption {
  grid-area: caption;
  margin-bottom: var(--space-inner);
}
.article_tile.balloon .description .tag_list {
  margin-top: var(--space-inner);
  grid-area: tag_list;
}

.banner_button {
  display: grid;
  grid-template: "title       ..... arrow" auto "description ..... arrow" auto/1fr 1em 1.5em;
  padding: var(--space-outer);
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius);
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.banner_button > * {
  -webkit-transition: all 0.3s 0s ease;
  transition: all 0.3s 0s ease;
}
.banner_button .title {
  grid-area: title;
  margin-bottom: var(--space-min);
  padding-bottom: var(--space-min);
  border-bottom: 1px solid var(--color-main);
}
.banner_button .title .main {
  font-family: var(--ff-heading);
  font-size: var(--fs-m);
  font-weight: var(--fw-bold);
}
.banner_button .description {
  grid-area: description;
  font-size: var(--fs-s);
}
.banner_button .arrow {
  grid-area: arrow;
  place-self: center center;
  color: var(--color-main);
}
.banner_button:hover {
  scale: 1.05;
  opacity: 1;
}
.banner_button:hover .arrow {
  -webkit-transform: translateX(50%);
          transform: translateX(50%);
}

ul.topics_list {
  margin: 0;
  padding: 0;
  list-style: none;
  border-top: 1px solid var(--color-border);
}
ul.topics_list > li {
  margin: 0;
  padding: var(--space-outer) var(--space-gap);
  list-style: none;
  display: grid;
  grid-template: " timestamp category title " auto/auto auto 1fr;
  gap: var(--space-gap);
  place-items: center start;
  border-bottom: 1px solid var(--color-border);
}
ul.topics_list > li .timestamp {
  grid-area: timestamp;
}
ul.topics_list > li .category {
  grid-area: category;
}
ul.topics_list > li .title {
  grid-area: title;
}
@media screen and (max-width: 750px) {
  ul.topics_list > li {
    grid-template: " timestamp category ..... " auto " title     title    title " auto/auto auto 1fr;
  }
}

ul.tag_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: var(--space-min);
  margin: 0;
  padding: 0;
  list-style: none;
}
ul.tag_list li {
  margin: 0;
  padding: 0;
}

.tag {
  display: inline-block;
  padding: 0.25em 0.5em;
  font-size: var(--fs-s);
  background-color: var(--color-main);
  color: var(--color-white);
  border-radius: var(--border-radius);
  border: 1px solid var(--color-main);
}

.c_map > iframe {
  display: block;
  width: 100%;
  height: 375px;
}

.c_access {
  display: grid;
  grid-template: " map ...... " auto " map access " auto " map ...... " auto/45% 1fr;
  gap: var(--space-gap);
}
.c_access > .map {
  grid-area: map;
}
.c_access > .map > iframe {
  width: 100%;
  aspect-ratio: 1/1;
  border-radius: var(--border-radius);
}
.c_access > .access {
  grid-area: access;
}
.c_access > .access > .title {
  border-bottom: 1px solid var(--color-main);
  padding-bottom: 0.5em;
  margin-bottom: 0.5em;
}
.c_access > .access > .title > .main {
  font-family: var(--ff-heading);
  font-size: var(--fs-m);
  font-weight: var(--fw-bold);
}
.c_access > .access > .method {
  margin-top: 1em;
}
.c_access > .access > .method > .container > .title > .main {
  font-family: var(--ff-heading);
  font-size: var(--fs-m);
  font-weight: var(--fw-bold);
}
.c_access > .access > .method > .container + .container {
  margin-top: 1em;
}

.c_note {
  padding: var(--space-outer);
  border-radius: var(--border-radius);
  border: 1px solid var(--color-border);
  display: grid;
  grid-template: " mark note " auto/auto 1fr;
  gap: var(--space-gap);
}
.c_note > .mark {
  grid-area: mark;
  color: var(--color-main);
  font-size: var(--fs-l);
}
.c_note > .note {
  grid-area: note;
}
* + .c_note {
  margin-top: var(--space-gap);
}

.c_attention {
  padding: var(--space-outer);
  border-radius: var(--border-radius);
  border: 1px solid var(--color-border);
  display: grid;
  grid-template: " eyecatch ..... " auto " eyecatch title " auto " eyecatch body  " auto " eyecatch ..... " auto/25% 1fr;
  gap: var(--space-gap);
}
.c_attention > .eyecatch {
  grid-area: eyecatch;
}
.c_attention > .title {
  grid-area: title;
}
.c_attention > .title > .main {
  font-family: var(--ff-heading);
  font-weight: var(--fw-bold);
  font-size: var(--fs-m);
}
.c_attention > .body {
  grid-area: body;
}

.c_theme_editor {
  overflow: hidden;
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius);
}
.c_theme_editor .title {
  padding: var(--space-outer);
  border-bottom: 1px solid var(--color-border);
}
.c_theme_editor .title > h1 {
  font-family: var(--ff-accent);
  line-height: var(--line-height-heading);
  letter-spacing: var(--letter-spacing-heading);
}
.c_theme_editor .title > h1 > .main {
  display: block;
  font-size: var(--fs-l);
  font-weight: var(--fw-bold);
}
.c_theme_editor .title > h1 > .sub {
  display: block;
  font-size: var(--fs-n);
  font-weight: var(--fw-normal);
}
.c_theme_editor .title > p {
  font-size: var(--fs-s);
  font-weight: var(--fw-normal);
  margin-top: var(--space-gap);
  color: var(--color-note);
}
.c_theme_editor .contents {
  padding: var(--space-outer);
}
.c_theme_editor .contents > h2 {
  font-family: var(--ff-accent);
  line-height: var(--line-height-heading);
  letter-spacing: var(--letter-spacing-heading);
  margin-bottom: var(--space-inner);
}
.c_theme_editor .contents > h2 > .main {
  display: block;
  font-size: var(--fs-l);
  font-weight: var(--fw-bold);
  text-align: center;
  padding-bottom: 0.25em;
}
.c_theme_editor .contents > h2 > .main::after {
  content: "";
  display: block;
  width: 6em;
  height: 2px;
  background-color: var(--color-sub);
  position: absolute;
  top: 100%;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.c_theme_editor .contents > h2 > .sub {
  display: block;
  font-size: var(--fs-n);
  font-weight: var(--fw-normal);
  text-align: center;
  margin-top: 0.5em;
}
.c_theme_editor .contents .container + .container {
  margin-top: var(--space-inner);
}
.c_theme_editor .contents .container img {
  border-radius: var(--border-radius);
}
.c_theme_editor .contents .container * + h3 {
  margin-top: var(--space-gap);
}
.c_theme_editor .contents .container h3 {
  font-family: var(--ff-accent);
  line-height: var(--line-height-heading);
  letter-spacing: var(--letter-spacing-heading);
  border-left: 0.5em solid var(--color-main);
  padding-left: 0.5em;
  margin-bottom: var(--space-gap);
}
.c_theme_editor .contents .container h3 > .main {
  font-size: var(--fs-m);
  font-weight: var(--fw-bold);
}
.c_theme_editor .contents .container > .note {
  font-size: var(--fs-s);
  color: var(--color-note);
}
.c_theme_editor .contents .container > .color-tip {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: var(--space-gap);
}
.c_theme_editor .contents .container > .color-tip > .tip {
  height: 3em;
  border-radius: var(--border-radius);
}
.c_theme_editor .contents .container > .color-tip > .tip.main {
  background-color: var(--color-main);
  -webkit-box-flex: 1;
      -ms-flex: 1 1 60%;
          flex: 1 1 60%;
}
.c_theme_editor .contents .container > .color-tip > .tip.main::after {
  content: "メインカラー";
  position: absolute;
  top: 100%;
  left: 0;
  font-size: var(--fs-s);
  color: var(--color-note);
}
.c_theme_editor .contents .container > .color-tip > .tip.sub {
  background-color: var(--color-sub);
  -webkit-box-flex: 1;
      -ms-flex: 1 1 25%;
          flex: 1 1 25%;
}
.c_theme_editor .contents .container > .color-tip > .tip.sub::after {
  content: "サブカラー";
  position: absolute;
  top: 100%;
  left: 0;
  font-size: var(--fs-s);
  color: var(--color-note);
}
.c_theme_editor .contents .container > .color-tip > .tip.accent {
  background-color: var(--color-accent);
  -webkit-box-flex: 1;
      -ms-flex: 1 1 15%;
          flex: 1 1 15%;
}
.c_theme_editor .contents .container > .color-tip > .tip.accent::after {
  content: "アクセントカラー";
  position: absolute;
  top: 100%;
  left: 0;
  font-size: var(--fs-s);
  color: var(--color-note);
}

.c_them_editor_panel {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 320px;
  height: 100%;
  border-right: 1px solid var(--color-border);
  display: none;
  overflow-y: scroll;
  height: 100%;
}
.c_them_editor_panel.show {
  display: block;
}
.c_them_editor_panel .panel {
  padding: var(--space-gap);
}

.accordion > h3 {
  cursor: pointer;
}
.accordion > h3 > span {
  pointer-events: none;
}
.accordion .accordion-contents {
  display: none;
}
.accordion .open + .accordion-contents {
  display: grid;
}

#contents-title {
  --background-img: url(../img/mv_bg_sample.jpg);
  --background-position: center center;
  --background-size: cover;
  --background-blur: 3px;
  --background-grd: 50%;
  --orverray-color: #FFFFFF;
  --orverray-opacity: 0.3;
}
#contents-title .index {
  --main-img: url(../img/mv_sample.png);
  --background-img: url(../img/mv_bg_sample.jpg);
  --background-position: center center;
  --background-size: cover;
  --background-blur: 3px;
  --background-grd: 0%;
  --orverray-color: #FFFFFF;
  --orverray-opacity: 0;
}
