@charset "UTF-8";
@import url("./css/commonstyles.css");
/* ==========================================================================
   Foundation
   ========================================================================== */
html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
}

main {
  display: block;
}

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}

pre {
  font-family: monospace, monospace;
  font-size: 1em;
}

a {
  background-color: transparent;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted;
}

b,
strong {
  font-weight: bolder;
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

img {
  border-style: none;
}

button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

fieldset {
  padding: 0.35em 0.75em 0.625em;
}

legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  /* 3 */
  white-space: normal;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type="checkbox"],
[type="radio"] {
  box-sizing: border-box;
  padding: 0;
}

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

[type="search"] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

details {
  display: block;
}

summary {
  display: list-item;
}

template {
  display: none;
}

[hidden] {
  display: none;
}

:root {
  --margin-component: 1em;
  --margin-layout: clamp(24px, 5.55555vw, 48px);
  --padding-overall: 5vw;
  --padding-component: 60px;
  --padding-headerimg: 48px;
  --width-overall: 1230px;
  --width-menu: 300px;
  --width-rmenu: 250px;
  --width-entry: 860px;
  --width-header-col2: 250px;
  --width-header-col2_topmenu-child: 250px;
}

*,
::before,
::after {
  box-sizing: border-box;
  border: 0 solid var(--clr-border, #deddd4);
  min-width: 0;
}

input,
button,
select,
textarea {
  border: revert;
  min-width: revert;
}

html {
  overflow-x: hidden;
  font-size: 62.5%;
  scroll-behavior: smooth;
}

html[data-spmenu="true"] {
  overflow: hidden;
}
html[data-spmenu="true"] #contents {
  pointer-events: none;
}

@media (min-width: 1025px) {
  html[data-spmenu="true"] {
    overflow-y: visible;
  }
  html[data-spmenu="true"] #contents {
    pointer-events: auto;
  }
}
html, body {
  height: 100%;
}

body {
  background: var(--clr-body-bg, var(--clr-base, #f5f5f0));
  color: var(--clr-body-txt, #333);
  font-family: 'Kosugi Maru', 'Hiragino Maru Gothic ProN', 'HG丸ｺﾞｼｯｸM-PRO', 'HGMaruGothicMPRO', Meiryo, sans-serif;
  font-size: 1.4rem;
  line-height: 1.7;
}

@media (min-width: 1025px) {
  body {
    font-size: 1.6rem;
    line-height: 2;
  }
}
p {
  margin: 0;
}

a {
  color: var(--clr-a-txt, #0268cc);
}

a:active, a:hover {
  outline: 0;
  text-decoration: none;
}

a img {
  border: none;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}

cite {
  font-style: normal;
}

ul[id], ul[class],
ol[id], ol[class] {
  list-style: none;
  margin: 0;
  padding: 0;
}

.display-none {
  display: none;
}

:target {
  scroll-margin-top: 24px;
}

/* ==========================================================================
   Layout
   ========================================================================== */
/*
==================================================
ラップ
==================================================
*/
#wrap {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/*
==================================================
カラム
==================================================
*/
/* グリッド名称 */
#main-header {
  grid-area: main-header;
}

#main {
  grid-area: main;
}

#main-footer {
  grid-area: main-footer;
}

#menu {
  grid-area: menu;
}

#rmenu {
  grid-area: rmenu;
}

/* 横幅　*/
@media (min-width: 1025px) {
  [data-column="col2"] #menu,
  [data-column="col3"] #menu {
    width: var(--width-menu);
  }
  [data-column="col2"] #rmenu,
  [data-column="col3"] #rmenu {
    width: var(--width-rmenu);
  }
}
/* カラム1
==================================================
*/
/* エントリー＆ページの横幅 */
[data-column="col1"][data-page*="entry"] #contents,
[data-column="col1"][data-page*="pages"] #contents {
  max-width: var(--width-entry);
}
[data-column="col1"][data-page*="entry"][data-main="wide"] #main section > h2,
[data-column="col1"][data-page*="entry"][data-main="wide"] #main section .txt-body,
[data-column="col1"][data-page*="pages"][data-main="wide"] #main section > h2,
[data-column="col1"][data-page*="pages"][data-main="wide"] #main section .txt-body {
  max-width: var(--width-entry);
}

/* カラム1（ワイド） */
[data-column="col1"][data-main="wide"] #main > *, [data-column="col1"][data-main="wide"] #main-footer > *, [data-column="col1"][data-main="wide"] #menu > *, [data-column="col1"][data-main="wide"] #rmenu > * {
  margin-bottom: var(--margin-layout);
}
[data-column="col1"][data-main="wide"] #header,
[data-column="col1"][data-main="wide"] #headerimg,
[data-column="col1"][data-main="wide"] #siteNavi,
[data-column="col1"][data-main="wide"] #footer {
  --width-overall: none;
}
[data-column="col1"][data-main="wide"] #main > * {
  padding-left: var(--padding-overall);
  padding-right: var(--padding-overall);
}
[data-column="col1"][data-main="wide"] #contents {
  padding: 0;
  max-width: none;
  width: 100%;
}
[data-column="col1"][data-main="wide"] #contents .inner > *:not(#main) {
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--padding-overall);
  padding-right: var(--padding-overall);
  width: auto;
}
[data-column="col1"][data-main="wide"][data-main-header*="wide"] #contents #main-header {
  padding-left: 0;
  padding-right: 0;
  max-width: none;
}
[data-column="col1"][data-main="wide"][data-main-header*="wide"] #main section {
  margin-top: 0;
}
[data-column="col1"][data-main="wide"][data-main-header*="wide"] #main .mainbox + section {
  margin-top: var(--margin-layout);
}
[data-column="col1"][data-main="wide"] #main section {
  border-radius: 0;
  padding: var(--padding-overall);
  margin-bottom: 0;
}
[data-column="col1"][data-main="wide"] #main section > h2,
[data-column="col1"][data-main="wide"] #main section .txt-body {
  margin-left: auto;
  margin-right: auto;
  max-width: var(--width-overall);
}

/* カラム2
==================================================
*/
/* サブメニュー非表示 */
[data-column="col2"] #rmenu {
  display: none;
}

[data-column="col2"] #menu .menubox.display-none {
  display: block;
}

/* デフォルト */
@media (min-width: 1025px) {
  [data-column="col2"] #contents .inner {
    display: grid;
    grid-template-areas: "main-header menu" "main menu" "main-footer menu";
    gap: 0 40px;
    grid-template-columns: 1fr auto;
    grid-template-rows: minmax(0, max-content) minmax(0, max-content) 1fr auto;
    justify-content: center;
  }

  [data-column*="col2"][data-menu="left"] #contents .inner {
    grid-template-areas: "menu main-header" "menu main" "menu main-footer";
    grid-template-columns: auto 1fr;
  }
}
/* トップヘッダー */
@media (min-width: 1025px) {
  [data-column="col2"][data-main-header*="header"] #main-header,
  [data-column="col2"][data-main-header*="wide"] #main-header {
    grid-column: 1 / 3;
    width: auto;
  }
  [data-column="col2"][data-main-header*="header"] #menu,
  [data-column="col2"][data-main-header*="wide"] #menu {
    grid-row: 2/4;
  }
}
/* カラム3
==================================================
*/
/* デフォルト */
@media (min-width: 1025px) {
  [data-column="col3"] #contents .inner {
    display: grid;
    grid-template-areas: "rmenu main-header menu" "rmenu main menu" "rmenu main-footer menu";
    gap: 0 30px;
    grid-template-columns: auto 1fr auto;
    grid-template-rows: minmax(0, max-content) minmax(0, max-content) 1fr auto;
    justify-content: center;
  }

  [data-column="col3"][data-menu="left"] #contents .inner {
    grid-template-areas: "menu main-header rmenu" "menu main rmenu" "menu main-footer rmenu";
  }
}
@media (min-width: 1025px) {
  [data-column="col3"][data-main-header*="header"] #main-header,
  [data-column="col3"][data-main-header*="wide"] #main-header {
    grid-column: 1 / 4;
    width: auto;
  }
  [data-column="col3"][data-main-header*="header"] #menu,
  [data-column="col3"][data-main-header*="wide"] #menu {
    grid-row: 2/4;
  }
  [data-column="col3"][data-main-header*="header"] #rmenu,
  [data-column="col3"][data-main-header*="wide"] #rmenu {
    grid-row: 2/4;
  }
}
/* スマホ特化型
==================================================
*/
/*
==================================================
ヘッダー（パーツ）
==================================================
*/
/* ロゴ */
#logo {
  color: var(--clr-logo-txt, #333);
  font-weight: 700;
  line-height: 1.5;
}
#logo img {
  display: block;
}
#logo a {
  color: inherit;
  text-decoration: none;
  display: contents;
}

/* ロゴレイアウト用 */
#logo {
  display: flex;
  align-items: center;
  gap: 8px;
  height: 100%;
  overflow: hidden;
}
#logo img {
  max-height: 100%;
}

@media (min-width: 1025px) {
  #logo {
    padding: 8px 0;
  }
  #logo img {
    max-height: 72px;
  }
  #logo.logo-square img {
    max-height: 56px;
  }
  #logo.logo-horizon img {
    max-height: 88px;
  }

  [data-header]:not([data-header="fixed"]) #logo.logo-horizon {
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
  }

  [data-header][data-header="row2-center"] #logo.logo-horizon {
    align-items: center;
  }

  [data-header][data-header="col2"] #logo {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding-top: 0;
  }
  [data-header][data-header="col2"] #logo.logo-horizon {
    align-items: center;
  }
  [data-header][data-header="col2"] #logo img {
    max-height: none;
  }
}
.logotext {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  flex-shrink: 0;
}

/* リード文 */
#header-lead {
  font-size: 1.1rem;
  padding: 8px 0;
  line-height: 1.5;
}

/* トップメニュー */
#topmenu {
  background-color: var(--clr-topmenu-bg, transparent);
  color: var(--clr-topmenu-txt, inherit);
  font-size: 1.4rem;
  line-height: 1.5;
}

.topmenu_ul {
  overflow: hidden;
}
.topmenu_ul > li {
  position: relative;
}
.topmenu_ul > li::before {
  content: '';
  border-bottom-color: rgba(255, 255, 255, 0.6);
  border-bottom-width: 1px;
  position: absolute;
  left: -100vw;
  right: 0;
  bottom: 0;
}
.topmenu_ul a {
  color: inherit;
  text-decoration: none;
  display: grid;
  gap: .1em;
  padding: 1.5em 0;
  position: relative;
  z-index: 0;
  overflow-wrap: anywhere;
}
.topmenu_ul a em {
  display: block;
  font-size: .66666em;
  font-style: normal;
}
.topmenu_ul .haschild {
  position: relative;
}
.topmenu_ul .haschild > span {
  display: block;
  position: relative;
}
.topmenu_ul .haschild > span::after {
  background-color: var(--clr-topmenu-icon, var(--clr-topmenu-txt, var(--clr-header-txt1, var(--clr-body-txt, #333))));
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2010.486%206.243%22%3E%3Cpath%20d%3D%22M.293.292a1%201%200%200%201%201.414%200l3.536%203.536L8.779.292a1%201%200%200%201%201.415%201.414L5.95%205.95a1%201%200%200%201-1.414%200L.293%201.707a1%201%200%200%201%200-1.415%22%2F%3E%3C%2Fsvg%3E") no-repeat center/10px auto;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2010.486%206.243%22%3E%3Cpath%20d%3D%22M.293.292a1%201%200%200%201%201.414%200l3.536%203.536L8.779.292a1%201%200%200%201%201.415%201.414L5.95%205.95a1%201%200%200%201-1.414%200L.293%201.707a1%201%200%200%201%200-1.415%22%2F%3E%3C%2Fsvg%3E") no-repeat center/10px auto;
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 40px;
  height: 100%;
  cursor: pointer;
}
.topmenu_ul .haschild > span a {
  padding-right: 40px;
}
.topmenu_ul .haschild.show > span::after {
  transform: rotate(180deg);
}
.topmenu_ul .haschild.show > .child {
  overflow: visible;
  opacity: 1;
}
.topmenu_ul .child {
  padding-left: 1em;
  overflow: hidden;
  opacity: 0;
}
.topmenu_ul .child > li {
  overflow: hidden;
}
.topmenu_ul .child > li:last-child > span {
  display: block;
  margin-bottom: 1em;
}
.topmenu_ul .child a {
  padding: .6em 0;
  transition: 0.45s cubic-bezier(0.19, 1, 0.22, 1);
}

/* ホバーアクション */
@media (max-width: 1024px) {
  .topmenu_ul .haschild:not(.show) .child * {
    border-width: 0;
    line-height: 0;
    margin-top: 0;
    margin-bottom: 0;
    padding-top: 0;
    padding-bottom: 0;
  }
  .topmenu_ul .haschild:not(.show) .child img {
    height: 0;
  }
  .topmenu_ul .haschild:not(.show) .child a {
    opacity: 0;
  }

  [data-color*="clr-topmenu-bg"] #topmenu {
    padding: 10px 16px;
  }
}
[data-color*="clr-header-bg1"] .topmenu_ul > li::before {
  border-color: var(--clr-header-bg1, var(--clr-accent));
  filter: invert(100%) grayscale(100%) contrast(100);
  opacity: .1;
}

[data-color*="clr-topmenu-bg"] #topmenu {
  border-radius: 16px;
  padding: .2857em 1.4286em;
}
[data-color*="clr-topmenu-bg"] .topmenu_ul > li::before {
  border-color: var(--clr-topmenu-bg);
  filter: invert(100%) grayscale(100%) contrast(100);
  opacity: .1;
}
[data-color*="clr-topmenu-bg"] .topmenu_ul > li:last-child::before {
  display: none;
}

@media (min-width: 1025px) {
  [data-header=""] #topmenu,
  [data-header="row2"] #topmenu,
  [data-header="row2-lead"] #topmenu,
  [data-header="row2-center"] #topmenu,
  [data-header="fixed"] #topmenu {
    font-size: 1.5rem;
  }
  [data-header=""] .topmenu_ul,
  [data-header="row2"] .topmenu_ul,
  [data-header="row2-lead"] .topmenu_ul,
  [data-header="row2-center"] .topmenu_ul,
  [data-header="fixed"] .topmenu_ul {
    display: flex;
    flex-wrap: wrap;
    overflow: visible;
  }
  [data-header=""] .topmenu_ul > li,
  [data-header="row2"] .topmenu_ul > li,
  [data-header="row2-lead"] .topmenu_ul > li,
  [data-header="row2-center"] .topmenu_ul > li,
  [data-header="fixed"] .topmenu_ul > li {
    display: grid;
    place-content: center;
  }
  [data-header=""] .topmenu_ul > li:not(:last-child),
  [data-header="row2"] .topmenu_ul > li:not(:last-child),
  [data-header="row2-lead"] .topmenu_ul > li:not(:last-child),
  [data-header="row2-center"] .topmenu_ul > li:not(:last-child),
  [data-header="fixed"] .topmenu_ul > li:not(:last-child) {
    margin-right: 2.2857em;
  }
  [data-header=""] .topmenu_ul > li::before,
  [data-header="row2"] .topmenu_ul > li::before,
  [data-header="row2-lead"] .topmenu_ul > li::before,
  [data-header="row2-center"] .topmenu_ul > li::before,
  [data-header="fixed"] .topmenu_ul > li::before {
    display: none;
  }
  [data-header=""] .topmenu_ul a,
  [data-header="row2"] .topmenu_ul a,
  [data-header="row2-lead"] .topmenu_ul a,
  [data-header="row2-center"] .topmenu_ul a,
  [data-header="fixed"] .topmenu_ul a {
    padding: .8em 0;
    text-align: center;
  }
  [data-header=""] .topmenu_ul .haschild > span::after,
  [data-header="row2"] .topmenu_ul .haschild > span::after,
  [data-header="row2-lead"] .topmenu_ul .haschild > span::after,
  [data-header="row2-center"] .topmenu_ul .haschild > span::after,
  [data-header="fixed"] .topmenu_ul .haschild > span::after {
    width: 12px;
  }
  [data-header=""] .topmenu_ul .haschild > span a,
  [data-header="row2"] .topmenu_ul .haschild > span a,
  [data-header="row2-lead"] .topmenu_ul .haschild > span a,
  [data-header="row2-center"] .topmenu_ul .haschild > span a,
  [data-header="fixed"] .topmenu_ul .haschild > span a {
    padding-right: 20px;
  }
  [data-header=""] .topmenu_ul .haschild:hover > ul, [data-header=""] .topmenu_ul .haschild.show:hover > ul,
  [data-header="row2"] .topmenu_ul .haschild:hover > ul,
  [data-header="row2"] .topmenu_ul .haschild.show:hover > ul,
  [data-header="row2-lead"] .topmenu_ul .haschild:hover > ul,
  [data-header="row2-lead"] .topmenu_ul .haschild.show:hover > ul,
  [data-header="row2-center"] .topmenu_ul .haschild:hover > ul,
  [data-header="row2-center"] .topmenu_ul .haschild.show:hover > ul,
  [data-header="fixed"] .topmenu_ul .haschild:hover > ul,
  [data-header="fixed"] .topmenu_ul .haschild.show:hover > ul {
    opacity: 1;
    pointer-events: auto;
    visibility: visible;
    transition: .3s ease;
    top: 100%;
  }
  [data-header=""] .topmenu_ul .haschild.show > span::after,
  [data-header="row2"] .topmenu_ul .haschild.show > span::after,
  [data-header="row2-lead"] .topmenu_ul .haschild.show > span::after,
  [data-header="row2-center"] .topmenu_ul .haschild.show > span::after,
  [data-header="fixed"] .topmenu_ul .haschild.show > span::after {
    transform: none;
  }
  [data-header=""] .topmenu_ul .haschild.show > .child,
  [data-header="row2"] .topmenu_ul .haschild.show > .child,
  [data-header="row2-lead"] .topmenu_ul .haschild.show > .child,
  [data-header="row2-center"] .topmenu_ul .haschild.show > .child,
  [data-header="fixed"] .topmenu_ul .haschild.show > .child {
    height: auto;
    overflow: visible;
    opacity: 0;
  }
  [data-header=""] .topmenu_ul .child,
  [data-header="row2"] .topmenu_ul .child,
  [data-header="row2-lead"] .topmenu_ul .child,
  [data-header="row2-center"] .topmenu_ul .child,
  [data-header="fixed"] .topmenu_ul .child {
    background: var(--clr-topmenu-child-bg, #fff);
    border-radius: 24px;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.08);
    opacity: 0;
    padding-left: 0;
    visibility: hidden;
    padding: 1.2em 2em;
    position: absolute;
    top: 90%;
    left: -1em;
    min-width: 210px;
    max-width: 100%;
    z-index: 1;
    pointer-events: none;
    height: auto;
    overflow: visible;
  }
  [data-header=""] .topmenu_ul .child a,
  [data-header="row2"] .topmenu_ul .child a,
  [data-header="row2-lead"] .topmenu_ul .child a,
  [data-header="row2-center"] .topmenu_ul .child a,
  [data-header="fixed"] .topmenu_ul .child a {
    color: var(--clr-topmenu-child-txt, var(--clr-body-txt, #333));
    margin: 0;
    padding: .6em 0;
    text-align: left;
  }
  [data-header=""] .topmenu_ul .child > li:last-child > span,
  [data-header="row2"] .topmenu_ul .child > li:last-child > span,
  [data-header="row2-lead"] .topmenu_ul .child > li:last-child > span,
  [data-header="row2-center"] .topmenu_ul .child > li:last-child > span,
  [data-header="fixed"] .topmenu_ul .child > li:last-child > span {
    margin: 0;
  }
  [data-header=""][data-color*="clr-topmenu-bg"] #topmenu,
  [data-header="row2"][data-color*="clr-topmenu-bg"] #topmenu,
  [data-header="row2-lead"][data-color*="clr-topmenu-bg"] #topmenu,
  [data-header="row2-center"][data-color*="clr-topmenu-bg"] #topmenu,
  [data-header="fixed"][data-color*="clr-topmenu-bg"] #topmenu {
    border-radius: 100px;
    padding: .2857em 1.4286em;
    min-height: auto;
  }

  [data-header="col2"] #topmenu {
    font-size: 1.5rem;
  }
  [data-header="col2"] .topmenu_ul {
    overflow: visible;
    margin-right: -24px;
  }
  [data-header="col2"] .topmenu_ul > li {
    padding: .5em 0;
    padding-right: 24px;
  }
  [data-header="col2"] .topmenu_ul > li:not(:last-child) {
    padding-bottom: 2em;
  }
  [data-header="col2"] .topmenu_ul > li::before {
    display: none;
  }
  [data-header="col2"] .topmenu_ul a {
    padding: 0;
  }
  [data-header="col2"] .topmenu_ul .haschild {
    position: static;
  }
  [data-header="col2"] .topmenu_ul .haschild > span {
    display: flex;
    align-items: center;
  }
  [data-header="col2"] .topmenu_ul .haschild > span::after {
    position: relative;
    width: 12px;
    height: 10px;
    transform: rotate(-90deg);
    flex-shrink: 0;
  }
  [data-header="col2"] .topmenu_ul .haschild > span a {
    padding-right: 8px;
  }
  [data-header="col2"] .topmenu_ul .haschild:hover > span::after,
  [data-header="col2"] .topmenu_ul .haschild:hover > span a, [data-header="col2"] .topmenu_ul .haschild.show:hover > span::after,
  [data-header="col2"] .topmenu_ul .haschild.show:hover > span a {
    opacity: .5;
  }
  [data-header="col2"] .topmenu_ul .haschild:hover > ul, [data-header="col2"] .topmenu_ul .haschild.show:hover > ul {
    opacity: 1;
    pointer-events: auto;
    visibility: visible;
    webkit-clip-path: inset(0);
    clip-path: inset(0);
  }
  [data-header="col2"] .topmenu_ul .haschild.show > .child {
    height: 100vh;
    overflow: visible;
    overflow-y: auto;
    opacity: 0;
  }
  [data-header="col2"] .topmenu_ul .child {
    background: var(--clr-topmenu-child-bg, #fff);
    opacity: 0;
    padding-left: 0;
    padding: 180px 40px 96px;
    visibility: hidden;
    position: absolute;
    top: 0;
    left: var(--width-header-col2);
    width: var(--width-header-col2_topmenu-child);
    height: 100vh;
    z-index: 1;
    pointer-events: none;
    overflow: visible;
    overflow-y: auto;
    -webkit-clip-path: inset(0 100% 0 0);
    clip-path: inset(0 100% 0 0);
    transition: .3s ease;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
  [data-header="col2"] .topmenu_ul .child::-webkit-scrollbar {
    display: none;
  }
  [data-header="col2"] .topmenu_ul .child li {
    padding: .5em 0;
  }
  [data-header="col2"] .topmenu_ul .child li:not(:last-child) {
    margin-bottom: 1.5em;
  }
  [data-header="col2"] .topmenu_ul .child a {
    color: var(--clr-topmenu-child-txt, var(--clr-body-txt, #333));
    text-align: left;
  }
  [data-header="col2"][data-color*="clr-topmenu-bg"] #topmenu {
    padding: 1.5em 20px;
  }
  [data-header="col2"][data-color*="clr-topmenu-bg"] .topmenu_ul {
    margin-right: calc(-24px - 20px);
  }
  [data-header="col2"][data-color*="clr-topmenu-bg"] .topmenu_ul > li {
    padding-right: calc(24px + 20px);
  }
}
/* ホバーアクション */
@media (hover: hover) {
  #topmenu a {
    transition: 0.2s;
  }
  #topmenu a:hover {
    opacity: 0.5;
  }
}
/* 検索ボタン */
@media (min-width: 1025px) {
  #header .search::before {
    background-color: var(--clr-header-txt1, var(--clr-header-fixed-txt, #333));
    -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2016.486%2017.34%22%3E%3Cpath%20data-name%3D%22%E3%83%91%E3%82%B9%20478%22%20d%3D%22M7%2012.707a4.738%204.738%200%200%200%202.868-.967l.575-.432.447-.59a5.588%205.588%200%200%200%201.1-3.658%205.523%205.523%200%200%200-1.49-3.528%204.767%204.767%200%200%200-7%200%205.607%205.607%200%200%200%200%207.643A4.812%204.812%200%200%200%207%2012.707m8.485%204.633a1%201%200%200%201-.707-.291l-3.708-3.71a6.754%206.754%200%200%201-9.02-.785%207.62%207.62%200%200%201%200-10.4%206.766%206.766%200%200%201%209.9%200%207.631%207.631%200%200%201%20.534%209.772l3.709%203.709a1%201%200%200%201-.708%201.706%22%2F%3E%3C%2Fsvg%3E") no-repeat center/16px auto;
    mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2016.486%2017.34%22%3E%3Cpath%20data-name%3D%22%E3%83%91%E3%82%B9%20478%22%20d%3D%22M7%2012.707a4.738%204.738%200%200%200%202.868-.967l.575-.432.447-.59a5.588%205.588%200%200%200%201.1-3.658%205.523%205.523%200%200%200-1.49-3.528%204.767%204.767%200%200%200-7%200%205.607%205.607%200%200%200%200%207.643A4.812%204.812%200%200%200%207%2012.707m8.485%204.633a1%201%200%200%201-.707-.291l-3.708-3.71a6.754%206.754%200%200%201-9.02-.785%207.62%207.62%200%200%201%200-10.4%206.766%206.766%200%200%201%209.9%200%207.631%207.631%200%200%201%20.534%209.772l3.709%203.709a1%201%200%200%201-.708%201.706%22%2F%3E%3C%2Fsvg%3E") no-repeat center/16px auto;
    content: '';
    cursor: pointer;
    display: block;
    width: 100%;
    height: 17px;
  }
  #header .search .search-form {
    background: rgba(0, 0, 0, 0.9);
    border-radius: 0;
    box-sizing: border-box;
    display: flex;
    align-items: normal;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    padding: 040px 25% 0;
    z-index: 100;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity .3s, visibility .3s;
    z-index: 1;
  }
  #header .search .search-form::before {
    background-color: #fff;
    -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2219.8%22%20height%3D%2219.798%22%20viewBox%3D%220%200%2019.8%2019.798%22%3E%3Cpath%20d%3D%22M18.385%200%209.9%208.485%201.415%200%200%201.413%208.485%209.9%200%2018.385%201.415%2019.8%209.9%2011.313l8.485%208.487%201.415-1.415L11.315%209.9%2019.8%201.413Z%22%2F%3E%3C%2Fsvg%3E") no-repeat center/19px auto;
    mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2219.8%22%20height%3D%2219.798%22%20viewBox%3D%220%200%2019.8%2019.798%22%3E%3Cpath%20d%3D%22M18.385%200%209.9%208.485%201.415%200%200%201.413%208.485%209.9%200%2018.385%201.415%2019.8%209.9%2011.313l8.485%208.487%201.415-1.415L11.315%209.9%2019.8%201.413Z%22%2F%3E%3C%2Fsvg%3E") no-repeat center/19px auto;
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    cursor: pointer;
    width: 60px;
    height: 60px;
  }

  html[data-searchbox="true"] #header .search .search-form {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
}
/* ホバーアクション */
@media (min-width: 1025px) {
  #header .search::before {
    transition: .2s;
  }
  #header .search:hover::before {
    opacity: .75;
  }
}
/* スマホボタン */
#spmenu-btn {
  display: block;
  position: relative;
  margin-left: auto;
  text-indent: 200%;
  white-space: nowrap;
  overflow: hidden;
  width: 44px;
  height: 44px;
  z-index: 100;
  margin-right: -8px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: 0;
  border-radius: 0;
  outline: none;
  padding: 0;
  box-sizing: border-box;
  min-width: 0;
}
#spmenu-btn::before, #spmenu-btn::after,
#spmenu-btn span::before {
  background-color: var(--clr-header-txt1, var(--clr-main, var(--clr-body-txt, #333)));
  border-radius: 10px;
  content: '';
  margin-left: -11px;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 22px;
  height: 3px;
  transition: .3s ease;
}
#spmenu-btn::before {
  margin-top: -8px;
}
#spmenu-btn::after {
  margin-top: 6px;
}
#spmenu-btn span::before {
  margin-top: -1px;
}

[data-spmenu="true"] #spmenu-btn::before {
  transform: translateY(7px) rotate(-45deg);
}
[data-spmenu="true"] #spmenu-btn::after {
  transform: translateY(-7px) rotate(45deg);
}
[data-spmenu="true"] #spmenu-btn span::before {
  opacity: 0;
}

@media (min-width: 1025px) {
  #spmenu-btn {
    display: none;
  }
}
/* スマホメニュー */
#spmenu {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  gap: 2em;
  overflow-x: hidden;
  overflow-y: scroll;
  opacity: 0;
  padding: 64px 0;
  z-index: 99;
  transition: .2s ease;
  height: 100vh;
  height: 100dvh;
}

@media (max-width: 1024px) {
  #spmenu {
    visibility: hidden;
  }

  [data-spmenu="true"] #body #header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 100;
    padding: 0;
  }
  [data-spmenu="true"] #body #header::before {
    background-color: var(--clr-header-bg1, var(--clr-accent, #ffd400));
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: 100vh;
    z-index: 99;
  }
  [data-spmenu="true"] #spmenu {
    opacity: 1;
    visibility: visible;
  }
}
/* ヘッダーレイアウト（スマホ）
==================================================
*/
#header {
  background-color: var(--clr-header-bg1, var(--clr-accent, #ffd400));
  color: var(--clr-header-txt1, inherit);
}

#logo-wrap {
  display: flex;
  align-items: center;
  gap: 1em;
  padding: 0.5em var(--padding-overall);
  height: 64px;
}

#spmenu-btn {
  flex-shrink: 0;
}

#spmenu {
  padding-left: var(--padding-overall);
  padding-right: var(--padding-overall);
}

#header-wrap,
#header-menu {
  display: flex;
  flex-direction: column;
  gap: 2em;
}

/* ヘッダーレイアウト（PC）
==================================================
*/
@media (min-width: 1025px) {
  [data-header=""] #logo,
  [data-header=""] #header-lead,
  [data-header=""] #topmenu,
  [data-header=""] #header .search,
  [data-header=""] #space7,
  [data-header="row2"] #logo,
  [data-header="row2"] #header-lead,
  [data-header="row2"] #topmenu,
  [data-header="row2"] #header .search,
  [data-header="row2"] #space7,
  [data-header="row2-lead"] #logo,
  [data-header="row2-lead"] #header-lead,
  [data-header="row2-lead"] #topmenu,
  [data-header="row2-lead"] #header .search,
  [data-header="row2-lead"] #space7,
  [data-header="row2-center"] #logo,
  [data-header="row2-center"] #header-lead,
  [data-header="row2-center"] #topmenu,
  [data-header="row2-center"] #header .search,
  [data-header="row2-center"] #space7,
  [data-header="fixed"] #logo,
  [data-header="fixed"] #header-lead,
  [data-header="fixed"] #topmenu,
  [data-header="fixed"] #header .search,
  [data-header="fixed"] #space7 {
    display: flex;
    align-items: center;
    min-height: 64px;
  }
  [data-header=""] #header-menu,
  [data-header="row2"] #header-menu,
  [data-header="row2-lead"] #header-menu,
  [data-header="row2-center"] #header-menu,
  [data-header="fixed"] #header-menu {
    flex-direction: row;
  }
  [data-header=""] #logo-wrap,
  [data-header=""] #spmenu,
  [data-header=""] #header-wrap,
  [data-header="row2"] #logo-wrap,
  [data-header="row2"] #spmenu,
  [data-header="row2"] #header-wrap,
  [data-header="row2-lead"] #logo-wrap,
  [data-header="row2-lead"] #spmenu,
  [data-header="row2-lead"] #header-wrap,
  [data-header="row2-center"] #logo-wrap,
  [data-header="row2-center"] #spmenu,
  [data-header="row2-center"] #header-wrap,
  [data-header="fixed"] #logo-wrap,
  [data-header="fixed"] #spmenu,
  [data-header="fixed"] #header-wrap {
    display: contents;
  }
}
/* ヘッダーレイアウト（1行）
==================================================
*/
@media (min-width: 1025px) {
  [data-header=""] #header .container,
  [data-header="row2"] #header .container,
  [data-header="row2-lead"] #header .container,
  [data-header="row2-center"] #header .container,
  [data-header="fixed"] #header .container {
    box-sizing: content-box;
    margin-left: auto;
    margin-right: auto;
    padding: 0.75em var(--padding-overall);
    max-width: var(--width-overall);
    display: flex;
    flex-wrap: wrap;
    gap: 0 1em;
    align-items: center;
  }
  [data-header=""] #header .search,
  [data-header="row2"] #header .search,
  [data-header="row2-lead"] #header .search,
  [data-header="row2-center"] #header .search,
  [data-header="fixed"] #header .search {
    overflow: hidden;
    margin-left: auto;
    flex-shrink: 0;
    width: 40px;
  }
  [data-header=""] #header-menu,
  [data-header="row2"] #header-menu,
  [data-header="row2-lead"] #header-menu,
  [data-header="row2-center"] #header-menu,
  [data-header="fixed"] #header-menu {
    flex-grow: 1;
  }
  [data-header=""] #topmenu,
  [data-header="row2"] #topmenu,
  [data-header="row2-lead"] #topmenu,
  [data-header="row2-center"] #topmenu,
  [data-header="fixed"] #topmenu {
    margin: 0 auto;
  }
  [data-header=""] #topmenu + .search,
  [data-header="row2"] #topmenu + .search,
  [data-header="row2-lead"] #topmenu + .search,
  [data-header="row2-center"] #topmenu + .search,
  [data-header="fixed"] #topmenu + .search {
    margin: 0;
  }

  [data-main-header="header"] #header .container {
    padding: 1.25em var(--padding-overall);
  }
}
/* 2行
==================================================
*/
@media (min-width: 1025px) {
  [data-header="row2"] #header-menu {
    background-color: var(--clr-header-bg2, transparent);
    color: var(--clr-header-txt2, inherit);
    align-items: center;
    position: relative;
  }
  [data-header="row2"] #header-menu {
    order: 1;
    width: 100%;
  }
  [data-header="row2"] #topmenu {
    margin: 0 auto 0 0;
    position: relative;
  }
  [data-header="row2"] #topmenu .topmenu_ul .haschild::after {
    background-color: var(--clr-topmenu-icon, var(--clr-topmenu-txt, var(--clr-header-txt2, var(--clr-header-txt1, var(--clr-body-txt, #333)))));
  }
  [data-header="row2"] #space7 {
    margin: 0 0 0 auto;
  }
  [data-header="row2"] #header .search::before {
    background-color: var(--clr-header-txt2, var(--clr-header-txt1, var(--clr-header-fixed-txt, var(--clr-body-txt, #333))));
  }
  [data-header="row2"][data-color*="clr-header-bg2"] #header-menu {
    border-radius: 100px;
    padding: 4px 32px;
    margin: 1em 0;
  }
}
/* 2行リード文
==================================================
*/
@media (min-width: 1025px) {
  [data-header="row2-lead"] #header-menu {
    align-items: center;
  }
  [data-header="row2-lead"] #header-lead {
    color: var(--clr-header-txt2, inherit);
    min-height: auto;
    order: -1;
    width: 100%;
  }
  [data-header="row2-lead"] #header-lead span {
    position: relative;
  }
  [data-header="row2-lead"][data-color*="clr-header-bg2"] #header .container {
    padding-top: 0;
  }
  [data-header="row2-lead"][data-color*="clr-header-bg2"] #header-lead {
    position: relative;
    margin-bottom: 2em;
  }
  [data-header="row2-lead"][data-color*="clr-header-bg2"] #header-lead::before {
    background-color: var(--clr-header-bg2, transparent);
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0 calc(-50vw + 50%);
  }
}
/* 2行中央揃え
==================================================
*/
@media (min-width: 1025px) {
  [data-header="row2-center"] #header .container {
    display: block;
  }
  [data-header="row2-center"] #logo,
  [data-header="row2-center"] #header-lead {
    justify-content: center;
    min-height: auto;
  }
  [data-header="row2-center"] #header-lead {
    margin-top: -1em;
    padding: 1em 0;
  }
  [data-header="row2-center"] #header-wrap {
    background-color: var(--clr-header-bg2, transparent);
    color: var(--clr-header-txt2, inherit);
    display: flex;
    flex-direction: row;
    justify-content: center;
  }
  [data-header="row2-center"] #header-menu {
    align-items: center;
  }
  [data-header="row2-center"] #header-menu {
    flex-grow: 0;
  }
  [data-header="row2-center"] #topmenu,
  [data-header="row2-center"] #space7 {
    position: relative;
  }
  [data-header="row2-center"] #topmenu {
    margin: 0;
  }
  [data-header="row2-center"] #topmenu .topmenu_ul .haschild::after {
    background-color: var(--clr-topmenu-icon, var(--clr-topmenu-txt, var(--clr-header-txt2, var(--clr-header-txt1, var(--clr-body-txt, #333)))));
  }
  [data-header="row2-center"] #header .search::before {
    background-color: var(--clr-header-txt2, var(--clr-header-txt1, var(--clr-header-fixed-txt, var(--clr-body-txt, #333))));
  }
  [data-header="row2-center"][data-color*="clr-header-bg2"] #header-wrap {
    border-radius: 100px;
    padding: 4px 32px;
    margin: 1em 0;
  }
}
/* トップ固定（ヘッダーワイドの時）
==================================================
*/
@media (max-width: 1024px) {
  [data-header="fixed"]:not([data-headerimg-img-sp="false"]) #header {
    background: transparent;
    position: absolute;
    top: 0;
    left: 0;
    padding: 10px var(--padding-overall) 0;
    width: 100%;
    z-index: 1;
  }
  [data-header="fixed"]:not([data-headerimg-img-sp="false"]) #header .container {
    background: var(--clr-header-bg1, #fff);
    border-radius: 100px;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.06);
    box-sizing: border-box;
    flex-wrap: nowrap;
  }
}
@media (min-width: 1025px) {
  [data-header="fixed"]:not([data-headerimg-img="false"]) #header {
    background: transparent;
    position: absolute;
    top: 0;
    left: 0;
    padding: 20px var(--padding-overall) 0;
    width: 100%;
    z-index: 1;
  }
  [data-header="fixed"]:not([data-headerimg-img="false"]) #header .container {
    background: var(--clr-header-bg1, #fff);
    border-radius: 100px;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.06);
    padding: 4px 32px;
    box-sizing: border-box;
    flex-wrap: nowrap;
    max-height: 112px;
  }
  [data-header="fixed"]:not([data-headerimg-img="false"]) .search-keyword {
    background: var(--clr-form-bg, #f7f7f7);
  }
}
/* 2カラム
==================================================
*/
@media (min-width: 1025px) {
  [data-header="col2"] #wrap {
    padding-left: var(--width-header-col2);
  }
  [data-header="col2"] #header {
    position: fixed;
    z-index: 2000;
    top: 0;
    left: 0;
    height: 100vh;
    width: var(--width-header-col2);
  }
  [data-header="col2"] #header .container {
    padding: 40px 24px;
    height: 100vh;
    overflow-y: auto;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
  [data-header="col2"] #header .container::-webkit-scrollbar {
    display: none;
  }
  [data-header="col2"] #header .search {
    display: flex;
    align-items: center;
    gap: 6px;
  }
  [data-header="col2"] #header .search::before {
    width: 16px;
    height: 16px;
  }
  [data-header="col2"] #header .search::after {
    content: attr(data-search-text);
    font-size: 1.4rem;
  }
  [data-header="col2"] #header .search .search-form {
    align-items: center;
    padding-top: 0;
    padding-bottom: 200px;
  }
  [data-header="col2"] #logo {
    justify-content: center;
    height: auto;
  }
  [data-header="col2"] #header-lead {
    text-align: center;
  }
  [data-header="col2"] #logo-wrap,
  [data-header="col2"] #spmenu {
    display: contents;
  }
  [data-header="col2"] #header-wrap {
    display: flex;
    flex-direction: column;
    gap: 2em;
    padding-top: 32px;
  }
  [data-header="col2"][data-main-header="header"] #main-header {
    padding-top: var(--margin-layout);
  }
  [data-header="col2"][data-main-header*="wide"] #main-header {
    margin-left: calc(calc(-50vw + 50%) + calc(var(--width-header-col2) / 2));
    margin-right: calc(calc(-50vw + 50%) + calc(var(--width-header-col2) / 2));
  }
  [data-header="col2"] #brand-bnr-box {
    z-index: 2000;
  }
}
/*
==================================================
コンテンツ
==================================================
*/
#contents {
  flex-grow: 1;
  box-sizing: content-box;
  display: flex;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--padding-overall);
  padding-right: var(--padding-overall);
  padding-bottom: var(--margin-layout);
  width: calc(100% - (var(--padding-overall) * 2));
  max-width: var(--width-overall);
}
#contents .inner {
  display: flow-root;
  position: relative;
  width: 100%;
}

#main > *, #main-footer > *, #menu > *, #rmenu > * {
  margin-top: var(--margin-layout);
}

/*
==================================================
メインヘッダー（レイアウト）
==================================================
*/
[data-main-header]:not([data-main-header*="header"]) #main-header > * {
  margin-top: var(--margin-layout);
}

/* ヘッダー画像 */
@media (min-width: 1025px) {
  [data-main-header="header"] #main-header {
    margin-left: calc(var(--padding-overall) / -2);
    margin-right: calc(var(--padding-overall) / -2);
  }
}
/* ヘッダー横幅ワイド */
[data-main-header*="wide"] #main-header {
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
}

/*
==================================================
メイン（パーツ）
==================================================
*/
#main section {
  background-color: var(--clr-txtbody-bg, #fff);
  color: var(--clr-txtbody-txt, inherit);
  display: flow-root;
  padding: clamp(16px, 4.44444vw, var(--padding-component));
}
#main section + section {
  margin-top: 0;
}
#main section:not([style]) + section:not([style]) {
  padding-top: 0;
}
#main section:first-of-type {
  border-top-left-radius: 16px;
  border-top-right-radius: 16px;
}
#main section:last-of-type {
  border-bottom-left-radius: 16px;
  border-bottom-right-radius: 16px;
}

/* ワイド化 */
[data-column="col1"][data-main="wide"] #main section[data-txt-body="wide"] > h2,
[data-column="col1"][data-main="wide"] #main section[data-txt-body="wide"] .txt-body {
  max-width: none;
}

/* シェアボタン */
#main .snsbox {
  display: flex;
  justify-content: flex-end;
  width: 100%;
}

@media (min-width: 1025px) {
  [data-column="col1"]:not([data-main="wide"]) #main,
  [data-column="col2"] #main {
    display: flow-root;
    position: relative;
  }
  [data-column="col1"]:not([data-main="wide"]) #main .snsbox,
  [data-column="col2"] #main .snsbox {
    display: block;
    margin: 0;
    position: absolute;
    top: 0;
    left: calc(calc(min(var(--padding-overall),72px) * -1) + 10px);
    width: auto;
    height: 100%;
    padding-top: var(--margin-layout);
  }
  [data-column="col1"]:not([data-main="wide"]) #main .snsbox .sns-title,
  [data-column="col2"] #main .snsbox .sns-title {
    display: none;
  }
  [data-column="col1"]:not([data-main="wide"]) #main .snsbox .snslist,
  [data-column="col2"] #main .snsbox .snslist {
    flex-direction: column;
    margin: 0;
    position: sticky;
    top: var(--margin-layout);
  }
  [data-column="col1"]:not([data-main="wide"])[data-main-header=""] #main,
  [data-column="col2"][data-main-header=""] #main {
    position: static;
  }
  [data-column="col1"]:not([data-main="wide"])[data-menu="left"] #main .snsbox,
  [data-column="col2"][data-menu="left"] #main .snsbox {
    left: auto;
    right: calc(calc(min(var(--padding-overall),72px) * -1) + 10px);
  }
}
/*
==================================================
メインフッター（レイアウト）
==================================================
*/
/* タグ一覧 */
#main-footer .taglist {
  justify-content: flex-end;
}

/* シェアボタン */
#main-footer :not(.profile-body) > .snsbox {
  display: flex;
  justify-content: flex-end;
  width: 100%;
}

/*
==================================================
メインメニュー（パーツ）
==================================================
*/
.menuboxlist .menubox:not(:first-child) {
  margin-top: var(--margin-layout);
}

/* メインメニュー */
.menulist {
  font-size: 1.4rem;
  line-height: 1.5;
}

.sitemenu,
#submenu:not([class="submenu-image"]) {
  background: var(--clr-menu-bg, #fff);
  border-radius: 16px;
  overflow: hidden;
}
.sitemenu > li:not(:last-child),
#submenu:not([class="submenu-image"]) > li:not(:last-child) {
  border-bottom-color: #f1f1f1;
  border-bottom-width: 1px;
}
.sitemenu a,
#submenu:not([class="submenu-image"]) a {
  color: var(--clr-menu-txt, inherit);
  text-decoration: none;
  display: flex;
  align-items: center;
  padding: 1.2em 1.5em;
}
.sitemenu .haschild,
#submenu:not([class="submenu-image"]) .haschild {
  position: relative;
}
.sitemenu .haschild > a,
#submenu:not([class="submenu-image"]) .haschild > a {
  padding-right: 56px;
}
.sitemenu .haschild::after,
#submenu:not([class="submenu-image"]) .haschild::after {
  background-color: var(--clr-menu-icon, var(--clr-menu-txt, var(--clr-body-txt, #333)));
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2014%2014%22%3E%3Cpath%20d%3D%22M6%2013V8H1a1%201%200%200%201%200-2h5V1a1%201%200%200%201%202%200v5h5a1%201%200%200%201%200%202H8v5a1%201%200%200%201-2%200%22%2F%3E%3C%2Fsvg%3E") no-repeat center/14px auto;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2014%2014%22%3E%3Cpath%20d%3D%22M6%2013V8H1a1%201%200%200%201%200-2h5V1a1%201%200%200%201%202%200v5h5a1%201%200%200%201%200%202H8v5a1%201%200%200%201-2%200%22%2F%3E%3C%2Fsvg%3E") no-repeat center/14px auto;
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 56px;
  height: 3.972em;
  cursor: pointer;
}
.sitemenu .haschild.show::after,
#submenu:not([class="submenu-image"]) .haschild.show::after {
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2014%202%22%3E%3Cpath%20d%3D%22M14%201a1%201%200%200%201-1%201H1a1%201%200%200%201%200-2h12a1%201%200%200%201%201%201%22%2F%3E%3C%2Fsvg%3E") no-repeat center/14px auto;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2014%202%22%3E%3Cpath%20d%3D%22M14%201a1%201%200%200%201-1%201H1a1%201%200%200%201%200-2h12a1%201%200%200%201%201%201%22%2F%3E%3C%2Fsvg%3E") no-repeat center/14px auto;
}
.sitemenu .haschild.show > .child,
#submenu:not([class="submenu-image"]) .haschild.show > .child {
  overflow: visible;
  opacity: 1;
}
.sitemenu .sitemenu_ul,
#submenu:not([class="submenu-image"]) .sitemenu_ul {
  padding-left: 1em;
}
.sitemenu .sitemenu_ul > li,
#submenu:not([class="submenu-image"]) .sitemenu_ul > li {
  overflow: hidden;
}
.sitemenu .sitemenu_ul > li:last-child > a,
#submenu:not([class="submenu-image"]) .sitemenu_ul > li:last-child > a {
  margin-bottom: 1em;
}
.sitemenu .sitemenu_ul a,
#submenu:not([class="submenu-image"]) .sitemenu_ul a {
  padding: .6em 1.5em;
}
.sitemenu .child,
#submenu:not([class="submenu-image"]) .child {
  overflow: hidden;
  opacity: 0;
}
.sitemenu .child .haschild::after,
#submenu:not([class="submenu-image"]) .child .haschild::after {
  height: 1.5em;
}
.sitemenu .child a,
#submenu:not([class="submenu-image"]) .child a {
  transition: 0.45s cubic-bezier(0.19, 1, 0.22, 1);
}

@media (max-width: 1024px) {
  .menubox .sitemenu .haschild:not(.show) .child *:not(span),
  #submenu:not([class="submenu-image"]) .haschild:not(.show) .child *:not(span) {
    border-width: 0;
    line-height: 0;
    margin-top: 0;
    margin-bottom: 0;
    padding-top: 0;
    padding-bottom: 0;
  }
  .menubox .sitemenu .haschild:not(.show) .child img,
  #submenu:not([class="submenu-image"]) .haschild:not(.show) .child img {
    height: 0;
  }
  .menubox .sitemenu .haschild:not(.show) .child a,
  #submenu:not([class="submenu-image"]) .haschild:not(.show) .child a {
    opacity: 0;
  }
}
@media (min-width: 1025px) {
  #body:not([data-column="col1"]) .menubox .sitemenu .haschild:not(.show) .child *:not(span),
  #body:not([data-column="col1"]) #submenu:not([class="submenu-image"]) .haschild:not(.show) .child *:not(span) {
    border-width: 0;
    line-height: 0;
    margin-top: 0;
    margin-bottom: 0;
    padding-top: 0;
    padding-bottom: 0;
  }
  #body:not([data-column="col1"]) .menubox .sitemenu .haschild:not(.show) .child img,
  #body:not([data-column="col1"]) #submenu:not([class="submenu-image"]) .haschild:not(.show) .child img {
    height: 0;
  }
  #body:not([data-column="col1"]) .menubox .sitemenu .haschild:not(.show) .child a,
  #body:not([data-column="col1"]) #submenu:not([class="submenu-image"]) .haschild:not(.show) .child a {
    opacity: 0;
  }

  [data-column="col1"] .sitemenu,
  [data-column="col1"] #submenu:not([class="submenu-image"]) {
    column-count: 3;
    gap: 2em;
    padding: 2em;
  }
  [data-column="col1"] .sitemenu li,
  [data-column="col1"] #submenu:not([class="submenu-image"]) li {
    break-inside: avoid;
    margin: 0 0 1.5em;
    border: none;
  }
  [data-column="col1"] .sitemenu li::after,
  [data-column="col1"] #submenu:not([class="submenu-image"]) li::after {
    display: none;
  }
  [data-column="col1"] .sitemenu a,
  [data-column="col1"] #submenu:not([class="submenu-image"]) a {
    padding: 0;
    display: inline;
  }
  [data-column="col1"] .sitemenu .sitemenu_ul,
  [data-column="col1"] #submenu:not([class="submenu-image"]) .sitemenu_ul {
    padding: 0;
  }
  [data-column="col1"] .sitemenu .sitemenu_ul li,
  [data-column="col1"] #submenu:not([class="submenu-image"]) .sitemenu_ul li {
    margin: 0.8em 0 0;
    opacity: 0.75;
  }
  [data-column="col1"] .sitemenu .child,
  [data-column="col1"] #submenu:not([class="submenu-image"]) .child {
    height: auto;
    overflow: visible;
    opacity: 1;
  }

  /* ホバーアクション */
  .menulist {
    font-size: 1.5rem;
  }
  .menulist a {
    transition: 0.2s;
  }
  .menulist a:hover {
    opacity: 0.5;
  }
  .menulist .haschild:hover::after {
    transition: 0.2s;
    opacity: 0.5;
  }
}
.menu-icon {
  flex-shrink: 0;
  line-height: 0;
}
.menu-icon img {
  max-width: 20px;
  margin-right: 8px;
  vertical-align: top;
}

/* 画像メニュー */
.submenu-image {
  display: flex;
  flex-wrap: wrap;
  gap: .5em;
}
.submenu-image ul, .submenu-image li, .submenu-image a, .submenu-image span {
  display: contents;
}

/* 月別アーカイブ */
/*
==================================================
サブメニュー（パーツ）
==================================================
*/
/*
==================================================
フッター（パーツ）
==================================================
*/
/* フッターナビ */
#footer-menu {
  font-size: 1.4rem;
  line-height: 1.5;
}

.footer-menu_ul {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  gap: 1.5em 3em;
}
.footer-menu_ul li {
  max-width: 100%;
}
.footer-menu_ul a {
  color: var(--clr-footermenu-txt, inherit);
  text-decoration: none;
}
.footer-menu_ul .child li {
  margin: 1em 0;
}
.footer-menu_ul .child li a {
  color: var(--clr-footermenu-child-txt, var(--clr-footermenu-txt, var(--clr-footer-txt, rgba(255, 255, 255, 0.75))));
}

@media (min-width: 1025px) {
  .footer-menu_ul {
    flex-direction: row;
    justify-content: center;
  }
}
/* ホバーアクション */
@media (min-width: 1025px) {
  #footer-menu a {
    transition: 0.2s;
  }
  #footer-menu a:hover {
    opacity: 0.5;
  }
}
/* コピーライト */
#copy {
  font-size: 1.1rem;
  text-align: center;
  width: 100%;
}

/* フッター（レイアウト）
==================================================
*/
#footer {
  background-color: var(--clr-footer-bg, var(--clr-main, #222));
  color: var(--clr-footer-txt, #fff);
}
#footer .inner {
  box-sizing: content-box;
  margin: 0 auto;
  padding: clamp(40px, 11.11111vw, 64px) var(--padding-overall);
  max-width: var(--width-overall);
  display: flex;
  flex-direction: column;
  gap: 3em;
}

/* 中央揃え
==================================================
*/
[data-footer=""] #space8 {
  text-align: center;
}

/* 両端揃え
==================================================
*/
@media (min-width: 1025px) {
  [data-footer*="col2"] #footer .inner {
    flex-direction: row;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  [data-footer*="col2"] #footer-menu {
    order: -1;
  }
}
/*
==================================================
ヘッダー（追従機能）
==================================================
*/
@media (max-width: 1024px) {
  html:not([data-spmenu="true"]) #body #header.fix {
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 100;
    transform: translateY(-100%);
  }
  html:not([data-spmenu="true"]) #body #header.fix:not(.show-header) {
    overflow: hidden;
  }
  html:not([data-spmenu="true"]) #body #header.fix:not(.show-header) .container {
    transition: 0.4s cubic-bezier(0.3, 0, 0.2, 1);
    box-shadow: none;
    opacity: 0;
    pointer-events: none;
  }
  html:not([data-spmenu="true"]) #body[data-header="fixed"]:not([data-headerimg-img-sp="false"]) #header.fix {
    position: fixed;
  }
  html:not([data-spmenu="true"]) #body #header.fix.hide-header {
    transform: translateY(-100%);
    transition: 0.4s transform cubic-bezier(0.3, 0, 0.2, 1);
    pointer-events: none;
  }
  html:not([data-spmenu="true"]) #body #header.fix.show-header {
    transform: none;
    transition: 0.4s transform cubic-bezier(0.3, 0, 0.2, 1);
  }
}
@media (min-width: 1025px) {
  #body:not([data-header="col2"]) #header.fix {
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 100;
    transform: translateY(-100%);
  }
  #body:not([data-header="col2"]) #header.fix:not(.show-header) {
    overflow: hidden;
  }
  #body:not([data-header="col2"]) #header.fix:not(.show-header) .container {
    transition: 0.4s cubic-bezier(0.3, 0, 0.2, 1);
    box-shadow: none;
    opacity: 0;
    pointer-events: none;
  }
  #body:not([data-header="col2"])[data-header="fixed"]:not([data-headerimg-img-sp="false"]) #header.fix {
    position: fixed;
  }
  #body:not([data-header="col2"]) #header.fix.hide-header {
    transform: translateY(-100%);
    transition: 0.4s transform cubic-bezier(0.3, 0, 0.2, 1);
    pointer-events: none;
  }
  #body:not([data-header="col2"]) #header.fix.show-header {
    transform: none;
    transition: 0.4s transform cubic-bezier(0.3, 0, 0.2, 1);
  }
}
/* ==========================================================================
   page
   ========================================================================== */
/*
==================================================
トップページ
==================================================
*/
#whatsnew li {
  background: #fff;
  border-radius: 16px;
  padding: 1.2em;
  display: flex;
  flex-direction: column;
  align-items: baseline;
  gap: .8em 1.3em;
}
#whatsnew li:not(:last-child) {
  margin-bottom: 4px;
}

.whatsnew-time {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: .2em 1em;
}
.whatsnew-time .cat {
  max-width: 100px;
}

.whatsnew-txt {
  font-size: 1.4rem;
  line-height: 1.6;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
.whatsnew-txt a {
  color: inherit;
  text-decoration: none;
}

@media (min-width: 1025px) {
  #whatsnew li {
    flex-direction: row;
  }

  .whatsnew-txt {
    -webkit-line-clamp: 1;
  }
  .whatsnew-txt a:hover {
    text-decoration: underline;
  }
}
/*
==================================================
ブログモード
==================================================
*/
.bloglist {
  display: grid;
  margin: var(--margin-component) 0;
  gap: clamp(18px, 5vw, 20px) 2%;
  grid-template-rows: max-content;
}

/* カラム変更 */
@media (max-width: 1024px) {
  .bloglist[data-bloglist-sp-column*="col2"] {
    grid-template-columns: repeat(2, 1fr);
  }
  .bloglist[data-bloglist-sp-column*="col3"] {
    grid-template-columns: repeat(3, 1fr);
  }
  .bloglist[data-bloglist-sp-column*="col4"] {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media (min-width: 1025px) {
  .bloglist[data-bloglist-column*="col2"] {
    grid-template-columns: repeat(2, 1fr);
  }
  .bloglist[data-bloglist-column*="col3"] {
    grid-template-columns: repeat(3, 1fr);
  }
  .bloglist[data-bloglist-column*="col4"] {
    grid-template-columns: repeat(4, 1fr);
  }
}
/*
==================================================
記事（パーツ）
==================================================
*/
/* NEWアイコン */
[data-blog-mark*="new"] {
  position: relative;
  z-index: 1;
}
[data-blog-mark*="new"]::before {
  background: #ffd400;
  color: #333;
  content: 'New!';
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: -.025em;
  line-height: 1;
  position: absolute;
  top: -20px;
  left: -20px;
  width: 59px;
  height: 59px;
  z-index: 1;
  clip-path: path("M1.757 19.089a29 29 0 1 1 42.357 34.678l1.267 4.518-6.013-2.185A29 29 0 0 1 1.757 19.089");
  transform: rotate(-20deg);
}
[data-blog-mark*="new"]::after {
  background: #fff;
  content: '';
  position: absolute;
  top: -21px;
  left: -21px;
  width: 61px;
  height: 61px;
  z-index: 1;
  clip-path: path("M46.375 60.293a.983.983 0 0 1-.342-.061l-5.665-2.061A30 30 0 0 1 17.323 2.827a30 30 0 0 1 28.95 52.4l1.064 3.8a1 1 0 0 1-.962 1.27M3.69 20.439A28 28 0 0 0 40 56.171a1.007 1.007 0 0 1 .7-.006l4.181 1.522-.74-2.642a1 1 0 0 1 .443-1.124A28 28 0 1 0 3.69 20.439");
  transform: rotate(-20deg);
}

/*
==================================================
記事（デザイン）
==================================================
*/
.blog {
  container-type: inline-size;
}
.blog .blog-inner {
  background: #fff;
  border-radius: 24px;
  overflow: hidden;
  text-align: left;
}
.blog .blog-thumb {
  overflow: hidden;
}
.blog .blog-thumb img {
  width: 100%;
  aspect-ratio: 41 / 24;
  max-height: 240px;
  object-fit: cover;
}
.blog .blog-body {
  display: flex;
  flex-wrap: wrap;
  gap: 1em;
  position: relative;
  padding: 1.5em 1.8em;
}
.blog .blog-info {
  order: 1;
  display: flex;
  flex-direction: column-reverse;
  justify-content: center;
  gap: .5em;
  width: calc(50% - .5em);
}
.blog .blog-title {
  color: inherit;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.4;
  width: 100%;
}
.blog .blog-title a {
  color: inherit;
  text-decoration: none;
}
.blog .blog-desc {
  opacity: .75;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  font-size: 1.3rem;
  line-height: 1.7;
}
.blog .author {
  order: 2;
  justify-content: flex-start;
  flex-direction: row-reverse;
  width: calc(50% - .5em);
}
.blog .blog-desc,
.blog .blog-more {
  display: none;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  .blog .blog-inner,
  .blog .blog-thumb img {
    transition: .2s ease;
  }
  .blog:hover .blog-inner {
    opacity: .7;
  }
  .blog:hover .blog-thumb img {
    transform: scale(1.1);
  }
}
/* リサイズ */
@container (max-width: 360px) {
  .blog .blog-title {
    -webkit-line-clamp: 2;
  }
}
@container (max-width: 300px) {
  .blog .blog-body {
    padding: 1em;
  }
}
@container (max-width: 240px) {
  .blog .blog-title {
    font-size: 1.4rem;
  }
  .blog .blog-info {
    width: 100%;
  }
  .blog .cat,
  .blog .author {
    display: none;
  }
}
/* 横向き */
.bloglist[data-bloglist-horizontal*="true"] .blog .blog-inner {
  display: flex;
}
.bloglist[data-bloglist-horizontal*="true"] .blog .blog-thumb {
  position: relative;
  width: 45%;
}
.bloglist[data-bloglist-horizontal*="true"] .blog .blog-thumb a {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.bloglist[data-bloglist-horizontal*="true"] .blog .blog-thumb img {
  width: 100%;
  height: 100%;
  max-height: none;
}
.bloglist[data-bloglist-horizontal*="true"] .blog .blog-body {
  width: 55%;
}
.bloglist[data-bloglist-horizontal*="true"] .blog .blog-title {
  -webkit-line-clamp: 2;
}

@container (max-width: 500px) {
  .bloglist[data-bloglist-horizontal*="true"] .blog .blog-title {
    font-size: 1.4rem;
  }
  .bloglist[data-bloglist-horizontal*="true"] .blog .blog-info {
    width: 100%;
  }
  .bloglist[data-bloglist-horizontal*="true"] .blog .cat,
  .bloglist[data-bloglist-horizontal*="true"] .blog .author {
    display: none;
  }
}
@container (min-width: 680px) {
  .bloglist[data-bloglist-horizontal*="true"] .blog .blog-desc {
    display: -webkit-box;
  }
}
@container (min-width: 800px) {}
@container (min-width: 1000px) {
  .bloglist[data-bloglist-horizontal*="true"] .blog .blog-title {
    -webkit-line-clamp: 3;
    font-size: 2.8rem;
    line-height: 1.5;
  }
}
/*
==================================================
カテゴリーページ
==================================================
*/
[class^="categorylist"] ul {
  margin: var(--margin-component) 0;
}
[class^="categorylist"] .article-thumb {
  border-radius: 16px;
  overflow: hidden;
}
[class^="categorylist"] .article-thumb img {
  width: 100%;
  aspect-ratio: 41 / 24;
  object-fit: cover;
}
[class^="categorylist"] .article-title {
  color: inherit;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  font-size: clamp(1.6rem, 4.44444vw, 1.8rem);
  font-weight: 700;
  line-height: 1.4;
}
[class^="categorylist"] .article-title a {
  color: inherit;
  text-decoration: none;
}
[class^="categorylist"] .article-desc {
  color: inherit;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  font-size: 1.3rem;
  line-height: 1.7;
  opacity: .75;
}
[class^="categorylist"] .article-more {
  display: none;
}

@media (min-width: 1025px) {
  [class^="categorylist"] .article-thumb img {
    max-height: 300px;
  }
  [class^="categorylist"] .article-inner,
  [class^="categorylist"] .article-thumb img {
    transition: all .2s ease;
  }
  [class^="categorylist"] .article:hover .article-inner {
    opacity: .7;
  }
  [class^="categorylist"] .article:hover .article-thumb img {
    transform: scale(1.1);
  }
}
/*　カテゴリー一覧（横並び） */
.categorylist ul {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%,300px), 1fr));
  gap: 2em;
}
.categorylist .article {
  position: relative;
}
.categorylist .article-inner {
  display: flex;
  flex-direction: column;
  gap: 1em;
}
.categorylist .article-body {
  display: flex;
  flex-direction: column;
  gap: .5em;
}

/*　カテゴリー一覧（縦並び） */
.categorylist-vertical {
  container-type: inline-size;
}
.categorylist-vertical ul {
  display: grid;
  gap: 1.5em;
}
.categorylist-vertical li {
  border-bottom-width: 1px;
  border-bottom-style: dashed;
  padding-bottom: 1.5em;
}
.categorylist-vertical .article {
  position: relative;
}
.categorylist-vertical .article-inner {
  display: flex;
  flex-wrap: wrap;
  gap: .5em 1.5em;
}
.categorylist-vertical .article-thumb {
  flex: 1 1 300px;
}
.categorylist-vertical .article-body {
  flex: 9999 1 300px;
  display: flex;
  flex-direction: column;
  gap: .5em;
  padding-top: .5em;
}
.categorylist-vertical .article-title {
  font-size: clamp(1.6rem, 4.44444vw, 2rem);
}
.categorylist-vertical .article-desc {
  font-size: 1.4rem;
}

@container (min-width: 400px) {
  .categorylist-vertical .article-desc {
    -webkit-line-clamp: 3;
  }
}
/*　カテゴリー一覧（交互） */
.categorylist-alternate {
  container-type: inline-size;
}
.categorylist-alternate ul {
  display: grid;
  gap: 2em;
}
.categorylist-alternate .article {
  position: relative;
}
.categorylist-alternate .article-inner {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%,400px), 1fr));
  gap: 1em 0;
}
.categorylist-alternate .article-body {
  display: flex;
  flex-direction: column;
  gap: .5em;
}
.categorylist-alternate .article-title {
  font-size: clamp(1.6rem, 4.44444vw, 2rem);
}

@container (min-width: 800px) {
  .categorylist-alternate ul {
    gap: 3em;
  }
  .categorylist-alternate .article-body {
    padding: min(2vw, 1.5em) 2vw;
  }
  .categorylist-alternate .article-title {
    -webkit-line-clamp: 3;
  }
  .categorylist-alternate .article-desc {
    -webkit-line-clamp: 4;
  }
  .categorylist-alternate li:nth-child(odd) .article-body {
    padding-right: 0;
  }
  .categorylist-alternate li:nth-child(even) .article-body {
    order: -1;
    padding-left: 0;
  }
}
/*
==================================================
エントリー
==================================================
*/
/* 関連記事一覧
==================================================
*/
#entrylist ul {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%,190px), 1fr));
  gap: 1em;
}
#entrylist .article {
  position: relative;
}
#entrylist .article-inner {
  display: flex;
  flex-direction: column;
  gap: 1em;
}
#entrylist .article-thumb {
  flex-shrink: 0;
  border-radius: 16px;
  overflow: hidden;
}
#entrylist .article-thumb img {
  width: 100%;
  aspect-ratio: 3 / 2;
  object-fit: cover;
}
#entrylist .article-body {
  display: flex;
  flex-direction: column;
  gap: .5em;
}
#entrylist .article-title {
  color: inherit;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.4;
}
#entrylist .article-title a {
  color: inherit;
  text-decoration: none;
}
#entrylist .article-desc {
  color: inherit;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  font-size: 1.3rem;
  line-height: 1.7;
  opacity: .75;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  #entrylist .article-inner,
  #entrylist .article-thumb img {
    transition: all .2s ease;
  }
  #entrylist .article:hover .article-inner {
    opacity: .7;
  }
  #entrylist .article:hover .article-thumb img {
    transform: scale(1.1);
  }
}
/*
==================================================
サイト内検索
==================================================
*/
#searchresult ul {
  margin: var(--margin-component) 0;
  display: grid;
  gap: 1.5em;
}
#searchresult li {
  border-bottom-width: 1px;
  border-bottom-style: dashed;
  padding-bottom: 1.5em;
}
#searchresult .article {
  position: relative;
}
#searchresult .article-inner {
  display: flex;
  flex-wrap: wrap;
  gap: .5em 1.5em;
}
#searchresult .article-thumb {
  flex: 1 1 300px;
  border-radius: 16px;
  overflow: hidden;
}
#searchresult .article-thumb img {
  width: 100%;
  aspect-ratio: 41 / 24;
  object-fit: cover;
}
#searchresult .article-body {
  flex: 9999 1 300px;
  display: flex;
  flex-direction: column;
  gap: .5em;
  padding-top: 0.5em;
}
#searchresult .article-title {
  color: inherit;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  font-size: clamp(1.6rem, 4.44444vw, 2rem);
  font-weight: 700;
  line-height: 1.4;
}
#searchresult .article-title a {
  color: inherit;
  text-decoration: none;
}
#searchresult .article-desc {
  color: inherit;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  font-size: 1.4rem;
  line-height: 1.7;
  opacity: .75;
}
#searchresult .article-more {
  display: none;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  #searchresult .article-inner,
  #searchresult .article-thumb img {
    transition: all .2s ease;
  }
  #searchresult .article:hover .article-inner {
    opacity: .7;
  }
  #searchresult .article:hover .article-thumb img {
    transform: scale(1.1);
  }
}
/*
==================================================
404ページ
==================================================
*/
#notfound .search {
  margin: 2em 0;
}
#notfound .search-keyword {
  background: #f7f7f7;
}

@media (min-width: 1025px) {
  #notfound .search-form {
    width: 360px;
  }
}
/* ==========================================================================
   Component
   ========================================================================== */
/* 著者
==================================================
*/
.author {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: .5em;
}

.author-image {
  width: 48px;
  height: 48px;
  flex-shrink: 0;
}
.author-image img {
  border-radius: 50%;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.author-body {
  display: flex;
  flex-direction: column;
  gap: .4em;
}

.author-name {
  font-size: 1.2rem;
  line-height: 1.5;
  opacity: .5;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  overflow: hidden;
}
.author-name a {
  color: inherit;
  text-decoration: none;
}

/* 引用
==================================================
*/
blockquote {
  background: #f8f8f8;
  border-radius: 16px;
  margin: var(--margin-component) 0;
  padding: 2em;
  position: relative;
}
blockquote::before {
  background-image: url(img/blockquote.svg);
  background-position: left center;
  background-repeat: no-repeat;
  background-size: 14px auto;
  content: '';
  display: block;
  margin-bottom: 10px;
  margin-top: -10px;
  width: 1em;
  height: 1em;
}

/* 画像付きボックス共通
==================================================
*/
[class*="alert"] {
  background: #fef1f1;
}

[class*="accept"] {
  background: #eef9f9;
}

[class*="attention"] {
  background: #fff8e5;
}

[class*="hint"] {
  background: #eff9fe;
}

.alert::before,
.accept::before,
.attention::before,
.thint::before,
.cbox-d .cbox-caption span::before {
  background-position: center;
  background-repeat: no-repeat;
  content: '';
  border-radius: 50%;
  position: absolute;
  width: 1.75em;
  height: 1.75em;
}

.alert:not(.noimage)::before,
[class*="cbox-alert"] .cbox-caption span::before {
  background-color: #ec6a6a;
  background-image: url(img/icon_alert.svg);
  background-size: .75em;
}

.accept:not(.noimage)::before,
[class*="cbox-accept"] .cbox-caption span::before {
  background-color: #2ab3b6;
  background-image: url(img/icon_accept.svg);
  background-size: .9375em;
}

.attention:not(.noimage)::before,
[class*="cbox-attention"] .cbox-caption span::before {
  background-color: #ffba00;
  background-image: url(img/icon_attention.svg);
  background-size: .1875em;
}

.thint:not(.noimage)::before,
[class*="cbox-hint"] .cbox-caption span::before {
  background-color: #1baee8;
  background-image: url(img/icon_thint.svg);
  background-size: .1875em;
}

/* 画像付きボックス
==================================================
*/
.alert, .accept, .attention, .thint {
  border-radius: 16px;
  line-height: 1.5;
  margin: var(--margin-component) 0;
  padding: 2em;
  position: relative;
}
.alert:not(.noimage), .accept:not(.noimage), .attention:not(.noimage), .thint:not(.noimage) {
  padding-left: calc(2em + 2.5em);
}
.alert:not(.noimage)::before, .accept:not(.noimage)::before, .attention:not(.noimage)::before, .thint:not(.noimage)::before {
  top: calc(2em - 0.125em);
  left: 2em;
}

/* キャプション付きボックス共通
==================================================
*/
.cbox-d {
  line-height: 1.5;
  margin: var(--margin-component) 0;
}
.cbox-d .cbox-caption {
  line-height: 1.5;
}
.cbox-d .cbox-caption span {
  display: block;
  font-size: .875em;
  position: relative;
}
.cbox-d .cbox-caption span::before {
  top: -.125em;
  left: 0;
}

[class*="cbox-alert"] .cbox-caption {
  background: #ec6a6a;
}
[class*="cbox-alert"] .cbox-caption span {
  color: #ec6a6a;
}

[class*="cbox-alert"],
[class*="cbox-alert"] .cbox-caption::before,
[class*="cbox-alert"] .cbox-caption::after {
  border-color: #ec6a6a;
}

[class*="cbox-accept"] .cbox-caption {
  background: #2ab3b6;
}
[class*="cbox-accept"] .cbox-caption span {
  color: #2ab3b6;
}

[class*="cbox-accept"],
[class*="cbox-accept"] .cbox-caption::before,
[class*="cbox-accept"] .cbox-caption::after {
  border-color: #2ab3b6;
}

[class*="cbox-attention"] .cbox-caption {
  background: #ffba00;
}
[class*="cbox-attention"] .cbox-caption span {
  color: #ffba00;
}

[class*="cbox-attention"],
[class*="cbox-attention"] .cbox-caption::before,
[class*="cbox-attention"] .cbox-caption::after {
  border-color: #ffba00;
}

[class*="cbox-hint"] .cbox-caption {
  background: #1baee8;
}
[class*="cbox-hint"] .cbox-caption span {
  color: #1baee8;
}

[class*="cbox-hint"],
[class*="cbox-hint"] .cbox-caption::before,
[class*="cbox-hint"] .cbox-caption::after {
  border-color: #1baee8;
}

/* デザイン01
==================================================
*/
.cbox-d[class*="01"] {
  border-radius: 4px;
  border-style: dashed;
  border-width: 2px;
}
.cbox-d[class*="01"] .cbox-caption {
  background: transparent;
  margin-bottom: -.5em;
  padding: 1.33333em 1.77777em 0;
}
.cbox-d[class*="01"] .cbox-caption span {
  padding-left: 2.5em;
}
.cbox-d[class*="01"] .cbox-body {
  padding: 1.5em 2em;
}

.cbox-alert01 {
  border-color: #fad5d5;
}

.cbox-accept01 {
  border-color: #c6ebeb;
}

.cbox-attention01 {
  border-color: #ffe08b;
}

.cbox-hint01 {
  border-color: #b9e7f9;
}

/* デザイン02
==================================================
*/
.cbox-d[class*="02"] {
  background: #fff;
  border-width: 2px;
  border-top: none;
  border-bottom-left-radius: 16px;
  border-bottom-right-radius: 16px;
  margin-top: calc(var(--margin-component) + .85712em + 24px);
}
.cbox-d[class*="02"] .cbox-caption {
  background: transparent;
  display: flex;
  margin-bottom: calc(-24px + -1em);
  padding: 0;
  top: -24px;
}
.cbox-d[class*="02"] .cbox-caption::before, .cbox-d[class*="02"] .cbox-caption::after {
  background: #fff;
  content: '';
  border-top-width: 2px;
  height: 24px;
}
.cbox-d[class*="02"] .cbox-caption::before {
  border-top-left-radius: 16px;
  border-left-width: 2px;
  margin-left: -2px;
  width: 24px;
}
.cbox-d[class*="02"] .cbox-caption::after {
  border-top-right-radius: 16px;
  border-right-width: 2px;
  flex-grow: 1;
  margin-right: -2px;
}
.cbox-d[class*="02"] .cbox-caption span {
  margin: 0 .55555em;
  padding-left: 2.5em;
  margin-top: -.85712em;
  z-index: 0;
}
.cbox-d[class*="02"] .cbox-caption span::after {
  background: #fff;
  content: '';
  position: absolute;
  left: -.55555em;
  right: -.55555em;
  bottom: 0;
  height: 22px;
  z-index: -1;
}
.cbox-d[class*="02"] .cbox-body {
  padding: 2em;
}

/* デザイン03
==================================================
*/
.cbox-d[class*="03"] {
  border-radius: 16px;
  margin-top: calc(var(--margin-component) + 1.25em);
}
.cbox-d[class*="03"] .cbox-caption {
  border-radius: 1000px;
  display: inline-block;
  margin: 0 1.77777em;
  padding: .25em .5em;
  position: relative;
  top: -1em;
  margin-bottom: -1.25em;
  max-width: calc(100% - 3.555554em);
}
.cbox-d[class*="03"] .cbox-caption span {
  color: #fff;
  padding-left: 1.7857em;
}
.cbox-d[class*="03"] .cbox-body {
  margin-top: -1.125em;
  padding: 2em;
}

/* デザイン04
==================================================
*/
.cbox-d[class*="04"] {
  background: #fff;
  border-width: 2px;
  border-top: none;
  border-radius: 16px;
  overflow: hidden;
}
.cbox-d[class*="04"] .cbox-caption {
  margin-bottom: 0;
  padding: .625em 1.77777em;
}
.cbox-d[class*="04"] .cbox-caption span {
  color: #fff;
  padding-left: 1.7857em;
}
.cbox-d[class*="04"] .cbox-body {
  padding: 1.5em 2em;
}

/* カテゴリーネーム
==================================================
*/
.cat {
  display: inline-flex;
}
.cat a {
  background: #ededed;
  border-radius: 100px;
  color: #333;
  font-size: 1rem;
  line-height: 2;
  padding: 0 1em;
  text-decoration: none;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  overflow: hidden;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  .cat a {
    transition: 0.2s;
  }
  .cat a:hover {
    opacity: 0.7;
  }
}
/* レビューチャート
==================================================
*/
.chart {
  line-height: 1.5;
}
.chart li {
  display: flex;
  gap: 0 8px;
  align-items: center;
  font-size: 1.2rem;
  padding: 2px 0;
}
.chart .chart-title {
  flex-shrink: 0;
  width: 30%;
}
.chart .graph {
  background: #f2f5f7;
  border-radius: 10px;
  flex-grow: 1;
}
.chart .graph .bar {
  background: #fac000;
  display: block;
  border-radius: 10px;
  height: 10px;
}
.chart .graph .bar[data-review='0'] {
  width: 0%;
}
.chart .graph .bar[data-review='1'] {
  width: 20%;
}
.chart .graph .bar[data-review='2'] {
  width: 40%;
}
.chart .graph .bar[data-review='3'] {
  width: 60%;
}
.chart .graph .bar[data-review='4'] {
  width: 80%;
}
.chart .graph .bar[data-review='5'] {
  width: 100%;
}

/* CTA
==================================================
*/
/* デザイン */
.cta {
  background: #ededed;
  color: #333;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  container-type: inline-size;
}
.cta a {
  color: inherit;
  display: block;
  text-decoration: none;
}
.cta .cta-img {
  position: relative;
  z-index: 0;
}
.cta .cta-img img {
  width: 100%;
  height: 140px;
  -webkit-mask-image: linear-gradient(black 30%, transparent);
  mask-image: linear-gradient(black 30%, transparent);
  object-fit: cover;
}
.cta .cta-body {
  margin-top: -10px;
  padding: 0 20px 20px;
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 20px 0;
}
.cta .cta-txt {
  display: flex;
  flex-direction: column;
  gap: 10px 0;
}
.cta .cta-title {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
}
.cta .cta-desc {
  font-size: 1.2rem;
  line-height: 1.7;
  opacity: .75;
}
.cta .cta-more {
  text-align: center;
}
.cta .cta-more span {
  background: #55b958;
  border-radius: 100px;
  color: #fff;
  display: inline-block;
  font-size: 1.2rem;
  padding: .5em 1.5em;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  .cta {
    transition: 0.2s;
  }
  .cta:hover {
    opacity: 0.7;
  }
}
/* リサイズ */
@container (max-width: 280px) {
  .cta .cta-img img {
    height: 90px;
  }
  .cta .cta-body {
    gap: 10px 0;
  }
  .cta .cta-title {
    font-size: 1.5rem;
  }
  .cta .cta-desc {
    font-size: 1rem;
  }
  .cta .cta-more span {
    font-size: 1rem;
  }
}
/* 画像位置左側 */
@container (min-width: 600px) {
  .cta.cta-left .cta-inner {
    flex-direction: row;
  }
  .cta.cta-left .cta-img img {
    -webkit-mask-image: linear-gradient(to right, black 30%, transparent);
    mask-image: linear-gradient(to right, black 30%, transparent);
    object-position: left;
  }
}
@container (min-width: 600px) {
  .cta .cta-inner {
    display: flex;
    flex-direction: row-reverse;
  }
  .cta .cta-img {
    width: 45%;
  }
  .cta .cta-img img {
    height: 100%;
    -webkit-mask-image: linear-gradient(to left, black 30%, transparent);
    mask-image: linear-gradient(to left, black 30%, transparent);
    object-position: right;
  }
  .cta .cta-img span {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
  }
  .cta .cta-body {
    margin-top: 0;
    padding: 32px;
    width: 55%;
  }
  .cta .cta-title {
    text-align: left;
  }
  .cta .cta-desc {
    font-size: 1.3rem;
  }
  .cta .cta-more {
    text-align: left;
  }
}
@container (min-width: 800px) {
  .cta[data-cta-size=""] .cta-img {
    width: 50%;
  }
  .cta[data-cta-size=""] .cta-body {
    width: 50%;
    padding: 40px;
    gap: 24px 0;
  }
  .cta[data-cta-size=""] .cta-title {
    font-size: 2.6rem;
  }
  .cta[data-cta-size=""] .cta-desc {
    display: block;
    font-size: 1.5rem;
  }
  .cta[data-cta-size=""] .cta-more span {
    display: block;
    font-size: 1.5rem;
    text-align: center;
  }
}
@container (min-width: 728px) {
  .cta[data-cta-size="horizontal"] .cta-img {
    width: 38%;
  }
  .cta[data-cta-size="horizontal"] .cta-body {
    width: 62%;
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0 20px;
  }
  .cta[data-cta-size="horizontal"] .cta-more {
    flex-shrink: 0;
  }
}
/* CTA フッターボタン型
==================================================
*/
.cta-footer {
  background: #ededed;
  color: #333;
  padding: 40px 0;
  text-align: center;
}
.cta-footer .cta-inner {
  padding-left: var(--padding-overall);
  padding-right: var(--padding-overall);
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.cta-footer .cta-txt {
  font-size: clamp(1.6rem, 2vw, 1.8rem);
  line-height: 1.4;
  font-weight: 700;
}
.cta-footer .cta-btns {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 24px;
}
.cta-footer .cta-more {
  text-align: center;
  width: 100%;
  max-width: 400px;
}
.cta-footer .cta-more a {
  background: #55b958;
  border-radius: 100px;
  color: #fff;
  display: block;
  font-size: 2rem;
  font-weight: 700;
  padding: .8em;
  text-decoration: none;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  .cta-footer .cta-more a {
    transition: 0.2s;
  }
  .cta-footer .cta-more a:hover {
    opacity: 0.7;
  }
}
/* CTA追従
==================================================
*/
#cta-fixed {
  display: none;
}

@media (min-width: 1025px) {
  #cta-fixed {
    background: #fff;
    display: block;
    position: absolute;
    right: 4px;
    bottom: 50%;
    opacity: 0;
    visibility: hidden;
    transition: opacity .5s ease, visibility .5s ease;
    z-index: 99;
    width: 250px;
  }
  #cta-fixed.fixed__follow {
    position: fixed;
    bottom: 4px;
    opacity: 1;
    visibility: visible;
  }
  #cta-fixed #cta-fixedbtn {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: 0;
    font: inherit;
    outline: none;
    padding: 0;
    background-color: #e6e6e6;
    border-radius: 50%;
    display: block;
    width: 26px;
    height: 26px;
    position: absolute;
    top: -13px;
    left: -13px;
    cursor: pointer;
  }
  #cta-fixed #cta-fixedbtn::before {
    background-color: #676767;
    -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%209.072%209.077%22%3E%3Cpath%20d%3D%22m7.365%208.783-2.83-2.83-2.834%202.83A1%201%200%200%201%20.292%207.365L3.12%204.539.292%201.711A1%201%200%201%201%201.701.293l2.835%202.832L7.364.3a.992.992%200%200%201%201.4-.012L8.777.3a.992.992%200%200%201%20.008%201.4l-.008.008L5.95%204.539l2.827%202.826a1%201%200%200%201%200%201.414%201%201%200%200%201-1.412%200%22%2F%3E%3C%2Fsvg%3E") no-repeat center/10px auto;
    mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%209.072%209.077%22%3E%3Cpath%20d%3D%22m7.365%208.783-2.83-2.83-2.834%202.83A1%201%200%200%201%20.292%207.365L3.12%204.539.292%201.711A1%201%200%201%201%201.701.293l2.835%202.832L7.364.3a.992.992%200%200%201%201.4-.012L8.777.3a.992.992%200%200%201%20.008%201.4l-.008.008L5.95%204.539l2.827%202.826a1%201%200%200%201%200%201.414%201%201%200%200%201-1.412%200%22%2F%3E%3C%2Fsvg%3E") no-repeat center/10px auto;
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
  }
  #cta-fixed .cta {
    margin: 0;
  }
  #cta-fixed.fixed__close {
    display: none;
  }
}
/* 日付
==================================================
*/
.date {
  font-size: 1.2rem;
  line-height: 1;
  position: relative;
  opacity: .5;
  flex-shrink: 0;
}
.date.updated {
  padding-left: 1.5em;
  position: relative;
}
.date.updated::before {
  background-color: var(--clr-body-txt, #333);
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2012.473%2011.503%22%3E%3Cpath%20d%3D%22m11.3%201.518.108-.072a.879.879%200%200%201%20.642-.233.532.532%200%200%201%20.408.629l-.724%203.4a.5.5%200%200%201-.568.421.413.413%200%200%201-.061-.013L7.7%204.93a.532.532%200%200%201-.4-.63.765.765%200%200%201%20.414-.458l.086-.051.981-.634a3.99%203.99%200%201%200%20.685%204.068l.057-.143%201.727.367-.067.19a5.752%205.752%200%201%201-.917-5.448Z%22%2F%3E%3C%2Fsvg%3E") no-repeat center left/contain;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2012.473%2011.503%22%3E%3Cpath%20d%3D%22m11.3%201.518.108-.072a.879.879%200%200%201%20.642-.233.532.532%200%200%201%20.408.629l-.724%203.4a.5.5%200%200%201-.568.421.413.413%200%200%201-.061-.013L7.7%204.93a.532.532%200%200%201-.4-.63.765.765%200%200%201%20.414-.458l.086-.051.981-.634a3.99%203.99%200%201%200%20.685%204.068l.057-.143%201.727.367-.067.19a5.752%205.752%200%201%201-.917-5.448Z%22%2F%3E%3C%2Fsvg%3E") no-repeat center left/contain;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 1em;
  height: 1em;
}

/* 資料請求
==================================================
*/
.documents {
  display: grid;
  gap: 2em 64px;
}

.documents-main {
  display: flex;
  flex-direction: column;
  gap: 1em 0;
}

.documents-stitle {
  font-size: clamp(1.8rem, 5vw, 2.2rem);
  font-weight: 700;
  line-height: 1.5;
}

/* Facebookページプラグイン
==================================================
*/
.facebook_plugin {
  overflow: hidden;
}

/* お問い合わせ
==================================================
*/
.form {
  display: flex;
  flex-direction: column;
  gap: 1.5em 0;
}
.form .item-list {
  display: flex;
  flex-direction: column;
  gap: 1em 0;
}
.form .item {
  display: flex;
  flex-direction: column;
  gap: 0.5em 0;
  margin: 0;
}
.form .item_t {
  font-weight: 700;
}
.form .item_t span {
  background-color: #f77e62;
  border-radius: 100px;
  color: #fff;
  display: inline-block;
  font-size: .6875em;
  line-height: 1;
  margin-left: 1em;
  padding: .4545em .8182em;
  position: relative;
  top: -.05em;
}
.form .item_d {
  margin: 0;
}
.form input,
.form textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: 0;
  border-radius: 0;
  font: inherit;
  outline: none;
  box-sizing: border-box;
  min-width: 0;
  color: var(--clr-form-txt, #333);
  font-size: 1.6rem;
}
.form input::placeholder,
.form textarea::placeholder {
  color: var(--clr-form-txt, #5b5b5b);
  opacity: .5;
}
.form input:-ms-input-placeholder,
.form textarea:-ms-input-placeholder {
  color: var(--clr-form-txt, #5b5b5b);
  opacity: .5;
}
.form input::-ms-input-placeholder,
.form textarea::-ms-input-placeholder {
  color: var(--clr-form-txt, #5b5b5b);
  opacity: .5;
}
.form input[type="text"],
.form input[type="email"],
.form input[type="tel"],
.form textarea {
  background: var(--clr-form-bg, #faf8f3);
  border: 1px solid var(--clr-form-bg, #faf8f3);
  border-radius: 8px;
  width: 100%;
  transition: border-color 0.2s ease 0s;
}
.form input[type="text"]:focus,
.form input[type="email"]:focus,
.form input[type="tel"]:focus,
.form textarea:focus {
  border-color: var(--clr-accent, #ffd400);
}
.form input[type="text"],
.form input[type="email"],
.form input[type="tel"] {
  padding: 0 1em;
  line-height: 3.75em;
  height: 3.75em;
}
.form textarea {
  display: block;
  padding: 1em;
  height: 170px;
  resize: vertical;
}
.form input[type=checkbox] {
  display: none;
}
.form input[type=checkbox] + span {
  background-color: transparent;
  cursor: pointer;
  display: inline-block;
  line-height: 1.3;
  padding: .25em 0 .25em 2.25em;
  position: relative;
  transition: color .1s linear;
  vertical-align: middle;
  max-width: 100%;
}
.form input[type=checkbox] + span::before {
  background: #fff;
  border-width: 0.0625em;
  content: '';
  display: block;
  position: absolute;
  top: .125em;
  left: .25em;
  transition: background-color .1s linear;
  width: 1.5em;
  height: 1.5em;
}
.form input[type=checkbox] + span::after {
  border-bottom: .125em solid #2ab3b6;
  border-right: .125em solid #2ab3b6;
  content: '';
  display: block;
  opacity: 0;
  position: absolute;
  top: .25em;
  left: .75em;
  transform: rotate(45deg);
  width: .5625em;
  height: .875em;
}
.form input[type=checkbox]:checked + span::before {
  border-color: #2ab3b6;
}
.form input[type=checkbox]:checked + span::after {
  opacity: 1;
}
.form input[type="submit"] {
  background-color: #2ab3b6;
  background-image: url(img/brn_arrow.svg);
  background-position: center right 28px;
  background-repeat: no-repeat;
  background-size: 16px auto;
  border-radius: 5em;
  box-shadow: 0.25em 0.25em 0 rgba(0, 0, 0, 0.08);
  cursor: pointer;
  color: #fff;
  font-size: 1.25em;
  line-height: 1.5;
  display: block;
  padding: 1.2em 0;
  margin-left: auto;
  margin-right: auto;
  max-width: 326px;
  width: 100%;
}

@media (min-width: 1025px) {
  .form .agree {
    text-align: center;
  }
  .form input[type="submit"] {
    transition: 0.2s;
  }
  .form input[type="submit"]:hover {
    opacity: .7;
  }
}
/* 注釈 */
.notes {
  font-size: .8em;
  padding-left: 1em;
  opacity: .5;
}
.notes::before {
  content: '\203b';
  margin-left: -1em;
}

/*
==================================================
フリースペース
==================================================
*/
#space1 .space-box:not(:first-child), #space2 .space-box:not(:first-child), #space3 .space-box:not(:first-child), #space4 .space-box:not(:first-child), #space5 .space-box:not(:first-child), #space6 .space-box:not(:first-child) {
  margin-top: var(--margin-layout);
}

#space7 {
  display: grid;
  gap: 2em;
}
#space7::after {
  display: none;
}

@media (min-width: 1025px) {
  [data-header=""] #space7,
  [data-header="row2"] #space7,
  [data-header="row2-lead"] #space7,
  [data-header="row2-center"] #space7,
  [data-header="fixed"] #space7 {
    display: flex;
    gap: 1em;
  }
}
#space8 .space-box:not(:first-child) {
  margin-top: 2em;
}

/*
==================================================
ヘッダー画像
==================================================
*/
/* 全体設定
==================================================
*/
.headerimg-img {
  text-align: center;
  line-height: 0;
  position: relative;
  z-index: 0;
}
.headerimg-img::before {
  background-color: var(--clr-headerimg-overlay, rgba(0, 0, 0, 0.3));
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: none;
}
.headerimg-img img {
  width: 100%;
  height: var(--h-hdr-sp, 100%);
  object-fit: cover;
}

@media (min-width: 1025px) {
  .headerimg-img img {
    height: var(--h-hdr-pc, 100%);
  }
}
.headerimg-item {
  position: relative;
}
.headerimg-item a {
  display: contents;
}
.headerimg-item img {
  object-fit: contain;
}

@media (max-width: 1024px) {
  .headerimg-item {
    text-align: center;
  }
}
.headerimg-txt {
  color: var(--clr-headerimg-txt, var(--clr-body-txt, inherit));
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 1em;
  overflow: hidden;
  position: relative;
}

.headerimg-title {
  font-size: clamp(2rem, 5.55555vw, 2.8rem);
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
}

[data-headerimg-type=""][data-page*="other"] .headerimg-title {
  padding-bottom: .8em;
  position: relative;
}
[data-headerimg-type=""][data-page*="other"] .headerimg-title::after {
  background: #eaeaea;
  content: '';
  border-radius: 10px;
  height: 4px;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
}

.headerimg-desc {
  font-size: clamp(1.3rem, 3.61111vw, 1.4rem);
  line-height: 1.9;
  opacity: .75;
}

@media (max-width: 1024px) {
  [data-headerimg-type="header"][data-headerimg-img-sp="true"] .headerimg-desc {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
  }
}
.headerimg-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 1em;
}
.headerimg-meta .author {
  flex-direction: row-reverse;
  margin-left: auto;
  order: 1;
}
.headerimg-meta .author .author-image {
  width: 74px;
  height: 74px;
}
.headerimg-meta .author .author-name {
  font-size: 1.4rem;
}
.headerimg-meta .date.updated::before {
  background-color: var(--clr-headerimg-txt, var(--clr-body-txt, #333));
}
.headerimg-meta .cat a {
  font-size: 1.2rem;
}

@media (max-width: 1024px) {
  [data-headerimg-img-sp="false"][data-headerimg-item-sp="false"][data-headerimg-title-sp="false"][data-headerimg-desc-sp="false"][data-headerimg-meta-sp="false"] #headerimg {
    display: none;
  }

  [data-headerimg-item-sp="false"][data-headerimg-title-sp="false"][data-headerimg-desc-sp="false"][data-headerimg-meta-sp="false"] .headerimg-inner {
    display: none;
  }

  [data-headerimg-title-sp="false"][data-headerimg-desc-sp="false"][data-headerimg-meta-sp="false"] .headerimg-txt {
    display: none;
  }
}
@media (min-width: 1025px) {
  [data-headerimg-img="false"][data-headerimg-item="false"][data-headerimg-title="false"][data-headerimg-desc="false"][data-headerimg-meta="false"] #headerimg {
    display: none;
  }

  [data-headerimg-item="false"][data-headerimg-title="false"][data-headerimg-desc="false"][data-headerimg-meta="false"] .headerimg-inner {
    display: none;
  }

  [data-headerimg-title="false"][data-headerimg-desc="false"][data-headerimg-meta="false"] .headerimg-txt {
    display: none;
  }
}
/* コンテンツ画像 */
[data-headerimg-type=""] #headerimg {
  background-color: var(--clr-txtbody-bg, #fff);
  border-radius: 16px;
  display: grid;
  gap: clamp(16px, 4.44444vw, var(--padding-component));
  padding: clamp(16px, 4.44444vw, var(--padding-component));
  overflow: hidden;
}
[data-headerimg-type=""] .headerimg-img {
  margin: clamp(calc(var(--padding-component) * -1), -4.44444vw, -16px);
  margin-bottom: 0;
}
[data-headerimg-type=""] .headerimg-inner {
  display: grid;
  gap: 2em;
}

@media (max-width: 1024px) {
  [data-headerimg-type=""]:not([data-main="wide"]):not([data-main-header="false"]):not([data-topslider="true"]):not([data-headerimg-img-sp="false"][data-headerimg-title-sp="false"][data-headerimg-desc-sp="false"][data-headerimg-item-sp="false"][data-headerimg-meta-sp="false"]) #main-header + #main > section:first-child {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
    margin-top: calc(clamp(calc(var(--padding-component) * -1), -4.44444vw, -16px) + clamp(16px, 4.44444vw, calc(var(--padding-component) / 2)));
    position: relative;
  }
  [data-headerimg-type=""]:not([data-main="wide"]):not([data-main-header="false"]):not([data-topslider="true"]):not([data-headerimg-img-sp="false"][data-headerimg-title-sp="false"][data-headerimg-desc-sp="false"][data-headerimg-item-sp="false"][data-headerimg-meta-sp="false"]) #main-header + #main > section:first-child::before {
    background: var(--clr-txtbody-bg, #fff);
    content: '';
    position: absolute;
    top: -16px;
    left: 0;
    width: 100%;
    height: 16px;
  }
  [data-headerimg-type=""]:not([data-main="wide"]):not([data-main-header="false"]):not([data-topslider="true"]):not([data-headerimg-img-sp="false"][data-headerimg-title-sp="false"][data-headerimg-desc-sp="false"][data-headerimg-item-sp="false"][data-headerimg-meta-sp="false"]) #main-header + #main > section:first-child:not([style]) {
    padding-top: 0;
  }
}
@media (min-width: 1025px) {
  [data-headerimg-type=""]:not([data-main="wide"]):not([data-main-header="false"]):not([data-topslider="true"]):not([data-headerimg-img="false"][data-headerimg-title="false"][data-headerimg-desc="false"][data-headerimg-item="false"][data-headerimg-meta="false"]) #main-header + #main > section:first-child {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
    margin-top: calc(clamp(calc(var(--padding-component) * -1), -4.44444vw, -16px) + clamp(16px, 4.44444vw, calc(var(--padding-component) / 2)));
    position: relative;
  }
  [data-headerimg-type=""]:not([data-main="wide"]):not([data-main-header="false"]):not([data-topslider="true"]):not([data-headerimg-img="false"][data-headerimg-title="false"][data-headerimg-desc="false"][data-headerimg-item="false"][data-headerimg-meta="false"]) #main-header + #main > section:first-child::before {
    background: var(--clr-txtbody-bg, #fff);
    content: '';
    position: absolute;
    top: -16px;
    left: 0;
    width: 100%;
    height: 16px;
  }
  [data-headerimg-type=""]:not([data-main="wide"]):not([data-main-header="false"]):not([data-topslider="true"]):not([data-headerimg-img="false"][data-headerimg-title="false"][data-headerimg-desc="false"][data-headerimg-item="false"][data-headerimg-meta="false"]) #main-header + #main > section:first-child:not([style]) {
    padding-top: 0;
  }
}
/* サムネイル画像 */
[data-headerimg-type="header"] #headerimg {
  background: #fff;
  border-radius: 32px;
  display: grid;
  overflow: hidden;
}
[data-headerimg-type="header"] .headerimg-img {
  grid-row: 1/2;
  grid-column: 1/2;
}
[data-headerimg-type="header"] .headerimg-inner {
  display: contents;
}
[data-headerimg-type="header"] .headerimg-item {
  display: flex;
  justify-content: center;
  align-items: center;
  grid-row: 1/2;
  grid-column: 1/2;
}
[data-headerimg-type="header"] .headerimg-item img {
  margin: clamp(16px, 4.44444vw, var(--padding-headerimg));
  max-width: calc(100% - calc(clamp(16px, 4.44444vw, var(--padding-headerimg)) * 2));
  max-height: calc(100% - calc(clamp(16px, 4.44444vw, var(--padding-headerimg)) * 2));
}
[data-headerimg-type="header"] .headerimg-txt {
  padding: clamp(16px, 4.44444vw, var(--padding-headerimg));
}
[data-headerimg-type="header"] .headerimg-title {
  flex-shrink: 0;
}

@media (max-width: 1024px) {
  [data-headerimg-type="header"]:not([data-headerimg-img-sp="false"]) .headerimg-item {
    height: var(--h-hdr-sp);
    overflow: hidden;
  }

  [data-headerimg-type="header"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-item-sp="false"]) .headerimg-img::before {
    display: block;
  }
}
@media (min-width: 1025px) {
  [data-headerimg-type="header"][data-headerimg-title="left"] #headerimg, [data-headerimg-type="header"][data-headerimg-title="right"] #headerimg, [data-headerimg-type="header"][data-headerimg-item="left"]:not([data-headerimg-title="center"]) #headerimg, [data-headerimg-type="header"][data-headerimg-item="right"]:not([data-headerimg-title="center"]) #headerimg {
    height: var(--h-hdr-pc);
  }
  [data-headerimg-type="header"][data-headerimg-title="left"] .headerimg-inner, [data-headerimg-type="header"][data-headerimg-title="right"] .headerimg-inner, [data-headerimg-type="header"][data-headerimg-item="left"]:not([data-headerimg-title="center"]) .headerimg-inner, [data-headerimg-type="header"][data-headerimg-item="right"]:not([data-headerimg-title="center"]) .headerimg-inner {
    display: flex;
    grid-row: 1/2;
    grid-column: 1/2;
    height: var(--h-hdr-pc);
  }
  [data-headerimg-type="header"][data-headerimg-title="left"] .headerimg-txt, [data-headerimg-type="header"][data-headerimg-title="right"] .headerimg-txt, [data-headerimg-type="header"][data-headerimg-item="left"]:not([data-headerimg-title="center"]) .headerimg-txt, [data-headerimg-type="header"][data-headerimg-item="right"]:not([data-headerimg-title="center"]) .headerimg-txt {
    width: 45%;
  }
  [data-headerimg-type="header"][data-headerimg-item="left"] .headerimg-item, [data-headerimg-type="header"][data-headerimg-item="right"] .headerimg-item {
    width: 55%;
    height: var(--h-hdr-pc);
  }

  [data-headerimg-type="header"]:not([data-headerimg-title="false"][data-headerimg-desc="false"][data-headerimg-meta="false"]):not([data-main-header*="wide"])[data-headerimg-title="left"] .headerimg-img, [data-headerimg-type="header"]:not([data-headerimg-title="false"][data-headerimg-desc="false"][data-headerimg-meta="false"]):not([data-main-header*="wide"])[data-headerimg-title="right"] .headerimg-img, [data-headerimg-type="header"]:not([data-headerimg-title="false"][data-headerimg-desc="false"][data-headerimg-meta="false"]):not([data-main-header*="wide"])[data-headerimg-item="left"]:not([data-headerimg-title="center"]) .headerimg-img, [data-headerimg-type="header"]:not([data-headerimg-title="false"][data-headerimg-desc="false"][data-headerimg-meta="false"]):not([data-main-header*="wide"])[data-headerimg-item="right"]:not([data-headerimg-title="center"]) .headerimg-img {
    width: 55%;
  }

  [data-headerimg-type="header"]:not([data-headerimg-item="false"]) .headerimg-img::before {
    display: block;
  }
}
/* ヘッダー画像 */
[data-main-header*="header"] #main-header {
  position: relative;
}
[data-main-header*="header"] #main-header::before {
  background-color: var(--clr-header-bg1, var(--clr-accent, #ffd400));
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 50%;
  margin: 0 calc(-50vw + 50%);
}
[data-main-header*="header"] #headerimg {
  position: relative;
}

@media (min-width: 1025px) {
  [data-main-header="header"] #headerimg {
    background: transparent;
    border-radius: 0;
  }
  [data-main-header="header"] .headerimg-img {
    border-radius: 32px;
    overflow: hidden;
  }
  [data-main-header="header"] .headerimg-txt {
    background: #fff;
    border-radius: 32px;
    margin-left: auto;
    margin-right: auto;
    width: calc(100% - var(--padding-overall));
  }

  [data-main-header="header"][data-headerimg-img="true"] .headerimg-txt {
    margin-top: -100px;
  }
  [data-main-header="header"][data-headerimg-img="true"][data-headerimg-title="center"] .headerimg-item img {
    margin-bottom: calc(clamp(16px, 4.44444vw, var(--padding-headerimg)) + 100px);
    max-height: calc(100% - calc(clamp(16px, 4.44444vw, var(--padding-headerimg)) + calc(clamp(16px, 4.44444vw, var(--padding-headerimg)) + 100px)));
  }

  [data-main-header="header"][data-headerimg-title="left"] .headerimg-txt, [data-main-header="header"][data-headerimg-title="right"] .headerimg-txt, [data-main-header="header"][data-headerimg-item="left"]:not([data-headerimg-title="center"]) .headerimg-txt, [data-main-header="header"][data-headerimg-item="right"]:not([data-headerimg-title="center"]) .headerimg-txt {
    margin-top: 3em;
    margin-bottom: 3em;
    align-self: center;
  }
  [data-main-header="header"][data-headerimg-item="left"]:not([data-headerimg-title="center"]) .headerimg-item, [data-main-header="header"][data-headerimg-item="right"]:not([data-headerimg-title="center"]) .headerimg-item {
    height: auto;
  }

  [data-main-header="header"]:not([data-headerimg-title="false"][data-headerimg-desc="false"][data-headerimg-meta="false"]):not([data-main-header*="wide"])[data-headerimg-title="left"] .headerimg-img, [data-main-header="header"]:not([data-headerimg-title="false"][data-headerimg-desc="false"][data-headerimg-meta="false"]):not([data-main-header*="wide"])[data-headerimg-title="right"] .headerimg-img, [data-main-header="header"]:not([data-headerimg-title="false"][data-headerimg-desc="false"][data-headerimg-meta="false"]):not([data-main-header*="wide"])[data-headerimg-item="left"]:not([data-headerimg-title="center"]) .headerimg-img, [data-main-header="header"]:not([data-headerimg-title="false"][data-headerimg-desc="false"][data-headerimg-meta="false"]):not([data-main-header*="wide"])[data-headerimg-item="right"]:not([data-headerimg-title="center"]) .headerimg-img {
    width: 74%;
  }
}
/* ヘッダー画像（ワイド） */
[data-main-header*="wide"] #headerimg {
  border-radius: 0;
}

@media (max-width: 1024px) {
  [data-main-header*="wide"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) #headerimg {
    height: var(--h-hdr-sp);
  }
  [data-main-header*="wide"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-inner {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 1em;
    grid-row: 1/2;
    grid-column: 1/2;
    padding: var(--padding-overall);
    height: var(--h-hdr-sp);
  }
  [data-main-header*="wide"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-item {
    height: auto;
  }
  [data-main-header*="wide"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-item img {
    margin: 0;
    max-width: 100%;
    max-height: 100%;
  }
  [data-main-header*="wide"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-txt {
    background: rgba(255, 255, 255, 0.94);
    border-radius: 32px;
    flex-shrink: 0;
  }
}
@media (min-width: 1025px) {
  [data-main-header*="wide"] #headerimg {
    background-color: var(--clr-header-bg1, var(--clr-accent, #ffd400));
    height: var(--h-hdr-pc);
  }
  [data-main-header*="wide"] .headerimg-inner {
    grid-row: 1/2;
    grid-column: 1/2;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-left: auto;
    margin-right: auto;
    padding: min(var(--padding-overall),72px) var(--padding-overall);
    max-width: calc(var(--width-overall) + calc(var(--padding-overall) * 2));
    width: 100%;
    height: var(--h-hdr-pc);
  }
  [data-main-header*="wide"] .headerimg-txt {
    background: rgba(255, 255, 255, 0.94);
    border-radius: 32px;
    margin-left: auto;
    margin-right: auto;
    width: 94%;
  }
}
/* ヘッダー画像（ヘッダーワイド+上部固定） */
@media (max-width: 1024px) {
  [data-header="fixed"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-inner {
    padding-top: calc(74px + var(--padding-overall));
  }
}
@media (min-width: 1025px) {
  [data-header="fixed"]:not([data-headerimg-img="false"]) .headerimg-inner {
    padding-top: calc(112px + min(var(--padding-overall),72px));
  }
}
/* ヘッダー画像 */
/* 非表示 */
[data-main-header="false"] #headerimg {
  display: none;
}

@media (min-width: 1025px) {
  [data-headerimg-img="false"] .headerimg-img {
    display: none;
  }
}
/* ヘッダーテキスト */
@media (min-width: 1025px) {
  /* 左揃え */
  [data-headerimg-title="left"][data-headerimg-type="header"]:not([data-main-header*="wide"]):not([data-headerimg-title="center"]) .headerimg-img {
    margin: 0 0 0 auto;
  }
  [data-headerimg-title="left"][data-headerimg-type="header"] .headerimg-txt {
    margin-left: 0;
    margin-right: auto;
  }

  /* 右揃え */
  [data-headerimg-title="right"][data-headerimg-type="header"]:not([data-main-header*="wide"]):not([data-headerimg-title="center"]) .headerimg-img {
    margin: 0 auto 0 0;
  }
  [data-headerimg-title="right"][data-headerimg-type="header"] .headerimg-txt {
    margin-left: auto;
    margin-right: 0;
  }

  /* 中央揃え */
  [data-headerimg-title="center"][data-main-header="header"] .headerimg-txt {
    margin-left: auto;
    margin-right: auto;
    max-width: 75%;
  }
  [data-headerimg-title="center"][data-main-header*="wide"] .headerimg-txt {
    margin-left: auto;
    margin-right: auto;
    max-width: 45%;
  }

  /* 非表示 */
  [data-headerimg-title="false"] .headerimg-title {
    display: none;
  }
}
/* 説明文 */
@media (min-width: 1025px) {
  /* 非表示 */
  [data-headerimg-desc="false"] .headerimg-desc {
    display: none;
  }
}
/* 画像アイテム */
@media (min-width: 1025px) {
  /* 左揃え */
  [data-headerimg-item="left"][data-headerimg-type="header"] .headerimg-item {
    margin: 0 auto 0 0;
  }
  [data-headerimg-item="left"][data-headerimg-type="header"]:not([data-headerimg-title="center"]) .headerimg-txt {
    margin-left: auto;
    margin-right: 0;
  }
  [data-headerimg-item="left"][data-headerimg-type="header"]:not([data-headerimg-title="false"][data-headerimg-desc="false"][data-headerimg-meta="false"]):not([data-main-header*="wide"]):not([data-headerimg-title="center"]) .headerimg-img {
    margin: 0 auto 0 0;
  }

  /* 右揃え */
  [data-headerimg-item="right"][data-headerimg-type="header"] .headerimg-item {
    margin: 0 0 0 auto;
  }
  [data-headerimg-item="right"][data-headerimg-type="header"] .headerimg-item {
    order: 1;
  }
  [data-headerimg-item="right"][data-headerimg-type="header"]:not([data-headerimg-title="center"]) .headerimg-txt {
    margin-left: 0;
    margin-right: auto;
  }
  [data-headerimg-item="right"][data-headerimg-type="header"]:not([data-headerimg-title="false"][data-headerimg-desc="false"][data-headerimg-meta="false"]):not([data-main-header*="wide"]):not([data-headerimg-title="center"]) .headerimg-img {
    margin: 0 0 0 auto;
  }

  /* 非表示 */
  [data-headerimg-item="false"] .headerimg-item {
    display: none;
  }
}
/* メタ */
@media (min-width: 1025px) {
  /* 非表示 */
  [data-headerimg-meta="false"] .headerimg-meta {
    display: none;
  }
}
/* スマホ設定
==================================================
*/
/* ヘッダー画像 */
@media (max-width: 1024px) {
  /* 非表示 */
  [data-headerimg-img-sp="false"] .headerimg-img {
    display: none;
  }
  [data-headerimg-img-sp="false"][data-headerimg-type="header"] .headerimg-inner {
    display: grid;
    gap: 2em;
    padding: clamp(16px, 4.44444vw, var(--padding-headerimg));
  }
  [data-headerimg-img-sp="false"][data-headerimg-type="header"] .headerimg-item img {
    margin: 0;
    max-width: 100%;
    max-height: 100%;
  }
  [data-headerimg-img-sp="false"][data-headerimg-type="header"] .headerimg-txt {
    padding: 0;
  }
  [data-headerimg-img-sp="false"][data-main-header*="wide"] .headerimg-inner {
    padding: var(--padding-overall);
  }
}
/* ヘッダーテキスト */
@media (max-width: 1024px) {
  /*画像下に表示 */
  [data-headerimg-title-sp="under"][data-main-header*="wide"]:not([data-headerimg-img-sp="false"]) .headerimg-txt {
    padding-left: var(--padding-overall);
    padding-right: var(--padding-overall);
  }

  [data-headerimg-title-sp="under"][data-header="fixed"]:not([data-headerimg-img-sp="false"]) .headerimg-item img {
    margin-top: calc(74px + clamp(16px, 4.44444vw, var(--padding-headerimg)));
  }

  /* 非表示 */
  [data-headerimg-title-sp="false"] .headerimg-title {
    display: none;
  }
}
/* 説明文 */
@media (max-width: 1024px) {
  /* 非表示 */
  [data-headerimg-desc-sp="false"] .headerimg-desc {
    display: none;
  }
}
/* 画像アイテム */
@media (max-width: 1024px) {
  /* 非表示 */
  [data-headerimg-item-sp="false"] .headerimg-item {
    display: none;
  }
}
/* メタ */
@media (max-width: 1024px) {
  /* 非表示 */
  [data-headerimg-meta-sp="false"] .headerimg-meta {
    display: none;
  }
}
/* 見出し
==================================================
*/
/* タイトル */
#whatsnew .title,
[class*='categorylist'] .title,
.entrylist-title,
.blogarea .title,
#searchresult .title,
.space-box > .title {
  font-size: clamp(2rem, 5.55555vw, 2.4rem);
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: var(--margin-component);
}
#whatsnew .title i,
[class*='categorylist'] .title i,
.entrylist-title i,
.blogarea .title i,
#searchresult .title i,
.space-box > .title i {
  font-size: 1.6rem;
  font-style: normal;
  margin-left: 1.25em;
  position: relative;
  top: -0.3rem;
}
#whatsnew .title i::before,
[class*='categorylist'] .title i::before,
.entrylist-title i::before,
.blogarea .title i::before,
#searchresult .title i::before,
.space-box > .title i::before {
  border-color: var(--clr-border, #deddd4);
  border-left-width: 1px;
  content: '';
  margin-right: 1.25em;
}

#whatsnew .title *:not(i),
.entrylist-title *:not(i),
.newentry-title *:not(i) {
  display: contents;
  font-size: inherit;
}
#whatsnew .title *:not(i)::before, #whatsnew .title *:not(i)::after,
.entrylist-title *:not(i)::before,
.entrylist-title *:not(i)::after,
.newentry-title *:not(i)::before,
.newentry-title *:not(i)::after {
  display: none;
}

#menu .space-box > .title,
#rmenu .space-box > .title,
#footer .space-box > .title {
  font-size: 1.8rem;
}

#menu .space-box > .title,
#rmenu .space-box > .title {
  background-color: var(--clr-menutitle-bg);
  color: var(--clr-menutitle-txt);
}

[data-color*="clr-menutitle-bg"] #menu .space-box > .title,
[data-color*="clr-menutitle-bg"] #rmenu .space-box > .title {
  border-radius: 16px;
  padding: .94444em 1.16666em;
}

#whatsnew .title,
[class*='categorylist'] .title,
.entrylist-title .title,
.blogarea .title,
#searchresult .title,
#main .space-box > .title {
  background-color: var(--clr-contenttitle-bg, transparent);
  color: var(--clr-contenttitle-txt, inherit);
}

[data-color*="clr-contenttitle-bg"] #whatsnew .title,
[data-color*="clr-contenttitle-bg"] [class*='categorylist'] .title,
[data-color*="clr-contenttitle-bg"] .entrylist-title .title,
[data-color*="clr-contenttitle-bg"] .blogarea .title,
[data-color*="clr-contenttitle-bg"] #searchresult .title,
[data-color*="clr-contenttitle-bg"] #main .space-box > .title {
  border-radius: 16px;
  padding: .70834em 1em;
}

[data-color*="clr-contenttitle-txt"] #whatsnew .title i::before,
[data-color*="clr-contenttitle-txt"] [class*='categorylist'] .title i::before,
[data-color*="clr-contenttitle-txt"] .entrylist-title .title i::before,
[data-color*="clr-contenttitle-txt"] .blogarea .title i::before,
[data-color*="clr-contenttitle-txt"] #searchresult .title i::before,
[data-color*="clr-contenttitle-txt"] #main .space-box > .title i::before {
  border-color: var(--clr-contenttitle-txt);
  opacity: .25;
}

.menubox > .title,
#pickupentry > .title,
.newentry-title {
  border-radius: 16px 16px 0 0;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.5;
  padding: .94444em 1.16666em;
}
.menubox > .title + .menulist > .sitemenu,
.menubox > .title + .menulist > #submenu:not([class="submenu-image"]),
.menubox > .title + .newentry,
#pickupentry > .title + .menulist > .sitemenu,
#pickupentry > .title + .menulist > #submenu:not([class="submenu-image"]),
#pickupentry > .title + .newentry,
.newentry-title + .menulist > .sitemenu,
.newentry-title + .menulist > #submenu:not([class="submenu-image"]),
.newentry-title + .newentry {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

.menubox > .title,
.newentry-title {
  background-color: var(--clr-menutitle-bg, var(--clr-main, #333));
  color: var(--clr-menutitle-txt, #fff);
}

#pickupentry > .title {
  background: var(--clr-accent, #ffd400);
  color: #333;
}

[data-color*="clr-accent"] #pickupentry > .title span {
  color: var(--clr-accent, #333);
  filter: invert(100%) grayscale(100%) contrast(100);
}

/* 見出し */
h1 {
  font-size: clamp(2rem, 5.55555vw, 2.8rem);
  font-weight: 700;
  line-height: 1.5;
  margin: 0 0 1.2em;
}

h2 {
  font-size: clamp(2rem, 5.55555vw, 2.8rem);
  font-weight: 700;
  line-height: 1.5;
  margin: 1em 0;
}
h2 i {
  font-size: .6em;
  display: block;
  font-style: normal;
}

h3 {
  font-size: clamp(1.9rem, 5.27777vw, 2.4rem);
  font-weight: 700;
  line-height: 1.5;
  margin: 1em 0;
}

h4 {
  font-size: clamp(1.8rem, 5vw, 2.2rem);
  font-weight: 700;
  line-height: 1.5;
  margin: 0.8em 0;
}

h5 {
  font-size: clamp(1.7rem, 4.72222vw, 2rem);
  font-weight: 700;
  line-height: 1.5;
  margin: 0.8em 0;
}

h6 {
  font-size: clamp(1.6rem, 4.44444vw, 1.8rem);
  font-weight: 700;
  line-height: 1.5;
  margin: 0.8em 0;
}

/* 見出しデザイン */
#main h1 {
  padding-bottom: .8em;
  position: relative;
}
#main h1::after {
  background: #eaeaea;
  content: '';
  border-radius: 10px;
  height: 4px;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
}

h2:not([class*="topic"]) {
  background-color: var(--clr-articletitle-bg, var(--clr-accent, #ffd400));
  color: var(--clr-articletitle-txt, #333);
  border-radius: 16px;
  margin-top: 2em;
  padding: .67856em 1em;
}
h2:not([class*="topic"]) i {
  margin-bottom: .1em;
}

#main section > h2:not([class*="topic"]) {
  margin-top: 0;
}

[data-column="col1"][data-main="wide"] h2:not([class*="topic"]) {
  background: transparent;
  border-radius: 0;
  font-size: clamp(2.2rem, 6.11111vw, 3rem);
  padding: 0;
  text-align: center;
}
[data-column="col1"][data-main="wide"] h2:not([class*="topic"]) i {
  color: var(--clr-accent, #ffd400);
}

h3:not([class*="topic"]) {
  margin-top: 2em;
  padding-bottom: .66666em;
  position: relative;
}
h3:not([class*="topic"])::before {
  background: var(--clr-accent, #ffd400);
  border-radius: .16666em;
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: .16666em;
}

.top_inner h3 {
  margin-top: unset;
  padding-bottom: unset;
  position: static;
}
.top_inner h3::before {
  display: none;
}

h4:not([class*="topic"]) {
  padding-left: .9091em;
  position: relative;
}
h4:not([class*="topic"])::before {
  background: var(--clr-accent, #ffd400);
  border-radius: .27272em;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: .27272em;
}

h5:not([class*="topic"]) {
  position: relative;
  padding-left: 1em;
}
h5:not([class*="topic"])::before {
  background: var(--clr-accent, #ffd400);
  border-radius: .2em;
  content: '';
  position: absolute;
  top: .45em;
  left: 0;
  width: .6em;
  height: .6em;
}

h6:not([class*="topic"]) {
  padding-left: 1em;
  position: relative;
}
h6:not([class*="topic"])::before {
  background: var(--clr-accent, #ffd400);
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%208.512%2010.323%22%3E%3Cpath%20d%3D%22M7.659%203.524a2%202%200%200%201%200%203.277L3.147%209.962A2%202%200%200%201%200%208.321V2A2%202%200%200%201%203.147.362Z%22%2F%3E%3C%2Fsvg%3E") no-repeat center left/0.5em auto;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%208.512%2010.323%22%3E%3Cpath%20d%3D%22M7.659%203.524a2%202%200%200%201%200%203.277L3.147%209.962A2%202%200%200%201%200%208.321V2A2%202%200%200%201%203.147.362Z%22%2F%3E%3C%2Fsvg%3E") no-repeat center left/0.5em auto;
  content: '';
  display: block;
  position: absolute;
  top: .2778em;
  left: 0;
  width: 1em;
  height: 1em;
}

/* リスト
==================================================
*/
ul:not([id]):not([class]),
ol:not([id]):not([class]) {
  line-height: 1.5;
  margin-top: var(--margin-component);
  margin-bottom: var(--margin-component);
}
ul:not([id]):not([class]) li,
ol:not([id]):not([class]) li {
  margin: 0.8em 0;
}

ol:not([id]):not([class]) li::marker {
  font-size: 1.8rem;
  font-family: 'Manrope', sans-serif;
  font-weight: 700;
  line-height: 1;
}

/*
==================================================
最新記事
==================================================
*/
ul.newentry {
  background: #fff;
  border-radius: 16px;
  display: grid;
  flex-direction: column;
  grid-template-columns: repeat(auto-fill, minmax(min(100%,320px), 1fr));
  gap: 0 1.25em;
  padding: 0 1.25em;
  overflow: hidden;
}
ul.newentry li {
  margin: 0 0 -1px;
  padding: 1.5em 0;
  position: relative;
}
ul.newentry li::after {
  border-bottom-color: #f1f1f1;
  border-bottom-width: 1px;
  content: '';
  position: absolute;
  left: -1.25em;
  right: -1.25em;
  bottom: 0;
}

.newentry .article .cat a {
  background-color: transparent;
  line-height: 1;
  padding: 0;
}
.newentry .article-inner {
  display: flex;
  align-items: center;
  gap: .8em;
}
.newentry .article-thumb {
  flex-shrink: 0;
  border-radius: 16px;
  overflow: hidden;
  width: 100px;
}
.newentry .article-thumb img {
  width: 100%;
  aspect-ratio: 25 / 18;
  object-fit: cover;
}
.newentry .article-body {
  display: flex;
  flex-direction: column;
  gap: .4em;
  flex-grow: 1;
}
.newentry .article-title {
  color: inherit;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.4;
}
.newentry .article-title a {
  color: inherit;
  text-decoration: none;
}
.newentry .article-info {
  display: flex;
  align-items: center;
  gap: 8px;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  .newentry .article-inner,
  .newentry .article-thumb img {
    transition: all .2s ease;
  }
  .newentry .article:hover .article-inner {
    opacity: .7;
  }
  .newentry .article:hover .article-thumb img {
    transform: scale(1.1);
  }
}
/* ページリスト
==================================================
*/
.pagelist_ul {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: .5em;
  line-height: 1;
}
.pagelist_ul li {
  background: var(--clr-accent, #ffd400);
  color: #333;
  border-radius: 40px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 2rem;
  width: 40px;
  height: 40px;
  overflow: hidden;
}
.pagelist_ul li.current {
  background: var(--clr-main, #333);
  color: #fff;
}
.pagelist_ul li.prev {
  margin-right: .5em;
}
.pagelist_ul li.next {
  margin-left: .5em;
}
.pagelist_ul a {
  color: inherit;
  display: flex;
  justify-content: center;
  align-items: center;
  text-decoration: none;
  width: 100%;
  height: 100%;
}

[data-color*="clr-accent"] .pagelist_ul a {
  color: var(--clr-accent, inherit);
  filter: invert(100%) grayscale(100%) contrast(100);
}

/* ホバーアクション */
@media (min-width: 1025px) {
  .pagelist_ul li {
    transition: 0.2s;
  }
  .pagelist_ul li:hover {
    background: var(--clr-main, #333);
    color: #fff;
  }

  [data-color*="clr-accent"] .pagelist_ul li:hover a {
    color: inherit;
    filter: none;
  }
}
/* ナビゲーション（前後の記事）
==================================================
*/
#relNavigate {
  display: grid;
  gap: 2em;
  grid-template-columns: repeat(auto-fit, minmax(min(100%,300px), 1fr));
}
#relNavigate a {
  color: inherit;
  display: flex;
  align-items: center;
  gap: 1em;
  overflow: hidden;
  text-decoration: none;
  position: relative;
}

.relNavigate-prev::before {
  background-color: #333;
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2022%2019.779%22%3E%3Cpath%20d%3D%22M8.364.586.586%208.364A1.991%201.991%200%200%200%200%209.835v.109a1.991%201.991%200%200%200%20.586%201.471l7.778%207.778a2%202%200%200%200%202.828-2.828L6.717%2011.89H20a2%202%200%201%200%200-4H6.717l4.475-4.476A2%202%200%201%200%208.364.586%22%2F%3E%3C%2Fsvg%3E") no-repeat center/12px auto;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2022%2019.779%22%3E%3Cpath%20d%3D%22M8.364.586.586%208.364A1.991%201.991%200%200%200%200%209.835v.109a1.991%201.991%200%200%200%20.586%201.471l7.778%207.778a2%202%200%200%200%202.828-2.828L6.717%2011.89H20a2%202%200%201%200%200-4H6.717l4.475-4.476A2%202%200%201%200%208.364.586%22%2F%3E%3C%2Fsvg%3E") no-repeat center/12px auto;
  border-radius: 34px;
  content: '';
  display: block;
  position: relative;
  flex-shrink: 0;
  width: 34px;
  height: 34px;
  z-index: 1;
}
.relNavigate-prev::after {
  background-color: #fff;
  border-radius: 34px;
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  margin-top: -17px;
  width: 34px;
  height: 34px;
}

.relNavigate-next::before {
  background-color: #fff;
  border-radius: 34px;
  content: '';
  position: absolute;
  right: 0;
  top: 50%;
  margin-top: -17px;
  width: 34px;
  height: 34px;
}
.relNavigate-next::after {
  background-color: #333;
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2022.001%2019.778%22%3E%3Cpath%20d%3D%22m13.636%2019.168%207.778-7.778A1.994%201.994%200%200%200%2022%209.919V9.81a1.994%201.994%200%200%200-.586-1.471L13.636.561a2%202%200%200%200-2.828%202.828l4.475%204.475H2a2%202%200%200%200%200%204h13.283l-4.475%204.476a2%202%200%201%200%202.779%202.877l.049-.049%22%2F%3E%3C%2Fsvg%3E") no-repeat center/12px auto;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2022.001%2019.778%22%3E%3Cpath%20d%3D%22m13.636%2019.168%207.778-7.778A1.994%201.994%200%200%200%2022%209.919V9.81a1.994%201.994%200%200%200-.586-1.471L13.636.561a2%202%200%200%200-2.828%202.828l4.475%204.475H2a2%202%200%200%200%200%204h13.283l-4.475%204.476a2%202%200%201%200%202.779%202.877l.049-.049%22%2F%3E%3C%2Fsvg%3E") no-repeat center/12px auto;
  border-radius: 34px;
  content: '';
  display: block;
  position: relative;
  flex-shrink: 0;
  margin-left: auto;
  width: 34px;
  height: 34px;
  z-index: 1;
}

.relNavigate-thumb {
  flex-shrink: 0;
  border-radius: 16px;
  overflow: hidden;
  width: 120px;
}
.relNavigate-thumb img {
  width: 100%;
  aspect-ratio: 5 / 3;
  object-fit: cover;
}

.relNavigate-caption {
  display: none;
}

.relNavigate-title {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.5;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  #relNavigate a,
  #relNavigate a::before,
  #relNavigate a::after,
  #relNavigate .relNavigate-thumb img {
    transition: .2s ease;
  }
  #relNavigate a:hover {
    opacity: .7;
  }
  #relNavigate a:hover::before, #relNavigate a:hover::after {
    transform: scale(0.9);
  }
  #relNavigate a:hover .relNavigate-thumb img {
    transform: scale(1.1);
  }
}
/*
==================================================
ページトップ
==================================================
*/
#pagetop {
  position: fixed;
  bottom: 15px;
  right: 10px;
  transition: opacity .5s ease, visibility .5s ease;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  z-index: 99;
}
#pagetop a {
  background-color: var(--clr-pagetop-bg, #fff);
  border-radius: 50%;
  display: block;
  position: relative;
  width: 60px;
  height: 60px;
}
#pagetop a::before {
  background-color: var(--clr-pagetop-icon, #333);
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2019.778%2022.001%22%3E%3Cpath%20d%3D%22M19.168%208.365%2011.39.587A1.994%201.994%200%200%200%209.919%200H9.81a1.994%201.994%200%200%200-1.471.587L.561%208.365a2%202%200%200%200%202.828%202.828l4.475-4.475V20a2%202%200%200%200%204%200V6.718l4.476%204.475a2%202%200%201%200%202.877-2.779%201.132%201.132%200%200%200-.049-.049%22%2F%3E%3C%2Fsvg%3E") no-repeat center/20px auto;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2019.778%2022.001%22%3E%3Cpath%20d%3D%22M19.168%208.365%2011.39.587A1.994%201.994%200%200%200%209.919%200H9.81a1.994%201.994%200%200%200-1.471.587L.561%208.365a2%202%200%200%200%202.828%202.828l4.475-4.475V20a2%202%200%200%200%204%200V6.718l4.476%204.475a2%202%200%201%200%202.877-2.779%201.132%201.132%200%200%200-.049-.049%22%2F%3E%3C%2Fsvg%3E") no-repeat center/20px auto;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
#pagetop.show {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  #pagetop a {
    transition: 0.2s;
  }
  #pagetop a:hover {
    opacity: .8;
    transform: scale(0.95);
  }
}
/*
==================================================
人気の記事
==================================================
*/
/* カウンター */
#pickupentry {
  counter-reset: pickuprank;
}

.pickup_rank {
  counter-increment: pickuprank;
}

.title + [id^="pickup_list"] {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

ul[id^="pickup_list"] {
  background: #fff;
  border-radius: 16px;
  display: grid;
  gap: 0 1.25em;
  padding: 0 1.25em;
  overflow: hidden;
}
ul[id^="pickup_list"] li {
  margin: 0 0 -1px;
  padding: 1.5em 0;
  position: relative;
}
ul[id^="pickup_list"] li::after {
  border-bottom-color: #f1f1f1;
  border-bottom-width: 1px;
  content: '';
  position: absolute;
  left: -1.25em;
  right: -1.25em;
  bottom: 0;
}

[id*="pickup_list"] .article-inner {
  display: flex;
  align-items: center;
  gap: .5em .8em;
}
[id*="pickup_list"] .article-thumb {
  flex-shrink: 0;
  border-radius: 16px;
  overflow: hidden;
  width: 100px;
}
[id*="pickup_list"] .article-thumb img {
  width: 100%;
  aspect-ratio: 25 / 18;
  object-fit: cover;
}
[id*="pickup_list"] .article-body {
  display: flex;
  flex-direction: column;
  gap: .4em;
  flex-grow: 1;
  max-width: 100%;
}
[id*="pickup_list"] .article-title {
  color: inherit;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.4;
}
[id*="pickup_list"] .article-title a {
  color: inherit;
  text-decoration: none;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  #pickupentry .article-inner,
  #pickupentry .article-thumb img {
    transition: all .2s ease;
  }
  #pickupentry .article:hover .article-inner {
    opacity: .7;
  }
  #pickupentry .article:hover .article-thumb img {
    transform: scale(1.1);
  }
}
/* ランキング
==================================================
*/
.pickup_rank {
  position: relative;
}
.pickup_rank::before {
  background: #e6e6e6;
  border: 2px solid #fff;
  border-radius: 50%;
  color: #333;
  content: counter(pickuprank);
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: 'Manrope', sans-serif;
  font-weight: 700;
  line-height: 1;
  position: absolute;
  left: -.8em;
  top: .5em;
  z-index: 2;
}
.pickup_rank.pickup_1::before, .pickup_rank.pickup_2::before, .pickup_rank.pickup_3::before {
  background: #ffd400;
}

/* デザイン01
==================================================
*/
[id="pickup_list1"] {
  grid-template-columns: repeat(auto-fill, minmax(min(100%,320px), 1fr));
}
[id="pickup_list1"] .pickup_rank::before {
  font-size: 1.5rem;
  width: 32px;
  height: 32px;
}

/* デザイン02
==================================================
*/
[id="pickup_list2"] {
  grid-template-columns: repeat(auto-fill, minmax(min(100%,320px), 1fr));
}
[id="pickup_list2"] .pickup_rank::before {
  font-size: 1.8rem;
  width: 40px;
  height: 40px;
}
[id="pickup_list2"] .article-inner {
  flex-direction: column;
  align-items: stretch;
}
[id="pickup_list2"] .article-thumb {
  width: 100%;
}
[id="pickup_list2"] .article-thumb img {
  aspect-ratio: 130 / 69;
}

/*
==================================================
ポイント
==================================================
*/
.point[data-point] {
  font-size: 1.375em;
  line-height: 1.5;
  margin: var(--margin-component) 0;
}
.point[data-point]::before {
  content: attr(data-point);
  color: #ffce00;
  font-family: 'Manrope', sans-serif;
  font-size: 1.54545em;
  font-weight: 700;
  line-height: 1;
  margin-right: .29412em;
  float: left;
  position: relative;
  top: -.05881em;
}
.point[data-point]::after {
  content: '';
  display: block;
  clear: both;
}

/*
==================================================
記事いいねシェアボタン
==================================================
*/
.postlike {
  background: #fff;
  border-radius: 16px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%,280px), 1fr));
  overflow: hidden;
}

.postlike-thumb {
  position: relative;
  min-height: 240px;
}
.postlike-thumb img {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  object-fit: cover;
}

.postlike-body {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 20px;
  line-height: 1.5;
}

.postlike-txt {
  font-size: clamp(1.3rem, 3vw, 2rem);
  font-weight: 700;
  text-align: center;
  margin-bottom: 0.5em;
}

.postlike-btns {
  margin-bottom: 1em;
}
.postlike-btns > div {
  margin: 3px 8px;
}

.quote::before {
  content: '\201c';
  opacity: .6;
}
.quote::after {
  content: '\201d';
  opacity: .6;
}

.postlike-caption {
  font-size: 1.3rem;
  opacity: .5;
}

/* プロフィール
==================================================
*/
.profile {
  container-type: inline-size;
}

.profile-inner {
  display: flex;
  flex-direction: column;
  gap: 20px 0;
}
.profile-inner .snsbox {
  justify-content: center;
  margin: 0;
}

.profile-body {
  display: flex;
  flex-direction: column;
  gap: .5em 0;
}

.profile-img {
  text-align: center;
}
.profile-img img {
  border-radius: 50%;
  width: 260px;
  height: 260px;
  object-fit: cover;
}

.profile-title {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1;
  text-align: center;
}

.profile-desc {
  font-size: 1.2rem;
  line-height: 1.7;
}

/* リサイズ */
@container (min-width: 640px) {
  .profile-inner {
    background: #fff;
    border-radius: 16px;
    padding: 3em;
    flex-direction: row;
    gap: 0 2em;
  }
  .profile-inner .snsbox {
    justify-content: flex-start;
  }

  .profile-img {
    flex-shrink: 0;
  }
  .profile-img img {
    width: 112px;
    height: 112px;
  }

  .profile-title {
    text-align: left;
  }
}
/* Q&A
==================================================
*/
[class^="question"]::before {
  content: "Q";
}

[class^="answer"]::before {
  content: "A";
}

[class^="question"],
[class^="answer"] {
  border: none;
  font-size: 1em;
}
[class^="question"]::before,
[class^="answer"]::before {
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: 'Manrope', sans-serif;
  font-weight: 700;
  position: absolute;
  left: 0;
  top: 0;
  width: 1.75em;
  height: 1.75em;
}

/* デザイン1 */
.question1,
.answer1 {
  margin: var(--margin-component) 0;
  padding: 0.3em 0 0 3.4em;
  position: relative;
  min-height: 2.625em;
}
.question1::before,
.answer1::before {
  border-radius: 2em;
  color: #fff;
  font-size: 1.5em;
}

.question1::before {
  background-color: #519aef;
}

.answer1::before {
  background-color: #f56068;
}

/* デザイン2 */
.question2,
.answer2 {
  padding: .5em 0 .5em 3.4em;
  position: relative;
  min-height: 2.625em;
}
.question2::before,
.answer2::before {
  font-size: 1.625em;
}

.question2::before {
  color: #519aef;
}

.answer2::before {
  color: #f56068;
}

/* FAQリスト */
.qa-list {
  margin: var(--margin-component) 0;
}

.qa-accordion {
  background: #fff;
  border: 3px solid #f4f5f8;
  border-radius: 16px;
  margin: .25em 0;
  overflow: hidden;
}
.qa-accordion .question2,
.qa-accordion .answer2 {
  padding: 1.5em 1.5em 1.5em 4em;
}
.qa-accordion .question2::before,
.qa-accordion .answer2::before {
  top: .6154em;
  left: .57691em;
}
.qa-accordion .question2 {
  background: #f4f5f8;
  padding-right: 72px;
}
.qa-accordion .question2::after {
  background-color: #fff;
  background-image: url(img/icon_add.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 14px auto;
  border-radius: 50%;
  content: '';
  position: absolute;
  top: 1.5625em;
  right: 22px;
  width: 30px;
  height: 30px;
  cursor: pointer;
}
.qa-accordion .question2 + .answer2 {
  display: none;
}
.qa-accordion .question2.show::after {
  background-image: url(img/icon_remove.svg);
}
.qa-accordion .question2.show + .answer2 {
  display: block;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  .qa-accordion .question2::after {
    transition: 0.2s;
  }
  .qa-accordion .question2:hover::after {
    transition: 0.2s;
    opacity: 0.5;
  }
}
/* ランキングリスト
==================================================
*/
.ranklist {
  margin: var(--margin-component) 0;
}
.ranklist li {
  border-style: dashed;
  border-bottom-width: 1px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0 1em;
  padding: .5em 0;
}
.ranklist li:first-child {
  border-top-width: 1px;
}

/* ランキング
==================================================
*/
.rank[data-rank] {
  font-size: clamp(1.6rem, 4.44444vw, 1.8rem);
  font-weight: 700;
  line-height: 1.5;
  margin: .5em 0;
}
.rank[data-rank]::before {
  color: #c5c7cb;
  content: attr(data-rank);
  font-family: 'Manrope', sans-serif;
  font-size: 1.55555em;
  font-weight: 700;
  line-height: 1;
  float: left;
  margin-right: .2143em;
  min-width: .5959em;
  position: relative;
  margin-top: -.07142em;
}
.rank[data-rank][data-rank='1']::before {
  color: #efb141;
}
.rank[data-rank][data-rank='2']::before {
  color: #a5b2ba;
}
.rank[data-rank][data-rank='3']::before {
  color: #b17757;
}
.rank[data-rank]::after {
  content: '';
  display: block;
  clear: both;
}

/* ランキングボックス
==================================================
*/
.rankbox {
  margin: 1.5em 0;
}
.rankbox .rank[data-rank] {
  font-size: clamp(2rem, 5.55555vw, 2.6rem);
  margin: 0;
  padding: .6923em 1em;
  display: grid;
  align-items: center;
  grid-template-columns: auto 1fr;
  grid-template-rows: 1fr auto;
}
.rankbox .rank[data-rank]::before {
  font-size: 2.692306em;
  margin-top: -.14286em;
  min-width: auto;
  grid-column: 1 / 2;
  grid-row: 1 / 3;
  align-self: start;
}
.rankbox .rank[data-rank] a {
  color: inherit;
  text-decoration: none;
  grid-column: 2 / 3;
}
.rankbox .rank[data-rank] i {
  display: block;
  font-size: 1.2rem;
  font-style: normal;
  line-height: 1;
  grid-column: 2 / 3;
  grid-row: 1 / 2;
}

.rankbox-container {
  background: #faf8f0;
  border-radius: 32px;
  padding: 10px;
}

.rankbox-contents {
  background: #fff;
  border-radius: 32px;
  padding: clamp(16px, 4.44444vw, 24px);
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 4.44444vw, 24px) 0;
}

.rankbox-details {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%,280px), 1fr));
  gap: clamp(16px, 4.44444vw, 24px);
}

.rankbox-desc {
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 4.44444vw, 24px) 0;
}

.rankbox-rate {
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 4.44444vw, 24px);
  align-items: center;
}
.rankbox-rate > * {
  width: 100%;
}

/* ランク画像 */
.rankbox-img {
  margin: 0 auto;
  text-align: center;
  max-width: 100%;
  width: 100%;
}
.rankbox-img img {
  margin: 0 auto 0.5em;
}

/* ランク見出し */
.rankbox-stitle {
  font-size: clamp(1.6rem, 4.44444vw, 1.8rem);
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: .5em;
}

/* 評価 */
.rankbox-rateoverall {
  display: flex;
  flex-direction: column;
  gap: 0.2em;
  align-items: center;
}
.rankbox-rateoverall .rankbox-stitle {
  margin-bottom: 0;
}
.rankbox-rateoverall .rate {
  font-size: 3rem;
}

.rate-unit {
  font-size: 1.2rem;
  opacity: .5;
}

/* 金額 */
.rankbox-price {
  font-size: 1.4rem;
  line-height: 1;
}
.rankbox-price b {
  font-family: 'Manrope', sans-serif;
  font-size: 1.714285em;
  font-weight: 700;
}

/* 備考 */
.rankbox-notes {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .25em;
}
.rankbox-notes span {
  background-color: #12B4E0;
  border-radius: 100px;
  color: #fff;
  display: block;
  font-size: 1.2rem;
  line-height: 1;
  padding: .66666em .8333em;
}

/* 説明文1 特徴 */
.feature .feature-body {
  font-size: .875em;
  line-height: 1.6;
}

/* フリーテキスト */
/* 説明文2 総評 */
.comment {
  background: #fffcea;
  border: 3px solid #ffd400;
  border-radius: 16px;
}
.comment .comment-tit {
  background: #ffd400;
  border-radius: 12px 12px 0 0;
  color: #333;
  font-size: clamp(1.6rem, 4.44444vw, 1.8rem);
  font-weight: 700;
  line-height: 1.5;
  padding: 1.11111em 1.44444em;
}
.comment .comment-body {
  font-size: .875em;
  line-height: 1.6;
  padding: 1.85714em;
}

/* ボタン */
.rankbox-more {
  text-align: center;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%,300px), 1fr));
  gap: 1em;
}
.rankbox-more a {
  background-color: #588eed;
  background-image: url(img/brn_arrow.svg);
  background-position: center right 28px;
  background-repeat: no-repeat;
  background-size: 16px auto;
  box-shadow: 0.2em 0.2em 0 rgba(0, 0, 0, 0.08);
  border-radius: 100px;
  color: #fff;
  display: block;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
  padding: 1.2em 2.5em;
  text-decoration: none;
}

/* ボタン 詳細ページはこちら */
.rankbox-more .detail a {
  background-color: #2ab3b6;
}

/* ボタン 公式ページはこちら */
.rankbox-more .official a {
  background-color: #ffa412;
}

@media (min-width: 1025px) {
  .rankbox-more a {
    transition: 0.2s;
  }
  .rankbox-more a:hover {
    opacity: .7;
  }
}
/* 画像スライダー（メインコンテンツ用ランキング）
==================================================
*/
.rankbox-slider img {
  margin: 0;
  object-fit: cover;
}
.rankbox-slider > div:not(:first-child):not([class]) {
  display: none;
}
.rankbox-slider .crl-d {
  display: flex;
  margin-top: .5em;
  gap: 0.5em;
}
.rankbox-slider .crl-d-ctl {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: 0;
  border-radius: 0;
  font: inherit;
  outline: none;
  padding: 0;
  position: relative;
  width: 60px;
  height: 66px;
  transition: .2s ease;
}
.rankbox-slider .crl-d-ctl img {
  width: 100%;
  height: 100%;
  mix-blend-mode: multiply;
}
.rankbox-slider .selected {
  opacity: 1;
  background: rgba(0, 0, 0, 0.3);
}

.rslide-wrap {
  position: relative;
}

@media (max-width: 1024px) {
  .rankbox-slider .crl-d {
    justify-content: center;
  }
}
/* 前後スライドボタン */
.rslide-arrow {
  opacity: 0;
  transition: opacity 0.3s ease;
}
.rslide-arrow .prev,
.rslide-arrow .next {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: 0;
  font: inherit;
  outline: none;
  padding: 0;
  background-color: #fff;
  border-radius: 50%;
  display: block;
  width: 32px;
  height: 32px;
  margin: 0 10px;
  text-indent: 200%;
  white-space: nowrap;
  overflow: hidden;
  position: absolute;
  top: 50%;
  margin-top: -16px;
  z-index: 1;
}
.rslide-arrow .prev::before,
.rslide-arrow .next::before {
  background-color: #333;
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2022.001%2019.778%22%3E%3Cpath%20d%3D%22m13.636%2019.168%207.778-7.778A1.994%201.994%200%200%200%2022%209.919V9.81a1.994%201.994%200%200%200-.586-1.471L13.636.561a2%202%200%200%200-2.828%202.828l4.475%204.475H2a2%202%200%200%200%200%204h13.283l-4.475%204.476a2%202%200%201%200%202.779%202.877l.049-.049%22%2F%3E%3C%2Fsvg%3E") no-repeat center/11px auto;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2022.001%2019.778%22%3E%3Cpath%20d%3D%22m13.636%2019.168%207.778-7.778A1.994%201.994%200%200%200%2022%209.919V9.81a1.994%201.994%200%200%200-.586-1.471L13.636.561a2%202%200%200%200-2.828%202.828l4.475%204.475H2a2%202%200%200%200%200%204h13.283l-4.475%204.476a2%202%200%201%200%202.779%202.877l.049-.049%22%2F%3E%3C%2Fsvg%3E") no-repeat center/11px auto;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
}
.rslide-arrow .prev {
  left: 0;
}
.rslide-arrow .prev::before {
  transform: scale(-1, 1);
}
.rslide-arrow .next {
  right: 0;
}

.rankbox-slider:hover .rslide-arrow {
  opacity: 1;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  .rslide-arrow .prev,
  .rslide-arrow .next {
    transition: .2s ease;
  }
  .rslide-arrow .prev:hover,
  .rslide-arrow .next:hover {
    transform: scale(0.9);
  }
}
/* ランキング（サイド用）
==================================================
*/
.rankside {
  display: inline-block;
  font-size: 1.4rem;
  line-height: 1.5;
  max-width: 100%;
}
.rankside img {
  margin-bottom: var(--margin-component);
}

/* 評価（スター）
==================================================
*/
.rate {
  display: inline-flex;
  gap: 0 0.5em;
  align-items: center;
  flex-shrink: 0;
}
.rate::before {
  background-position: 0 center, calc(1em * 1) center, calc(1em * 2) center, calc(1em * 3) center, calc(1em * 4) center;
  background-repeat: no-repeat;
  background-size: 1em auto;
  content: '';
  display: inline-block;
  width: calc(1em * 5);
  height: 1em;
}
.rate.rate-mini::before {
  background-image: url(img/star1.svg);
  width: 1em;
}
.rate.rate-numonly::before {
  display: none;
}
.rate.rate-num::after {
  font-family: 'Manrope', sans-serif;
  font-size: 1.1875em;
  font-style: normal;
  font-weight: 700;
  line-height: 1;
  min-width: 1.47368em;
  text-align: center;
}
.rate.rate-mini::after {
  min-width: .63157em;
}
.rate.rate0::before {
  background-image: url(img/star_empty.svg), url(img/star_empty.svg), url(img/star_empty.svg), url(img/star_empty.svg), url(img/star_empty.svg);
}
.rate.rate0.rate-num::after {
  content: '0';
}
.rate.rate0_5::before {
  background-image: url(img/star1_half.svg), url(img/star_empty.svg), url(img/star_empty.svg), url(img/star_empty.svg), url(img/star_empty.svg);
}
.rate.rate0_5.rate-num::after {
  content: '0.5';
}
.rate.rate1::before {
  background-image: url(img/star1.svg), url(img/star_empty.svg), url(img/star_empty.svg), url(img/star_empty.svg), url(img/star_empty.svg);
}
.rate.rate1.rate-num::after {
  content: '1.0';
}
.rate.rate1.rate-mini::after {
  content: '1';
}
.rate.rate1_5::before {
  background-image: url(img/star1.svg), url(img/star2_half.svg), url(img/star_empty.svg), url(img/star_empty.svg), url(img/star_empty.svg);
}
.rate.rate1_5.rate-num::after {
  content: '1.5';
}
.rate.rate2::before {
  background-image: url(img/star1.svg), url(img/star2.svg), url(img/star_empty.svg), url(img/star_empty.svg), url(img/star_empty.svg);
}
.rate.rate2.rate-num::after {
  content: '2.0';
}
.rate.rate2.rate-mini::after {
  content: '2';
}
.rate.rate2_5::before {
  background-image: url(img/star1.svg), url(img/star2.svg), url(img/star3_half.svg), url(img/star_empty.svg), url(img/star_empty.svg);
}
.rate.rate2_5.rate-num::after {
  content: '2.5';
}
.rate.rate3::before {
  background-image: url(img/star1.svg), url(img/star2.svg), url(img/star3.svg), url(img/star_empty.svg), url(img/star_empty.svg);
}
.rate.rate3.rate-num::after {
  content: '3.0';
}
.rate.rate3.rate-mini::after {
  content: '3';
}
.rate.rate3_5::before {
  background-image: url(img/star1.svg), url(img/star2.svg), url(img/star3.svg), url(img/star4_half.svg), url(img/star_empty.svg);
}
.rate.rate3_5.rate-num::after {
  content: '3.5';
}
.rate.rate4::before {
  background-image: url(img/star1.svg), url(img/star2.svg), url(img/star3.svg), url(img/star4.svg), url(img/star_empty.svg);
}
.rate.rate4.rate-num::after {
  content: '4.0';
}
.rate.rate4.rate-mini::after {
  content: '4';
}
.rate.rate4_5::before {
  background-image: url(img/star1.svg), url(img/star2.svg), url(img/star3.svg), url(img/star4.svg), url(img/star5_half.svg);
}
.rate.rate4_5.rate-num::after {
  content: '4.5';
}
.rate.rate5::before {
  background-image: url(img/star1.svg), url(img/star2.svg), url(img/star3.svg), url(img/star4.svg), url(img/star5.svg);
}
.rate.rate5.rate-num::after {
  content: '5.0';
}
.rate.rate5.rate-mini::after {
  content: '5';
}

/* スクロール
==================================================
*/
/* 横向き */
.scroll-table .scroll-area {
  position: relative;
  overflow-x: auto;
  overflow-y: hidden;
  white-space: nowrap;
  padding-bottom: 8px;
}
.scroll-table .scroll-area > * {
  margin: 0;
}

.scroll-area::-webkit-scrollbar {
  width: 8px;
}

.scroll-area::-webkit-scrollbar:horizontal {
  height: 8px;
}

.scroll-area::-webkit-scrollbar-track {
  background-color: rgba(0, 0, 0, 0.07);
  border-radius: 12px;
}

.scroll-area::-webkit-scrollbar-thumb {
  background-color: rgba(0, 0, 0, 0.11);
  border-radius: 12px;
}

.scroll-area:hover::-webkit-scrollbar-thumb {
  background-color: rgba(0, 0, 0, 0.2);
}

/* 縦向き */
.scroll-table[data-scroll-direction="vertical"] .scroll-area {
  overflow-x: hidden;
  overflow-y: auto;
  white-space: normal;
  max-height: 250px;
  padding: 0 8px 0 0;
}

/* 検索ボタン
==================================================
*/
.search input {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border-style: solid;
  border-radius: 0;
  font: inherit;
  outline: none;
  border: 0;
  box-sizing: border-box;
  min-width: 0;
}

.search-form {
  border-radius: 100px;
  display: flex;
  align-items: center;
  position: relative;
  height: 48px;
}

.search-keyword {
  background: var(--clr-form-bg, #fff);
  border-radius: 100px;
  display: block;
  width: 100%;
  height: 48px;
  flex-shrink: 0;
}
.search-keyword input[type="search"] {
  border: none;
  color: var(--clr-form-txt, #333);
  cursor: auto;
  font-size: 1.6rem;
  line-height: 48px;
  padding: 0 48px 0 24px;
  width: 100%;
  height: 100%;
}
.search-keyword input[type="search"]::placeholder {
  color: var(--clr-form-txt, #5b5b5b);
  opacity: .5;
}
.search-keyword input[type="search"]:-ms-input-placeholder {
  color: var(--clr-form-txt, #5b5b5b);
  opacity: .5;
}
.search-keyword input[type="search"]::-ms-input-placeholder {
  color: var(--clr-form-txt, #5b5b5b);
  opacity: .5;
}

.search-submit {
  background: var(--clr-main, #333);
  border-radius: 100px;
  display: block;
  margin-left: -48px;
  width: 48px;
  height: 48px;
}
.search-submit input[type="submit"] {
  background-color: #fff;
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2016.486%2017.34%22%3E%3Cpath%20data-name%3D%22%E3%83%91%E3%82%B9%20478%22%20d%3D%22M7%2012.707a4.738%204.738%200%200%200%202.868-.967l.575-.432.447-.59a5.588%205.588%200%200%200%201.1-3.658%205.523%205.523%200%200%200-1.49-3.528%204.767%204.767%200%200%200-7%200%205.607%205.607%200%200%200%200%207.643A4.812%204.812%200%200%200%207%2012.707m8.485%204.633a1%201%200%200%201-.707-.291l-3.708-3.71a6.754%206.754%200%200%201-9.02-.785%207.62%207.62%200%200%201%200-10.4%206.766%206.766%200%200%201%209.9%200%207.631%207.631%200%200%201%20.534%209.772l3.709%203.709a1%201%200%200%201-.708%201.706%22%2F%3E%3C%2Fsvg%3E") no-repeat center/16px auto;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2016.486%2017.34%22%3E%3Cpath%20data-name%3D%22%E3%83%91%E3%82%B9%20478%22%20d%3D%22M7%2012.707a4.738%204.738%200%200%200%202.868-.967l.575-.432.447-.59a5.588%205.588%200%200%200%201.1-3.658%205.523%205.523%200%200%200-1.49-3.528%204.767%204.767%200%200%200-7%200%205.607%205.607%200%200%200%200%207.643A4.812%204.812%200%200%200%207%2012.707m8.485%204.633a1%201%200%200%201-.707-.291l-3.708-3.71a6.754%206.754%200%200%201-9.02-.785%207.62%207.62%200%200%201%200-10.4%206.766%206.766%200%200%201%209.9%200%207.631%207.631%200%200%201%20.534%209.772l3.709%203.709a1%201%200%200%201-.708%201.706%22%2F%3E%3C%2Fsvg%3E") no-repeat center/16px auto;
  overflow: hidden;
  padding: 0;
  text-indent: 200%;
  white-space: nowrap;
  cursor: pointer;
  width: 100%;
  height: 100%;
}

@media (min-width: 1025px) {
  .search-form {
    width: 280px;
  }

  .search-submit {
    transition: .2s;
  }
  .search-submit:hover {
    opacity: .7;
  }
}
/*
==================================================
サイトマップ
==================================================
*/
#sitemaps ul {
  display: flex;
  flex-direction: column;
  gap: 1em 0;
}
#sitemaps li {
  display: flex;
  flex-direction: column;
  gap: 1em 0;
  line-height: 1.5;
}
#sitemaps a {
  color: inherit;
  display: block;
  padding-left: 1.5em;
  position: relative;
  text-decoration: none;
  align-self: flex-start;
  max-width: 100%;
}
#sitemaps > ul {
  gap: 2em 0;
}
#sitemaps > ul > li > a {
  font-size: 1.25em;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  padding-left: 1em;
}
#sitemaps > ul > li > a::before {
  background: var(--clr-main, #333);
  border-radius: .15em;
  content: '';
  position: absolute;
  top: .45em;
  left: 0;
  width: .6em;
  height: .6em;
}
#sitemaps > ul ul a::before {
  background: #cdcdc9;
  border-radius: .375em;
  content: '';
  position: absolute;
  top: .5em;
  left: .375em;
  width: .375em;
  height: .375em;
}
#sitemaps > ul ul ul {
  padding-left: 1.5em;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  #sitemaps a {
    transition: .2s;
  }
  #sitemaps a:hover {
    opacity: .5;
  }
}
/* パンくず
==================================================
*/
#siteNavi {
  background-color: var(--clr-siteNavi-bg, #fff);
  padding: 0 var(--padding-overall);
}
#siteNavi ul {
  color: var(--clr-siteNavi-txt, var(--clr-body-txt, inherit));
  display: flex;
  align-items: center;
  overflow-x: auto;
  white-space: nowrap;
  font-size: 1.2rem;
  line-height: 1;
  margin: 0 auto;
  padding: 2.16666em 0;
  max-width: var(--width-overall);
  -ms-overflow-style: none;
  /* IE, Edge 対応 */
  scrollbar-width: none;
  /* Firefox 対応 */
}
#siteNavi ul::-webkit-scrollbar {
  /* Chrome, Safari 対応 */
  display: none;
}
#siteNavi ul li {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
#siteNavi ul li:first-child::before {
  background: var(--clr-accent, #ffd400);
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2016.002%2017%22%3E%3Cpath%20d%3D%22M8%200%20.008%208H0v9h5v-6h6v6h5V8Z%22%2F%3E%3C%2Fsvg%3E") no-repeat center/100% auto;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2016.002%2017%22%3E%3Cpath%20d%3D%22M8%200%20.008%208H0v9h5v-6h6v6h5V8Z%22%2F%3E%3C%2Fsvg%3E") no-repeat center/100% auto;
  content: '';
  display: block;
  margin-right: 1em;
  width: 1.417em;
  height: 1.417em;
}
#siteNavi ul li:not(:last-child)::after {
  background: var(--clr-accent, #ffd400);
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%206.247%2010.488%22%3E%3Cpath%20d%3D%22M.293%2010.19a1%201%200%200%201%200-1.413L3.827%205.24.293%201.707A1%201%200%200%201%201.706.293l4.2%204.2.048.044a1%201%200%200%201%200%201.417l-4.244%204.24a.995.995%200%200%201-1.416%200%22%2F%3E%3C%2Fsvg%3E") no-repeat center/100% auto;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%206.247%2010.488%22%3E%3Cpath%20d%3D%22M.293%2010.19a1%201%200%200%201%200-1.413L3.827%205.24.293%201.707A1%201%200%200%201%201.706.293l4.2%204.2.048.044a1%201%200%200%201%200%201.417l-4.244%204.24a.995.995%200%200%201-1.416%200%22%2F%3E%3C%2Fsvg%3E") no-repeat center/100% auto;
  content: '';
  display: block;
  margin: 0 1em;
  width: .584em;
  height: .917em;
}
#siteNavi ul li a {
  color: inherit;
  text-decoration: none;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  #siteNavi a {
    transition: .2s;
  }
  #siteNavi a:hover {
    opacity: .5;
  }
}
/*
==================================================
スライダー（パーツ）
==================================================
*/
/* 矢印 */
.slick-arrow {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: 0;
  font: inherit;
  outline: none;
  padding: 0;
  box-sizing: border-box;
  min-width: 0;
  grid-row: 1/2;
  background-color: #fff;
  border-radius: 50%;
  display: block;
  width: 50px;
  height: 50px;
  text-indent: 200%;
  white-space: nowrap;
  overflow: hidden;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
  opacity: 0;
  transition: opacity 0.3s ease;
  cursor: pointer;
}
.slick-arrow::before {
  background-color: #333;
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2022.001%2019.778%22%3E%3Cpath%20d%3D%22m13.636%2019.168%207.778-7.778A1.994%201.994%200%200%200%2022%209.919V9.81a1.994%201.994%200%200%200-.586-1.471L13.636.561a2%202%200%200%200-2.828%202.828l4.475%204.475H2a2%202%200%200%200%200%204h13.283l-4.475%204.476a2%202%200%201%200%202.779%202.877l.049-.049%22%2F%3E%3C%2Fsvg%3E") no-repeat center/33% auto;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2022.001%2019.778%22%3E%3Cpath%20d%3D%22m13.636%2019.168%207.778-7.778A1.994%201.994%200%200%200%2022%209.919V9.81a1.994%201.994%200%200%200-.586-1.471L13.636.561a2%202%200%200%200-2.828%202.828l4.475%204.475H2a2%202%200%200%200%200%204h13.283l-4.475%204.476a2%202%200%201%200%202.779%202.877l.049-.049%22%2F%3E%3C%2Fsvg%3E") no-repeat center/33% auto;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
}

.slick-prev {
  left: 16px;
}
.slick-prev::before {
  transform: scale(-1, 1);
}

.slick-next {
  right: 16px;
}

.slick-slider:hover .slick-arrow {
  opacity: 1;
}

@media (max-width: 480px) {
  .slick-arrow {
    width: 30px;
    height: 30px;
  }
}
ul[id$="slider_ul"].slide_item .slick-arrow,
.slider-type2 .slick-arrow {
  width: 28px;
  height: 28px;
}

.arrow-rectangle .slick-arrow {
  width: 40px;
  height: 25%;
  min-height: 56px;
  max-height: 88px;
}

.arrow-rectangle ul[id$="slider_ul"].slide_item .slick-arrow {
  width: 32px;
  height: 25%;
  min-height: 56px;
  max-height: 88px;
}

.arrow-rectangle .slick-prev {
  border-radius: 0 4px 4px 0;
  left: 0;
}

.arrow-rectangle .slick-next {
  border-radius: 4px 0 0 4px;
  right: 0;
}

@media screen and (min-width: 480px) {
  [data-main-header*="wide"] #main-header #topslider.cpadding.arrow-rectangle .slick-arrow {
    border-radius: 4px;
  }
  [data-main-header*="wide"] #main-header #topslider.cpadding.arrow-rectangle .slick-prev {
    left: 25px;
  }
  [data-main-header*="wide"] #main-header #topslider.cpadding.arrow-rectangle .slick-next {
    right: 25px;
  }
}
@media (max-width: 480px) {
  .arrow-rectangle .slick-arrow {
    width: 24px;
  }

  .arrow-rectangle ul[id$="slider_ul"].slide_item .slick-arrow {
    width: 24px;
  }
}
/* ホバーアクション */
@media (min-width: 1025px) {
  .slick-arrow {
    transition: .2s ease;
  }
  .slick-arrow:hover {
    transform: translateY(-50%) scale(0.9);
  }
}
/* ドット */
ul.slick-dots {
  display: flex;
  justify-content: center;
  margin: 20px 0 0;
  position: relative;
}
ul.slick-dots li {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  margin: 4px;
  padding: 0;
  cursor: pointer;
}
ul.slick-dots button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: 0;
  border-radius: 0;
  font: inherit;
  outline: none;
  box-sizing: border-box;
  min-width: 0;
  display: block;
  width: 20px;
  height: 20px;
  padding: 4px;
  text-indent: 200%;
  white-space: nowrap;
  overflow: hidden;
}
ul.slick-dots button::before {
  background-color: var(--clr-main, #333);
  border-radius: 50%;
  border: 0 solid var(--clr-accent, #ffd400);
  content: '';
  position: absolute;
  top: 4px;
  left: 4px;
  width: 12px;
  height: 12px;
  opacity: .38;
  transition: all .2s;
}
ul.slick-dots button:hover::before {
  opacity: 1;
}
ul.slick-dots .slick-active button::before {
  background-color: transparent;
  border: 4px solid var(--clr-accent, #ffd400);
  top: 0px;
  left: 0px;
  width: 20px;
  height: 20px;
  opacity: 1;
}

/* スライダー(日付) */
ul[id$="slider_ul"] .sliderdate {
  background-color: rgba(255, 255, 255, 0.8);
  position: absolute;
  top: 10px;
  left: 10px;
  font-size: .6875em;
  font-weight: 700;
  line-height: 1;
  padding: .5455em .7273em;
  border-radius: 100px;
}

/* タイトル */
.slidertitle {
  background-color: #fff;
  display: block;
  font-weight: 700;
  line-height: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding: 1.3em 1.7em;
  position: absolute;
  bottom: 0;
  width: 100%;
  text-decoration: none;
}

/* 均等に小さく表示 */
ul[id$="slider_ul"].slide_item .slidertitle {
  font-size: .875em;
}

/* 中央に大きく表示 */
ul[id$="slider_ul"].slide_center .slidertitle {
  font-size: 1.25em;
}

/*
==================================================
スライダー
==================================================
*/
#topslider_ul.slick-initialized {
  height: auto;
  opacity: 1;
}

#topslider_ul {
  display: grid;
  height: 0;
  opacity: 0;
  transition: opacity 0.3s linear;
}

ul[id$="slider_ul"] .slick-slide {
  border-radius: 32px;
  overflow: hidden;
}

ul[id$="slider_ul"] a {
  text-decoration: none;
}

/* 均等に小さく表示 */
#topslider ul[id$="slider_ul"].slide_item {
  background-color: transparent;
}

@media (min-width: 1025px) {
  [data-main-header*="wide"][data-header="col2"] #main-header ul[id$="slider_ul"].slide_item {
    margin-top: var(--margin-layout);
  }
}
/* 中央に大きく表示 */
ul[id$="slider_ul"].slide_center .slick-list {
  margin-right: -12px;
}

ul[id$="slider_ul"].slide_center .slick-slide {
  margin-right: 12px;
}

[data-main-header*="wide"] #main-header #topslider:not(.cpadding) ul[id$="slider_ul"].slide_center .slick-slide {
  border-radius: 0;
}

@media screen and (min-width: 480px) {
  [data-main-header*="wide"] #main-header #topslider.cpadding {
    display: flow-root;
    margin: 0 auto;
    max-width: calc(var(--width-overall) - 10%);
    overflow: visible;
  }
  [data-main-header*="wide"] #main-header #topslider.cpadding ul[id$="slider_ul"].slide_center {
    margin-top: var(--margin-layout);
    overflow: visible;
  }
  [data-main-header*="wide"] #main-header #topslider.cpadding .slick-list {
    overflow: visible;
  }
}
/*
==================================================
SNSボタン
==================================================
*/
[class^="snsicon-"] {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  display: block;
  width: 32px;
  height: 32px;
}
[class^="snsicon-"][class$="-black"], [class^="snsicon-"][class$="-white"] {
  width: 26px;
  height: 26px;
  margin: 4px;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  [class^="snsicon-"] {
    transition: all 0.15s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  }
  [class^="snsicon-"]:hover {
    transform: scale(1.1);
  }
}
/* facebook */
.snsicon-facebook {
  background-image: url(img/icon_facebook_circle.svg);
}

.snsicon-facebook-black {
  background-image: url(img/icon_facebook_black.svg);
}

.snsicon-facebook-white {
  background-image: url(img/icon_facebook_white.svg);
}

/* twitter */
.snsicon-twitter {
  background-image: url(img/icon_twitter_circle.svg);
}

.snsicon-twitter-black {
  background-image: url(img/icon_twitter_black.svg);
}

.snsicon-twitter-white {
  background-image: url(img/icon_twitter_white.svg);
}

/* instagram */
.snsicon-instagram {
  background-image: url(img/icon_instagram_circle.svg);
}

.snsicon-instagram-black {
  background-image: url(img/icon_instagram_black.svg);
}

.snsicon-instagram-white {
  background-image: url(img/icon_instagram_white.svg);
}

/* youtube */
.snsicon-youtube {
  background-image: url(img/icon_youtube_circle.svg);
}

.snsicon-youtube-black {
  background-image: url(img/icon_youtube_black.svg);
}

.snsicon-youtube-white {
  background-image: url(img/icon_youtube_white.svg);
}

/* rss */
.snsicon-rss {
  background-image: url(img/icon_rss_circle.svg);
}

.snsicon-rss-black {
  background-image: url(img/icon_rss_black.svg);
}

.snsicon-rss-white {
  background-image: url(img/icon_rss_white.svg);
}

/* はてなブックマーク */
.snsicon-hatena {
  background-image: url(img/icon_hatena_circle.svg);
}

/* LINE */
.snsicon-line {
  background-image: url(img/icon_line_circle.svg);
}

/* SNSボタン一覧
==================================================
*/
.snsbox {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .5em;
}
.snsbox .sns-title {
  font-size: 1.2rem;
  line-height: 1;
  opacity: 0.5;
}
.snsbox .snslist {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: .5em;
  overflow: visible;
}

/* テーブルデザイン
==================================================
*/
/* 標準 */
table[data-table*="normal"] {
  border: none;
  border-collapse: collapse;
  font-size: 1.4rem;
  line-height: 1.5;
  margin: var(--margin-component) 0;
  table-layout: fixed;
  width: 100%;
}
table[data-table*="normal"] tr {
  border-color: var(--clr-border, #deddd4);
  border-style: dashed;
  border-width: 1px 0;
}
table[data-table*="normal"] th, table[data-table*="normal"] td {
  background-color: transparent;
  border-width: 0;
  padding: 1.2857em;
  text-align: left;
  vertical-align: top;
}
table[data-table*="normal"] th {
  font-weight: normal;
  width: 25%;
}

@media (max-width: 1024px) {
  table[data-table*="normal"] {
    font-size: 1.2rem;
  }
  table[data-table*="normal"] th, table[data-table*="normal"] td {
    display: block;
    padding: 1em 0;
    width: auto;
  }
  table[data-table*="normal"] th + td {
    margin-top: -1.5em;
  }
}
/* 比較表
==================================================
*/
.comparison {
  background: #fff;
  border-collapse: collapse;
  margin: var(--margin-component) 0;
  table-layout: fixed;
}
.comparison tr th, .comparison tr td {
  background: transparent;
  border-color: var(--clr-border, #deddd4);
  border-right-style: dashed;
  border-width: 0 1px 0 0;
  font-size: 1.1rem;
  line-height: 1.5;
  padding: 20px;
  text-align: center;
  vertical-align: top;
}
.comparison tr th {
  opacity: 0.5;
  vertical-align: middle;
}
.comparison thead td img {
  max-width: 120px;
  max-height: 120px;
}
.comparison tbody tr:nth-child(even) {
  background: #fff;
}
.comparison tbody tr:nth-child(odd) {
  background: #f7f8fa;
}

.comparison-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px 0;
}

.comparison-title {
  font-weight: 700;
}

.comparison-official a {
  background-color: #ffa412;
  border-radius: 100px;
  box-shadow: 0.18181em 0.18181em 0 rgba(0, 0, 0, 0.08);
  color: #fff;
  display: block;
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
  padding: 8px;
  text-decoration: none;
}

@media (min-width: 1025px) {
  .comparison-official a {
    transition: .2s;
  }
  .comparison-official a:hover {
    opacity: .7;
  }
}
/* タグ一覧
==================================================
*/
.taglist {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .5em;
}
.taglist .tag {
  background: #ededed;
  border-radius: 100px;
  color: #333;
  display: block;
  font-size: 1.1rem;
  line-height: 1;
  padding: .72727em;
  text-decoration: none;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  .taglist .tag {
    transition: all 0.3s cubic-bezier(0.23, 1, 0.32, 1);
  }
  .taglist .tag:hover {
    background-color: var(--clr-accent, #ffd400);
    color: #fff;
  }
}
/* Twitterタイムライン
==================================================
*/
.twitter_plugin {
  overflow: hidden;
}

/* 口コミ
==================================================
*/
.user1,
.user2 {
  background: #fff;
  border: 2px dashed #e3e3e7;
  border-radius: 16px;
  line-height: 1.7;
  margin: var(--margin-component) 0;
  padding: 2em;
}
.user1:not(.noimage),
.user2:not(.noimage) {
  background: #fff url(./img/user1.png) no-repeat 1.375em 1.1875em/3.375em auto;
  padding-left: calc(4em + 2em);
}

.user2:not(.noimage) {
  background-image: url(./img/user2.png);
}

/* 口コミリスト */
.user1-custom,
.user2-custom {
  background: #fff;
  border: 2px dashed #e3e3e7;
  border-radius: 16px;
  display: flex;
  gap: 0 1em;
  margin: var(--margin-component) 0;
  padding: 2em;
}

.user-img {
  flex-shrink: 0;
  max-width: 80px;
}

.user-body {
  display: flex;
  flex-direction: column;
  gap: .5em 0;
}

.user-review {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .5em;
  line-height: 1;
}
.user-review .user-status {
  font-size: 0.7em;
  opacity: 0.5;
}

.user-title {
  font-weight: 700;
  line-height: 1.7;
}

.user-desc {
  font-size: .8em;
  line-height: 1.7;
}

/*
=============================
目次用スタイル(SIRIUS2)
=============================
*/
/* 目次 基本スタイル
==================================================
*/
#index_wrapper {
  clear: both;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 8px 0;
  padding: 0 16px;
}

#indexlist {
  background-color: #f9f9fb;
  width: 90%;
}

#index_inner {
  padding: 20px 24px;
  line-height: 1.5;
  position: relative;
}

/* タイトル */
#indexlist .title {
  max-width: 100%;
}

/* 表示・非表示の切り替え */
#index_button {
  position: absolute;
  top: 11px;
  right: 12px;
  opacity: 1;
  width: 44px;
  height: 44px;
}
#index_button > span::before {
  border-top: 1px solid #2f2f32;
  border-right: 1px solid #2f2f32;
  content: '';
  display: block;
  transform: rotate(-45deg);
  position: absolute;
  top: 20px;
  right: 16px;
  width: 11px;
  height: 11px;
  opacity: .6;
}
#index_button span span {
  display: none;
}

#index_panel:checked + #index_button > span::before {
  transform: rotate(135deg);
  top: 13px;
}

/* アコーディオン */
#index_panel[type="checkbox"] {
  display: none;
}

#indexlist #index_inner #index_panel:checked ~ ul, #indexlist #index_inner #index_panel:checked ~ ol {
  border-width: 0;
  line-height: 0;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
  opacity: 0;
  visibility: hidden;
  overflow: hidden;
}
#indexlist #index_inner #index_panel:checked ~ ul *, #indexlist #index_inner #index_panel:checked ~ ol * {
  border-width: 0;
  line-height: 0;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
}
#indexlist #index_inner #index_panel:checked ~ ul ::before,
#indexlist #index_inner #index_panel:checked ~ ul ::after, #indexlist #index_inner #index_panel:checked ~ ol ::before,
#indexlist #index_inner #index_panel:checked ~ ol ::after {
  border-width: 0;
  line-height: 0;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
  height: 0;
}

/* リストの調整 */
#indexlist ul, #indexlist ol {
  list-style: none;
  margin: 16px 0;
  margin-left: -6px;
  opacity: 1;
  overflow: visible;
  padding: 0;
  text-align: left;
}
#indexlist li {
  font-size: 15px;
  line-height: 1.5;
  padding-left: 1.46667em;
  position: relative;
  margin: .53334em 0;
  z-index: 0;
}
#indexlist #index_inner > ul, #indexlist #index_inner > ol {
  margin: 17px 0 0;
}

.onload #indexlist #index_inner * {
  transition: margin 0.25s cubic-bezier(0.2, 0.7, 0.4, 0.95), padding 0.25s cubic-bezier(0.2, 0.7, 0.4, 0.95);
}

/* 数字付きリストの調整 */
#indexlist ol {
  counter-reset: indexchild;
}
#indexlist ol > li > span {
  display: flex;
  margin-left: -1.46667em;
}
#indexlist ol > li > span::before {
  counter-increment: indexchild;
  content: counter(indexchild) ".";
  color: inherit;
  font-size: inherit;
  font-weight: normal;
  line-height: inherit;
  margin: 0 0.4em 0 0.2em;
  position: static;
  flex-shrink: 0;
}

/* 数字付きリスト-カウンター */
#indexlist.idx_counters #index_inner > ol {
  counter-reset: indexchild;
}
#indexlist.idx_counters #index_inner > ol > li > span::before {
  counter-increment: indexchild;
  content: counter(indexchild) ".";
}
#indexlist.idx_counters ul ol > li > span::before,
#indexlist.idx_counters ol ol > li > span::before {
  content: counters(indexchild,"-") ".";
}

/* 目次詳細設定 */
/* 横幅100% */
#index_wrapper.fullwidth {
  padding: 0;
}
#index_wrapper.fullwidth #indexlist {
  width: 100%;
  max-width: 100%;
}

/* 角丸の指定 */
#indexlist.idx_round {
  border-radius: 8px;
}

/* 横幅の自動調整 */
#index_wrapper #indexlist.idx_auto {
  display: inline-block;
  width: auto;
  max-width: 90%;
  min-width: 250px;
}

#menu #indexlist, #rmenu #indexlist {
  width: 100%;
  max-width: 100%;
}

/* 左寄せ */
#index_wrapper.setleft {
  justify-content: flex-start;
}

/* 目次フリースペース */
.idx_space {
  margin: 8px 0;
  text-align: center;
}
.idx_space div, .idx_space ul, .idx_space ol, .idx_space li {
  text-align: left;
}
.idx_space::after {
  display: block;
  content: '';
  clear: both;
}

/* ==========================================================================
   preview
   ========================================================================== */
/*
==================================================
プレビュー表示用
==================================================
*/
@media (min-width: 480px) {
  #editor,
  #previewcontents {
    font-size: 1.6rem;
    line-height: 2;
  }
}
