@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(20px, 5.55555vw, 40px);
  --padding-overall: 5vw;
  --width-overall: 1230px;
  --width-menu: 300px;
  --width-rmenu: 250px;
  --width-entry: 860px;
}

*,
::before,
::after {
  box-sizing: border-box;
  border: 0 solid var(--clr-border, #ebebed);
  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-color: var(--clr-body-bg, #fff);
  color: var(--clr-body-txt, #333);
  font-family: 'Roboto','Poppins','Noto Sans JP', 'Helvetica Neue', Arial, 'Hiragino Kaku Gothic ProN', 'Hiragino Sans', 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"] #main section {
  padding: var(--padding-overall);
  margin-top: 0;
  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);
}
[data-column="col1"][data-main="wide"] #main .mainbox + section {
  margin-top: var(--margin-layout);
}

/* カラム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 64px;
    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 24px;
    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, var(--clr-header-fixed-txt, var(--clr-main, #1f2d3d)));
  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;
  }
}
.logotext {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

/* リード文 */
#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 a {
  color: inherit;
  text-decoration: none;
  display: grid;
  gap: .1em;
  position: relative;
  padding: 1.2em 0;
  z-index: 0;
}
.topmenu_ul a::after {
  content: '';
  border-bottom-width: 1px;
  position: absolute;
  left: -100vw;
  right: 0;
  bottom: 0;
}
.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-header-fixed-txt, var(--clr-body-txt, rgba(51, 51, 51, 0.5))))));
  -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%2018.974%2011.191%22%3E%3Cpath%20d%3D%22M.294%201%201%20.294a1%201%200%200%201%201.413%200l7.076%207.069%207.07-7.069a1%201%200%200%201%201.414%200l.708.706a1%201%200%200%201%200%201.414l-7.735%207.731a.46.46%200%200%201-.043.046l-.709.706a1%201%200%200%201-1.413%200L.294%202.416A1%201%200%200%201%20.292%201%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%2018.974%2011.191%22%3E%3Cpath%20d%3D%22M.294%201%201%20.294a1%201%200%200%201%201.413%200l7.076%207.069%207.07-7.069a1%201%200%200%201%201.414%200l.708.706a1%201%200%200%201%200%201.414l-7.735%207.731a.46.46%200%200%201-.043.046l-.709.706a1%201%200%200%201-1.413%200L.294%202.416A1%201%200%200%201%20.292%201%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 a {
  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;
  }
  .topmenu_ul a::before {
    background-color: #000;
    content: '';
    position: absolute;
    top: 0;
    left: -100vw;
    right: 0;
    bottom: 0;
    z-index: -1;
    opacity: 0;
    transition: .2s;
  }
  .topmenu_ul a:hover::before, .topmenu_ul a:active::before {
    opacity: .1;
  }

  [data-color*="clr-header-bg1"] .topmenu_ul a::before {
    background-color: var(--clr-header-bg1);
    filter: invert(100%) grayscale(100%) contrast(100);
  }

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

[data-color*="clr-topmenu-bg"] #topmenu {
  padding: 10px 16px;
}
[data-color*="clr-topmenu-bg"] .topmenu_ul a::after {
  border-color: var(--clr-topmenu-bg);
  filter: invert(100%) grayscale(100%) contrast(100);
  opacity: .1;
  top: 0;
  bottom: auto;
}
[data-color*="clr-topmenu-bg"] .topmenu_ul > li:first-child > span a::after {
  display: none;
}

@media (min-width: 1025px) {
  .topmenu_ul {
    display: flex;
    flex-wrap: wrap;
    overflow: visible;
  }
  .topmenu_ul > li {
    display: grid;
    place-content: center;
  }
  .topmenu_ul > li:not(:last-child) {
    margin-right: 2.2857em;
  }
  .topmenu_ul a {
    padding: .5em 0;
    text-align: center;
  }
  .topmenu_ul a::after {
    display: none;
  }
  .topmenu_ul .haschild > span::after {
    width: 12px;
  }
  .topmenu_ul .haschild > span a {
    padding-right: 20px;
  }
  .topmenu_ul .haschild:hover > ul, .topmenu_ul .haschild.show:hover > ul {
    opacity: 1;
    pointer-events: auto;
    visibility: visible;
    transition: .3s ease;
    top: 100%;
  }
  .topmenu_ul .haschild.show > span::after {
    transform: none;
  }
  .topmenu_ul .haschild.show > .child {
    height: auto;
    overflow: visible;
    opacity: 0;
  }
  .topmenu_ul .child {
    background: var(--clr-topmenu-child-bg, #fff);
    box-shadow: 0 5px 10px rgba(0, 0, 0, 0.15);
    opacity: 0;
    padding-left: 0;
    visibility: hidden;
    position: absolute;
    top: 110%;
    left: -1em;
    min-width: 210px;
    max-width: 100%;
    z-index: 1;
    pointer-events: none;
    height: auto;
    overflow: visible;
  }
  .topmenu_ul .child li:not(:last-child) {
    box-shadow: inset 0 -1px 0 var(--clr-border, #f8f8f8);
  }
  .topmenu_ul .child a {
    color: var(--clr-topmenu-child-txt, var(--clr-body-txt, #333));
    padding: 1.2em 1.5em;
    text-align: left;
  }

  [data-color*="clr-topmenu-bg"] #topmenu {
    padding: 0 2.4rem;
  }
  [data-color*="clr-topmenu-bg"] .topmenu_ul > li > a {
    padding-left: 0;
  }

  [data-color*="clr-topmenu-child-bg"] .topmenu_ul .child {
    padding: .8em;
  }
  [data-color*="clr-topmenu-child-bg"] .topmenu_ul .child li:not(:last-child) {
    box-shadow: none;
  }
  [data-color*="clr-topmenu-child-bg"] .topmenu_ul .child a {
    padding: 0.8em 0.5em;
  }
}
/* ホバーアクション */
@media (min-width: 1025px) {
  #topmenu a {
    transition: 0.2s;
  }
  #topmenu a:hover {
    opacity: 0.5;
  }
}
/* 検索ボタン */
@media (min-width: 1025px) {
  #header .search {
    overflow: hidden;
    margin-left: auto;
    flex-shrink: 0;
    width: 40px;
  }
  #header .search::before {
    background-color: var(--clr-header-txt1, var(--clr-header-fixed-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%2016.486%2017.34%22%3E%3Cpath%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 38%/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%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 38%/16px auto;
    content: '';
    cursor: pointer;
    width: 100%;
    height: 100%;
  }
  #header .search .search-form {
    background: rgba(255, 255, 255, 0.95);
    display: flex;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    padding: 40px 25% 0;
    z-index: 100;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity .15s ease, visibility .15s ease;
  }
  #header .search .search-form::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%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;
  }
  #header .search .search-keyword {
    flex-shrink: 0;
    width: 100%;
    height: 56px;
  }
  #header .search .search-keyword::before {
    background-color: #fff;
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 136px;
    z-index: -1;
  }
  #header .search .search-keyword input[type="search"] {
    padding: 0 56px 0 32px;
  }
  #header .search .search-submit {
    margin-left: -56px;
    width: 56px;
    height: 56px;
    position: relative;
  }

  html[data-searchbox="true"] #header .search .search-form {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
}
/* スマホボタン */
#spmenu-btn {
  display: block;
  position: relative;
  margin-left: auto;
  text-indent: 200%;
  white-space: nowrap;
  overflow: hidden;
  width: 26px;
  height: 44px;
  z-index: 100;
  -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 {
  border-bottom: 2px solid var(--clr-header-txt1, var(--clr-header-fixed-txt, var(--clr-main, var(--clr-body-txt, #333))));
  content: '';
  margin-left: -13px;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 26px;
  transition: .3s ease;
}
#spmenu-btn::before {
  margin-top: -9px;
}
#spmenu-btn::after {
  margin-top: 7px;
}
#spmenu-btn span::before {
  margin-top: -1px;
}

[data-spmenu="true"] #spmenu-btn::before {
  transform: translateY(9px) 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;
    width: 100%;
    z-index: 100;
  }
  [data-spmenu="true"] #body #header::before {
    background-color: var(--clr-header-bg1, #fff);
    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-base, #f7f8fa));
  color: var(--clr-header-txt1, var(--clr-header-fixed-txt, 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) {
  #logo,
  #header-lead,
  #topmenu,
  #header .search,
  #space7 {
    display: flex;
    align-items: center;
    min-height: 64px;
  }

  #header-menu {
    flex-direction: row;
  }

  #logo-wrap,
  #spmenu,
  #header-wrap {
    display: contents;
  }
}
/* ヘッダーレイアウト（1行）
==================================================
*/
@media (min-width: 1025px) {
  #header .container {
    box-sizing: content-box;
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--padding-overall);
    padding-right: var(--padding-overall);
    max-width: var(--width-overall);
    display: flex;
    flex-wrap: wrap;
    gap: 0 1em;
    align-items: center;
  }

  #header-menu {
    flex-grow: 1;
  }

  #topmenu {
    margin: 0 auto;
  }
  #topmenu + .search {
    margin: 0;
  }
}
/* 2行
==================================================
*/
@media (min-width: 1025px) {
  [data-header="row2"] #header-menu {
    color: var(--clr-header-txt2, inherit);
    position: relative;
  }
  [data-header="row2"] #header-menu::before {
    background-color: var(--clr-header-bg2, #fff);
    border-bottom-width: 1px;
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0 calc(-50vw + 50%);
  }
  [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, rgba(51, 51, 51, 0.5))))));
  }
  [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-body-txt, #333)));
  }
  [data-header="row2"][data-color*="clr-header-bg2"] #header-menu::before {
    border-bottom-width: 0;
  }
}
/* 2行リード文
==================================================
*/
@media (min-width: 1025px) {
  [data-header="row2-lead"] #header-lead {
    color: var(--clr-header-txt2, inherit);
    position: relative;
    min-height: auto;
    order: -1;
    width: 100%;
  }
  [data-header="row2-lead"] #header-lead::before {
    background-color: var(--clr-header-bg2, #eff1f5);
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0 calc(-50vw + 50%);
  }
  [data-header="row2-lead"] #header-lead span {
    position: relative;
  }
}
/* 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;
    padding: 1em 0;
  }
  [data-header="row2-center"] #header-lead {
    margin-top: -16px;
  }
  [data-header="row2-center"] #header-wrap {
    color: var(--clr-header-txt2, inherit);
    display: flex;
    flex-direction: row;
    justify-content: center;
    position: relative;
  }
  [data-header="row2-center"] #header-wrap::before {
    background-color: var(--clr-header-bg2, #fff);
    border-bottom-width: 1px;
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0 calc(-50vw + 50%);
  }
  [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, rgba(51, 51, 51, 0.5))))));
  }
  [data-header="row2-center"] #header .search::before {
    background-color: var(--clr-header-txt2, var(--clr-header-txt1, var(--clr-body-txt, #333)));
  }
  [data-header="row2-center"][data-color*="clr-header-bg2"] #header-wrap::before {
    border-bottom-width: 0;
  }
}
/* トップ固定（ヘッダーワイドの時）
==================================================
*/
@media (max-width: 1024px) {
  [data-header="fixed"]:not([data-headerimg-img-sp="false"]) #header {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1;
  }
  [data-header="fixed"]:not([data-headerimg-img-sp="false"]) #header .container {
    flex-wrap: nowrap;
  }
  [data-header="fixed"]:not([data-headerimg-img-sp="false"]) #header:not(.fix) {
    background-color: transparent;
    --clr-header-fixed-txt: #fff;
  }
  [data-spmenu="true"] [data-header="fixed"]:not([data-headerimg-img-sp="false"]) #header {
    --clr-header-fixed-txt: inherit;
  }
}
@media (min-width: 1025px) {
  [data-header="fixed"]:not([data-headerimg-img="false"]) #header {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1;
  }
  [data-header="fixed"]:not([data-headerimg-img="false"]) #header .container {
    max-height: 104px;
    flex-wrap: nowrap;
  }
  [data-header="fixed"]:not([data-headerimg-img="false"]) #header:not(.fix) {
    background-color: transparent;
    --clr-header-fixed-txt: #fff;
  }
}
/*
==================================================
コンテンツ
==================================================
*/
#contents {
  flex-grow: 1;
  background: #fff;
  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 {
  width: 100%;
}

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

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

/* ヘッダー横幅ワイド */
[data-main-header*="wide"] #main-header {
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
}
[data-main-header*="wide"] #main-header > * {
  margin-top: 0;
}

/*
==================================================
メイン（パーツ）
==================================================
*/
/* ワイド化 */
[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;
}

[class="txt-body"] {
  background-color: var(--clr-txtbody-bg, transparent);
  color: var(--clr-txtbody-txt, inherit);
}

[data-color*="clr-txtbody-bg"] [class="txt-body"] {
  padding: clamp(10px, 2.8vw, 24px);
}

/*
==================================================
メインフッター（レイアウト）
==================================================
*/
/* タグ一覧 */
#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;
}

.title + .menulist {
  margin-top: -.85712em;
}

.sitemenu,
#submenu:not([class="submenu-image"]) {
  background-color: var(--clr-menu-bg, transparent);
  overflow: hidden;
}
.sitemenu a,
#submenu:not([class="submenu-image"]) a {
  color: var(--clr-menu-txt, inherit);
  text-decoration: none;
  display: flex;
  align-items: center;
  position: relative;
  padding: 1.2em 0;
}
.sitemenu a::after,
#submenu:not([class="submenu-image"]) a::after {
  content: '';
  border-bottom-width: 1px;
  position: absolute;
  left: -100vw;
  right: 0;
  bottom: 0;
}
.sitemenu > li,
#submenu:not([class="submenu-image"]) > li {
  overflow: hidden;
}
.sitemenu .haschild,
#submenu:not([class="submenu-image"]) .haschild {
  position: relative;
}
.sitemenu .haschild > a,
#submenu:not([class="submenu-image"]) .haschild > a {
  padding-right: 40px;
}
.sitemenu .haschild::after,
#submenu:not([class="submenu-image"]) .haschild::after {
  background-color: var(--clr-menu-icon, var(--clr-menu-txt, var(--clr-body-txt, rgba(51, 51, 51, 0.5))));
  -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%2018.974%2011.191%22%3E%3Cpath%20d%3D%22M.294%201%201%20.294a1%201%200%200%201%201.413%200l7.076%207.069%207.07-7.069a1%201%200%200%201%201.414%200l.708.706a1%201%200%200%201%200%201.414l-7.735%207.731a.46.46%200%200%201-.043.046l-.709.706a1%201%200%200%201-1.413%200L.294%202.416A1%201%200%200%201%20.292%201%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%2018.974%2011.191%22%3E%3Cpath%20d%3D%22M.294%201%201%20.294a1%201%200%200%201%201.413%200l7.076%207.069%207.07-7.069a1%201%200%200%201%201.414%200l.708.706a1%201%200%200%201%200%201.414l-7.735%207.731a.46.46%200%200%201-.043.046l-.709.706a1%201%200%200%201-1.413%200L.294%202.416A1%201%200%200%201%20.292%201%22%2F%3E%3C%2Fsvg%3E") no-repeat center/10px auto;
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 40px;
  height: 3.9em;
  cursor: pointer;
}
.sitemenu .haschild.show::after,
#submenu:not([class="submenu-image"]) .haschild.show::after {
  transform: rotate(180deg);
}
.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 .child,
#submenu:not([class="submenu-image"]) .child {
  overflow: hidden;
  opacity: 0;
}
.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;
  }
}
[data-color*="clr-menu-bg"] .sitemenu,
[data-color*="clr-menu-bg"] #submenu:not([class="submenu-image"]) {
  padding: 10px 16px;
}
[data-color*="clr-menu-bg"] .sitemenu a::after,
[data-color*="clr-menu-bg"] #submenu:not([class="submenu-image"]) a::after {
  border-color: var(--clr-menu-bg);
  filter: invert(100%) grayscale(100%) contrast(100);
  opacity: .1;
  top: 0;
  bottom: auto;
}
[data-color*="clr-menu-bg"] .sitemenu > li:first-child > a::after,
[data-color*="clr-menu-bg"] #submenu:not([class="submenu-image"]) > li:first-child > a::after {
  display: none;
}

@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"] .title + .menulist {
    margin-top: 0;
  }
  [data-column="col1"] .sitemenu,
  [data-column="col1"] #submenu:not([class="submenu-image"]) {
    column-count: 3;
    gap: 2em;
  }
  [data-column="col1"] .sitemenu li,
  [data-column="col1"] #submenu:not([class="submenu-image"]) li {
    break-inside: avoid;
    margin: 0 0 1.5em;
  }
  [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 a::after,
  [data-column="col1"] #submenu:not([class="submenu-image"]) a::after {
    display: none;
  }
  [data-column="col1"] .sitemenu .haschild > a,
  [data-column="col1"] #submenu:not([class="submenu-image"]) .haschild > a {
    padding-right: 0;
  }
  [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;
  }
  [data-column="col1"][data-color*="clr-menu-bg"] .sitemenu,
  [data-column="col1"][data-color*="clr-menu-bg"] #submenu:not([class="submenu-image"]) {
    padding: 2em;
  }

  /* ホバーアクション */
  .menulist span {
    transition: 0.2s;
  }

  .menulist a:hover {
    opacity: 1;
  }
  .menulist a:hover span {
    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: 1em 4em;
}
.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, #1a1a1a));
  color: var(--clr-footer-txt, #fff);
}
#footer .inner {
  box-sizing: content-box;
  margin: 0 auto;
  padding: var(--margin-layout) var(--padding-overall);
  max-width: var(--width-overall);
  display: flex;
  flex-direction: column;
  gap: 2em;
}

/* 中央揃え
==================================================
*/
[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[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 #header.fix {
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 100;
    transform: translateY(-100%);
  }
  #body[data-header="fixed"]:not([data-headerimg-img-sp="false"]) #header.fix {
    position: fixed;
  }
  #body #header.fix.hide-header {
    transform: translateY(-100%);
    transition: 0.4s transform cubic-bezier(0.3, 0, 0.2, 1);
    pointer-events: none;
  }
  #body #header.fix.show-header {
    transform: none;
    transition: 0.4s transform cubic-bezier(0.3, 0, 0.2, 1);
  }
}
#header.fix {
  opacity: .98;
}
#header.fix:not(.show-header) {
  overflow: hidden;
}

html[data-searchbox="true"] #header.fix {
  opacity: 1;
  transition: none;
}

/* ==========================================================================
   page
   ========================================================================== */
/*
==================================================
トップページ
==================================================
*/
#whatsnew li {
  border-bottom-width: 1px;
  padding: 1.3em 0;
  display: flex;
  flex-direction: column;
  align-items: baseline;
  gap: .8em 1.3em;
}
#whatsnew li:first-child {
  border-top-width: 1px;
}

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

.whatsnew-txt {
  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"]::after {
  background-color: #fdd633;
  border-radius: 50%;
  color: #000;
  content: 'NEW';
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
  position: absolute;
  top: -15px;
  right: -15px;
  width: 48px;
  height: 48px;
  z-index: 1;
}

/*
==================================================
記事（デザイン）
==================================================
*/
.blog {
  container-type: inline-size;
}
.blog .blog-inner {
  background-color: #fff;
  border-radius: 12px;
  box-shadow: rgba(34, 45, 57, 0.08) 0 0 0 1px;
  overflow: hidden;
  text-align: left;
}
.blog .blog-thumb img {
  width: 100%;
  aspect-ratio: 3 / 2;
  max-height: 260px;
  object-fit: cover;
}
.blog .blog-body {
  position: relative;
  padding: 30px;
}
.blog .cat {
  position: absolute;
  top: -11px;
  max-width: 75%;
}
.blog .date {
  font-size: 1.3rem;
  position: absolute;
  right: 30px;
  bottom: 30px;
  line-height: 44px;
}
.blog .blog-title {
  color: inherit;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 10px;
}
.blog .blog-title a {
  color: inherit;
  text-decoration: none;
}
.blog .author {
  margin-bottom: 10px;
}
.blog .blog-desc {
  opacity: .75;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  overflow: hidden;
  font-size: 1.3rem;
  margin-bottom: 48px;
}
.blog .blog-more a {
  border-radius: 100px;
  box-shadow: inset 0 0 0 1px var(--clr-border, #ebebed);
  color: inherit;
  display: inline-block;
  font-size: 1.2rem;
  line-height: 44px;
  padding: 0 24px;
  min-height: 44px;
  text-decoration: none;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  .blog {
    transition: all 0.3s cubic-bezier(0.23, 1, 0.32, 1);
  }
  .blog .blog-inner,
  .blog .blog-more,
  .blog .blog-thumb {
    transition: all 0.3s cubic-bezier(0.23, 1, 0.32, 1);
  }
  .blog:hover {
    transform: translateY(-4px);
    z-index: 1;
  }
  .blog:hover .blog-inner {
    box-shadow: 0 10px 15px 0 rgba(30, 45, 62, 0.04), 0 0 50px 0 rgba(31, 44, 60, 0.1);
  }
  .blog:hover .blog-thumb {
    opacity: 0.5;
  }
  .blog:hover .blog-more a {
    background-color: var(--clr-accent, #1cadff);
    box-shadow: inset 0 0 0 0 var(--clr-border, #ebebed);
    color: #fff;
  }
}
/* リサイズ */
@container (max-width: 360px) {
  .blog .blog-body {
    padding: 24px;
  }
  .blog .date {
    right: 24px;
    bottom: 24px;
  }
  .blog .blog-title {
    -webkit-line-clamp: 2;
    font-size: 1.7rem;
  }
  .blog .blog-desc {
    -webkit-line-clamp: 2;
    margin-bottom: 32px;
  }
}
@container (max-width: 300px) {
  .blog .blog-body {
    padding: 16px;
  }
  .blog .date {
    font-size: 1.2rem;
    line-height: 28px;
    right: 16px;
    bottom: 16px;
  }
  .blog .blog-title {
    font-size: 1.5rem;
    margin-bottom: 16px;
  }
  .blog .author {
    margin-bottom: 0;
    max-width: calc(100% - 84px);
  }
  .blog .blog-desc {
    display: none;
  }
  .blog .blog-more {
    display: none;
  }
}
@container (max-width: 240px) {
  .blog .blog-title {
    font-size: 1.4rem;
    margin-bottom: 38px;
  }
  .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 .cat {
  margin: 0 0 16px;
  position: static;
}
.bloglist[data-bloglist-horizontal*="true"] .blog .blog-title {
  -webkit-line-clamp: 2;
  margin-bottom: 30px;
}
.bloglist[data-bloglist-horizontal*="true"] .blog .blog-desc {
  display: none;
}
.bloglist[data-bloglist-horizontal*="true"] .blog .blog-more {
  display: none;
}

@container (max-width: 500px) {
  .bloglist[data-bloglist-horizontal*="true"] .blog .date {
    line-height: 28px;
  }
  .bloglist[data-bloglist-horizontal*="true"] .blog .blog-title {
    font-size: 1.4rem;
    margin-bottom: 38px;
  }
  .bloglist[data-bloglist-horizontal*="true"] .blog .author {
    display: none;
  }
}
@container (min-width: 680px) {
  .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%;
  }
  .bloglist[data-bloglist-horizontal*="true"] .blog .blog-body {
    width: 55%;
  }
  .bloglist[data-bloglist-horizontal*="true"] .blog .cat {
    margin: 0 0 16px;
    position: static;
  }
  .bloglist[data-bloglist-horizontal*="true"] .blog .blog-title {
    -webkit-line-clamp: 2;
    margin-bottom: 16px;
  }
  .bloglist[data-bloglist-horizontal*="true"] .blog .blog-desc {
    display: -webkit-box;
    -webkit-line-clamp: 2;
  }
  .bloglist[data-bloglist-horizontal*="true"] .blog .blog-more {
    display: block;
  }
}
@container (min-width: 800px) {
  .bloglist[data-bloglist-horizontal*="true"] .blog .blog-thumb {
    width: 50%;
  }
  .bloglist[data-bloglist-horizontal*="true"] .blog .blog-body {
    width: 50%;
  }
}
@container (min-width: 1000px) {
  .bloglist[data-bloglist-horizontal*="true"] .blog .blog-thumb {
    width: 56%;
  }
  .bloglist[data-bloglist-horizontal*="true"] .blog .blog-body {
    width: 44%;
  }
  .bloglist[data-bloglist-horizontal*="true"] .blog .blog-title {
    -webkit-line-clamp: 3;
    font-size: 2.8rem;
    line-height: 1.5;
  }
  .bloglist[data-bloglist-horizontal*="true"] .blog .author {
    margin-bottom: 16px;
  }
  .bloglist[data-bloglist-horizontal*="true"] .blog .blog-desc {
    -webkit-line-clamp: 4;
    font-size: 1.4rem;
  }
}
/*
==================================================
カテゴリーページ
==================================================
*/
[class^="categorylist"] ul {
  margin: var(--margin-component) 0;
}
[class^="categorylist"] .article-thumb img {
  width: 100%;
  aspect-ratio: 3 / 2;
  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-desc a {
  color: inherit;
  text-decoration: none;
}
[class^="categorylist"] .article-more {
  display: none;
}

@media (min-width: 1025px) {
  [class^="categorylist"] .article a {
    transition: 0.2s;
  }
  [class^="categorylist"] .article a:hover {
    opacity: 0.5;
  }
  [class^="categorylist"] .article-thumb img {
    max-height: 300px;
  }
}
/*　カテゴリー一覧（横並び） */
.categorylist ul {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%,300px), 1fr));
  gap: 1.5em;
}
.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 ul {
  display: grid;
  gap: 1.5em;
}
.categorylist-vertical .article {
  position: relative;
}
.categorylist-vertical .article-inner {
  display: flex;
  flex-wrap: wrap;
  gap: 1em;
}
.categorylist-vertical .article-thumb {
  flex: 1 1 180px;
}
.categorylist-vertical .article-body {
  flex: 9999 1 420px;
  display: flex;
  flex-direction: column;
  gap: .5em;
}

/*　カテゴリー一覧（交互） */
.categorylist-alternate {
  container-type: inline-size;
}
.categorylist-alternate ul {
  display: grid;
  gap: 1.5em;
}
.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%,200px), 1fr));
  gap: 1em;
}
#entrylist .article {
  position: relative;
}
#entrylist .article-inner {
  display: flex;
  flex-direction: column;
  gap: 12px 16px;
}
#entrylist .article-thumb {
  flex-shrink: 0;
}
#entrylist .article-thumb img {
  width: 100%;
  aspect-ratio: 3 / 2;
  object-fit: cover;
}
#entrylist .article-body {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
#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: 3;
  overflow: hidden;
  font-size: 1.3rem;
  line-height: 1.4;
  margin-bottom: 12px;
  opacity: .75;
}
#entrylist .article-desc a {
  color: inherit;
  text-decoration: none;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  #entrylist .article a {
    transition: 0.2s;
  }
  #entrylist .article a:hover {
    opacity: 0.5;
  }
}
/*
==================================================
サイト内検索
==================================================
*/
#searchresult ul {
  margin: var(--margin-component) 0;
  display: grid;
  gap: 1.5em;
}
#searchresult .article {
  position: relative;
}
#searchresult .article-inner {
  display: flex;
  flex-wrap: wrap;
  gap: 1em;
}
#searchresult .article-thumb {
  flex: 1 1 180px;
}
#searchresult .article-thumb img {
  width: 100%;
  aspect-ratio: 3 / 2;
  object-fit: cover;
}
#searchresult .article-body {
  flex: 9999 1 420px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
#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, 1.8rem);
  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: 3;
  overflow: hidden;
  font-size: 1.3rem;
  line-height: 1.7;
  margin-bottom: 12px;
  opacity: .75;
}
#searchresult .article-desc a {
  color: inherit;
  text-decoration: none;
}
#searchresult .article-more {
  display: none;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  #searchresult .article a {
    transition: 0.2s;
  }
  #searchresult .article a:hover {
    opacity: 0.5;
  }
}
/*
==================================================
404ページ
==================================================
*/
#notfound .search {
  margin: var(--margin-component) 0;
  max-width: 400px;
}

/* ==========================================================================
   Component
   ========================================================================== */
/* 著者
==================================================
*/
.author {
  display: flex;
  align-items: center;
  text-align: left;
}

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

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

.author-name {
  font-size: 1.2rem;
  line-height: 1.5;
  opacity: .5;
}
.author-name a {
  color: inherit;
  text-decoration: none;
}

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

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

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

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

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

.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: #dd305d;
  background-image: url(img/icon_alert.svg);
  background-size: 0.8125em;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* デザイン02
==================================================
*/
.cbox-d[class*="02"] {
  background: #fff;
  border-width: 2px;
  border-top: none;
  margin-top: calc(var(--margin-component) + .84375em);
}
.cbox-d[class*="02"] .cbox-caption {
  background: transparent;
  display: flex;
  margin-bottom: -.5em;
  padding: 0;
}
.cbox-d[class*="02"] .cbox-caption::before, .cbox-d[class*="02"] .cbox-caption::after {
  content: '';
  border-top-width: 2px;
}
.cbox-d[class*="02"] .cbox-caption::before {
  margin-right: .75em;
  width: 0.75em;
}
.cbox-d[class*="02"] .cbox-caption::after {
  flex-grow: 1;
  margin-left: 0.75em;
}
.cbox-d[class*="02"] .cbox-caption span {
  padding-left: 2.5em;
  margin-top: -.85712em;
}

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

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

/* カテゴリーネーム
==================================================
*/
.cat {
  display: inline-flex;
}
.cat a {
  background-color: var(--clr-accent, #1cadff);
  border-radius: 2px;
  color: #fff;
  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-color: #f2f5f7;
  border-radius: 3px;
  overflow: hidden;
  flex-grow: 1;
}
.chart .graph .bar {
  background-color: #ffcc66;
  display: block;
  height: 12px;
}
.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-color: #f6f6f6;
  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-color: #637e9a;
  border-radius: 100px;
  color: #fff;
  display: inline-block;
  font-size: 1.2rem;
  padding: 10px 24px;
}

/* ホバーアクション */
@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-color: #f6f6f6;
  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-color: #637e9a;
  border-radius: 100px;
  color: #fff;
  display: block;
  font-size: 1.7rem;
  font-weight: 700;
  padding: 19px 24px;
  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-color: #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: #1a1a1a;
    border-radius: 50%;
    display: block;
    width: 30px;
    height: 30px;
    position: absolute;
    top: -10px;
    left: -10px;
    cursor: pointer;
  }
  #cta-fixed #cta-fixedbtn::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%20viewBox%3D%220%200%209.9%209.9%22%3E%3Cpath%20d%3D%22M8.485%200%204.95%203.536%201.414%200%200%201.414%203.536%204.95%200%208.485%201.414%209.9%204.95%206.364%208.485%209.9%209.9%208.485%206.364%204.95%209.9%201.414Z%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%209.9%209.9%22%3E%3Cpath%20d%3D%22M8.485%200%204.95%203.536%201.414%200%200%201.414%203.536%204.95%200%208.485%201.414%209.9%204.95%206.364%208.485%209.9%209.9%208.485%206.364%204.95%209.9%201.414Z%22%2F%3E%3C%2Fsvg%3E") no-repeat center/12px 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: #b31d1d;
  border-radius: 0.25em;
  color: #fff;
  display: inline-block;
  font-size: 0.75em;
  line-height: 1;
  margin-left: 1em;
  padding: 0.333333em 0.5em;
  position: relative;
  top: -0.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-color: var(--clr-form-bg, #f7f8fa);
  border: 1px solid var(--clr-border, #ebebed);
  border-radius: 1px;
  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, #1cadff);
}
.form input[type="text"],
.form input[type="email"],
.form input[type="tel"] {
  padding: 0 1em;
  line-height: 3.125em;
  height: 3.125em;
}
.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: 0.25em 0 0.25em 1.75em;
  position: relative;
  transition: color .1s linear;
  vertical-align: middle;
  max-width: 100%;
}
.form input[type=checkbox] + span::before {
  background-color: #fff;
  border-width: 0.0625em;
  content: '';
  display: block;
  position: absolute;
  top: 0.25em;
  left: 0.25em;
  transition: background-color .1s linear;
  width: 1.125em;
  height: 1.125em;
}
.form input[type=checkbox] + span::after {
  border-bottom: 0.125em solid var(--clr-accent, #1cadff);
  border-right: 0.125em solid var(--clr-accent, #1cadff);
  content: '';
  display: block;
  opacity: 0;
  position: absolute;
  top: 0.375em;
  left: 0.625em;
  transform: rotate(45deg);
  width: 0.4375em;
  height: 0.625em;
}
.form input[type=checkbox]:checked + span::after {
  opacity: 1;
}
.form input[type="submit"] {
  background-color: var(--clr-accent, #1cadff);
  border-radius: 5em;
  box-shadow: 0 0.25em 0.2em rgba(0, 0, 0, 0.16);
  cursor: pointer;
  color: #fff;
  font-size: 1.125em;
  line-height: 1.5;
  display: block;
  padding: 1em 0;
  margin-left: auto;
  margin-right: auto;
  max-width: 256px;
  width: 100%;
}

[data-color*="clr-form-bg"] .form input[type="text"],
[data-color*="clr-form-bg"] .form input[type="email"],
[data-color*="clr-form-bg"] .form input[type="tel"],
[data-color*="clr-form-bg"] .form textarea {
  border-width: 0;
}

@media (min-width: 1025px) {
  .form .agree {
    text-align: center;
  }
  .form input[type="submit"] {
    transition: 0.2s;
  }
  .form input[type="submit"]:hover {
    opacity: 0.5;
  }
}
/* 注釈 */
.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) {
  #space7 {
    display: flex;
    gap: 1em;
  }
}
#space8 .space-box:not(:first-child) {
  margin-top: 2em;
}

/*
==================================================
ヘッダー画像
==================================================
*/
/* 全体設定
==================================================
*/
[data-headerimg-type="header"] #headerimg {
  position: relative;
  z-index: 0;
}
[data-headerimg-type="header"] #headerimg::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 {
  text-align: center;
  line-height: 0;
}
.headerimg-img img {
  width: 100%;
  height: var(--h-hdr-sp, 100%);
  object-fit: cover;
}

.headerimg-item {
  max-height: 100%;
}
.headerimg-item a {
  display: contents;
}
.headerimg-item img {
  max-height: 100%;
  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: grid;
  gap: 1em;
}

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

@media (max-width: 1024px) {
  [data-headerimg-desc-sp="true"] .headerimg-title {
    border-bottom-width: 2px;
    padding-bottom: 0.6em;
  }
}
@media (min-width: 1025px) {
  [data-headerimg-desc="true"] .headerimg-title {
    border-bottom-width: 2px;
    padding-bottom: 0.6em;
  }
}
[data-page*="other"] .headerimg-title {
  border-bottom-width: 2px;
  padding-bottom: 0.6em;
}

.headerimg-desc {
  font-size: clamp(1.4rem, 3.88888vw, 1.6rem);
  line-height: 1.6;
}

@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 {
  color: var(--clr-headerimg-txt, var(--clr-body-txt, inherit));
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 1em;
}
.headerimg-meta .date.updated::before {
  background-color: var(--clr-headerimg-txt, var(--clr-body-txt, #333));
}

@media (max-width: 1024px) {
  [data-headerimg-type="header"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) #headerimg {
    height: var(--h-hdr-sp);
    overflow: hidden;
  }
  [data-headerimg-type="header"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) #headerimg::before {
    display: block;
  }
  [data-headerimg-type="header"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-inner {
    padding: var(--padding-overall);
    height: var(--h-hdr-sp);
  }
  [data-headerimg-type="header"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-item {
    text-align: center;
  }
  [data-headerimg-type="header"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-txt {
    color: var(--clr-headerimg-txt, #fff);
  }
  [data-headerimg-type="header"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-title {
    border-bottom-width: 0;
    padding: 0;
  }
  [data-headerimg-type="header"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-meta .author-name,
  [data-headerimg-type="header"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-meta .date {
    opacity: 1;
  }
  [data-headerimg-type="header"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-meta .date.updated::before {
    background-color: var(--clr-headerimg-txt, #fff);
    opacity: 1;
  }

  [data-header="fixed"]:not([data-headerimg-img-sp="false"])#body #headerimg::before {
    display: block;
    grid-row: 1/2;
    grid-column: 1/2;
  }

  [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::before {
    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-type="header"] #headerimg {
    height: var(--h-hdr-pc);
    overflow: hidden;
  }
  [data-headerimg-type="header"] #headerimg::before {
    display: block;
  }
  [data-headerimg-type="header"] .headerimg-inner {
    padding: min(var(--padding-overall),72px);
    height: var(--h-hdr-pc);
  }
  [data-headerimg-type="header"] .headerimg-item {
    text-align: center;
  }
  [data-headerimg-type="header"] .headerimg-txt {
    color: var(--clr-headerimg-txt, #fff);
  }
  [data-headerimg-type="header"] .headerimg-title {
    border-bottom-width: 0;
    padding: 0;
  }
  [data-headerimg-type="header"] .headerimg-meta .author-name,
  [data-headerimg-type="header"] .headerimg-meta .date {
    opacity: 1;
  }
  [data-headerimg-type="header"] .headerimg-meta .date.updated::before {
    background-color: var(--clr-headerimg-txt, #fff);
    opacity: 1;
  }

  [data-header="fixed"]#body #headerimg::before {
    display: block;
  }

  [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::before {
    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;
  }
}
/* コンテンツ画像 */
#headerimg {
  display: grid;
  gap: 2em;
}

.headerimg-inner {
  display: contents;
}

@media (min-width: 1025px) {
  .headerimg-img img {
    height: var(--h-hdr-pc, 100%);
  }
}
/* サムネイル画像・ヘッダー画像 */
@media (max-width: 1024px) {
  [data-headerimg-type="header"][data-headerimg-img-sp="true"]:not([data-headerimg-title-sp="under"]) #headerimg {
    gap: 0;
  }
  [data-headerimg-type="header"][data-headerimg-img-sp="true"]:not([data-headerimg-title-sp="under"]) .headerimg-img,
  [data-headerimg-type="header"][data-headerimg-img-sp="true"]:not([data-headerimg-title-sp="under"]) .headerimg-inner {
    grid-row: 1/2;
    grid-column: 1/2;
  }
  [data-headerimg-type="header"][data-headerimg-img-sp="true"]:not([data-headerimg-title-sp="under"]) .headerimg-inner {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 2em;
    position: relative;
    z-index: 0;
  }
  [data-headerimg-type="header"][data-headerimg-img-sp="true"]:not([data-headerimg-title-sp="under"]) .headerimg-txt {
    width: 100%;
  }
  [data-headerimg-type="header"][data-headerimg-img-sp="true"]:not([data-headerimg-title-sp="under"]) .headerimg-item {
    text-align: center;
  }
}
@media (min-width: 1025px) {
  [data-headerimg-type="header"] #headerimg {
    gap: 0;
    position: relative;
  }
  [data-headerimg-type="header"] .headerimg-img,
  [data-headerimg-type="header"] .headerimg-inner {
    grid-row: 1/2;
    grid-column: 1/2;
  }
  [data-headerimg-type="header"] .headerimg-inner {
    display: flex;
    align-items: center;
    position: relative;
    z-index: 0;
    gap: 3vw;
  }
  [data-headerimg-type="header"] .headerimg-item {
    display: flex;
    justify-content: center;
    flex-shrink: 0;
    width: 47%;
  }
  [data-headerimg-type="header"] .headerimg-txt {
    text-align: left;
    max-width: 70%;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
  [data-headerimg-type="header"] .headerimg-item {
    text-align: center;
  }
}
/* ヘッダー画像（ワイド） */
@media (max-width: 1024px) {
  [data-main-header*="wide"][data-headerimg-img-sp="false"] #headerimg {
    margin-top: var(--margin-layout);
    padding-left: var(--padding-overall);
    padding-right: var(--padding-overall);
  }
}
@media (min-width: 1025px) {
  [data-main-header*="wide"] .headerimg-inner {
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--padding-overall);
    padding-right: var(--padding-overall);
    max-width: calc(var(--width-overall) + calc(var(--padding-overall) * 2));
    width: 100%;
  }
}
/* ヘッダー画像（ヘッダーワイド+上部固定） */
@media (max-width: 1024px) {
  [data-header="fixed"]:not([data-headerimg-img-sp="false"]) #headerimg .headerimg-inner {
    padding-top: calc(64px + var(--padding-overall));
  }
}
@media (min-width: 1025px) {
  [data-header="fixed"]:not([data-headerimg-img="false"]) #headerimg .headerimg-inner {
    padding-top: calc(104px + 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"] .headerimg-txt {
    width: 50%;
    margin-left: 0;
  }

  /* 右揃え */
  [data-headerimg-title="right"][data-headerimg-type="header"] .headerimg-txt {
    width: 50%;
    margin-right: 0;
  }

  /* 中央揃え */
  [data-headerimg-title="center"][data-headerimg-type="header"] .headerimg-txt {
    text-align: center;
  }
  [data-headerimg-title="center"][data-headerimg-type="header"] .headerimg-meta {
    justify-content: center;
  }

  /* 非表示 */
  [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="right"][data-headerimg-type="header"] .headerimg-item {
    order: 1;
    margin-left: 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;
  }
}
/* ヘッダーテキスト */
@media (max-width: 1024px) {
  /*画像下に表示 */
  [data-headerimg-title-sp="under"][data-headerimg-type="header"][data-headerimg-img-sp="true"]:not([data-headerimg-item-sp="false"]) .headerimg-img {
    grid-row: 1/2;
    grid-column: 1/2;
  }
  [data-headerimg-title-sp="under"][data-headerimg-type="header"][data-headerimg-img-sp="true"]:not([data-headerimg-item-sp="false"]) .headerimg-item {
    display: flex;
    justify-content: center;
    align-items: center;
    grid-row: 1/2;
    grid-column: 1/2;
    position: relative;
    background-color: var(--clr-headerimg-overlay, rgba(0, 0, 0, 0.3));
    height: var(--h-hdr-sp);
    overflow: hidden;
  }
  [data-headerimg-title-sp="under"][data-headerimg-type="header"][data-headerimg-img-sp="true"]:not([data-headerimg-item-sp="false"]) .headerimg-item img {
    margin: var(--padding-overall);
    max-width: calc(100% - calc(var(--padding-overall) * 2));
    max-height: calc(100% - calc(var(--padding-overall) * 2));
  }

  [data-headerimg-title-sp="under"][data-main-header*="wide"][data-headerimg-img-sp="true"] .headerimg-txt {
    padding: 0 var(--padding-overall);
  }

  [data-headerimg-title-sp="under"][data-header="fixed"][data-headerimg-img-sp="true"] .headerimg-inner .headerimg-item {
    background-color: transparent;
  }
  [data-headerimg-title-sp="under"][data-header="fixed"][data-headerimg-img-sp="true"] .headerimg-inner .headerimg-item img {
    margin-top: calc(64px + var(--padding-overall));
    max-height: calc(100% - calc(var(--padding-overall) + calc(64px + var(--padding-overall))));
  }

  /* 非表示 */
  [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,
.menubox > .title,
#pickupentry > .title,
.newentry-title,
.space-box > .title {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.5;
  margin: var(--margin-component) 0;
}
#whatsnew .title i,
[class*='categorylist'] .title i,
.entrylist-title i,
.blogarea .title i,
#searchresult .title i,
.menubox > .title i,
#pickupentry > .title i,
.newentry-title i,
.space-box > .title i {
  font-size: 1.2rem;
  font-style: normal;
  margin-left: 1em;
  position: relative;
  top: -0.2rem;
}

#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;
}

[class*='categorylist'] .title,
.entrylist-title,
.blogarea .title,
#searchresult .title,
.menubox > .title,
#pickupentry > .title,
.newentry-title,
#main .space-box > .title,
#menu .space-box > .title,
#rmenu .space-box > .title {
  display: flex;
  align-items: center;
}
[class*='categorylist'] .title::after,
.entrylist-title::after,
.blogarea .title::after,
#searchresult .title::after,
.menubox > .title::after,
#pickupentry > .title::after,
.newentry-title::after,
#main .space-box > .title::after,
#menu .space-box > .title::after,
#rmenu .space-box > .title::after {
  border-top-width: 1px;
  content: '';
  flex-grow: 1;
  margin-left: 1.5rem;
}

.menubox > .title,
#pickupentry > .title,
.newentry-title,
#menu .space-box > .title,
#rmenu .space-box > .title {
  background-color: var(--clr-menutitle-bg, transparent);
  color: var(--clr-menutitle-txt, var(--clr-main, #1f2d3d));
}

[data-color*="clr-menutitle-bg"] .menubox > .title,
[data-color*="clr-menutitle-bg"] #pickupentry > .title,
[data-color*="clr-menutitle-bg"] .newentry-title,
[data-color*="clr-menutitle-bg"] #menu .space-box > .title,
[data-color*="clr-menutitle-bg"] #rmenu .space-box > .title {
  padding: .77777em .88888em;
}
[data-color*="clr-menutitle-bg"] .menubox > .title::after,
[data-color*="clr-menutitle-bg"] #pickupentry > .title::after,
[data-color*="clr-menutitle-bg"] .newentry-title::after,
[data-color*="clr-menutitle-bg"] #menu .space-box > .title::after,
[data-color*="clr-menutitle-bg"] #rmenu .space-box > .title::after {
  display: none;
}

[data-column="col2"][data-color*="clr-menutitle-bg"] #menu .space-box > .title + .menulist > ul:not([class="submenu-image"]),
[data-column="col2"][data-color*="clr-menutitle-bg"] #rmenu .space-box > .title + .menulist > ul:not([class="submenu-image"]),
[data-column="col3"][data-color*="clr-menutitle-bg"] #menu .space-box > .title + .menulist > ul:not([class="submenu-image"]),
[data-column="col3"][data-color*="clr-menutitle-bg"] #rmenu .space-box > .title + .menulist > ul:not([class="submenu-image"]),
[data-column="col1"][data-color*="clr-menutitle-bg"][data-color*="clr-menu-bg"] #menu .space-box > .title + .menulist > ul:not([class="submenu-image"]),
[data-column="col1"][data-color*="clr-menutitle-bg"][data-color*="clr-menu-bg"] #rmenu .space-box > .title + .menulist > ul:not([class="submenu-image"]) {
  margin-top: -1.2857em;
}

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

[data-color*="clr-contenttitle-bg"] #whatsnew .title,
[data-color*="clr-contenttitle-bg"] [class*='categorylist'] .title,
[data-color*="clr-contenttitle-bg"] .entrylist-title,
[data-color*="clr-contenttitle-bg"] .blogarea .title,
[data-color*="clr-contenttitle-bg"] #searchresult .title,
[data-color*="clr-contenttitle-bg"] #main .space-box > .title {
  padding: .77777em .88888em;
}
[data-color*="clr-contenttitle-bg"] #whatsnew .title::after,
[data-color*="clr-contenttitle-bg"] [class*='categorylist'] .title::after,
[data-color*="clr-contenttitle-bg"] .entrylist-title::after,
[data-color*="clr-contenttitle-bg"] .blogarea .title::after,
[data-color*="clr-contenttitle-bg"] #searchresult .title::after,
[data-color*="clr-contenttitle-bg"] #main .space-box > .title::after {
  display: none;
}

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

h2 {
  font-size: clamp(1.9rem, 5.27777vw, 2.6rem);
  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 {
  border-bottom-width: 2px;
  padding-bottom: 0.6em;
}

h2:not([class*="topic"]) {
  background-color: var(--clr-articletitle-bg, var(--clr-base, #f7f8fa));
  color: var(--clr-articletitle-txt, var(--clr-main, #1f2d3d));
  margin-top: 1.5em;
  padding: .80769em 1em;
}
h2:not([class*="topic"]) i {
  color: var(--clr-accent, #1cadff);
  margin-bottom: .1em;
}

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

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

h3:not([class*="topic"]) {
  border-bottom: 0.125em solid var(--clr-main, #1f2d3d);
  margin-top: 1.5em;
  padding-bottom: 0.6em;
}

.top_inner h3 {
  border: unset;
  margin-top: unset;
  padding-bottom: unset;
}

h4:not([class*="topic"]) {
  border-left: 0.18181em solid var(--clr-main, #1f2d3d);
  padding-left: 0.6em;
}

h5:not([class*="topic"]) {
  position: relative;
  padding-left: 1em;
}
h5:not([class*="topic"])::before {
  background-color: var(--clr-main, #1f2d3d);
  border-radius: 0.05em;
  content: '';
  position: absolute;
  top: 0.45em;
  left: 0;
  width: 0.6em;
  height: 0.6em;
}

h6:not([class*="topic"]) {
  padding-left: 1em;
  position: relative;
}
h6:not([class*="topic"])::before {
  background-color: var(--clr-main, #1f2d3d);
  -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.586%2011.172%22%3E%3Cpath%20d%3D%22M6.293%204.879a1%201%200%200%201%200%201.414l-4.586%204.586A1%201%200%200%201%200%2010.172V1A1%201%200%200%201%201.707.293Z%22%2F%3E%3C%2Fsvg%3E") no-repeat center left/auto 0.77777em;
  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.586%2011.172%22%3E%3Cpath%20d%3D%22M6.293%204.879a1%201%200%200%201%200%201.414l-4.586%204.586A1%201%200%200%201%200%2010.172V1A1%201%200%200%201%201.707.293Z%22%2F%3E%3C%2Fsvg%3E") no-repeat center left/auto 0.77777em;
  content: '';
  display: block;
  position: absolute;
  top: .2222em;
  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.5em 0;
}

/*
==================================================
最新記事
==================================================
*/
.newentry {
  display: grid;
  flex-direction: column;
  grid-template-columns: repeat(auto-fill, minmax(min(100%,200px), 1fr));
  gap: var(--margin-component);
}

.newentry .article .date {
  font-size: 1rem;
}
.newentry .article .cat {
  margin-left: 1em;
}
.newentry .article .cat a {
  background-color: transparent;
  color: inherit;
  line-height: 1;
  opacity: .5;
  text-decoration: none;
  padding: 0;
}
.newentry .article-inner {
  display: flex;
  gap: 12px 16px;
}
.newentry .article-thumb {
  flex-shrink: 0;
  width: 120px;
}
.newentry .article-thumb img {
  width: 100%;
  aspect-ratio: 3 / 2;
  object-fit: cover;
}
.newentry .article-thumb + .article-body {
  border: none;
  padding: 0;
}
.newentry .article-body {
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex-grow: 1;
  border-bottom-width: 1px;
  padding-bottom: 1em;
}
.newentry .article-title {
  color: inherit;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.4;
}
.newentry .article-title a {
  color: inherit;
  text-decoration: none;
}
.newentry .article-info {
  font-size: 1rem;
  display: flex;
  align-items: center;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  .newentry .article a {
    transition: 0.2s;
  }
  .newentry .article a:hover {
    opacity: 0.5;
  }

  [data-column="col1"] .newentry .article-inner {
    flex-direction: column;
  }
  [data-column="col1"] .newentry .article-thumb {
    width: auto;
  }
}
/* ページリスト
==================================================
*/
.pagelist_ul {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 1em;
  line-height: 1;
}

/* ナビゲーション（前後の記事）
==================================================
*/
#relNavigate {
  display: grid;
  gap: 1em;
  grid-template-columns: repeat(auto-fit, minmax(min(100%,300px), 1fr));
}
#relNavigate a {
  background-color: #fff;
  border-radius: 12px;
  box-shadow: rgba(34, 45, 57, 0.08) 0 0 0 1px;
  color: inherit;
  display: flex;
  align-items: center;
  overflow: hidden;
  text-decoration: none;
}

.relNavigate-thumb {
  flex-shrink: 0;
  width: 26%;
  height: 100%;
}
.relNavigate-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.relNavigate-body {
  display: flex;
  flex-wrap: wrap;
  overflow: hidden;
  line-height: 1;
  padding: 22px 16px;
}

.relNavigate-caption {
  font-size: 1.2rem;
  font-style: normal;
  position: relative;
  margin-bottom: 10px;
}
.relNavigate-caption::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%2011.191%2018.974%22%3E%3Cpath%20d%3D%22m1%2018.68-.706-.71a1%201%200%200%201%200-1.413l7.069-7.072-7.069-7.07A1%201%200%200%201%20.292%201L1%20.293a1%201%200%200%201%201.414%200l7.731%207.735a.46.46%200%200%201%20.046.043l.706.709a1%201%200%200%201%200%201.413L2.416%2018.68a1%201%200%200%201-1.414%200%22%2F%3E%3C%2Fsvg%3E") no-repeat center/auto 0.83333em;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2011.191%2018.974%22%3E%3Cpath%20d%3D%22m1%2018.68-.706-.71a1%201%200%200%201%200-1.413l7.069-7.072-7.069-7.07A1%201%200%200%201%20.292%201L1%20.293a1%201%200%200%201%201.414%200l7.731%207.735a.46.46%200%200%201%20.046.043l.706.709a1%201%200%200%201%200%201.413L2.416%2018.68a1%201%200%200%201-1.414%200%22%2F%3E%3C%2Fsvg%3E") no-repeat center/auto 0.83333em;
  content: '';
  position: absolute;
  top: 0;
  width: 1em;
  height: 1em;
}

.relNavigate-prev .relNavigate-caption {
  padding-left: 1.3em;
}
.relNavigate-prev .relNavigate-caption::before {
  left: 0;
  transform: scale(-1, 1);
}

.relNavigate-next .relNavigate-caption {
  padding-right: 1.3em;
}
.relNavigate-next .relNavigate-caption::before {
  right: 0;
}

.relNavigate-title {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  overflow: hidden;
  font-size: 1.4rem;
  width: 100%;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  #relNavigate a,
  #relNavigate .relNavigate-thumb::after {
    transition: all 0.3s cubic-bezier(0.23, 1, 0.32, 1);
  }
  #relNavigate a:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 15px 0 rgba(30, 45, 62, 0.04), 0 0 50px 0 rgba(31, 44, 60, 0.1);
  }
  #relNavigate a:hover .relNavigate-thumb {
    opacity: 0.5;
  }
}
/*
==================================================
ページトップ
==================================================
*/
#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, var(--clr-main, #000));
  border-radius: 50%;
  display: block;
  opacity: .6;
  position: relative;
  width: 48px;
  height: 48px;
}
#pagetop a::before {
  background-color: var(--clr-pagetop-icon, #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%2018.974%2011.191%22%3E%3Cpath%20d%3D%22m18.68%2010.192-.71.706a1%201%200%200%201-1.413%200L9.485%203.829l-7.07%207.072a1%201%200%200%201-1.415%200l-.706-.706a1%201%200%200%201%200-1.414l7.734-7.736a.46.46%200%200%201%20.043-.044L8.78.293a1%201%200%200%201%201.413%200l8.487%208.483a1%201%200%200%201%200%201.414%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%20viewBox%3D%220%200%2018.974%2011.191%22%3E%3Cpath%20d%3D%22m18.68%2010.192-.71.706a1%201%200%200%201-1.413%200L9.485%203.829l-7.07%207.072a1%201%200%200%201-1.415%200l-.706-.706a1%201%200%200%201%200-1.414l7.734-7.736a.46.46%200%200%201%20.043-.044L8.78.293a1%201%200%200%201%201.413%200l8.487%208.483a1%201%200%200%201%200%201.414%22%2F%3E%3C%2Fsvg%3E") no-repeat center/19px 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;
  }
}
/*
==================================================
人気の記事
==================================================
*/
/* カウンター */
#pickupentry {
  counter-reset: pickuprank;
}

.pickup_rank {
  counter-increment: pickuprank;
}

[id^="pickup_list"] {
  display: grid;
  gap: var(--margin-component);
}

[id*="pickup_list"] .article-inner {
  display: flex;
  gap: 12px 16px;
}
[id*="pickup_list"] .article-thumb {
  flex-shrink: 0;
  width: 120px;
}
[id*="pickup_list"] .article-thumb img {
  width: 100%;
  aspect-ratio: 3 / 2;
  object-fit: cover;
}
[id*="pickup_list"] .article-body {
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex-grow: 1;
}
[id*="pickup_list"] .article-title {
  color: inherit;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.4;
}
[id*="pickup_list"] .article-title a {
  color: inherit;
  text-decoration: none;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  #pickupentry .article a {
    transition: 0.2s;
  }
  #pickupentry .article a:hover {
    opacity: 0.5;
  }
}
/* ランキング
==================================================
*/
.pickup_rank::before {
  background: #f6f6f6;
  color: #333;
  content: counter(pickuprank);
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: 700;
}
.pickup_rank.pickup_1::before {
  background: #fc7d86;
  color: #fff;
}
.pickup_rank.pickup_2::before {
  background: #fb9266;
  color: #fff;
}
.pickup_rank.pickup_3::before {
  background: #f6c93c;
  color: #fff;
}

/* デザイン01
==================================================
*/
[id="pickup_list1"] {
  grid-template-columns: repeat(auto-fill, minmax(min(100%,400px), 1fr));
}
[id="pickup_list1"] .pickup_rank {
  display: flex;
  gap: 0 4px;
}
[id="pickup_list1"] .pickup_rank::before {
  border-radius: 2px;
  font-size: 1.3rem;
  width: 18px;
  flex-shrink: 0;
}

/* デザイン02
==================================================
*/
[id="pickup_list2"] {
  grid-template-columns: repeat(auto-fill, minmax(min(100%,200px), 1fr));
}
[id="pickup_list2"] .pickup_rank {
  position: relative;
}
[id="pickup_list2"] .pickup_rank::before {
  border-radius: 50%;
  font-size: 1.8rem;
  position: absolute;
  left: 3px;
  top: 3px;
  width: 30px;
  height: 30px;
  z-index: 2;
}
[id="pickup_list2"] .article-inner {
  flex-direction: column;
}
[id="pickup_list2"] .article-thumb {
  width: 100%;
}

/*
==================================================
ポイント
==================================================
*/
.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: #409cfa;
  font-size: 1.636363em;
  font-weight: 700;
  line-height: 1;
  margin-right: 0.23274em;
  float: left;
  position: relative;
  top: -0.05555em;
}
.point[data-point]::after {
  content: '';
  display: block;
  clear: both;
}

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

.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: 0.4;
}
.quote::after {
  content: '\201d';
  opacity: 0.4;
}

.postlike-caption {
  font-size: 1.3rem;
  opacity: 0.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: 16px 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 {
    border-top-width: 1px;
    border-bottom-width: 1px;
    padding: 30px;
    flex-direction: row;
    gap: 0 30px;
  }
  .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-size: 1.5em;
  position: absolute;
  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;
  text-align: center;
  font-weight: 700;
  left: 0;
  top: 0;
}

.question1::before {
  background-color: #3f81dc;
}

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

/* デザイン2 */
.question2,
.answer2 {
  padding: .5em 0 .5em 3.4em;
  position: relative;
  min-height: 2.625em;
}
.question2::before,
.answer2::before {
  text-align: center;
  font-weight: 700;
  position: absolute;
  left: 0;
  top: 0.1em;
}

.question2::before {
  color: #3f81dc;
}

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

/* FAQリスト */
.qa-list {
  margin: var(--margin-component) 0;
}
.qa-list > .qa-accordion:not(:first-child) {
  border-top: none;
}

.qa-accordion {
  border-top-width: 1px;
  border-bottom-width: 1px;
}
.qa-accordion .question2,
.qa-accordion .answer2 {
  padding: 1.5em 56px 1.5em 3.4em;
}
.qa-accordion .question2::before,
.qa-accordion .answer2::before {
  top: 0.75em;
}
.qa-accordion .question2::after {
  background-color: #a0a6ac;
  clip-path: polygon(0 43.75%, 43.75% 43.75%, 43.75% 0, 55.75% 0, 55.75% 43.75%, 100% 43.75%, 100% 55.75%, 55.75% 55.75%, 55.75% 100%, 43.75% 100%, 43.75% 55.75%, 0 55.75%);
  content: '';
  position: absolute;
  top: 2em;
  right: 20px;
  width: 16px;
  height: 16px;
  cursor: pointer;
}
.qa-accordion .question2 + .answer2 {
  display: none;
}
.qa-accordion .question2.show::after {
  clip-path: polygon(0 43.75%, 100% 43.75%, 100% 55.75%, 0 55.75%);
}
.qa-accordion .question2.show + .answer2 {
  display: block;
}
.qa-accordion .answer2 {
  background-color: #fafafb;
}

/* ランキングリスト
==================================================
*/
.ranklist {
  margin: var(--margin-component) 0;
}
.ranklist li {
  border-bottom-width: 1px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0 1em;
  padding: 10px 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: 0.5em 0;
}
.rank[data-rank]::before {
  color: #d1d5dd;
  content: attr(data-rank);
  font-size: 1.72222em;
  font-weight: 700;
  line-height: 1;
  float: left;
  margin-right: 0.2em;
  min-width: 0.581em;
  position: relative;
  margin-top: -0.06451em;
}
.rank[data-rank][data-rank='1']::before {
  color: #efb141;
  background: -webkit-linear-gradient(135deg, #efb141, #f5d08d);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.rank[data-rank][data-rank='2']::before {
  color: #a5b2ba;
  background: -webkit-linear-gradient(135deg, #a5b2ba, #cbd2d7);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.rank[data-rank][data-rank='3']::before {
  color: #b17757;
  background: -webkit-linear-gradient(135deg, #b17757, #d1af9c);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.rank[data-rank]::after {
  content: '';
  display: block;
  clear: both;
}

/* ランキングボックス
==================================================
*/
.rankbox {
  margin: 1.5em 0;
}
.rankbox .rank[data-rank] {
  border-bottom-width: 1px;
  font-size: clamp(2rem, 5.55555vw, 2.6rem);
  font-weight: 700;
  line-height: 1.5;
  padding: 0.38461em 0 0.6154em;
  margin: 0;
}
.rankbox .rank[data-rank]::before {
  font-size: 2.46153em;
  margin-top: -0.15625em;
}
.rankbox .rank[data-rank] a {
  color: inherit;
  text-decoration: none;
}
.rankbox .rank[data-rank] i {
  display: block;
  font-size: 1.2rem;
  font-style: normal;
  line-height: 1;
}

.rankbox-container {
  background-color: #fff;
  border: 4px solid #f0f3f5;
  padding: clamp(15px, 4vw, 30px);
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 4.44444vw, 24px) 0;
}

.rankbox-contents {
  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;
}

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

/* 備考 */
.rankbox-notes {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .5em;
}
.rankbox-notes span {
  background-color: #f3fbfd;
  border-radius: 4px;
  color: #2bb3d8;
  display: block;
  font-size: 1rem;
  line-height: 1;
  padding: .66666em;
}

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

/* フリーテキスト */
/* 説明文2 総評 */
.comment {
  background-color: #fff8ea;
}
.comment .comment-inner {
  padding: clamp(16px, 4.44444vw, 30px);
}
.comment .comment-tit {
  color: #f7880d;
  font-size: clamp(1.6rem, 4.44444vw, 1.8rem);
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: .5em;
}
.comment .comment-body {
  font-size: 1em;
  line-height: 1.6;
}

/* ボタン */
.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;
  box-shadow: 0 5px 4px rgba(0, 0, 0, 0.16);
  border-radius: 4px;
  color: #fff;
  display: block;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
  padding: 24px 16px;
  text-decoration: none;
}

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

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

/* ホバーアクション */
@media (min-width: 1025px) {
  .rankbox-more a {
    transition: 0.2s;
  }
  .rankbox-more a:hover {
    opacity: 0.5;
  }
}
/* 画像スライダー（メインコンテンツ用ランキング）
==================================================
*/
.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: rgba(0, 0, 0, 0.35);
  border-radius: 50%;
  display: block;
  width: 32px;
  height: 32px;
  margin: 0 10px;
  text-indent: 200%;
  white-space: nowrap;
  overflow: hidden;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
}
.rslide-arrow .prev::before,
.rslide-arrow .next::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%20viewBox%3D%220%200%2011.191%2018.974%22%3E%3Cpath%20d%3D%22m1%2018.68-.706-.71a1%201%200%200%201%200-1.413l7.069-7.072-7.069-7.07A1%201%200%200%201%20.292%201L1%20.293a1%201%200%200%201%201.414%200l7.731%207.735a.46.46%200%200%201%20.046.043l.706.709a1%201%200%200%201%200%201.413L2.416%2018.68a1%201%200%200%201-1.414%200%22%2F%3E%3C%2Fsvg%3E") no-repeat center/6px 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%2011.191%2018.974%22%3E%3Cpath%20d%3D%22m1%2018.68-.706-.71a1%201%200%200%201%200-1.413l7.069-7.072-7.069-7.07A1%201%200%200%201%20.292%201L1%20.293a1%201%200%200%201%201.414%200l7.731%207.735a.46.46%200%200%201%20.046.043l.706.709a1%201%200%200%201%200%201.413L2.416%2018.68a1%201%200%200%201-1.414%200%22%2F%3E%3C%2Fsvg%3E") no-repeat center/6px 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;
}

/* ランキング（サイド用）
==================================================
*/
.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/star.svg);
  width: 1em;
}
.rate.rate-numonly::before {
  display: none;
}
.rate.rate-num::after {
  font-size: 1.1875em;
  font-style: normal;
  font-weight: 700;
  line-height: 1;
  min-width: 1.36842em;
  text-align: center;
}
.rate.rate-mini::after {
  min-width: .561403em;
}
.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/star_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/star.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/star.svg), url(img/star_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/star.svg), url(img/star.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/star.svg), url(img/star.svg), url(img/star_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/star.svg), url(img/star.svg), url(img/star.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/star.svg), url(img/star.svg), url(img/star.svg), url(img/star_half.svg), url(img/star_empty.svg);
}
.rate.rate3_5.rate-num::after {
  content: '3.5';
}
.rate.rate4::before {
  background-image: url(img/star.svg), url(img/star.svg), url(img/star.svg), url(img/star.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/star.svg), url(img/star.svg), url(img/star.svg), url(img/star.svg), url(img/star_half.svg);
}
.rate.rate4_5.rate-num::after {
  content: '4.5';
}
.rate.rate5::before {
  background-image: url(img/star.svg), url(img/star.svg), url(img/star.svg), url(img/star.svg), url(img/star.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: 4px;
}
.scroll-table .scroll-area > * {
  margin: 0;
}

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

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

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

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

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

/* 縦向き */
.scroll-table[data-scroll-direction="vertical"] .scroll-area {
  overflow-x: hidden;
  overflow-y: auto;
  white-space: normal;
  max-height: 250px;
  padding: 0 4px 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 {
  position: relative;
  height: 48px;
}

.search-keyword {
  display: block;
  height: 100%;
}
.search-keyword input[type="search"] {
  background-color: var(--clr-form-bg, #f7f8fa);
  box-shadow: inset 0 0 0 1px var(--clr-border, #ebebed);
  border-radius: 100px;
  border: none;
  color: var(--clr-form-txt, #333);
  cursor: auto;
  font-size: 1.6rem;
  line-height: 48px;
  padding: 0 48px 0 16px;
  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;
}

[data-color*="clr-form-bg"] .search-keyword input[type="search"] {
  box-shadow: none;
}

.search-submit {
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  width: 48px;
  height: 100%;
}
.search-submit input[type="submit"] {
  background-color: var(--clr-form-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%2016.486%2017.34%22%3E%3Cpath%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 38%/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%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 38%/16px auto;
  overflow: hidden;
  padding: 0;
  text-indent: 200%;
  white-space: nowrap;
  cursor: pointer;
  width: 100%;
  height: 100%;
}

/*
==================================================
サイトマップ
==================================================
*/
#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-color: var(--clr-main, #1f2d3d);
  border-radius: 0.05em;
  content: '';
  position: absolute;
  top: 0.5em;
  left: 0;
  width: 0.6em;
  height: 0.6em;
}
#sitemaps > ul ul a::before {
  content: '\30fb';
  font-size: 1.2em;
  line-height: 1;
  margin-left: -1em;
  top: 0.1em;
  position: absolute;
}
#sitemaps > ul ul ul {
  padding-left: 1em;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  #sitemaps a {
    transition: 0.2s;
  }
  #sitemaps a:hover {
    opacity: 0.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, rgba(51, 51, 51, 0.5)));
  display: flex;
  align-items: center;
  overflow-x: auto;
  white-space: nowrap;
  font-size: 1rem;
  line-height: 1;
  margin: 0 auto;
  padding: 2.8em 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:not(:last-child)::after {
  background-color: var(--clr-siteNavi-txt, var(--clr-body-txt, rgba(51, 51, 51, 0.5)));
  -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%2011.191%2018.974%22%3E%3Cpath%20d%3D%22m1%2018.68-.706-.71a1%201%200%200%201%200-1.413l7.069-7.072-7.069-7.07A1%201%200%200%201%20.292%201L1%20.293a1%201%200%200%201%201.414%200l7.731%207.735a.46.46%200%200%201%20.046.043l.706.709a1%201%200%200%201%200%201.413L2.416%2018.68a1%201%200%200%201-1.414%200%22%2F%3E%3C%2Fsvg%3E") no-repeat center/4px 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%2011.191%2018.974%22%3E%3Cpath%20d%3D%22m1%2018.68-.706-.71a1%201%200%200%201%200-1.413l7.069-7.072-7.069-7.07A1%201%200%200%201%20.292%201L1%20.293a1%201%200%200%201%201.414%200l7.731%207.735a.46.46%200%200%201%20.046.043l.706.709a1%201%200%200%201%200%201.413L2.416%2018.68a1%201%200%200%201-1.414%200%22%2F%3E%3C%2Fsvg%3E") no-repeat center/4px auto;
  content: '';
  display: block;
  margin: 0 0.5em;
  width: 1em;
  height: 1em;
  opacity: 0.4;
  flex-shrink: 0;
}
#siteNavi ul a {
  color: inherit;
  text-decoration: none;
}

/* ホバーアクション */
@media (min-width: 1025px) {
  #siteNavi a {
    transition: 0.2s;
  }
  #siteNavi a:hover {
    opacity: 0.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: rgba(0, 0, 0, 0.25);
  border-radius: 50%;
  display: block;
  width: 40px;
  height: 40px;
  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: #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%2011.191%2018.974%22%3E%3Cpath%20d%3D%22m1%2018.68-.706-.71a1%201%200%200%201%200-1.413l7.069-7.072-7.069-7.07A1%201%200%200%201%20.292%201L1%20.293a1%201%200%200%201%201.414%200l7.731%207.735a.46.46%200%200%201%20.046.043l.706.709a1%201%200%200%201%200%201.413L2.416%2018.68a1%201%200%200%201-1.414%200%22%2F%3E%3C%2Fsvg%3E") no-repeat 52% center/24% 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%2011.191%2018.974%22%3E%3Cpath%20d%3D%22m1%2018.68-.706-.71a1%201%200%200%201%200-1.413l7.069-7.072-7.069-7.07A1%201%200%200%201%20.292%201L1%20.293a1%201%200%200%201%201.414%200l7.731%207.735a.46.46%200%200%201%20.046.043l.706.709a1%201%200%200%201%200%201.413L2.416%2018.68a1%201%200%200%201-1.414%200%22%2F%3E%3C%2Fsvg%3E") no-repeat 52% center/24% auto;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
}

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

.slick-next {
  right: 14px;
}

.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: 34px;
  height: 25%;
  min-height: 56px;
  max-height: 88px;
}

.arrow-rectangle ul[id$="slider_ul"].slide_item .slick-arrow {
  width: 28px;
  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;
  }
}
/* ドット */
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: 2px;
  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: 5px;
  text-indent: 200%;
  white-space: nowrap;
  overflow: hidden;
}
ul.slick-dots button::before {
  background-color: #333;
  border-radius: 50%;
  content: '';
  position: absolute;
  top: 5px;
  left: 5px;
  width: 10px;
  height: 10px;
  opacity: .15;
}
ul.slick-dots button:hover::before {
  opacity: .58;
}
ul.slick-dots .slick-active button::before {
  opacity: 1;
}

/* スライダー(日付) */
ul[id$="slider_ul"] .sliderdate {
  background-color: rgba(255, 255, 255, 0.8);
  color: #333;
  position: absolute;
  top: 6px;
  left: 6px;
  font-size: .8em;
  line-height: 1;
  padding: .4em .5em;
  border-radius: 2px;
}

/* タイトル */
.slidertitle {
  display: block;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

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

/* 中央に大きく表示 */
ul[id$="slider_ul"].slide_center .slidertitle {
  background-color: rgba(0, 0, 0, 0.3);
  -webkit-mask-image: linear-gradient(transparent 0%, black 60%);
  mask-image: linear-gradient(transparent 0%, black 60%);
  font-size: 1.125em;
  padding: 2.4em 1.2em 1.2em;
  position: absolute;
  bottom: 0;
  width: 100%;
  color: #fff;
  text-decoration: none;
}

[data-main-header="header wide"] #main-header ul[id$="slider_ul"].slide_center .slidertitle {
  padding: 1.2em;
}

/*
==================================================
スライダー
==================================================
*/
#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"] a {
  text-decoration: none;
}

[data-main-header*="wide"] #main-header #topslider {
  background: #fff;
}

/* 均等に小さく表示 */
ul[id$="slider_ul"].slide_item a:hover {
  text-decoration: underline;
}

[data-main-header*="wide"] #main-header ul[id$="slider_ul"].slide_item {
  margin-top: var(--margin-layout);
}

/* 中央に大きく表示 */
@media screen and (min-width: 480px) {
  [data-main-header*="wide"] #main-header #topslider.cpadding {
    margin: 0 auto;
    max-width: calc(var(--width-overall) + (48px * 2));
    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;
    margin-right: -12px;
  }
  [data-main-header*="wide"] #main-header #topslider.cpadding .slick-slide {
    margin-right: 12px;
  }
}
/*
==================================================
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, #ebebed);
  border-width: 1px 0;
}
table[data-table*="normal"] th, table[data-table*="normal"] td {
  border-width: 0;
  padding: 1.3em;
  text-align: left;
  vertical-align: top;
}
table[data-table*="normal"] th {
  background: #f7f8fa;
  border-color: var(--clr-border, #ebebed);
  border-right-width: 1px;
  font-weight: normal;
  width: 25%;
}
table[data-table*="normal"] td {
  background: #fff;
}

@media (max-width: 1024px) {
  table[data-table*="normal"] {
    font-size: 1.2rem;
  }
  table[data-table*="normal"] th, table[data-table*="normal"] td {
    border-width: 0;
    display: block;
    padding: 1em;
    width: auto;
  }
}
/* 比較表
==================================================
*/
.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, #ebebed);
  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: #fdaf32;
  border-radius: 4px;
  color: #fff;
  display: block;
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
  padding: 8px;
  text-decoration: none;
}

/* タグ一覧
==================================================
*/
.taglist {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .5em;
}
.taglist .tag {
  background-color: #f7f8fa;
  box-shadow: inset 0 0 0 1px #eff2f6;
  border-radius: 4px;
  color: #333;
  display: block;
  font-size: 1.2rem;
  line-height: 1;
  padding: .66666em;
  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, #1cadff);
    box-shadow: inset 0 0 0 0 #eff2f6;
    color: #fff;
  }
}
/* Twitterタイムライン
==================================================
*/
.twitter_plugin {
  overflow: hidden;
}

/* 口コミ
==================================================
*/
.user1,
.user2 {
  background: #fff;
  border-width: 1px;
  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-color: #fff;
  border-width: 1px;
  display: flex;
  gap: 0 16px;
  margin: var(--margin-component) 0;
  padding: 1.5em;
}

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

.user-body {
  display: flex;
  flex-direction: column;
  gap: 0.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: 0.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;
  }
}
