﻿@charset "UTF-8";
@import url("./css/commonstyles.css");
/* ==========================================================================
   Foundation
   ========================================================================== */
html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
}
body {
  margin: 0;
}
main {
  display: block;
}
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}
hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}
pre {
  font-family: monospace, monospace;
  font-size: 1em;
}
a {
  background-color: transparent;
}
abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted;
}
b,
strong {
  font-weight: bolder;
}
code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}
small {
  font-size: 80%;
}
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sub {
  bottom: -0.25em;
}
sup {
  top: -0.5em;
}
img {
  border-style: none;
}
button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}
button,
input {
  overflow: visible;
}
button,
select {
  text-transform: none;
}
button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}
fieldset {
  padding: 0.35em 0.75em 0.625em;
}
legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  /* 3 */
  white-space: normal;
}
progress {
  vertical-align: baseline;
}
textarea {
  overflow: auto;
}
[type="checkbox"],
[type="radio"] {
  box-sizing: border-box;
  padding: 0;
}
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}
[type="search"] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}
::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}
details {
  display: block;
}
summary {
  display: list-item;
}
template {
  display: none;
}
[hidden] {
  display: none;
}
:root {
  --margin-component: 1em;
  --margin-layout: clamp(24px, 5.55555vw, 48px);
  --padding-overall: 5vw;
  --width-overall: 1230px;
  --width-menu: 300px;
  --width-rmenu: 250px;
  --width-entry: 860px;
  --width-header-col2: 250px;
  --width-header-col2_topmenu-child: 250px;
  --width-colsp-overall: 560px;
}
*,
::before,
::after {
  box-sizing: border-box;
  border: 0 solid var(--clr-border, #e1e1e1);
  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;
}
html, body {
  height: 100%;
}
body {
  background: var(--clr-body-bg, var(--clr-base, #f9f9f7)) url(img/bg.png) repeat center top;
  color: var(--clr-body-txt, #333);
  font-family: 'Noto Serif JP','游明朝',YuMincho,'Hiragino Mincho ProN W3','ヒラギノ明朝 ProN W3','Hiragino Mincho ProN','HG明朝E','ＭＳ Ｐ明朝','ＭＳ 明朝',serif;
  font-size: 1.4rem;
  line-height: 1.7;
}
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;
}
/*
==================================================
カラム
==================================================
*/
/* カラム1
==================================================
*/
/* カラム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"] #topmenu,
[data-column="col1"][data-main="wide"] #headerimg,
[data-column="col1"][data-main="wide"] #siteNavi,
[data-column="col1"][data-main="wide"] #footer {
  --width-overall: none;
}
[data-column="col1"][data-main="wide"] #main > * {
  padding-left: var(--padding-overall);
  padding-right: var(--padding-overall);
}
[data-column="col1"][data-main="wide"] #contents {
  padding: 0;
  max-width: none;
  width: 100%;
}
[data-column="col1"][data-main="wide"] #contents .inner > *:not(#main) {
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--padding-overall);
  padding-right: var(--padding-overall);
  width: auto;
}
[data-column="col1"][data-main="wide"][data-main-header*="wide"] #contents #main-header {
  padding-left: 0;
  padding-right: 0;
  max-width: none;
}
[data-column="col1"][data-main="wide"][data-main-header*="wide"] #main section {
  margin-top: 0;
}
[data-column="col1"][data-main="wide"][data-main-header*="wide"] #main .mainbox + section {
  margin-top: var(--margin-layout);
}
[data-column="col1"][data-main="wide"] #main section {
  border-radius: 0;
  padding: var(--padding-overall);
  margin-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);
}
/* カラム2
==================================================
*/
/* サブメニュー非表示 */
[data-column="col2"] #rmenu {
  display: none;
}
[data-column="col2"] #menu .menubox.display-none {
  display: block;
}
/* カラム3
==================================================
*/
/* スマホ特化型
==================================================
*/
/* カラム1（ワイド） */
[data-column="colsp"][data-main="wide"] #main > *, [data-column="colsp"][data-main="wide"] #main-footer > *, [data-column="colsp"][data-main="wide"] #menu > *, [data-column="colsp"][data-main="wide"] #rmenu > * {
  margin-bottom: var(--margin-layout);
}
[data-column="colsp"][data-main="wide"] #header,
[data-column="colsp"][data-main="wide"] #topmenu,
[data-column="colsp"][data-main="wide"] #headerimg,
[data-column="colsp"][data-main="wide"] #siteNavi,
[data-column="colsp"][data-main="wide"] #footer {
  --width-overall: none;
}
[data-column="colsp"][data-main="wide"] #main > * {
  padding-left: var(--padding-overall);
  padding-right: var(--padding-overall);
}
[data-column="colsp"][data-main="wide"] #contents {
  padding: 0;
  max-width: none;
  width: 100%;
}
[data-column="colsp"][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="colsp"][data-main="wide"][data-main-header*="wide"] #contents #main-header {
  padding-left: 0;
  padding-right: 0;
  max-width: none;
}
[data-column="colsp"][data-main="wide"][data-main-header*="wide"] #main section {
  margin-top: 0;
}
[data-column="colsp"][data-main="wide"][data-main-header*="wide"] #main .mainbox + section {
  margin-top: var(--margin-layout);
}
[data-column="colsp"][data-main="wide"] #main section {
  border-radius: 0;
  padding: var(--padding-overall);
  margin-top: 0;
  margin-bottom: 0;
}
[data-column="colsp"][data-main="wide"] #main section > h2,
[data-column="colsp"][data-main="wide"] #main section .txt-body {
  margin-left: auto;
  margin-right: auto;
  max-width: var(--width-overall);
}
[data-column="colsp"] #pc-contents, [data-column="colsp"] #pc-menu {
  display: none;
}
@media (min-width: 560px) {
  [data-column="colsp"] {
    transition: padding .2s;
    position: relative;
    z-index: 0;
  }
  [data-column="colsp"]::before {
    background-color: var(--bg-color-colsp, var(--clr-base, #f9f9f7));
    background-image: var(--bg-image-colsp, url(img/bg.png));
    background-repeat: var(--bg-repeat-colsp, repeat);
    background-size: var(--bg-size-colsp);
    background-position: center top;
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: -1;
  }
  [data-column="colsp"]::after {
    background-color: #000;
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    opacity: .02;
    z-index: -1;
  }
  [data-column="colsp"] #wrap {
    background-color: var(--clr-body-bg, var(--clr-base, #f9f9f7));
    background-image: var(--bg-image-wrap, url(img/bg.png));
    background-repeat: var(--bg-repeat-wrap, repeat);
    background-attachment: var(--bg-attachment-wrap);
    background-position: center top;
    box-shadow: 0 60px 80px rgba(0, 0, 0, 0.1);
    margin: 0 auto;
    max-width: var(--width-colsp-overall);
    overflow: hidden;
    z-index: 0;
  }
  [data-column="colsp"][data-main-header*="wide"] #main-header {
    margin-left: calc(var(--padding-overall) * -1);
    margin-right: calc(var(--padding-overall) * -1);
  }
  [data-column="colsp"][data-color*="bg-color-colsp"]::after {
    display: none;
  }
}
@media (min-width: 690px) {
  [data-column="colsp"] {
    --padding-overall: 24px;
  }
}
@media (min-width: 1220px) {
  html[data-spmenu="true"] {
    overflow-y: visible;
  }
  html[data-spmenu="true"] #contents {
    pointer-events: auto;
  }
  [data-spmenu="true"] #body[data-column="colsp"] #header::before {
    display: none;
  }
  [data-column="colsp"] {
    padding-top: 40px;
  }
  [data-column="colsp"] #wrap {
    padding-top: 0 !important;
  }
  [data-column="colsp"] #spmenu-btn,
  [data-column="colsp"] #spmenu {
    display: none;
  }
  [data-column="colsp"] #pc-contents {
    color: var(--clr-pc-contents, var(--clr-header-txt1, var(--clr-header-fixed-txt, inherit)));
    display: flex;
    justify-content: center;
    align-items: center;
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: calc(calc(100vw - var(--width-colsp-overall)) / 2);
  }
  [data-column="colsp"] #pc-contents #logo {
    height: auto;
    flex-shrink: 0;
  }
  [data-column="colsp"] #pc-contents #header-lead {
    padding: 0;
  }
  [data-column="colsp"] .pc-contents__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2em;
    padding: 300px 50px 400px;
    max-width: 380px;
    height: 100vh;
    overflow-y: auto;
    -ms-overflow-style: none;
    /* IE, Edge 対応 */
    scrollbar-width: none;
    /* Firefox 対応 */
  }
  [data-column="colsp"] .pc-contents__inner::-webkit-scrollbar {
    /* Chrome, Safari 対応 */
    display: none;
  }
  [data-column="colsp"] #pc-menu {
    color: var(--clr-pc-menu, var(--clr-header-txt1, var(--clr-header-fixed-txt, inherit)));
    display: flex;
    justify-content: center;
    align-items: center;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: calc(calc(100vw - var(--width-colsp-overall)) / 2);
  }
  [data-column="colsp"] #pc-menu #header-menu {
    max-width: 320px;
    width: 100%;
    margin-left: 50px;
    margin-right: 50px;
    padding: 300px 0 400px;
    height: 100vh;
    overflow-y: auto;
    -ms-overflow-style: none;
    /* IE, Edge 対応 */
    scrollbar-width: none;
    /* Firefox 対応 */
  }
  [data-column="colsp"] #pc-menu #header-menu::-webkit-scrollbar {
    /* Chrome, Safari 対応 */
    display: none;
  }
  [data-column="colsp"] #pc-menu .haschild > span::after {
    background-color: var(--clr-pc-menu-icon, var(--clr-topmenu-icon, var(--clr-topmenu-txt, var(--clr-header-txt1, var(--clr-body-txt, #333)))));
  }
}
@media (min-width: 1440px) {
  [data-column="colsp"] {
    padding-left: 120px;
  }
  [data-column="colsp"] #pc-contents {
    width: calc(calc(100vw - var(--width-colsp-overall) + 120px) / 2);
  }
  [data-column="colsp"] #pc-menu {
    width: calc(calc(100vw - var(--width-colsp-overall) - 120px) / 2);
  }
}
[data-fix-spmenu] #footer {
  padding-bottom: 60px;
}
[data-fix-spmenu] #fix-spmenu {
  display: grid;
  visibility: visible;
  max-width: var(--width-colsp-overall);
  margin: 0 auto;
  right: 0;
}
@media (max-width: 1219px) {
  #pagetop {
    display: none;
  }
}
@media (min-width: 1220px) {
  [data-fix-spmenu] #footer {
    padding-bottom: 0;
  }
  [data-fix-spmenu] #fix-spmenu {
    display: none;
    visibility: hidden;
  }
}
@media screen and (min-width: 768px) {
  [data-column="colsp"] ul[id$="slider_ul"].slide_center li img {
    height: 240px;
  }
}
[data-column="colsp"][data-main-header="header wide"] #main-header ul[id$="slider_ul"] li img {
  height: clamp(120px, calc(10rem + ((1vw - 7.68px) * 23.1023)), 180px);
}
[data-column="colsp"][data-main-header="header wide"] #main-header ul[id$="slider_ul"].slide_center li img {
  height: clamp(160px, calc(10rem + ((1vw - 7.68px) * 23.1023)), 240px);
}
@media screen and (min-width: 480px) {
  [data-column="colsp"] ul[id$="slider_ul"].slide_item li img {
    height: 140px;
  }
}
/*
==================================================
ヘッダー（パーツ）
==================================================
*/
/* ロゴ */
#logo {
  color: var(--clr-logo-txt, var(--clr-header-fixed-txt, #333));
  font-weight: 700;
  line-height: 1.5;
}
#logo img {
  display: block;
}
#logo a {
  color: inherit;
  text-decoration: none;
  display: contents;
}
/* ロゴレイアウト用 */
#logo {
  display: flex;
  align-items: center;
  gap: 8px;
  height: 100%;
  overflow: hidden;
}
#logo img {
  max-height: 100%;
}
.logotext {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  flex-shrink: 0;
}
/* リード文 */
#header-lead {
  font-size: 1.2rem;
  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;
  padding: .8em 0;
  position: relative;
  z-index: 0;
  overflow-wrap: anywhere;
}
.topmenu_ul a em {
  display: block;
  font-size: .66666em;
  font-style: normal;
}
.topmenu_ul .haschild {
  position: relative;
}
.topmenu_ul .haschild > span {
  display: block;
  position: relative;
}
.topmenu_ul .haschild > span::after {
  background-color: var(--clr-topmenu-icon, var(--clr-topmenu-txt, var(--clr-header-txt1, var(--clr-body-txt, #333))));
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2011.314%206.364%22%3E%3Cpath%20d%3D%22m10.606%200-4.95%204.95L.707%200%200%20.707l4.95%204.95.707.707L11.313.707Z%22%2F%3E%3C%2Fsvg%3E") no-repeat center/11px auto;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2011.314%206.364%22%3E%3Cpath%20d%3D%22m10.606%200-4.95%204.95L.707%200%200%20.707l4.95%204.95.707.707L11.313.707Z%22%2F%3E%3C%2Fsvg%3E") no-repeat center/11px 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: scale(1, -1);
}
.topmenu_ul .haschild.show > .child {
  height: auto;
  overflow: visible;
  opacity: 1;
}
.topmenu_ul .child {
  padding-left: 1em;
  overflow: hidden;
  opacity: 0;
}
.topmenu_ul .child a {
  padding: .6em 0;
  transition: .3s ease;
}
[data-color*="clr-topmenu-bg"] #topmenu {
  padding: 1em 2em;
}
.topmenu_ul .haschild:not(.show) .child * {
  border-width: 0;
  line-height: 0;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
}
.topmenu_ul .haschild:not(.show) .child img {
  height: 0;
}
.topmenu_ul .haschild:not(.show) .child a {
  opacity: 0;
}
[data-color*="clr-topmenu-bg"] #topmenu {
  padding: 10px 16px;
}
/* ホバーアクション */
@media (hover: hover) {
  #topmenu a {
    transition: 0.2s;
  }
  #topmenu a:hover {
    opacity: 0.5;
  }
}
/* スマホボタン */
#spmenu-btn {
  display: block;
  position: relative;
  margin-left: auto;
  text-indent: 200%;
  white-space: nowrap;
  overflow: hidden;
  width: 44px;
  height: 44px;
  z-index: 100;
  margin-right: -8px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: 0;
  border-radius: 0;
  outline: none;
  padding: 0;
  box-sizing: border-box;
  min-width: 0;
}
#spmenu-btn::before, #spmenu-btn::after,
#spmenu-btn span::before {
  background-color: var(--clr-header-txt1, var(--clr-header-fixed-txt, var(--clr-body-txt, #333)));
  border-radius: 10px;
  content: '';
  margin-left: -11px;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 26px;
  height: 1px;
  transition: .4s ease;
}
#spmenu-btn::before {
  margin-top: -8px;
}
#spmenu-btn::after {
  margin-top: 6px;
  margin-left: -3px;
  width: 18px;
}
#spmenu-btn span::before {
  margin-top: -1px;
}
[data-spmenu="true"] #spmenu-btn::before {
  transform: translateY(7px) rotate(-30deg);
}
[data-spmenu="true"] #spmenu-btn::after {
  transform: translateY(-7px) rotate(30deg);
  margin-left: -11px;
  width: 26px;
}
[data-spmenu="true"] #spmenu-btn span::before {
  opacity: 0;
}
/* スマホメニュー */
#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: 0.8s cubic-bezier(0.19, 1, 0.22, 1);
  height: 100vh;
  height: 100dvh;
}
#spmenu {
  visibility: hidden;
}
#header::before {
  background-color: var(--clr-header-bg1, rgba(255, 255, 255, 0.48));
  -webkit-backdrop-filter: blur(50px);
  backdrop-filter: blur(50px);
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 100vh;
  z-index: 99;
  opacity: 0;
  transition: opacity 1.2s cubic-bezier(0.19, 1, 0.22, 1);
  pointer-events: none;
}
[data-spmenu="true"] #body #header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
}
[data-spmenu="true"] #body #header::before {
  opacity: 1;
  transition: opacity 0.8s cubic-bezier(0.19, 1, 0.22, 1);
  pointer-events: auto;
}
[data-spmenu="true"] #spmenu {
  opacity: 1;
  visibility: visible;
}
[data-spmenu="true"] #body #header {
  max-width: var(--width-colsp-overall);
  margin: 0 auto;
  right: 0;
}
@media (min-width: 560px) {
  [data-spmenu="true"] #spmenu-btn {
    position: fixed;
    right: var(--padding-overall);
  }
}
/* ヘッダーレイアウト（スマホ）
==================================================
*/
#header {
  background-color: var(--clr-header-bg1, transparent);
  color: var(--clr-header-txt1, var(--clr-header-fixed-txt, inherit));
}
[data-main-header]:not([data-main-header*="wide"]):not([data-color*="clr-header-bg1"]):not([data-color*="clr-topmenu-bg"]):not([data-header="row2-center"][data-color*="clr-header-bg2"]):not([data-header="row2"][data-color*="clr-header-bg2"]) #header {
  margin-bottom: calc(var(--margin-layout) / 2 * -1);
}
#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;
}
/* トップ固定（ヘッダーワイドの時）
==================================================
*/
[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::after {
  background-color: rgba(255, 255, 255, 0.48);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  z-index: -1;
}
[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;
}
/* 2カラム
==================================================
*/
/*
==================================================
コンテンツ
==================================================
*/
#contents {
  flex-grow: 1;
  box-sizing: content-box;
  display: flex;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--padding-overall);
  padding-right: var(--padding-overall);
  padding-bottom: calc(var(--margin-layout) * 2);
  width: calc(100% - (var(--padding-overall) * 2));
}
#contents .inner {
  display: flow-root;
  position: relative;
  width: 100%;
}
#main > *, #main-footer > *, #menu > *, #rmenu > * {
  margin-top: var(--margin-layout);
}
/*
==================================================
メインヘッダー（レイアウト）
==================================================
*/
[data-main-header]:not([data-main-header*="wide"]) #main-header > * {
  margin-top: var(--margin-layout);
}
/* ヘッダー横幅ワイド */
[data-main-header*="wide"] #main-header {
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
}
/*
==================================================
メイン（パーツ）
==================================================
*/
/* ワイド化 */
[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;
}
[data-column="colsp"][data-main="wide"] #main section[data-txt-body="wide"] > h2,
[data-column="colsp"][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;
}
.menubox .sitemenu,
#submenu:not([class="submenu-image"]) {
  overflow: hidden;
}
.menubox .sitemenu a,
#submenu:not([class="submenu-image"]) a {
  color: var(--clr-menu-txt, inherit);
  text-decoration: none;
  display: flex;
  align-items: center;
  padding: .8em 0;
}
.menubox .sitemenu .haschild,
#submenu:not([class="submenu-image"]) .haschild {
  position: relative;
}
.menubox .sitemenu .haschild > a,
#submenu:not([class="submenu-image"]) .haschild > a {
  padding-right: 44px;
}
.menubox .sitemenu .haschild::after,
#submenu:not([class="submenu-image"]) .haschild::after {
  background-color: var(--clr-menu-icon, var(--clr-menu-txt, var(--clr-body-txt, #333)));
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2011.314%206.364%22%3E%3Cpath%20d%3D%22m10.606%200-4.95%204.95L.707%200%200%20.707l4.95%204.95.707.707L11.313.707Z%22%2F%3E%3C%2Fsvg%3E") no-repeat center/11px auto;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2011.314%206.364%22%3E%3Cpath%20d%3D%22m10.606%200-4.95%204.95L.707%200%200%20.707l4.95%204.95.707.707L11.313.707Z%22%2F%3E%3C%2Fsvg%3E") no-repeat center/11px auto;
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 44px;
  height: 3.1em;
  cursor: pointer;
}
.menubox .sitemenu .haschild.show::after,
#submenu:not([class="submenu-image"]) .haschild.show::after {
  transform: scale(1, -1);
}
.menubox .sitemenu .haschild.show > .child,
#submenu:not([class="submenu-image"]) .haschild.show > .child {
  height: auto;
  overflow: visible;
  opacity: 1;
}
.menubox .sitemenu .sitemenu_ul,
#submenu:not([class="submenu-image"]) .sitemenu_ul {
  padding-left: 1em;
}
.menubox .sitemenu .sitemenu_ul a,
#submenu:not([class="submenu-image"]) .sitemenu_ul a {
  padding: .6em 0;
}
.menubox .sitemenu .child,
#submenu:not([class="submenu-image"]) .child {
  overflow: hidden;
  opacity: 0;
}
.menubox .sitemenu .child a,
#submenu:not([class="submenu-image"]) .child a {
  transition: .3s ease;
}
.menubox .sitemenu .child .haschild::after,
#submenu:not([class="submenu-image"]) .child .haschild::after {
  height: 2.5em;
}
.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;
}
.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;
}
#menu > .menubox, #rmenu > .menubox, .menuboxlist > .menubox {
  background: var(--clr-menu-bg, #fff);
  padding: 1.25em;
}
/* 月別アーカイブ */
/*
==================================================
サブメニュー（パーツ）
==================================================
*/
/*
==================================================
フッター（パーツ）
==================================================
*/
/* フッターナビ */
#footer-menu {
  font-size: 1.4rem;
  line-height: 1.5;
}
.footer-menu_ul {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  gap: 1em 3em;
}
.footer-menu_ul li {
  max-width: 100%;
}
.footer-menu_ul a {
  color: var(--clr-footermenu-txt, inherit);
  text-decoration: none;
}
.footer-menu_ul .child li {
  margin: 1em 0;
}
.footer-menu_ul .child li a {
  color: var(--clr-footermenu-child-txt, var(--clr-footermenu-txt, var(--clr-footer-txt, rgba(255, 255, 255, 0.75))));
}
/* コピーライト */
#copy {
  font-size: 1.1rem;
  padding: 2.8em;
  position: relative;
  text-align: center;
  width: 100%;
  pointer-events: none;
}
#copy::after {
  border: 1px solid rgba(255, 255, 255, 0.18);
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: 0 calc(-50vw + 50%);
}
/* フッター（レイアウト）
==================================================
*/
#footer {
  background-color: var(--clr-footer-bg, var(--clr-main, #9d9d9b));
  color: var(--clr-footer-txt, #fff);
}
#footer .inner {
  box-sizing: content-box;
  margin: 0 auto;
  padding: 0 var(--padding-overall);
  max-width: var(--width-overall);
  display: flex;
  flex-direction: column;
  gap: 2em;
}
#footer .inner > *:first-child:not(#copy) {
  margin-top: clamp(40px, 11.11111vw, 64px);
}
#footer .inner > *:nth-last-child(2) {
  margin-bottom: calc(clamp(40px, 11.11111vw, 64px) - 2em);
}
/* 中央揃え
==================================================
*/
[data-footer=""] #space8 {
  text-align: center;
}
/* 両端揃え
==================================================
*/
/*
==================================================
ヘッダー（追従機能）
==================================================
*/
@media (max-width: 1219px) {
  html:not([data-spmenu="true"]) #body #header.fix {
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 100;
    transform: translateY(-100%);
    background-color: var(--clr-header-bg1, rgba(255, 255, 255, 0.48));
    -webkit-backdrop-filter: blur(20px);
    backdrop-filter: blur(20px);
  }
  html:not([data-spmenu="true"]) #body #header.fix::after {
    display: none;
  }
  html:not([data-spmenu="true"]) #body #header.fix:not(.show-header) {
    overflow: hidden;
  }
  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);
  }
  #header.fix {
    max-width: var(--width-colsp-overall);
    margin: 0 auto;
    left: 0;
    right: 0;
  }
}
/* ==========================================================================
   page
   ========================================================================== */
/*
==================================================
トップページ
==================================================
*/
#whatsnew .scroll-table {
  background: #fff;
  padding: 2em;
}
#whatsnew li {
  border-bottom-width: 1px;
  padding: 0 0 1em;
  display: flex;
  flex-direction: column;
  align-items: baseline;
  gap: .8em 1.3em;
}
#whatsnew li:not(:last-child) {
  margin-bottom: 1em;
}
.whatsnew-time {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: .2em 1em;
}
.whatsnew-txt {
  font-size: 1.4rem;
  line-height: 1.6;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
.whatsnew-txt a {
  color: inherit;
  text-decoration: none;
}
/*
==================================================
ブログモード
==================================================
*/
.bloglist {
  display: grid;
  margin: var(--margin-component) 0;
  gap: clamp(18px, 5vw, 30px);
  grid-template-rows: max-content;
}
/* カラム変更 */
.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);
}
/*
==================================================
記事（パーツ）
==================================================
*/
/* NEWアイコン */
[data-blog-mark*="new"] {
  position: relative;
  z-index: 1;
}
[data-blog-mark*="new"]::before {
  background-color: #fff;
  border-radius: 50%;
  color: #333;
  content: 'NEW';
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: 'Amiri', serif;
  font-size: 1.3rem;
  font-style: italic;
  font-weight: 700;
  line-height: 1;
  position: absolute;
  top: -10px;
  left: -10px;
  width: 44px;
  height: 44px;
  z-index: 1;
  transform: rotate(-15deg);
}
[data-blog-mark*="new"]::after {
  background: var(--clr-accent, #98838e);
  filter: saturate(180%) opacity(50%);
  mix-blend-mode: multiply;
  border-radius: 50%;
  content: '';
  position: absolute;
  top: -10px;
  left: -10px;
  width: 44px;
  height: 44px;
  z-index: 1;
}
/*
==================================================
記事（デザイン）
==================================================
*/
.blog {
  container-type: inline-size;
}
.blog .blog-inner {
  display: grid;
  gap: 1em;
  text-align: left;
}
.blog .blog-thumb {
  overflow: hidden;
}
.blog .blog-thumb img {
  width: 100%;
  aspect-ratio: 41/27;
  max-height: 270px;
  object-fit: cover;
}
.blog .blog-body {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .8em;
  overflow: hidden;
  position: relative;
}
.blog .blog-info {
  display: contents;
}
.blog .date {
  order: 3;
}
.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;
  width: 100%;
}
.blog .blog-title a {
  color: inherit;
  text-decoration: none;
}
.blog .blog-desc,
.blog .blog-more {
  display: none;
}
/*
==================================================
カテゴリーページ
==================================================
*/
[class^="categorylist"] ul {
  margin: var(--margin-component) 0;
}
[class^="categorylist"] .article-thumb {
  overflow: hidden;
}
[class^="categorylist"] .article-thumb img {
  width: 100%;
  aspect-ratio: 41/27;
  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, 2rem);
  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.4rem;
  line-height: 1.7;
  opacity: .75;
}
[class^="categorylist"] .article-more {
  margin-top: .5em;
  text-align: right;
}
[class^="categorylist"] .article-more a {
  color: inherit;
  font-family: 'Amiri', serif;
  font-size: 1.6rem;
  text-decoration: none;
  text-transform: uppercase;
  position: relative;
}
[class^="categorylist"] .article-more a::before, [class^="categorylist"] .article-more a::after {
  background-color: #333;
  content: '';
  left: -100%;
  top: 50%;
  position: absolute;
  width: 72px;
  height: 1px;
}
[class^="categorylist"] .article-more a::before {
  opacity: .26;
}
[class^="categorylist"] .article-more a::after {
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 0.8s cubic-bezier(0.19, 1, 0.22, 1);
}
/*　カテゴリー一覧（横並び） */
.categorylist ul {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%,300px), 1fr));
  gap: 2em;
}
.categorylist .article {
  position: relative;
}
.categorylist .article-inner {
  display: flex;
  flex-direction: column;
  gap: 1em;
}
.categorylist .article-body {
  display: flex;
  flex-direction: column;
  gap: .5em;
}
/*　カテゴリー一覧（縦並び） */
.categorylist-vertical ul {
  display: grid;
  gap: 2em;
}
.categorylist-vertical .article {
  position: relative;
}
.categorylist-vertical .article-inner {
  display: flex;
  flex-wrap: wrap;
  gap: .5em 1.5em;
}
.categorylist-vertical .article-thumb {
  flex: 1 1 360px;
}
.categorylist-vertical .article-body {
  flex: 9999 1 240px;
  display: flex;
  flex-direction: column;
  gap: .5em;
  padding-top: .5em;
}
/*　カテゴリー一覧（交互） */
.categorylist-alternate {
  container-type: inline-size;
}
.categorylist-alternate ul {
  display: grid;
  gap: 2em;
}
.categorylist-alternate .article {
  position: relative;
}
.categorylist-alternate .article-inner {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%,400px), 1fr));
  gap: 1em 0;
}
.categorylist-alternate .article-body {
  display: flex;
  flex-direction: column;
  gap: .5em;
}
/*
==================================================
エントリー
==================================================
*/
/* 関連記事一覧
==================================================
*/
#entrylist ul {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%,190px), 1fr));
  gap: 1em;
}
#entrylist .article {
  position: relative;
}
#entrylist .article-inner {
  display: flex;
  flex-direction: column;
  gap: 1em;
}
#entrylist .article-thumb {
  flex-shrink: 0;
  overflow: hidden;
}
#entrylist .article-thumb img {
  width: 100%;
  aspect-ratio: 5/3;
  object-fit: cover;
}
#entrylist .article-body {
  display: flex;
  flex-direction: column;
  gap: .5em;
}
#entrylist .article-title {
  color: inherit;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.4;
}
#entrylist .article-title a {
  color: inherit;
  text-decoration: none;
}
#entrylist .article-desc {
  color: inherit;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  font-size: 1.3rem;
  line-height: 1.7;
  opacity: .75;
}
/*
==================================================
サイト内検索
==================================================
*/
#searchresult ul {
  margin: var(--margin-component) 0;
  display: grid;
  gap: 2.5em;
}
#searchresult .article {
  position: relative;
}
#searchresult .article-inner {
  display: flex;
  flex-wrap: wrap;
  gap: .5em 1.5em;
}
#searchresult .article-thumb {
  flex: 1 1 360px;
  overflow: hidden;
}
#searchresult .article-thumb img {
  width: 100%;
  aspect-ratio: 41/27;
  object-fit: cover;
  max-height: 200px;
}
#searchresult .article-body {
  flex: 9999 1 240px;
  display: flex;
  flex-direction: column;
  gap: .5em;
  padding-top: .5em;
}
#searchresult .article-title {
  color: inherit;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  font-size: clamp(1.6rem, 4.44444vw, 2rem);
  font-weight: 700;
  line-height: 1.4;
}
#searchresult .article-title a {
  color: inherit;
  text-decoration: none;
}
#searchresult .article-desc {
  color: inherit;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  font-size: 1.4rem;
  line-height: 1.7;
  opacity: .75;
}
#searchresult .article-more {
  display: none;
}
/*
==================================================
404ページ
==================================================
*/
#notfound .search {
  margin: 2em 0;
}
/* ==========================================================================
   Component
   ========================================================================== */
/* 著者
==================================================
*/
.author {
  display: flex;
  align-items: center;
  gap: .5em;
}
.author-image {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}
.author-image img {
  border-radius: 50%;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.author-body {
  display: flex;
  align-items: center;
  gap: 1em;
}
.author-name {
  font-size: 1.2rem;
  line-height: 1.5;
  opacity: .5;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  overflow: hidden;
}
.author-name a {
  color: inherit;
  text-decoration: none;
}
/* 引用
==================================================
*/
blockquote {
  background: #fff;
  border-left: 1px solid #dbdbda;
  margin: var(--margin-component) 0;
  padding: 2em;
  position: relative;
}
blockquote::before {
  background-image: url(img/blockquote.svg);
  background-position: left center;
  background-repeat: no-repeat;
  background-size: 14px auto;
  content: '';
  display: block;
  margin-bottom: 10px;
  margin-top: -10px;
  width: 1em;
  height: 1em;
}
/* 画像付きボックス共通
==================================================
*/
[class*="alert"] {
  background: #fbf2f5;
}
[class*="accept"] {
  background: #e9f6f6;
}
[class*="attention"] {
  background: #fdf7e8;
}
[class*="hint"] {
  background: #e9f3fc;
}
.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: #d84264;
  background-image: url(img/icon_alert.svg);
  background-size: .8125em;
}
.accept:not(.noimage)::before,
[class*="cbox-accept"] .cbox-caption span::before {
  background-color: #2fada9;
  background-image: url(img/icon_accept.svg);
  background-size: 1em;
}
.attention:not(.noimage)::before,
[class*="cbox-attention"] .cbox-caption span::before {
  background-color: #f7b94e;
  background-image: url(img/icon_attention.svg);
  background-size: .1875em;
}
.thint:not(.noimage)::before,
[class*="cbox-hint"] .cbox-caption span::before {
  background-color: #5398e9;
  background-image: url(img/icon_thint.svg);
  background-size: .3125em;
}
/* 画像付きボックス
==================================================
*/
.alert, .accept, .attention, .thint {
  line-height: 1.5;
  margin: var(--margin-component) 0;
  padding: 2em;
  position: relative;
}
.alert:not(.noimage), .accept:not(.noimage), .attention:not(.noimage), .thint:not(.noimage) {
  padding-left: calc(2em + 2.5em);
}
.alert:not(.noimage)::before, .accept:not(.noimage)::before, .attention:not(.noimage)::before, .thint:not(.noimage)::before {
  top: calc(2em - 0.125em);
  left: 2em;
}
/* キャプション付きボックス共通
==================================================
*/
.cbox-d {
  line-height: 1.5;
  margin: var(--margin-component) 0;
}
.cbox-d .cbox-caption {
  line-height: 1.5;
}
.cbox-d .cbox-caption span {
  display: block;
  font-size: .875em;
  position: relative;
}
.cbox-d .cbox-caption span::before {
  top: 0;
  left: 0;
}
[class*="cbox-alert"] .cbox-caption {
  background: #d84264;
}
[class*="cbox-alert"] .cbox-caption span {
  color: #d84264;
}
[class*="cbox-alert"],
[class*="cbox-alert"] .cbox-caption::before,
[class*="cbox-alert"] .cbox-caption::after {
  border-color: #d84264;
}
[class*="cbox-accept"] .cbox-caption {
  background: #2fada9;
}
[class*="cbox-accept"] .cbox-caption span {
  color: #2fada9;
}
[class*="cbox-accept"],
[class*="cbox-accept"] .cbox-caption::before,
[class*="cbox-accept"] .cbox-caption::after {
  border-color: #2fada9;
}
[class*="cbox-attention"] .cbox-caption {
  background: #f7b94e;
}
[class*="cbox-attention"] .cbox-caption span {
  color: #f7b94e;
}
[class*="cbox-attention"],
[class*="cbox-attention"] .cbox-caption::before,
[class*="cbox-attention"] .cbox-caption::after {
  border-color: #f7b94e;
}
[class*="cbox-hint"] .cbox-caption {
  background: #5398e9;
}
[class*="cbox-hint"] .cbox-caption span {
  color: #5398e9;
}
[class*="cbox-hint"],
[class*="cbox-hint"] .cbox-caption::before,
[class*="cbox-hint"] .cbox-caption::after {
  border-color: #5398e9;
}
/* デザイン01
==================================================
*/
.cbox-d[class*="01"] {
  border-width: 1px;
}
.cbox-d[class*="01"] .cbox-caption {
  background: transparent;
  margin-bottom: -.5em;
  padding: 1.33333em 1.77777em 0;
}
.cbox-d[class*="01"] .cbox-caption span {
  padding-left: 2.5em;
}
.cbox-d[class*="01"] .cbox-body {
  padding: 1.5em 2em;
}
.cbox-alert01 {
  border-color: #f0d5dc;
}
.cbox-accept01 {
  border-color: #c9e0e0;
}
.cbox-attention01 {
  border-color: #f8e5b2;
}
.cbox-hint01 {
  border-color: #bbddf5;
}
/* デザイン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;
}
.cbox-d[class*="02"] .cbox-body {
  padding: 2em;
}
/* デザイン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.77777em;
  padding: .25em 1.1em .25em .5em;
  position: relative;
  top: -1em;
  margin-bottom: -1.25em;
  max-width: calc(100% - 3.555554em);
}
.cbox-d[class*="03"] .cbox-caption span {
  color: #fff;
  padding-left: 1.7857em;
}
.cbox-d[class*="03"] .cbox-body {
  margin-top: -1.125em;
  padding: 2em;
}
/* デザイン04
==================================================
*/
.cbox-d[class*="04"] {
  background: #fff;
  border-width: 2px;
  border-top: none;
  overflow: hidden;
}
.cbox-d[class*="04"] .cbox-caption {
  margin-bottom: 0;
  padding: .625em 1.77777em;
}
.cbox-d[class*="04"] .cbox-caption span {
  color: #fff;
  padding-left: 1.7857em;
}
.cbox-d[class*="04"] .cbox-body {
  padding: 1.5em 2em;
}
/* カテゴリーネーム
==================================================
*/
.cat {
  display: inline-flex;
  align-items: center;
  gap: .4em;
  font-size: 1.1rem;
}
.cat::before {
  background: var(--clr-accent, #98838e);
  border-radius: .9090909em;
  content: '';
  display: block;
  width: .9090909em;
  height: .9090909em;
  flex-shrink: 0;
}
.cat a {
  color: inherit;
  line-height: 2;
  text-decoration: none;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  overflow: hidden;
  position: relative;
}
/* レビューチャート
==================================================
*/
.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: #f5f5f5;
  border-radius: 2px;
  flex-grow: 1;
}
.chart .graph .bar {
  background: #fc9c9a;
  display: block;
  border-radius: 2px;
  height: 8px;
}
.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: #edede9;
  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: #555555;
  border-radius: 100px;
  color: #fff;
  display: inline-block;
  font-size: 1.2rem;
  padding: .5em 1.5em;
}
/* CTA フッターボタン型
==================================================
*/
.cta-footer {
  background: #edede9;
  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: #555555;
  border-radius: 100px;
  color: #fff;
  display: block;
  font-size: 2rem;
  font-weight: 700;
  padding: .8em;
  text-decoration: none;
}
/* CTA追従
==================================================
*/
#cta-fixed {
  display: none;
}
/* 日付
==================================================
*/
.date {
  font-size: 1.2rem;
  line-height: 1;
  padding-left: 1.5em;
  position: relative;
  opacity: .5;
  flex-shrink: 0;
}
.date::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%2014%2014%22%3E%3Cpath%20d%3D%22M0%207a7%207%200%201%201%207%207%207%207%200%200%201-7-7m1.271%200A5.729%205.729%200%201%200%207%201.274%205.729%205.729%200%200%200%201.271%207m7.187%202.359L6.551%207.451A.642.642%200%200%201%206.364%207V3.182a.636.636%200%200%201%201.271%200v3.555l1.723%201.722a.636.636%200%201%201-.9.9Z%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%2014%2014%22%3E%3Cpath%20d%3D%22M0%207a7%207%200%201%201%207%207%207%207%200%200%201-7-7m1.271%200A5.729%205.729%200%201%200%207%201.274%205.729%205.729%200%200%200%201.271%207m7.187%202.359L6.551%207.451A.642.642%200%200%201%206.364%207V3.182a.636.636%200%200%201%201.271%200v3.555l1.723%201.722a.636.636%200%201%201-.9.9Z%22%2F%3E%3C%2Fsvg%3E") no-repeat center left/contain;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 1em;
  height: 1em;
}
.date.updated::before {
  -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;
}
/* 資料請求
==================================================
*/
.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 {
  color: #b31d1d;
  display: inline-block;
  font-size: .75em;
  line-height: 1;
  margin-left: .8em;
  position: relative;
  top: -.05em;
}
.form .item_t span::before {
  content: '\0203B';
}
.form .item_d {
  margin: 0;
}
.form input,
.form textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: 0;
  border-radius: 0;
  font: inherit;
  outline: none;
  box-sizing: border-box;
  min-width: 0;
  color: var(--clr-form-txt, #333);
  font-size: 1.6rem;
}
.form input::placeholder,
.form textarea::placeholder {
  color: var(--clr-form-txt, #5b5b5b);
  opacity: .5;
}
.form input:-ms-input-placeholder,
.form textarea:-ms-input-placeholder {
  color: var(--clr-form-txt, #5b5b5b);
  opacity: .5;
}
.form input::-ms-input-placeholder,
.form textarea::-ms-input-placeholder {
  color: var(--clr-form-txt, #5b5b5b);
  opacity: .5;
}
.form input[type="text"],
.form input[type="email"],
.form input[type="tel"],
.form textarea {
  background: var(--clr-form-bg, #fff);
  border-color: var(--clr-form-bg, #dbdbda);
  border-style: solid;
  border-width: 0 0 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, #98838e);
}
.form input[type="text"],
.form input[type="email"],
.form input[type="tel"] {
  padding: 0 1em;
  line-height: 3.75em;
  height: 3.75em;
}
.form textarea {
  display: block;
  padding: 1em;
  height: 170px;
  resize: vertical;
}
.form input[type=checkbox] {
  display: none;
}
.form input[type=checkbox] + span {
  background-color: transparent;
  cursor: pointer;
  display: inline-block;
  line-height: 1.3;
  padding: .25em 0 .25em 2.25em;
  position: relative;
  transition: color .1s linear;
  vertical-align: middle;
  max-width: 100%;
}
.form input[type=checkbox] + span::before {
  background: #fff;
  border-width: 0.0625em;
  content: '';
  display: block;
  position: absolute;
  top: .125em;
  left: .25em;
  width: 1.5em;
  height: 1.5em;
}
.form input[type=checkbox] + span::after {
  background-color: #554d49;
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2215.916%22%20height%3D%2213.189%22%20viewBox%3D%220%200%2015.916%2013.189%22%3E%3Cpath%20d%3D%22m13.822%200-7.97%208.114L2.088%205.26%200%205.271l4.74%206.19%201.324%201.729%201.364-1.827L15.916%200Z%22%20fill%3D%22%23554d49%22%2F%3E%3C%2Fsvg%3E") no-repeat center/1em auto;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2215.916%22%20height%3D%2213.189%22%20viewBox%3D%220%200%2015.916%2013.189%22%3E%3Cpath%20d%3D%22m13.822%200-7.97%208.114L2.088%205.26%200%205.271l4.74%206.19%201.324%201.729%201.364-1.827L15.916%200Z%22%20fill%3D%22%23554d49%22%2F%3E%3C%2Fsvg%3E") no-repeat center/1em auto;
  content: '';
  display: block;
  opacity: 0;
  position: absolute;
  top: .125em;
  left: .25em;
  width: 1.5em;
  height: 1.5em;
  cursor: pointer;
}
.form input[type=checkbox]:checked + span::after {
  opacity: 1;
}
.form input[type="submit"] {
  background-color: #554d49;
  background-image: url(img/brn_arrow.svg);
  background-position: center right 28px;
  background-repeat: no-repeat;
  background-size: 16px auto;
  border-radius: .25em;
  box-shadow: 0 0.5em 1em rgba(85, 77, 73, 0.24);
  cursor: pointer;
  color: #fff;
  font-size: 1.25em;
  line-height: 1.5;
  display: block;
  padding: 1.4em 0;
  margin-left: auto;
  margin-right: auto;
  max-width: 370px;
  width: 100%;
}
/* 注釈 */
.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;
}
#space8 .space-box:not(:first-child) {
  margin-top: 2em;
}
/*
==================================================
ヘッダー画像
==================================================
*/
/* 全体設定
==================================================
*/
.headerimg-img {
  text-align: center;
  line-height: 0;
  position: relative;
  z-index: 0;
}
.headerimg-img::before {
  background-color: var(--clr-headerimg-overlay, rgba(0, 0, 0, 0.3));
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: none;
}
.headerimg-img img {
  width: 100%;
  height: var(--h-hdr-sp, 100%);
  object-fit: cover;
}
.headerimg-item {
  position: relative;
}
.headerimg-item a {
  display: contents;
}
.headerimg-item img {
  object-fit: contain;
}
.headerimg-item {
  text-align: center;
}
.headerimg-txt {
  color: var(--clr-headerimg-txt, var(--clr-body-txt, inherit));
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 1em;
  overflow: hidden;
  position: relative;
}
.headerimg-title {
  font-size: clamp(2rem, 5.55555vw, 2.8rem);
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
}
[data-headerimg-type=""][data-page*="other"] .headerimg-title {
  padding-bottom: .8em;
  position: relative;
  border-bottom: 1px solid #bebebd;
}
[data-headerimg-type=""][data-page*="other"] .headerimg-title::before {
  border-bottom: 1px solid #bebebd;
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 2px;
}
.headerimg-desc {
  font-size: clamp(1.3rem, 3.61111vw, 1.4rem);
  line-height: 1.9;
  opacity: .75;
}
[data-headerimg-type="header"][data-headerimg-img-sp="true"] .headerimg-desc {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
}
.headerimg-meta {
  display: contents;
}
.headerimg-meta .date::before {
  background-color: var(--clr-headerimg-txt, var(--clr-body-txt, #333));
}
.headerimg-meta .cat {
  order: -1;
}
[data-headerimg-img-sp="false"][data-headerimg-item-sp="false"][data-headerimg-title-sp="false"][data-headerimg-desc-sp="false"][data-headerimg-meta-sp="false"] #headerimg {
  display: none;
}
[data-headerimg-item-sp="false"][data-headerimg-title-sp="false"][data-headerimg-desc-sp="false"][data-headerimg-meta-sp="false"] .headerimg-inner {
  display: none;
}
[data-headerimg-title-sp="false"][data-headerimg-desc-sp="false"][data-headerimg-meta-sp="false"] .headerimg-txt {
  display: none;
}
/* コンテンツ画像 */
[data-headerimg-type=""] #headerimg {
  display: grid;
  gap: 2em;
}
[data-headerimg-type=""] .headerimg-inner {
  display: contents;
}
/* サムネイル画像 */
[data-headerimg-type="header"] #headerimg {
  display: grid;
  overflow: hidden;
}
[data-headerimg-type="header"] .headerimg-img {
  grid-row: 1/2;
  grid-column: 1/2;
}
[data-headerimg-type="header"] .headerimg-inner {
  display: contents;
}
[data-headerimg-type="header"] .headerimg-item {
  display: flex;
  justify-content: center;
  align-items: center;
  grid-row: 1/2;
  grid-column: 1/2;
}
[data-headerimg-type="header"] .headerimg-item img {
  margin: clamp(16px, 4.44444vw, 48px);
  max-width: calc(100% - calc(clamp(16px, 4.44444vw, 48px) * 2));
  max-height: calc(100% - calc(clamp(16px, 4.44444vw, 48px) * 2));
}
[data-headerimg-type="header"] .headerimg-txt {
  padding: clamp(16px, 4.44444vw, 48px);
  position: relative;
}
[data-headerimg-type="header"] .headerimg-txt::before {
  background: var(--clr-accent, #98838e);
  mix-blend-mode: multiply;
  filter: saturate(150%);
  opacity: .5;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
}
[data-headerimg-type="header"] .headerimg-title {
  flex-shrink: 0;
}
[data-headerimg-type="header"]:not([data-headerimg-img-sp="false"]) .headerimg-item {
  height: var(--h-hdr-sp);
  overflow: hidden;
}
[data-headerimg-type="header"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-item-sp="false"]) .headerimg-img::before {
  display: block;
}
/* ヘッダー画像 */
[data-main-header="header"] #headerimg {
  margin-left: calc(var(--padding-overall) * -1);
  margin-right: calc(var(--padding-overall) * -1);
}
[data-main-header="header"] .headerimg-img {
  margin: 0 var(--padding-overall);
}
[data-main-header="header"] .headerimg-item {
  margin: 0 var(--padding-overall);
}
[data-main-header="header"] .headerimg-txt {
  margin-top: -5em;
  padding-top: calc(clamp(16px, 4.44444vw, 48px) + 5em);
}
[data-main-header="header"][data-headerimg-title-sp="false"][data-headerimg-desc-sp="false"][data-headerimg-meta-sp="false"]:not([data-headerimg-img-sp="false"]) #headerimg {
  overflow: visible;
  padding-bottom: min(8vw, 64px);
  position: relative;
}
[data-main-header="header"][data-headerimg-title-sp="false"][data-headerimg-desc-sp="false"][data-headerimg-meta-sp="false"]:not([data-headerimg-img-sp="false"]) #headerimg::before {
  background: var(--clr-accent, #98838e);
  mix-blend-mode: multiply;
  filter: saturate(150%);
  opacity: .5;
  content: '';
  position: absolute;
  top: 50%;
  left: -100vw;
  right: -100vw;
  bottom: 0;
  z-index: -1;
}
/* ヘッダー画像（ワイド） */
[data-main-header*="wide"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) #headerimg {
  height: var(--h-hdr-sp);
}
[data-main-header*="wide"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-img {
  margin: 0;
}
[data-main-header*="wide"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 1em;
  grid-row: 1/2;
  grid-column: 1/2;
  padding: var(--padding-overall);
  height: var(--h-hdr-sp);
}
[data-main-header*="wide"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-item {
  height: auto;
  margin: 0;
}
[data-main-header*="wide"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-item img {
  margin: 0;
  max-width: 100%;
  max-height: 100%;
}
[data-main-header*="wide"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-txt {
  color: var(--clr-headerimg-txt, #fff);
  flex-shrink: 0;
  margin: 0;
  padding: 0;
}
[data-main-header*="wide"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-txt::before {
  display: none;
}
[data-main-header*="wide"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-txt .cat::before {
  background-color: var(--clr-headerimg-txt, #fff);
}
[data-main-header*="wide"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-txt .date::before {
  background-color: var(--clr-headerimg-txt, #fff);
}
[data-main-header*="wide"]:not([data-headerimg-title-sp="false"][data-headerimg-desc-sp="false"][data-headerimg-item-sp="false"][data-headerimg-meta-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-img::before {
  display: block;
}
/* ヘッダー画像（ヘッダーワイド+上部固定） */
[data-header="fixed"][data-main-header*="wide"] #headerimg .headerimg-img::before {
  display: block;
}
[data-header="fixed"]:not([data-headerimg-img-sp="false"]):not([data-headerimg-title-sp="under"]) .headerimg-inner {
  padding-top: calc(64px + var(--padding-overall));
}
/* ヘッダー画像 */
/* 非表示 */
[data-main-header="false"] #headerimg {
  display: none;
}
/* ヘッダーテキスト */
/* スマホ設定
==================================================
*/
/* ヘッダー画像 */
/* 非表示 */
[data-headerimg-img-sp="false"] .headerimg-img {
  display: none;
}
[data-headerimg-img-sp="false"][data-headerimg-type="header"] .headerimg-inner {
  display: grid;
  gap: 1em;
  padding: clamp(16px, 4.44444vw, 48px);
  position: relative;
}
[data-headerimg-img-sp="false"][data-headerimg-type="header"] .headerimg-inner::before {
  background: var(--clr-accent, #98838e);
  mix-blend-mode: multiply;
  filter: saturate(150%);
  opacity: .5;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
[data-headerimg-img-sp="false"][data-headerimg-type="header"] .headerimg-item img {
  margin: 0;
  max-width: 100%;
  max-height: 100%;
}
[data-headerimg-img-sp="false"][data-headerimg-type="header"] .headerimg-txt {
  padding: 0;
  margin-top: 0;
}
[data-headerimg-img-sp="false"][data-headerimg-type="header"] .headerimg-txt::before {
  display: none;
}
[data-headerimg-img-sp="false"][data-main-header*="wide"] .headerimg-inner {
  padding: var(--padding-overall);
}
/* ヘッダーテキスト */
/*画像下に表示 */
[data-headerimg-title-sp="under"][data-main-header*="wide"]:not([data-headerimg-img-sp="false"]) .headerimg-txt {
  padding-left: var(--padding-overall);
  padding-right: var(--padding-overall);
}
[data-headerimg-title-sp="under"][data-header="fixed"]:not([data-headerimg-img-sp="false"]) .headerimg-item img {
  margin-top: calc(64px + clamp(16px, 4.44444vw, 48px));
  max-height: calc(100% - calc(clamp(16px, 4.44444vw, 48px) + calc(64px + clamp(16px, 4.44444vw, 48px))));
}
/* 非表示 */
[data-headerimg-title-sp="false"] .headerimg-title {
  display: none;
}
/* 説明文 */
/* 非表示 */
[data-headerimg-desc-sp="false"] .headerimg-desc {
  display: none;
}
/* 画像アイテム */
/* 非表示 */
[data-headerimg-item-sp="false"] .headerimg-item {
  display: none;
}
/* メタ */
/* 非表示 */
[data-headerimg-meta-sp="false"] .headerimg-meta {
  display: none;
}
/* 見出し
==================================================
*/
/* タイトル */
#whatsnew .title,
[class*='categorylist'] .title,
.entrylist-title,
.blogarea .title,
#searchresult .title,
.space-box > .title {
  font-size: clamp(2rem, 5.55555vw, 2.8rem);
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: var(--margin-component);
}
#whatsnew .title i,
[class*='categorylist'] .title i,
.entrylist-title i,
.blogarea .title i,
#searchresult .title i,
.space-box > .title i {
  font-size: 1.4rem;
  font-style: normal;
  margin-left: 1em;
  position: relative;
  top: -.5rem;
}
#whatsnew .title *:not(i),
[class*='categorylist'] .title *:not(i),
.entrylist-title *:not(i),
.blogarea .title *:not(i),
#searchresult .title *:not(i),
.space-box > .title *:not(i) {
  display: contents;
  font-size: inherit;
}
#whatsnew .title *:not(i)::before, #whatsnew .title *:not(i)::after,
[class*='categorylist'] .title *:not(i)::before,
[class*='categorylist'] .title *:not(i)::after,
.entrylist-title *:not(i)::before,
.entrylist-title *:not(i)::after,
.blogarea .title *:not(i)::before,
.blogarea .title *:not(i)::after,
#searchresult .title *:not(i)::before,
#searchresult .title *:not(i)::after,
.space-box > .title *:not(i)::before,
.space-box > .title *:not(i)::after {
  display: none;
}
#whatsnew .title,
[class*='categorylist'] .title,
.blogarea .title,
.entrylist-title,
#searchresult .title,
#main .space-box > .title {
  background-color: var(--clr-contenttitle-bg);
  color: var(--clr-contenttitle-txt);
}
[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: .64284em .85713em;
}
#menu .space-box > .title,
#rmenu .space-box > .title,
#footer .space-box > .title {
  font-size: 2rem;
}
#menu .space-box > .title,
#rmenu .space-box > .title {
  background-color: var(--clr-menutitle-bg);
  color: var(--clr-menutitle-txt);
}
[data-color*="clr-menutitle-bg"] #menu .space-box > .title,
[data-color*="clr-menutitle-bg"] #rmenu .space-box > .title {
  padding: .64284em .85713em;
}
.menubox > .title,
#pickupentry > .title,
.newentry-title {
  background-color: var(--clr-menutitle-bg);
  color: var(--clr-menutitle-txt);
  border-bottom-width: 1px;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  padding-bottom: .72726em;
  margin-bottom: 1em;
}
.menubox > .title *:not(i),
#pickupentry > .title *:not(i),
.newentry-title *:not(i) {
  display: contents;
  font-size: inherit;
}
.menubox > .title *:not(i)::before, .menubox > .title *:not(i)::after,
#pickupentry > .title *:not(i)::before,
#pickupentry > .title *:not(i)::after,
.newentry-title *:not(i)::before,
.newentry-title *:not(i)::after {
  display: none;
}
[data-color*="clr-menutitle-bg"] .menubox > .title,
[data-color*="clr-menutitle-bg"] #pickupentry > .title,
[data-color*="clr-menutitle-bg"] .newentry-title {
  padding: .8em;
}
/* 見出し */
h1 {
  font-size: clamp(2rem, 5.55555vw, 2.8rem);
  font-weight: 700;
  line-height: 1.5;
  margin: 0 0 1.2em;
}
h2 {
  font-size: clamp(2rem, 5.55555vw, 2.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 {
  padding-bottom: .8em;
  position: relative;
  border-bottom: 1px solid #bebebd;
}
#main h1::before {
  border-bottom: 1px solid #bebebd;
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 2px;
}
h2:not([class*="topic"]) {
  background: #fff;
  color: var(--clr-articletitle-txt, #333);
  margin-top: 2em;
  padding: .7693em 1em;
  position: relative;
  z-index: 0;
}
h2:not([class*="topic"]) i {
  margin-bottom: .1em;
}
h2:not([class*="topic"])::before {
  background: var(--clr-articletitle-bg, var(--clr-accent, #98838e));
  filter: saturate(180%);
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
  opacity: .18;
}
h2:not([class*="topic"])::after {
  border-bottom: 1px solid var(--clr-accent, #98838e);
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
  opacity: .5;
}
[data-color*="clr-articletitle-bg"] h2:not([class*="topic"])::before {
  filter: none;
  opacity: 1;
}
[data-color*="clr-articletitle-bg"] h2:not([class*="topic"])::after {
  border-bottom: none;
}
#main section > h2:not([class*="topic"]) {
  margin-top: 0;
}
[data-column="col1"][data-main="wide"] h2:not([class*="topic"]) {
  background: transparent;
  font-size: clamp(2.2rem, 6.11111vw, 3rem);
  padding: 0;
  text-align: center;
}
[data-column="col1"][data-main="wide"] h2:not([class*="topic"]) i {
  color: var(--clr-accent, #98838e);
}
[data-column="col1"][data-main="wide"] h2:not([class*="topic"])::before, [data-column="col1"][data-main="wide"] h2:not([class*="topic"])::after {
  display: none;
}
[data-column="colsp"][data-main="wide"] h2:not([class*="topic"]) {
  background: transparent;
  font-size: clamp(2.2rem, 6.11111vw, 3rem);
  padding: 0;
  text-align: center;
}
[data-column="colsp"][data-main="wide"] h2:not([class*="topic"]) i {
  color: var(--clr-accent, #98838e);
}
[data-column="colsp"][data-main="wide"] h2:not([class*="topic"])::before, [data-column="colsp"][data-main="wide"] h2:not([class*="topic"])::after {
  display: none;
}
h3:not([class*="topic"]) {
  border-bottom: 1px solid var(--clr-accent, #98838e);
  margin-top: 2em;
  padding-bottom: .66666em;
  position: relative;
}
.top_inner h3 {
  border-bottom: unset;
  margin-top: unset;
  padding-bottom: unset;
  position: static;
}
h4:not([class*="topic"]) {
  padding-left: .9091em;
  position: relative;
  border-left: 1px solid var(--clr-accent, #98838e);
}
h4:not([class*="topic"])::after {
  border-left: 1px solid var(--clr-accent, #98838e);
  content: '';
  position: absolute;
  top: 0;
  left: 2px;
  bottom: 0;
}
h5:not([class*="topic"]) {
  position: relative;
  padding-left: 1em;
}
h5:not([class*="topic"])::before {
  background: var(--clr-accent, #98838e);
  content: '';
  position: absolute;
  top: .5em;
  left: 0;
  width: .5em;
  height: .5em;
}
h6:not([class*="topic"]) {
  padding-left: 1.2em;
  position: relative;
}
h6:not([class*="topic"])::before {
  background: var(--clr-accent, #98838e);
  -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.344%2016%22%3E%3Cpath%20d%3D%22M11.344%208%20.008%200l5.327%208L0%2016Z%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%2011.344%2016%22%3E%3Cpath%20d%3D%22M11.344%208%20.008%200l5.327%208L0%2016Z%22%2F%3E%3C%2Fsvg%3E") no-repeat center left/contain;
  content: '';
  display: block;
  position: absolute;
  top: .2778em;
  left: 0;
  width: 1em;
  height: 1em;
}
/* リスト
==================================================
*/
ul:not([id]):not([class]),
ol:not([id]):not([class]) {
  line-height: 1.5;
  margin-top: var(--margin-component);
  margin-bottom: var(--margin-component);
}
ul:not([id]):not([class]) li,
ol:not([id]):not([class]) li {
  margin: 0.8em 0;
}
ul:not([id]):not([class]) {
  list-style: none;
}
ul:not([id]):not([class]) li::before {
  background-color: #333;
  display: inline-block;
  border-radius: .1875em;
  content: '';
  margin-left: -1em;
  margin-right: .8125em;
  width: .1875em;
  height: .1875em;
  position: relative;
  top: -.3125em;
}
ol:not([id]):not([class]) li::marker {
  font-size: 1.25em;
  font-family: 'Amiri', serif;
  font-weight: 500;
  line-height: 1;
}
/*
==================================================
最新記事
==================================================
*/
ul.newentry {
  display: grid;
  align-items: start;
  grid-template-columns: repeat(auto-fill, minmax(min(100%,320px), 1fr));
  gap: 0 1.25em;
  overflow: hidden;
}
ul.newentry li {
  border-bottom-width: 1px;
  padding: 0 0 1.25em;
}
ul.newentry li:not(:last-child) {
  margin: 0 0 1.25em;
}
.newentry .article .date {
  padding: 0;
}
.newentry .article .date::before {
  display: none;
}
.newentry .article .cat {
  opacity: .5;
}
.newentry .article .cat::before {
  display: none;
}
.newentry .article-inner {
  display: flex;
  align-items: center;
  gap: .8em;
}
.newentry .article-thumb {
  flex-shrink: 0;
  overflow: hidden;
  width: 100px;
}
.newentry .article-thumb img {
  width: 100%;
  aspect-ratio: 25/18;
  object-fit: cover;
}
.newentry .article-body {
  display: flex;
  flex-direction: column;
  gap: .4em;
  flex-grow: 1;
}
.newentry .article-title {
  color: inherit;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.4;
}
.newentry .article-title a {
  color: inherit;
  text-decoration: none;
}
.newentry .article-info {
  display: flex;
  align-items: center;
  gap: 8px;
}
/* ページリスト
==================================================
*/
.pagelist_ul {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 1em;
  line-height: 1;
}
.pagelist_ul li {
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: 'Amiri', serif;
  font-size: 2rem;
  width: 26px;
  height: 42px;
  overflow: hidden;
}
.pagelist_ul li.current {
  border-bottom: 1px solid var(--clr-body-txt, #333);
}
.pagelist_ul li.prev {
  margin-right: .5em;
}
.pagelist_ul li.next {
  margin-left: .5em;
}
.pagelist_ul a {
  color: inherit;
  display: flex;
  justify-content: center;
  align-items: center;
  text-decoration: none;
  width: 100%;
  height: 100%;
}
/* ナビゲーション（前後の記事）
==================================================
*/
#relNavigate {
  border-top-width: 1px;
  border-bottom-width: 1px;
  display: grid;
  gap: 1em 2em;
  grid-template-columns: repeat(auto-fit, minmax(min(100%,300px), 1fr));
  padding: 1em 0;
}
#relNavigate a {
  color: inherit;
  display: flex;
  align-items: center;
  gap: 1em;
  overflow: hidden;
  text-decoration: none;
  position: relative;
}
.relNavigate-prev .relNavigate-caption::before {
  content: 'PREV';
}
.relNavigate-next .relNavigate-caption::before {
  content: 'NEXT';
}
.relNavigate-thumb {
  flex-shrink: 0;
  overflow: hidden;
  width: 120px;
}
.relNavigate-thumb img {
  width: 100%;
  aspect-ratio: 5 / 3;
  object-fit: cover;
}
.relNavigate-caption {
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  display: flex;
  line-height: 1;
  margin-bottom: .4em;
}
.relNavigate-caption::before {
  font-family: 'Amiri', serif;
  font-size: 1.6rem;
  font-style: normal;
  font-weight: 700;
  line-height: 1;
  opacity: .38;
  text-indent: 0;
  white-space: normal;
  flex-shrink: 0;
  width: 100%;
}
.relNavigate-title {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  overflow: hidden;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.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: #f9f9f7;
  border: 1px solid rgba(51, 51, 51, 0.29);
  border-radius: 50%;
  display: block;
  position: relative;
  width: 56px;
  height: 56px;
}
#pagetop a::before {
  background-color: var(--clr-pagetop-icon, #333);
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2016.967%209.9%22%3E%3Cpath%20d%3D%22M8.481%200%207.069%201.414%200%208.486%201.414%209.9l7.067-7.072L15.555%209.9l1.412-1.414-7.072-7.072Z%22%2F%3E%3C%2Fsvg%3E") no-repeat center/17px 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.967%209.9%22%3E%3Cpath%20d%3D%22M8.481%200%207.069%201.414%200%208.486%201.414%209.9l7.067-7.072L15.555%209.9l1.412-1.414-7.072-7.072Z%22%2F%3E%3C%2Fsvg%3E") no-repeat center/17px auto;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
#pagetop.show {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
[data-color*="clr-pagetop-bg"] #pagetop a {
  background-color: var(--clr-pagetop-bg);
  border: none;
}
/*
==================================================
人気の記事
==================================================
*/
/* カウンター */
#pickupentry {
  counter-reset: pickuprank;
  background: var(--clr-menu-bg, #fff);
  padding: 1.25em;
}
.pickup_rank {
  counter-increment: pickuprank;
}
ul[id^="pickup_list"] {
  display: grid;
  align-items: start;
  gap: 0 1.25em;
  overflow: visible;
}
ul[id^="pickup_list"] li {
  border-bottom-width: 1px;
  padding: 0 0 1.25em;
}
ul[id^="pickup_list"] li:not(:last-child) {
  margin: 0 0 1.25em;
}
[id*="pickup_list"] .article-inner {
  display: flex;
  align-items: center;
  gap: .5em .8em;
}
[id*="pickup_list"] .article-thumb {
  flex-shrink: 0;
  overflow: hidden;
  width: 100px;
}
[id*="pickup_list"] .article-thumb img {
  width: 100%;
  aspect-ratio: 25/18;
  object-fit: cover;
}
[id*="pickup_list"] .article-body {
  display: flex;
  gap: .8em;
  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.3rem;
  font-weight: 700;
  line-height: 1.4;
}
[id*="pickup_list"] .article-title a {
  color: inherit;
  text-decoration: none;
}
/* ランキング
==================================================
*/
.pickup_rank .article-body {
  display: flex;
  position: relative;
}
.pickup_rank .article-body::after {
  color: #333;
  content: counter(pickuprank);
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: 'Amiri', serif;
  font-size: 6.4rem;
  font-style: italic;
  font-weight: 500;
  line-height: 1;
  opacity: .25;
  flex-shrink: 0;
  margin-bottom: -.15625em;
  position: relative;
  left: -.04687em;
}
/* デザイン01
==================================================
*/
[id="pickup_list1"] {
  grid-template-columns: repeat(auto-fill, minmax(min(100%,320px), 1fr));
}
[id="pickup_list1"] .article-body {
  justify-content: space-between;
  align-items: center;
}
/* デザイン02
==================================================
*/
[id="pickup_list2"] {
  grid-template-columns: repeat(auto-fill, minmax(min(100%,320px), 1fr));
}
[id="pickup_list2"] .article-inner {
  flex-direction: column;
  align-items: stretch;
}
[id="pickup_list2"] .article-thumb {
  width: 100%;
}
[id="pickup_list2"] .article-thumb img {
  aspect-ratio: 130/69;
}
[id="pickup_list2"] .article-body::after {
  order: -1;
}
/*
==================================================
ポイント
==================================================
*/
.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: #b78eb0;
  font-family: 'Amiri', serif;
  font-size: 1.90909em;
  font-style: italic;
  font-weight: 700;
  line-height: 1;
  margin-right: .2381em;
  float: left;
  position: relative;
  top: -.0238em;
}
.point[data-point]::after {
  content: '';
  display: block;
  clear: both;
}
/*
==================================================
記事いいねシェアボタン
==================================================
*/
.postlike {
  background: #fff;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%,280px), 1fr));
  overflow: hidden;
}
.postlike-thumb {
  position: relative;
  min-height: 240px;
}
.postlike-thumb img {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  object-fit: cover;
}
.postlike-body {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 20px;
  line-height: 1.5;
}
.postlike-txt {
  font-size: clamp(1.3rem, 3vw, 2rem);
  font-weight: 700;
  text-align: center;
  margin-bottom: 0.5em;
}
.postlike-btns {
  margin-bottom: 1em;
}
.postlike-btns > div {
  margin: 3px 8px;
}
.quote::before {
  content: '\201c';
  opacity: .6;
}
.quote::after {
  content: '\201d';
  opacity: .6;
}
.postlike-caption {
  font-size: 1.3rem;
  opacity: .5;
}
/* プロフィール
==================================================
*/
.profile {
  container-type: inline-size;
}
.profile-inner {
  display: flex;
  flex-direction: column;
  gap: 20px 0;
}
.profile-inner .snsbox {
  justify-content: center;
  margin: 0;
}
.profile-body {
  display: flex;
  flex-direction: column;
  gap: .5em 0;
}
.profile-img {
  text-align: center;
}
.profile-img img {
  border-radius: 50%;
  width: 200px;
  height: 200px;
  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;
}
/* Q&A
==================================================
*/
[class^="question"]::before {
  content: "Q";
}
[class^="answer"]::before {
  content: "A";
}
[class^="question"],
[class^="answer"] {
  border: none;
  font-size: 1em;
}
[class^="question"]::before,
[class^="answer"]::before {
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: 'Amiri', serif;
  font-weight: 700;
  line-height: 1;
  position: absolute;
  left: 0;
  top: 0;
}
/* デザイン1 */
.question1,
.answer1 {
  margin: var(--margin-component) 0;
  padding: 0.3em 0 0 3.4em;
  position: relative;
  min-height: 2.625em;
}
.question1::before,
.answer1::before {
  border-radius: 2em;
  color: #fff;
  font-size: 1.625em;
  width: 1.61539em;
  height: 1.61539em;
}
.question1::before {
  background-color: #8ba2be;
}
.answer1::before {
  background-color: #bf99b9;
}
/* デザイン2 */
.question2,
.answer2 {
  padding: .5em 0 .5em 3em;
  position: relative;
  min-height: 2.625em;
}
.question2::before,
.answer2::before {
  font-size: 2.125em;
  width: 1.2353em;
  height: 1.2353em;
  top: .17646em;
}
.question2::before {
  color: #8ba2be;
}
.answer2::before {
  color: #bf99b9;
}
/* FAQリスト */
.qa-list {
  margin: var(--margin-component) 0;
}
.qa-accordion {
  background: #fff;
  border-bottom-width: 1px;
  overflow: hidden;
  position: relative;
  z-index: 0;
}
.qa-accordion .question2,
.qa-accordion .answer2 {
  padding: 1.5em 1.5em 1.5em 4em;
}
.qa-accordion .question2::before,
.qa-accordion .answer2::before {
  top: .64705em;
  left: .4706em;
  transition: .4s ease;
}
.qa-accordion .question2 {
  padding-right: 72px;
}
.qa-accordion .question2::after {
  background-color: #f4f4f4;
  background-image: url(img/icon_add.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 11px auto;
  border-radius: 50%;
  content: '';
  position: absolute;
  top: 1.65625em;
  right: 22px;
  width: 27px;
  height: 27px;
  cursor: pointer;
  z-index: 1;
}
.qa-accordion .question2 + .answer2 {
  height: auto;
  overflow: hidden;
  opacity: 0;
  transition: .4s ease;
  margin-top: -2em;
}
.qa-accordion .question2:not(.show) + .answer2 {
  border-width: 0;
  line-height: 0;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
  min-height: 0;
}
.qa-accordion .question2:not(.show) + .answer2::before {
  top: -.5em;
}
.qa-accordion .question2:not(.show) + .answer2 *,
.qa-accordion .question2:not(.show) + .answer2 *::before,
.qa-accordion .question2:not(.show) + .answer2 *::after {
  border-width: 0;
  line-height: 0;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
  height: 0;
}
.qa-accordion .question2.show::after {
  background-image: url(img/icon_remove.svg);
}
.qa-accordion .question2.show + .answer2 {
  height: auto;
  overflow: visible;
  opacity: 1;
}
/* ランキングリスト
==================================================
*/
.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: .5em 0;
}
.ranklist li:first-child {
  border-top-width: 1px;
}
/* ランキング
==================================================
*/
.rank[data-rank] {
  font-size: clamp(1.6rem, 4.44444vw, 1.8rem);
  font-weight: 700;
  line-height: 1.5;
  margin: .5em 0;
}
.rank[data-rank]::before {
  color: #d1d5dd;
  content: attr(data-rank);
  font-family: 'Amiri', serif;
  font-size: 2.22222em;
  font-style: italic;
  font-weight: 700;
  line-height: 1;
  float: left;
  margin-right: .2em;
  min-width: .5959em;
  position: relative;
  margin-top: -.075em;
  margin-bottom: -.25em;
}
.rank[data-rank][data-rank='1']::before {
  color: #d0c3a6;
}
.rank[data-rank][data-rank='2']::before {
  color: #b5c4d0;
}
.rank[data-rank][data-rank='3']::before {
  color: #b49664;
}
.rank[data-rank]::after {
  content: '';
  display: block;
  clear: both;
}
/* ランキングボックス
==================================================
*/
.rankbox {
  margin: 1.5em 0;
}
.rankbox .rank[data-rank] {
  background: #f6f5f2;
  border: 1px solid #e0d9d3;
  font-size: clamp(2rem, 5.55555vw, 3rem);
  margin: 0;
  padding: .6923em 1em;
  display: grid;
  align-items: center;
  grid-template-columns: auto 1fr;
  grid-template-rows: 1fr auto;
}
.rankbox .rank[data-rank]::before {
  font-size: 3.2em;
  margin-top: -.10417em;
  min-width: auto;
  grid-column: 1 / 2;
  grid-row: 1 / 3;
  align-self: start;
}
.rankbox .rank[data-rank] a {
  color: inherit;
  text-decoration: none;
  grid-column: 2 / 3;
}
.rankbox .rank[data-rank] i {
  display: block;
  font-size: 1.4rem;
  font-style: normal;
  line-height: 1;
  grid-column: 2 / 3;
  grid-row: 1 / 2;
}
.rankbox-container {
  background: #fff;
  padding: 6px;
}
.rankbox-contents {
  background: #fff;
  border: 1px solid #e0d9d3;
  border-top: none;
  padding: clamp(16px, 4.44444vw, 32px);
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 4.44444vw, 32px) 0;
}
.rankbox-details {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%,280px), 1fr));
  gap: clamp(16px, 4.44444vw, 32px);
}
.rankbox-desc {
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 4.44444vw, 32px) 0;
}
.rankbox-rate {
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 4.44444vw, 32px);
  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 {
  border-left: 1px solid #3b2513;
  color: #393327;
  font-size: clamp(1.6rem, 4.44444vw, 2.2rem);
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 1em;
  padding-left: 0.63636em;
}
/* 評価 */
.rankbox-rateoverall {
  display: flex;
  flex-direction: column;
  gap: 0.2em;
  align-items: center;
}
.rankbox-rateoverall .rankbox-stitle {
  border: none;
  margin-bottom: 0.3em;
  padding-left: 0;
}
.rankbox-rateoverall .rankbox-rate-num .rate {
  font-size: 5.2rem;
}
.rankbox-rateoverall .rankbox-rate-num .rate::after {
  font-style: italic;
}
.rankbox-rateoverall .rate {
  font-size: 3rem;
}
.rate-unit {
  font-size: 1.2rem;
  opacity: .5;
}
/* 金額 */
.rankbox-price {
  font-size: 1.4rem;
  line-height: 1;
}
.rankbox-price b {
  font-family: 'Amiri', serif;
  font-size: 2.14285em;
  font-weight: 700;
}
/* 備考 */
.rankbox-notes {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .25em;
}
.rankbox-notes span {
  background-color: #f4f4f4;
  color: #393327;
  display: block;
  font-size: 1rem;
  line-height: 1;
  padding: .8em 1em;
}
/* 説明文1 特徴 */
.feature .feature-body {
  font-size: .875em;
  line-height: 1.6;
}
/* フリーテキスト */
/* 説明文2 総評 */
.comment {
  background: #f4f4f4;
  padding: clamp(16px, 4.44444vw, 32px);
}
.comment .comment-tit {
  border-left: 1px solid #3b2513;
  color: #393327;
  font-size: clamp(1.6rem, 4.44444vw, 2.2rem);
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 1em;
  padding-left: 0.63636em;
}
.comment .comment-body {
  font-size: .875em;
  line-height: 1.6;
}
/* ボタン */
.rankbox-more {
  text-align: center;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%,300px), 1fr));
  gap: 1em 1.5em;
}
.rankbox-more a {
  background-image: url(img/brn_arrow.svg);
  background-position: center right 28px;
  background-repeat: no-repeat;
  background-size: 16px auto;
  border-radius: .2em;
  color: #fff;
  display: block;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
  padding: 1.4em 2.5em;
  text-decoration: none;
}
/* ボタン 詳細ページはこちら */
.rankbox-more .detail a {
  background-color: #554d49;
  box-shadow: 0 0.4em 0.8em rgba(85, 77, 73, 0.24);
}
/* ボタン 公式ページはこちら */
.rankbox-more .official a {
  background-color: #ed7483;
  box-shadow: 0 0.4em 0.8em rgba(237, 116, 131, 0.24);
}
/* 画像スライダー（メインコンテンツ用ランキング）
==================================================
*/
.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;
}
.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(255, 255, 255, 0.6);
  -webkit-backdrop-filter: blur(50px);
  backdrop-filter: blur(50px);
  border-radius: 50%;
  display: block;
  width: 32px;
  height: 32px;
  margin: 0 10px;
  text-indent: 200%;
  white-space: nowrap;
  overflow: hidden;
  position: absolute;
  top: 50%;
  margin-top: -16px;
  z-index: 1;
}
.rslide-arrow .prev::before,
.rslide-arrow .next::before {
  background-color: #333;
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%229.897%22%20height%3D%2216.967%22%20viewBox%3D%220%200%209.897%2016.967%22%3E%3Cpath%20d%3D%22M1.414%200%200%201.414l7.067%207.067L0%2015.553l1.415%201.414L9.9%208.481%208.481%207.067Z%22%20fill%3D%22%23333%22%2F%3E%3C%2Fsvg%3E") no-repeat 54% center/18% auto;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%229.897%22%20height%3D%2216.967%22%20viewBox%3D%220%200%209.897%2016.967%22%3E%3Cpath%20d%3D%22M1.414%200%200%201.414l7.067%207.067L0%2015.553l1.415%201.414L9.9%208.481%208.481%207.067Z%22%20fill%3D%22%23333%22%2F%3E%3C%2Fsvg%3E") no-repeat 54% center/18% 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-family: 'Amiri', serif;
  font-size: 1.4375em;
  font-style: normal;
  font-weight: 700;
  line-height: 1;
  min-width: 1.26086em;
  margin-bottom: -0.1897em;
  text-align: center;
}
.rate.rate-mini::after {
  min-width: .52173em;
}
.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: 6px;
}
.scroll-table .scroll-area > * {
  margin: 0;
}
.scroll-area::-webkit-scrollbar {
  width: 2px;
}
.scroll-area::-webkit-scrollbar:horizontal {
  height: 2px;
}
.scroll-area::-webkit-scrollbar-track {
  background-color: rgba(0, 0, 0, 0.04);
}
.scroll-area::-webkit-scrollbar-thumb {
  background-color: rgba(0, 0, 0, 0.16);
}
.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 6px 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: 56px;
}
.search-keyword {
  display: block;
  position: relative;
  height: 100%;
  z-index: 0;
}
.search-keyword::before {
  background: var(--clr-form-bg, #fff);
  border-bottom: 1px solid #dbdbda;
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}
.search-keyword::after {
  background-color: var(--clr-form-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%2017.407%2017.405%22%3E%3Cpath%20d%3D%22M7.006%2014.005A6.989%206.989%200%200%200%2011.3%2012.53l4.632%204.635a.871.871%200%200%200%201.231-1.231l-4.631-4.631a7%207%200%201%200-5.526%202.702ZM3.285%203.283a5.262%205.262%200%201%201%200%207.442%205.243%205.243%200%200%201-.027-7.415l.027-.027Z%22%20fill%3D%22%23333%22%2F%3E%3C%2Fsvg%3E") no-repeat center/17px 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%2017.407%2017.405%22%3E%3Cpath%20d%3D%22M7.006%2014.005A6.989%206.989%200%200%200%2011.3%2012.53l4.632%204.635a.871.871%200%200%200%201.231-1.231l-4.631-4.631a7%207%200%201%200-5.526%202.702ZM3.285%203.283a5.262%205.262%200%201%201%200%207.442%205.243%205.243%200%200%201-.027-7.415l.027-.027Z%22%20fill%3D%22%23333%22%2F%3E%3C%2Fsvg%3E") no-repeat center/17px auto;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 48px;
  height: 100%;
}
.search-keyword input[type="search"] {
  border: none;
  color: var(--clr-form-txt, #333);
  cursor: auto;
  font-size: 1.6rem;
  line-height: 56px;
  padding: 0 16px 0 48px;
  width: 100%;
  height: 100%;
}
.search-keyword input[type="search"]::placeholder {
  color: var(--clr-form-txt, #5b5b5b);
  opacity: .5;
}
.search-keyword input[type="search"]:-ms-input-placeholder {
  color: var(--clr-form-txt, #5b5b5b);
  opacity: .5;
}
.search-keyword input[type="search"]::-ms-input-placeholder {
  color: var(--clr-form-txt, #5b5b5b);
  opacity: .5;
}
.search-submit {
  display: none;
}
[data-color*="clr-form-bg"] .search-keyword::before {
  border-bottom: none;
}
/*
==================================================
サイトマップ
==================================================
*/
#sitemaps ul {
  display: flex;
  flex-direction: column;
  gap: 1em 0;
}
#sitemaps li {
  display: flex;
  flex-direction: column;
  gap: 1em 0;
  line-height: 1.5;
}
#sitemaps a {
  color: inherit;
  display: block;
  padding-left: 1.5em;
  position: relative;
  text-decoration: none;
  align-self: flex-start;
  max-width: 100%;
}
#sitemaps > ul {
  gap: 2em 0;
}
#sitemaps > ul > li > a {
  font-size: 1.25em;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  padding-left: 1em;
}
#sitemaps > ul > li > a::before {
  background: var(--clr-accent, #333);
  content: '';
  position: absolute;
  top: .5em;
  left: 0;
  width: .5em;
  height: .5em;
}
#sitemaps > ul ul a::before {
  background: #333;
  border-radius: .25em;
  content: '';
  position: absolute;
  top: .625em;
  left: .625em;
  width: .25em;
  height: .25em;
}
#sitemaps > ul ul ul {
  padding-left: 1.5em;
}
/* パンくず
==================================================
*/
#siteNavi {
  background-color: var(--clr-siteNavi-bg, #f5f5f2);
  padding: 0 var(--padding-overall);
}
#siteNavi ul {
  color: var(--clr-siteNavi-txt, var(--clr-body-txt, rgba(51, 51, 51, 0.6)));
  display: flex;
  align-items: center;
  overflow-x: auto;
  white-space: nowrap;
  font-size: 1.2rem;
  line-height: 1;
  margin: 0 auto;
  padding: 2.5em 0;
  -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 {
  content: '/';
  display: block;
  margin: 0 1em;
  width: 1em;
  height: 1em;
  opacity: 0.5;
  text-align: center;
  flex-shrink: 0;
}
#siteNavi ul a {
  color: inherit;
  text-decoration: none;
}
/*
==================================================
スライダー（パーツ）
==================================================
*/
/* 矢印 */
.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(255, 255, 255, 0.6);
  -webkit-backdrop-filter: blur(50px);
  backdrop-filter: blur(50px);
  border-radius: 50%;
  display: block;
  width: 56px;
  height: 56px;
  text-indent: 200%;
  white-space: nowrap;
  overflow: hidden;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
  opacity: 0;
  transition: opacity 0.3s ease;
  cursor: pointer;
}
.slick-arrow::before {
  background-color: #333;
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%229.897%22%20height%3D%2216.967%22%20viewBox%3D%220%200%209.897%2016.967%22%3E%3Cpath%20d%3D%22M1.414%200%200%201.414l7.067%207.067L0%2015.553l1.415%201.414L9.9%208.481%208.481%207.067Z%22%20fill%3D%22%23333%22%2F%3E%3C%2Fsvg%3E") no-repeat 54% center/18% auto;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%229.897%22%20height%3D%2216.967%22%20viewBox%3D%220%200%209.897%2016.967%22%3E%3Cpath%20d%3D%22M1.414%200%200%201.414l7.067%207.067L0%2015.553l1.415%201.414L9.9%208.481%208.481%207.067Z%22%20fill%3D%22%23333%22%2F%3E%3C%2Fsvg%3E") no-repeat 54% center/18% auto;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
}
.slick-prev {
  left: 16px;
}
.slick-prev::before {
  transform: scale(-1, 1);
}
.slick-next {
  right: 16px;
}
.slick-slider:hover .slick-arrow {
  opacity: 1;
}
.slick-arrow {
  width: 30px;
  height: 30px;
}
ul[id$="slider_ul"].slide_item .slick-arrow,
.slider-type2 .slick-arrow {
  width: 28px;
  height: 28px;
}
.arrow-rectangle .slick-arrow {
  width: 40px;
  height: 25%;
  min-height: 56px;
  max-height: 88px;
}
.arrow-rectangle ul[id$="slider_ul"].slide_item .slick-arrow {
  width: 32px;
  height: 25%;
  min-height: 56px;
  max-height: 88px;
}
.arrow-rectangle .slick-prev {
  border-radius: 0 4px 4px 0;
  left: 0;
}
.arrow-rectangle .slick-next {
  border-radius: 4px 0 0 4px;
  right: 0;
}
@media screen and (min-width: 480px) {
  [data-main-header*="wide"] #main-header #topslider.cpadding.arrow-rectangle .slick-arrow {
    border-radius: 4px;
  }
  [data-main-header*="wide"] #main-header #topslider.cpadding.arrow-rectangle .slick-prev {
    left: 25px;
  }
  [data-main-header*="wide"] #main-header #topslider.cpadding.arrow-rectangle .slick-next {
    right: 25px;
  }
}
.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: 32px 0 0;
  position: relative;
}
ul.slick-dots li {
  position: relative;
  display: inline-block;
  margin: 4px;
  padding: 0;
  cursor: pointer;
}
ul.slick-dots button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: 0;
  font: inherit;
  outline: none;
  box-sizing: border-box;
  min-width: 0;
  color: var(--clr-body-txt, inherit);
  border-radius: 40px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: 'Amiri', serif;
  font-size: 1.4rem;
  width: 40px;
  height: 40px;
  z-index: 0;
  opacity: .38;
  transition: opacity .3s ease;
}
ul.slick-dots button:hover {
  opacity: 1;
}
ul.slick-dots button::before {
  border: 1px solid var(--clr-body-txt, #333);
  border-radius: 50%;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
  transition: .6s ease-out;
  opacity: 0;
}
ul.slick-dots .slick-active button {
  opacity: 1;
}
ul.slick-dots .slick-active button::before {
  opacity: .3;
}
/* スライダー(日付) */
ul[id$="slider_ul"] .sliderdate {
  justify-self: flex-start;
  align-self: end;
  color: #fff;
  font-family: 'Tangerine', cursive;
  font-size: 2em;
  font-weight: 700;
  line-height: 1;
  padding: .16666em .33333em;
}
ul[id$="slider_ul"].slide_center .sliderdate {
  grid-row: 1/2;
  grid-column: 1/2;
}
ul[id$="slider_ul"].slide_item .sliderdate {
  grid-row: 1/3;
  grid-column: 1/2;
}
/* タイトル */
.slidertitle {
  display: block;
  font-weight: 700;
  line-height: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  width: 100%;
  text-decoration: none;
}
ul[id$="slider_ul"].slide_center .slidertitle {
  grid-row: 2/3;
  grid-column: 1/2;
  align-self: end;
  background-color: rgba(255, 255, 255, 0.4);
  -webkit-backdrop-filter: blur(50px);
  backdrop-filter: blur(50px);
  font-size: 1.25em;
  padding: 1.3em 1.7em;
}
ul[id$="slider_ul"].slide_item .slidertitle {
  font-size: .875em;
  margin-top: .8em;
}
/*
==================================================
スライダー
==================================================
*/
[data-main-header*="header"] #main-header #topslider {
  margin-bottom: 32px;
  overflow: visible;
  position: relative;
}
[data-main-header*="header"] #main-header #topslider::before {
  background: #cebfc7;
  mix-blend-mode: multiply;
  content: '';
  position: absolute;
  top: 40px;
  left: calc(-50vw + 50%);
  right: calc(-50vw + 50%);
  bottom: 0;
  transform: translateY(32px);
  z-index: -1;
}
#topslider_ul.slick-initialized {
  height: auto;
  opacity: 1;
}
#topslider_ul {
  display: grid;
  height: 0;
  opacity: 0;
  transition: opacity 0.3s linear;
}
ul[id$="slider_ul"] .slick-slide a {
  text-decoration: none;
  display: grid;
  grid-template-rows: 1fr min-content;
}
ul[id$="slider_ul"] .slider-img {
  grid-row: 1/3;
  grid-column: 1/2;
}
/* 均等に小さく表示 */
#topslider ul[id$="slider_ul"].slide_item {
  background-color: transparent;
}
/* 中央に大きく表示 */
@media screen and (min-width: 480px) {
  [data-main-header*="wide"] #main-header #topslider.cpadding {
    margin-left: auto;
    margin-right: auto;
    max-width: calc(var(--width-overall) - 10%);
    overflow: visible;
  }
  [data-main-header*="wide"] #main-header #topslider.cpadding ul[id$="slider_ul"].slide_center {
    overflow: visible;
  }
  [data-main-header*="wide"] #main-header #topslider.cpadding .slick-list {
    overflow: visible;
    margin-right: -40px;
  }
  [data-main-header*="wide"] #main-header #topslider.cpadding .slick-slide {
    margin-right: 40px;
    filter: none;
  }
}
/*
==================================================
SNSボタン
==================================================
*/
[class^="snsicon-"] {
  background-position: center;
  background-repeat: no-repeat;
  background-size: 20px auto;
  display: block;
  border-radius: 5px;
  width: 34px;
  height: 34px;
}
[class^="snsicon-"][class$="-black"], [class^="snsicon-"][class$="-white"] {
  background-size: 16px auto;
  border-radius: 40px;
  border-width: 1px;
  border-style: solid;
  width: 40px;
  height: 40px;
}
[class^="snsicon-"][class$="-black"] {
  border-color: rgba(0, 0, 0, 0.38);
  opacity: .67;
}
[class^="snsicon-"][class$="-white"] {
  border-color: rgba(255, 255, 255, 0.38);
  opacity: 1;
}
/* facebook */
.snsicon-facebook {
  background-image: url(img/icon_facebook_white.svg);
  background-color: #1877f2;
}
.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_white.svg);
  background-color: #000;
}
.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_white.svg);
  background-color: #cf2e92;
}
.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_white.svg);
  background-color: #ff0000;
}
.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_white.svg);
  background-color: #f39801;
}
.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_white.svg);
  background-color: #00a4de;
}
/* line */
.snsicon-line {
  background-image: url(img/icon_line_white.svg);
  background-color: #00b900;
}
/* 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-width: 1px 0;
}
table[data-table*="normal"] th, table[data-table*="normal"] td {
  background-color: transparent;
  border-width: 0;
  padding: 1.14283em;
  text-align: left;
  vertical-align: top;
}
table[data-table*="normal"] th {
  font-weight: normal;
  width: 25%;
  opacity: .54;
}
table[data-table*="normal"] {
  font-size: 1.2rem;
}
table[data-table*="normal"] th, table[data-table*="normal"] td {
  display: block;
  padding: 1em 0;
  width: auto;
}
table[data-table*="normal"] th + td {
  margin-top: -1.5em;
}
/* 比較表
==================================================
*/
.comparison {
  background: #fff;
  border-color: var(--clr-border, #e1e1e1);
  border-width: 1px;
  border-collapse: collapse;
  margin: var(--margin-component) 0;
  table-layout: fixed;
}
.comparison tr th, .comparison tr td {
  background: transparent;
  border-color: var(--clr-border, #e1e1e1);
  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: #f7f7f5;
}
.comparison-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px 0;
}
.comparison-title {
  font-weight: 700;
}
.comparison-official a {
  background-color: #ed7483;
  border-radius: 2px;
  box-shadow: 0 0.36364em 0.72727em rgba(237, 116, 131, 0.24);
  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: #ededed;
  border-radius: 100px;
  color: #333;
  display: block;
  font-size: 1.1rem;
  line-height: 1;
  padding: .72727em;
  text-decoration: none;
}
/* Twitterタイムライン
==================================================
*/
.twitter_plugin {
  overflow: hidden;
}
/* 口コミ
==================================================
*/
.user1,
.user2 {
  background: #fff;
  border-width: 1px;
  line-height: 1.7;
  margin: var(--margin-component) 0;
  padding: 2.5em 2em;
}
.user1:not(.noimage),
.user2:not(.noimage) {
  background: #fff url(./img/user1.png) no-repeat 1.375em 1.125em/4.5em auto;
  padding-left: calc(5em + 2em);
}
.user2:not(.noimage) {
  background-image: url(./img/user2.png);
}
/* 口コミリスト */
.user1-custom,
.user2-custom {
  background: #fff;
  border-width: 1px;
  display: flex;
  gap: 0 1em;
  margin: var(--margin-component) 0;
  padding: 1.5em;
}
.user-img {
  flex-shrink: 0;
  max-width: 80px;
}
.user-body {
  display: flex;
  flex-direction: column;
  gap: .5em 0;
}
.user-review {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .5em;
  line-height: 1;
}
.user-review .user-status {
  font-size: 0.7em;
  opacity: 0.5;
}
.user-title {
  font-weight: 700;
  line-height: 1.7;
}
.user-desc {
  border-top-width: 1px;
  font-size: .8em;
  line-height: 1.7;
  padding-top: .625em;
}
/*
=============================
目次用スタイル(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;
  }
}