@charset "UTF-8";
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
}

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/* Text-level semantics
   ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: 0em;
}

sup {
  top: -0.25em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none;
}

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input { /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select { /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 2px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type=checkbox],
[type=radio] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type=search] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none;
}

/**
 * Convert font-size from px to rem with px fallback
 *
 * @param $size - the value in pixel you want to convert
 *
 * e.g. p {@include fontSize(12px);}
 * 
 */
:root {
  --color-main: #444444;
  --color-sub: #111111;
  --color-primary: #FF7078;
  --color-secondary: #F8F2EB;
  --color-link: var(--color-main);
  --color-hover: var(--color-sub);
  --color-txt: var(--color-main);
  --color-txt-weak: rgba(68,68,68,.65);
  --color-line: rgba(68,68,68,.2);
  --color-accent: var(--color-sub);
  --color-important: #000;
  --color-warning: #f00;
  --color-disable: #999;
  --color-bg: #ffffff;
  --color-overlay: #444444;
  --borderw: 1px;
  --borderrad: max(10px, calc(var(--borderw) * 3));
  --hover-animation: 0.05s steps(5) 0s infinite normal backwards animate_color;
  --hover-animation-bg: 0.05s steps(5) 0s infinite normal backwards animate_color_bg;
  --hover-animation-arrow: 1s linear infinite hoverArrowImgRight;
  --hover-animation-arrow-l: 1s linear infinite hoverArrowImgLeft;
  --icon-transform: translateX(-4px);
  --icon-transition: transform,stroke-width, 0.15s cubic-bezier(0.17, 0.84, 0.44, 1);
  --scrollbar-width: 0px;
  --wcalc-window-side-width: calc((100vw - var(--scrollbar-width) - 1440px) / 2);
  --docPadding: clamp(20px, 13.7931034483px + 1.724137931vw, 80px);
  --ghw: clamp(60px, 51.724137931px + 2.2988505747vw, 140px);
  --input-color-main: var(--color-txt);
  --input-color-main-bg: #ffffff;
  --input-color-main-active: var(--color-accent);
  --input-error: #ff0000;
  --input-error-bg: #444444; /* rgba(255,0,0,0.2)*/
  --system-fonts: sans-serif;
  --font-primaly: "Zen Kaku Gothic Antique", serif;
  --font-secondary: "Zen Kaku Gothic Antique", serif;
  --font-en: sans-serif;
  --font-ja: "Zen Kaku Gothic Antique", serif;
}

/* ============================================================================================== */
/* Global                                                                                         */
/* ============================================================================================== */
::-moz-selection {
  background-color: var(--color-txt);
  color: #fff;
}

::selection {
  background-color: var(--color-txt);
  color: #fff;
}

/* ----------------------------- */
* {
  box-sizing: border-box;
}

body {
  height: 100%;
  margin: 0;
  padding: 0;
  background-color: var(--color-bg);
  /*background-image: url(/assets/img/global/bg.webp);
  background-size: 600px;
  background-blend-mode: multiply;*/
}

main {
  width: 100%;
  height: auto;
}

/* ----------------------------------------------------------------------------------------*/
a {
  color: inherit;
  transition: 0.2s ease;
  transition-property: color, opacity, background-color;
}
a[href^=tel] {
  pointer-events: auto;
}
@media (min-width: 75em) {
  a[href^=tel] {
    pointer-events: none;
    text-decoration: none;
    cursor: auto;
  }
}
a:hover {
  text-decoration: none;
  color: var(--color-hover);
  opacity: 1 !important;
  transition: color 0.2s ease;
}

/* ----------------------------------------------------------------------------------------*/
/* tabindex */
:focus {
  outline: 1px dotted currentColor;
}

:focus-visible {
  outline: 2px dashed currentColor;
  background: transparent;
}

/* ----------------------------------------------------------------------------------------*/
h1,
h2,
h3,
h4,
h5,
h6 {
  margin-bottom: 0;
  font-size: inherit;
  font-weight: 500;
  line-height: 1.65;
}
[lang=en] h1,
[lang=en] h2,
[lang=en] h3,
[lang=en] h4,
[lang=en] h5,
[lang=en] h6 {
  line-height: 1.3;
}

/* ----------------------------------------------------------------------------------------*/
abbr[title], dfn[title] {
  border: none;
  text-decoration: none;
}

/* ----------------------------------------------------------------------------------------*/
menu {
  margin: 0;
  padding: 0;
}

/* ----------------------------------------------------------------------------------------*/
p {
  margin-bottom: 0;
}

pre {
  margin-bottom: 0;
}

dl {
  margin-bottom: 0;
}

ul {
  margin-bottom: 0;
}

ol {
  margin-bottom: 0;
  list-style: decimal;
  padding-left: 1em;
}

b, strong {
  font-weight: bold;
}

dd {
  margin-left: 1.75em;
}

/* ----------------------------------------------------------------------------------------*/
img {
  display: block;
  width: 100%;
  height: auto;
}

/* ----------------------------------------------------------------------------------------*/
hr {
  height: 0;
  margin: 2em 0;
  border: none;
  border-top: 1px solid var(--color-main);
  border-radius: 20px;
}

/* discList --------------------------------- */
ul {
  list-style: none;
  padding: 0;
}

li {
  position: relative;
  padding-left: 1.75em;
}

ul > li {
  position: relative;
  padding-left: 1.75em;
  /*&::before {
      position: absolute;
      content: '';
      display: block;
      left: 0;
      width: 3px;
      height: 3px;
      background-color: currentColor;
  }

  & li::before {
      content: '';
      display: block;
      width: 2px;
      height: 2px;
      border: 1px solid currentColor;
      background-color: transparent;
  }*/
}
ul > li::before {
  position: absolute;
  content: "・";
  left: 0;
}

/* orderedList --------------------------------- */
ol {
  list-style: none;
  padding: 0;
}

ol > li {
  position: relative;
  counter-increment: ol-number;
  padding-left: 1.75em;
}
ol > li::before {
  position: absolute;
  content: counter(ol-number) ".";
  left: 0;
}

/**
 * Swiper 5.4.0
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * http://swiperjs.com
 *
 * Copyright 2014-2020 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: May 15, 2020
 */
@font-face {
  font-family: swiper-icons;
  src: url("data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA") format("woff");
  font-weight: 400;
  font-style: normal;
}
:root {
  --swiper-theme-color:#000;
}

.swiper-container {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  z-index: 1;
}

.swiper-container-vertical > .swiper-wrapper {
  flex-direction: column;
}

.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  box-sizing: content-box;
}

.swiper-container-android .swiper-slide, .swiper-wrapper {
  transform: translate3d(0px, 0, 0);
}

.swiper-container-multirow > .swiper-wrapper {
  flex-wrap: wrap;
}

.swiper-container-multirow-column > .swiper-wrapper {
  flex-wrap: wrap;
  flex-direction: column;
}

.swiper-container-free-mode > .swiper-wrapper {
  transition-timing-function: ease-out;
  margin: 0 auto;
}

.swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  transition-property: transform;
}

.swiper-slide-invisible-blank {
  visibility: hidden;
}

.swiper-container-autoheight, .swiper-container-autoheight .swiper-slide {
  height: auto;
}

.swiper-container-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height;
}

.swiper-container-3d {
  perspective: 1200px;
}

.swiper-container-3d .swiper-cube-shadow, .swiper-container-3d .swiper-slide, .swiper-container-3d .swiper-slide-shadow-bottom, .swiper-container-3d .swiper-slide-shadow-left, .swiper-container-3d .swiper-slide-shadow-right, .swiper-container-3d .swiper-slide-shadow-top, .swiper-container-3d .swiper-wrapper {
  transform-style: preserve-3d;
}

.swiper-container-3d .swiper-slide-shadow-bottom, .swiper-container-3d .swiper-slide-shadow-left, .swiper-container-3d .swiper-slide-shadow-right, .swiper-container-3d .swiper-slide-shadow-top {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 10;
}

.swiper-container-3d .swiper-slide-shadow-left {
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-container-3d .swiper-slide-shadow-right {
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-container-3d .swiper-slide-shadow-top {
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-container-3d .swiper-slide-shadow-bottom {
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-container-css-mode > .swiper-wrapper {
  overflow: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.swiper-container-css-mode > .swiper-wrapper::-webkit-scrollbar {
  display: none;
}

.swiper-container-css-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: start start;
}

.swiper-container-horizontal.swiper-container-css-mode > .swiper-wrapper {
  scroll-snap-type: x mandatory;
}

.swiper-container-vertical.swiper-container-css-mode > .swiper-wrapper {
  scroll-snap-type: y mandatory;
}

:root {
  --swiper-navigation-size:44px;
}

.swiper-button-next, .swiper-button-prev {
  position: absolute;
  top: 50%;
  width: calc(var(--swiper-navigation-size) / 44 * 27);
  height: var(--swiper-navigation-size);
  margin-top: calc(-1 * var(--swiper-navigation-size) / 2);
  z-index: 10;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--swiper-navigation-color, var(--swiper-theme-color));
}

.swiper-button-next.swiper-button-disabled, .swiper-button-prev.swiper-button-disabled {
  opacity: 0.35;
  cursor: auto;
  pointer-events: none;
}

.swiper-button-next:after, .swiper-button-prev:after {
  font-family: swiper-icons;
  font-size: var(--swiper-navigation-size);
  text-transform: none !important;
  letter-spacing: 0;
  text-transform: none;
  font-variant: initial;
  line-height: 1;
}

.swiper-button-prev, .swiper-container-rtl .swiper-button-next {
  left: 10px;
  right: auto;
}

.swiper-button-prev:after, .swiper-container-rtl .swiper-button-next:after {
  content: "prev";
}

.swiper-button-next, .swiper-container-rtl .swiper-button-prev {
  right: 10px;
  left: auto;
}

.swiper-button-next:after, .swiper-container-rtl .swiper-button-prev:after {
  content: "next";
}

.swiper-button-next.swiper-button-white, .swiper-button-prev.swiper-button-white {
  --swiper-navigation-color:#ffffff;
}

.swiper-button-next.swiper-button-black, .swiper-button-prev.swiper-button-black {
  --swiper-navigation-color:#000000;
}

.swiper-button-lock {
  display: none;
}

.swiper-pagination {
  position: absolute;
  text-align: center;
  transition: 0.3s opacity;
  transform: translate3d(0, 0, 0);
  z-index: 10;
}

.swiper-pagination.swiper-pagination-hidden {
  opacity: 0;
}

.swiper-container-horizontal > .swiper-pagination-bullets, .swiper-pagination-custom, .swiper-pagination-fraction {
  bottom: 10px;
  left: 0;
  width: 100%;
}

.swiper-pagination-bullets-dynamic {
  overflow: hidden;
  font-size: 0;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transform: scale(0.33);
  position: relative;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
  transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
  transform: scale(0.33);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
  transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
  transform: scale(0.33);
}

.swiper-pagination-bullet {
  width: 8px;
  height: 8px;
  display: inline-block;
  border-radius: 100%;
  background: #000;
  opacity: 0.2;
}

button.swiper-pagination-bullet {
  border: none;
  margin: 0;
  padding: 0;
  box-shadow: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer;
}

.swiper-pagination-bullet-active {
  opacity: 1;
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
}

.swiper-container-vertical > .swiper-pagination-bullets {
  right: 10px;
  top: 50%;
  transform: translate3d(0px, -50%, 0);
}

.swiper-container-vertical > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 6px 0;
  display: block;
}

.swiper-container-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
}

.swiper-container-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  display: inline-block;
  transition: 0.2s transform, 0.2s top;
}

.swiper-container-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 4px;
}

.swiper-container-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}

.swiper-container-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 0.2s transform, 0.2s left;
}

.swiper-container-horizontal.swiper-container-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 0.2s transform, 0.2s right;
}

.swiper-pagination-progressbar {
  background: rgba(0, 0, 0, 0.25);
  position: absolute;
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  transform: scale(0);
  transform-origin: left top;
}

.swiper-container-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  transform-origin: right top;
}

.swiper-container-horizontal > .swiper-pagination-progressbar, .swiper-container-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
  width: 100%;
  height: 4px;
  left: 0;
  top: 0;
}

.swiper-container-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite, .swiper-container-vertical > .swiper-pagination-progressbar {
  width: 4px;
  height: 100%;
  left: 0;
  top: 0;
}

.swiper-pagination-white {
  --swiper-pagination-color:#ffffff;
}

.swiper-pagination-black {
  --swiper-pagination-color:#000000;
}

.swiper-pagination-lock {
  display: none;
}

.swiper-scrollbar {
  border-radius: 10px;
  position: relative;
  -ms-touch-action: none;
  background: rgba(0, 0, 0, 0.1);
}

.swiper-container-horizontal > .swiper-scrollbar {
  position: absolute;
  left: 1%;
  bottom: 3px;
  z-index: 50;
  height: 5px;
  width: 98%;
}

.swiper-container-vertical > .swiper-scrollbar {
  position: absolute;
  right: 3px;
  top: 1%;
  z-index: 50;
  width: 5px;
  height: 98%;
}

.swiper-scrollbar-drag {
  height: 100%;
  width: 100%;
  position: relative;
  background: rgba(0, 0, 0, 0.5);
  border-radius: 10px;
  left: 0;
  top: 0;
}

.swiper-scrollbar-cursor-drag {
  cursor: move;
}

.swiper-scrollbar-lock {
  display: none;
}

.swiper-zoom-container {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}

.swiper-zoom-container > canvas, .swiper-zoom-container > img, .swiper-zoom-container > svg {
  max-width: 100%;
  max-height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.swiper-slide-zoomed {
  cursor: move;
}

.swiper-lazy-preloader {
  width: 42px;
  height: 42px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -21px;
  margin-top: -21px;
  z-index: 10;
  transform-origin: 50%;
  animation: swiper-preloader-spin 1s infinite linear;
  box-sizing: border-box;
  border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
  border-radius: 50%;
  border-top-color: transparent;
}

.swiper-lazy-preloader-white {
  --swiper-preloader-color:#fff;
}

.swiper-lazy-preloader-black {
  --swiper-preloader-color:#000;
}

@keyframes swiper-preloader-spin {
  100% {
    transform: rotate(360deg);
  }
}
.swiper-container .swiper-notification {
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
  opacity: 0;
  z-index: -1000;
}

.swiper-container-fade.swiper-container-free-mode .swiper-slide {
  transition-timing-function: ease-out;
}

.swiper-container-fade .swiper-slide {
  pointer-events: none;
  transition-property: opacity;
}

.swiper-container-fade .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-container-fade .swiper-slide-active, .swiper-container-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-container-cube {
  overflow: visible;
}

.swiper-container-cube .swiper-slide {
  pointer-events: none;
  backface-visibility: hidden;
  z-index: 1;
  visibility: hidden;
  transform-origin: 0 0;
  width: 100%;
  height: 100%;
}

.swiper-container-cube .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-container-cube.swiper-container-rtl .swiper-slide {
  transform-origin: 100% 0;
}

.swiper-container-cube .swiper-slide-active, .swiper-container-cube .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-container-cube .swiper-slide-active, .swiper-container-cube .swiper-slide-next, .swiper-container-cube .swiper-slide-next + .swiper-slide, .swiper-container-cube .swiper-slide-prev {
  pointer-events: auto;
  visibility: visible;
}

.swiper-container-cube .swiper-slide-shadow-bottom, .swiper-container-cube .swiper-slide-shadow-left, .swiper-container-cube .swiper-slide-shadow-right, .swiper-container-cube .swiper-slide-shadow-top {
  z-index: 0;
  backface-visibility: hidden;
}

.swiper-container-cube .swiper-cube-shadow {
  position: absolute;
  left: 0;
  bottom: 0px;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: 0.6;
  filter: blur(50px);
  z-index: 0;
}

.swiper-container-flip {
  overflow: visible;
}

.swiper-container-flip .swiper-slide {
  pointer-events: none;
  backface-visibility: hidden;
  z-index: 1;
}

.swiper-container-flip .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-container-flip .swiper-slide-active, .swiper-container-flip .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-container-flip .swiper-slide-shadow-bottom, .swiper-container-flip .swiper-slide-shadow-left, .swiper-container-flip .swiper-slide-shadow-right, .swiper-container-flip .swiper-slide-shadow-top {
  z-index: 0;
  backface-visibility: hidden;
}

/* ============================================================================================== */
/* Module / Animation                                                                             */
/* ============================================================================================== */
@keyframes animate_color {
  /*
  0% {
      color: var(--color-secondary);
      fill: var(--color-secondary);
  }
  */
  0% {
    color: rgb(247, 131, 194);
    fill: rgb(247, 131, 194);
  }
  1% {
    color: rgb(222, 142, 149);
    fill: rgb(222, 142, 149);
  }
  2% {
    color: rgb(213, 136, 162);
    fill: rgb(213, 136, 162);
  }
  3% {
    color: rgb(191, 187, 163);
    fill: rgb(191, 187, 163);
  }
  4% {
    color: rgb(211, 190, 143);
    fill: rgb(211, 190, 143);
  }
  5% {
    color: rgb(235, 139, 166);
    fill: rgb(235, 139, 166);
  }
  6% {
    color: rgb(231, 133, 159);
    fill: rgb(231, 133, 159);
  }
  7% {
    color: rgb(233, 151, 139);
    fill: rgb(233, 151, 139);
  }
  8% {
    color: rgb(171, 173, 153);
    fill: rgb(171, 173, 153);
  }
  9% {
    color: rgb(226, 104, 180);
    fill: rgb(226, 104, 180);
  }
  10% {
    color: rgb(220, 148, 111);
    fill: rgb(220, 148, 111);
  }
  11% {
    color: rgb(156, 167, 170);
    fill: rgb(156, 167, 170);
  }
  12% {
    color: rgb(178, 130, 192);
    fill: rgb(178, 130, 192);
  }
  13% {
    color: rgb(246, 174, 191);
    fill: rgb(246, 174, 191);
  }
  14% {
    color: rgb(195, 147, 110);
    fill: rgb(195, 147, 110);
  }
  15% {
    color: rgb(157, 132, 114);
    fill: rgb(157, 132, 114);
  }
  16% {
    color: rgb(173, 116, 196);
    fill: rgb(173, 116, 196);
  }
  17% {
    color: rgb(200, 154, 137);
    fill: rgb(200, 154, 137);
  }
  18% {
    color: rgb(236, 134, 106);
    fill: rgb(236, 134, 106);
  }
  19% {
    color: rgb(232, 199, 198);
    fill: rgb(232, 199, 198);
  }
  20% {
    color: rgb(158, 110, 101);
    fill: rgb(158, 110, 101);
  }
  21% {
    color: rgb(250, 149, 115);
    fill: rgb(250, 149, 115);
  }
  22% {
    color: rgb(163, 136, 108);
    fill: rgb(163, 136, 108);
  }
  23% {
    color: rgb(212, 136, 123);
    fill: rgb(212, 136, 123);
  }
  24% {
    color: rgb(165, 144, 198);
    fill: rgb(165, 144, 198);
  }
  25% {
    color: rgb(182, 132, 152);
    fill: rgb(182, 132, 152);
  }
  26% {
    color: rgb(164, 177, 198);
    fill: rgb(164, 177, 198);
  }
  27% {
    color: rgb(211, 118, 168);
    fill: rgb(211, 118, 168);
  }
  28% {
    color: rgb(243, 196, 198);
    fill: rgb(243, 196, 198);
  }
  29% {
    color: rgb(254, 153, 192);
    fill: rgb(254, 153, 192);
  }
  30% {
    color: rgb(218, 187, 117);
    fill: rgb(218, 187, 117);
  }
  31% {
    color: rgb(198, 163, 122);
    fill: rgb(198, 163, 122);
  }
  32% {
    color: rgb(161, 151, 156);
    fill: rgb(161, 151, 156);
  }
  33% {
    color: rgb(212, 113, 151);
    fill: rgb(212, 113, 151);
  }
  34% {
    color: rgb(200, 167, 168);
    fill: rgb(200, 167, 168);
  }
  35% {
    color: rgb(198, 177, 118);
    fill: rgb(198, 177, 118);
  }
  36% {
    color: rgb(198, 180, 117);
    fill: rgb(198, 180, 117);
  }
  37% {
    color: rgb(175, 192, 133);
    fill: rgb(175, 192, 133);
  }
  38% {
    color: rgb(241, 127, 117);
    fill: rgb(241, 127, 117);
  }
  39% {
    color: rgb(183, 139, 105);
    fill: rgb(183, 139, 105);
  }
  40% {
    color: rgb(251, 121, 165);
    fill: rgb(251, 121, 165);
  }
  41% {
    color: rgb(167, 166, 169);
    fill: rgb(167, 166, 169);
  }
  42% {
    color: rgb(156, 200, 142);
    fill: rgb(156, 200, 142);
  }
  43% {
    color: rgb(178, 168, 138);
    fill: rgb(178, 168, 138);
  }
  44% {
    color: rgb(165, 187, 124);
    fill: rgb(165, 187, 124);
  }
  45% {
    color: rgb(171, 156, 173);
    fill: rgb(171, 156, 173);
  }
  46% {
    color: rgb(211, 164, 171);
    fill: rgb(211, 164, 171);
  }
  47% {
    color: rgb(166, 181, 136);
    fill: rgb(166, 181, 136);
  }
  48% {
    color: rgb(207, 197, 156);
    fill: rgb(207, 197, 156);
  }
  49% {
    color: rgb(216, 172, 136);
    fill: rgb(216, 172, 136);
  }
  50% {
    color: rgb(183, 112, 107);
    fill: rgb(183, 112, 107);
  }
  51% {
    color: rgb(234, 121, 198);
    fill: rgb(234, 121, 198);
  }
  52% {
    color: rgb(181, 157, 161);
    fill: rgb(181, 157, 161);
  }
  53% {
    color: rgb(203, 159, 175);
    fill: rgb(203, 159, 175);
  }
  54% {
    color: rgb(237, 119, 113);
    fill: rgb(237, 119, 113);
  }
  55% {
    color: rgb(223, 166, 163);
    fill: rgb(223, 166, 163);
  }
  56% {
    color: rgb(252, 122, 108);
    fill: rgb(252, 122, 108);
  }
  57% {
    color: rgb(172, 193, 121);
    fill: rgb(172, 193, 121);
  }
  58% {
    color: rgb(199, 153, 186);
    fill: rgb(199, 153, 186);
  }
  59% {
    color: rgb(202, 182, 150);
    fill: rgb(202, 182, 150);
  }
  60% {
    color: rgb(197, 140, 104);
    fill: rgb(197, 140, 104);
  }
  100% {
    color: var(--color-txt);
    fill: var(--color-txt);
  }
}
@keyframes animate_color_bg {
  0% {
    background-color: rgb(242, 66, 69);
    border-color: rgb(242, 66, 69);
    fill: rgb(242, 66, 69);
  }
  5% {
    background-color: rgb(189, 97, 87);
    border-color: rgb(189, 97, 87);
    fill: rgb(189, 97, 87);
  }
  10% {
    background-color: rgb(230, 99, 85);
    border-color: rgb(230, 99, 85);
    fill: rgb(230, 99, 85);
  }
  15% {
    background-color: rgb(175, 91, 86);
    border-color: rgb(175, 91, 86);
    fill: rgb(175, 91, 86);
  }
  20% {
    background-color: rgb(203, 82, 89);
    border-color: rgb(203, 82, 89);
    fill: rgb(203, 82, 89);
  }
  25% {
    background-color: rgb(161, 78, 79);
    border-color: rgb(161, 78, 79);
    fill: rgb(161, 78, 79);
  }
  30% {
    background-color: rgb(242, 99, 70);
    border-color: rgb(242, 99, 70);
    fill: rgb(242, 99, 70);
  }
  35% {
    background-color: rgb(179, 71, 64);
    border-color: rgb(179, 71, 64);
    fill: rgb(179, 71, 64);
  }
  40% {
    background-color: rgb(233, 95, 83);
    border-color: rgb(233, 95, 83);
    fill: rgb(233, 95, 83);
  }
  45% {
    background-color: rgb(185, 104, 57);
    border-color: rgb(185, 104, 57);
    fill: rgb(185, 104, 57);
  }
  50% {
    background-color: rgb(178, 78, 86);
    border-color: rgb(178, 78, 86);
    fill: rgb(178, 78, 86);
  }
  100% {
    background-color: var(--color-txt);
    border-color: var(--color-txt);
    fill: var(--color-txt);
  }
}
@keyframes animate_color_loop {
  /*
  0% {
      color: var(--color-secondary);
      fill: var(--color-secondary);
  }
  */
  0% {
    --animate-color: rgb(229, 130, 122);
  }
  5% {
    --animate-color: rgb(168, 120, 113);
  }
  10% {
    --animate-color: rgb(230, 134, 150);
  }
  15% {
    --animate-color: rgb(248, 102, 146);
  }
  20% {
    --animate-color: rgb(219, 150, 157);
  }
  25% {
    --animate-color: rgb(223, 172, 180);
  }
  30% {
    --animate-color: rgb(169, 132, 107);
  }
  35% {
    --animate-color: rgb(206, 114, 137);
  }
  40% {
    --animate-color: rgb(252, 166, 151);
  }
  45% {
    --animate-color: rgb(254, 165, 195);
  }
  50% {
    --animate-color: rgb(227, 153, 162);
  }
  55% {
    --animate-color: rgb(181, 183, 135);
  }
  60% {
    --animate-color: rgb(156, 126, 144);
  }
  65% {
    --animate-color: rgb(231, 171, 109);
  }
  70% {
    --animate-color: rgb(231, 125, 196);
  }
  75% {
    --animate-color: rgb(242, 123, 116);
  }
  80% {
    --animate-color: rgb(251, 155, 101);
  }
  85% {
    --animate-color: rgb(160, 154, 124);
  }
  90% {
    --animate-color: rgb(200, 109, 139);
  }
  95% {
    --animate-color: rgb(235, 136, 118);
  }
  100% {
    --animate-color: rgb(176, 112, 144);
  }
  105% {
    --animate-color: rgb(188, 166, 126);
  }
  110% {
    --animate-color: rgb(246, 175, 107);
  }
  115% {
    --animate-color: rgb(209, 192, 119);
  }
  120% {
    --animate-color: rgb(236, 195, 168);
  }
  125% {
    --animate-color: rgb(237, 195, 173);
  }
}
/* ------------------------------------------------------------- */
@keyframes animate_shake {
  0%, 100% {
    transform: translateX(0);
  }
  10% {
    transform: translateX(-9px);
  }
  20% {
    transform: translateX(8px);
  }
  30% {
    transform: translateX(-7px);
  }
  40% {
    transform: translateX(6px);
  }
  50% {
    transform: translateX(-5px);
  }
  60% {
    transform: translateX(4px);
  }
  70% {
    transform: translateX(-3px);
  }
  80% {
    transform: translateX(2px);
  }
  90% {
    transform: translateX(-1px);
  }
}
/* ------------------------------------------------------------- */
@keyframes hideOftText {
  0% {
    transform: translate3d(0, 0, 0);
  }
  100% {
    transform: translate3d(0, -100%, 0);
  }
}
@keyframes showOftText {
  0% {
    transform: translate3d(0, 100%, 0);
  }
  100% {
    transform: translate3d(0, 0, 0);
  }
}
/* ------------------------------------------------------------- */
@keyframes hoverImg {
  0% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
  }
}
/* ------------------------------------------------------------- */
@keyframes hoverArrowImgRight {
  0% {
    transform: translateX(0px);
  }
  5% {
    transform: translateX(12px);
  }
  10% {
    transform: translateX(6px);
  }
  15% {
    transform: translateX(10px);
  }
  20% {
    transform: translateX(8px);
  }
  100% {
    transform: translateX(8px);
  }
}
@keyframes hoverArrowImgLeft {
  0% {
    transform: translateX(0px);
  }
  5% {
    transform: translateX(-12px);
  }
  10% {
    transform: translateX(-6px);
  }
  15% {
    transform: translateX(-10px);
  }
  20% {
    transform: translateX(-8px);
  }
  100% {
    transform: translateX(-8px);
  }
}
/* ============================================================================================== */
/* UI / Button                                                                                    */
/* ============================================================================================== */
/*
 * UI / Button
 * - default style
 *  - primary 
 *  - -secondary 
 *  - warning
 *  - disabled 
 *  - decoration
 *
 * - option : sizing
 * - option : width
 * - option : icon
 * - option : levitate
 * 
 * - type : fill
 * - type : underline
 * - type : card
 * - type : navigate
 */
.btn {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  text-decoration: none;
  transition: 0.5s ease;
  transition-property: border, background, color, box-shadow;
  font-feature-settings: "palt";
}
.btn:hover {
  text-decoration: none;
  border: none;
}
.btn svg, .btn use {
  transition: none;
}

/* button 要素は input.scss (form関連部品) に記述しています。 */
/* ----------------------------------------------------------------------- */
/* default style */
/* ----------------------------------------------------------------------- */
.btn {
  position: relative;
  min-width: 2.5rem;
  min-height: 2.5rem;
  padding: 0.9375rem 1.25rem;
  border: none;
  border-radius: 60px;
  box-sizing: border-box;
  text-align: center;
  text-decoration: none !important;
  color: inherit;
  white-space: nowrap;
  line-height: 1;
  font-size: 13px;
  background-color: var(--color-bg);
  --borderw: 1px;
  /* -primary */
  /* -secondary */
  /* warning */
  /* anchor link */
  /* disabled */
}
.btn::before {
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  border-radius: 60px;
  border: var(--borderw) solid;
  content: "";
  opacity: 1;
  backface-visibility: hidden;
  transition: inherit;
}
a:hover .btn, .btn:hover {
  background-color: var(--color-hover);
  color: #fff;
}
a:hover .btn::before, .btn:hover::before {
  opacity: 1;
  color: var(--color-hover);
}
a:hover .btn::before {
  opacity: 1;
}
.btn.-primary {
  color: var(--color-accent);
  font-weight: bold;
  font-family: var(--font-m);
}
.btn.-primary::before {
  border-width: 2px;
  opacity: 1;
}
a:hover .btn.-primary, .btn.-primary:hover {
  color: #fff;
  background-color: var(--color-accent);
}
a:hover .btn.-primary::before, .btn.-primary:hover::before {
  border-color: var(--color-accent);
}
a:active .btn.-primary, .btn.-primary:active {
  color: #fff;
  background-color: var(--color-accent);
}
.btn.-primary .icon {
  stroke-width: 1.4;
}
.btn.-secondary {
  font-weight: bold;
  font-family: var(--font-m);
}
.btn.-secondary::before {
  border-width: 2px;
  opacity: 0.7;
}
a:hover .btn.-secondary, .btn.-secondary:hover {
  color: #fff;
  background-color: var(--color-accent);
}
a:hover .btn.-secondary::before, .btn.-secondary:hover::before {
  border-color: var(--color-accent);
}
a:active .btn.-secondary, .btn.-secondary:active {
  color: #fff;
  background-color: var(--color-accent);
}
.btn.-secondary .icon {
  stroke-width: 1.4;
}
.btn.-warning {
  color: rgb(255, 0, 0);
  border-color: rgba(255, 0, 0, 0.4);
  font-weight: bold;
  font-family: var(--font-m);
}
.btn.-warning::before {
  border-width: 2px;
  opacity: 1;
}
a:hover .btn.-warning, .btn.-warning:hover {
  color: #fff;
  background-color: rgb(255, 0, 0);
}
a:hover .btn.-warning::before, .btn.-warning:hover::before {
  border-color: rgb(255, 0, 0);
}
.btn.-warning .icon {
  stroke-width: 1.4;
}
.btn[disabled] {
  opacity: 0.3;
  pointer-events: none;
  box-shadow: none !important;
}

/* ----------------------------------------------------------------------- */
.btn {
  /* option : sizing */
  /* option : align */
  /* option : width */
  /* px等の指定はレスポンシブでは使いづらいことと、ほぼ使用することが無かったので廃止しました。 */
}
.btn.-xs {
  min-width: 1.25rem !important;
  min-height: 1.25rem !important;
  padding: 0.3125rem 0.5rem !important;
}
.btn.-s {
  min-width: 1.875rem !important;
  min-height: 1.875rem !important;
  padding: 0.625rem !important;
}
.btn.-l {
  min-width: 3.125rem !important;
  min-height: 3.125rem !important;
  padding: 1.25rem !important;
}
.btn.-xl {
  min-width: 3.75rem !important;
  min-height: 3.75rem !important;
  padding: 1.5625rem !important;
}
.btn.-left {
  justify-content: flex-start;
}
.btn.-right {
  justify-content: flex-end;
}
.btn.-center {
  justify-content: center;
}
.btn.-w10p {
  width: 10%;
}
.btn.-w20p {
  width: 20%;
}
.btn.-w30p {
  width: 30%;
}
.btn.-w40p {
  width: 40%;
}
.btn.-w50p {
  width: 50%;
}
.btn.-w60p {
  width: 60%;
}
.btn.-w70p {
  width: 70%;
}
.btn.-w80p {
  width: 80%;
}
.btn.-w90p {
  width: 90%;
}
.btn.-w100p {
  width: 100%;
}

/* ----------------------------------------------------------------------- */
/* option : icon */
.btn-lbl {
  display: inline-block;
}

.btn .lbl {
  display: inline-block;
}
.btn .icon {
  opacity: inherit;
  margin-left: -0.3125rem;
  margin-right: 0.1875rem;
}
.btn .icon:first-child {
  margin: -0.375rem 0.625rem -0.375rem 0.625rem;
}
.btn .icon:last-child {
  margin: -0.375rem 0.625rem -0.375rem 0.625rem;
}
.btn .icon:only-child {
  margin: -0.375rem 0.625rem;
}
.btn.-xs .icon {
  font-size: 70%;
}
.btn.-xs .icon:first-child {
  margin-right: 0.3125rem;
}
.btn.-xs .icon:last-child {
  margin-left: 0.3125rem;
}
.btn.-xs .icon:only-child {
  margin: -0.625rem -0.3125rem;
}
.btn.-s .icon {
  font-size: 90%;
}
.btn.-s .icon:first-child {
  margin-right: 0.3125rem;
}
.btn.-s .icon:last-child {
  margin-left: 0.3125rem;
}
.btn.-s .icon:only-child {
  margin: -0.625rem;
}
.btn.-l .icon {
  font-size: 120%;
}
.btn.-l .icon:last-child {
  margin: -0.5rem -0.125rem -0.5rem 0.5rem;
}
.btn.-l .icon:only-child {
  margin: -0.3125rem -0.625rem;
}
.btn.-xl .icon {
  font-size: 140%;
}
.btn.-xl .icon:last-child {
  margin: -0.75rem -0.125rem -0.75rem 0.625rem;
}
.btn.-xl .icon:only-child {
  margin: -0.3125rem -0.625rem;
}
.btn .more__ico {
  transition: all 0.4s cubic-bezier(0.17, 0.84, 0.44, 1);
  transform: translateX(0);
}
.btn:hover .more__ico {
  transform: translateX(5px);
}
.btn .down__ico {
  transition: all 0.4s cubic-bezier(0.17, 0.84, 0.44, 1);
  transform: translateY(0);
}
.btn:hover .down__ico {
  transform: translateY(5px);
}

/* ----------------------------------------------------------------------- */
/* option : levitate */
.btn.btn--lev {
  box-shadow: 0.3125rem 0.3125rem 0.8125rem rgba(0, 0, 0, 0.2);
  transition-duration: 0.3s;
  /* 塗りつぶしボタンの場合は影を少し濃くする */
}
.btn.btn--lev::before {
  border: none;
}
.btn.btn--lev.btn--fill {
  box-shadow: 0.625rem 0.625rem 0.9375rem rgba(0, 0, 0, 0.2);
}
.btn.btn--lev:hover {
  box-shadow: 0.625rem 0.625rem 1.125rem rgba(0, 0, 0, 0.2);
}
.btn.btn--lev:active {
  box-shadow: 0.1875rem 0.1875rem 0.3125rem rgba(0, 0, 0, 0.2);
}

/* ----------------------------------------------------------------------- */
/* type : fill */
/* ----------------------------------------------------------------------- */
.btn.btn--fill {
  color: #fff;
  background-color: var(--color-main);
  /* primary */
  /* -secondary */
  /* warning */
  /* disabled */
}
a:hover .btn.btn--fill, .btn.btn--fill:hover {
  color: #fff !important;
  background-color: var(--color-hover) !important;
}
.btn.btn--fill::before {
  position: absolute;
  content: "";
  bottom: 0;
  top: auto;
  left: 0;
  display: block;
  width: 100%;
  height: 20%;
  transition: 0.2s cubic-bezier(0.55, 0.06, 0.83, 0.43);
  transition-property: height, opacity, background;
  border: none;
  opacity: 1;
  border-radius: 5px;
}
.btn.btn--fill.-primary {
  color: rgb(255, 255, 255);
  background-color: var(--color-accent);
  font-weight: 500;
}
a:hover .btn.btn--fill.-primary, .btn.btn--fill.-primary:hover {
  font-weight: 500 !important;
  background-color: var(--color-main) !important;
  border-color: var(--color-main) !important;
  color: rgb(255, 255, 255) !important;
}
.btn.btn--fill.-secondary {
  background-color: var(--color-main);
  font-weight: 500;
}
a:hover .btn.btn--fill.-secondary, .btn.btn--fill.-secondary:hover {
  font-weight: 500 !important;
  background-color: var(--color-main) !important;
  border-color: var(--color-main) !important;
  color: rgb(255, 255, 255) !important;
}
.btn.btn--fill.-warning {
  background-color: rgb(255, 0, 0) !important;
}
a:hover .btn.btn--fill.-warning, .btn.btn--fill.-warning:hover {
  color: #fff !important;
  background-color: rgb(255, 0, 0) !important;
  border-color: rgb(255, 0, 0) !important;
}
.btn.btn--fill[disabled] {
  background: rgba(0, 0, 0, 0.25);
  color: #fff;
  pointer-events: none;
}

/* ----------------------------------------------------------------------- */
/* type : text */
/* ----------------------------------------------------------------------- */
.btn--t {
  min-width: 0;
}
.btn--t::before {
  position: absolute;
  display: block;
  bottom: 0;
  left: 0;
  top: auto;
  right: auto;
  width: 100%;
  height: 0;
  margin: auto 0 0;
  border: none;
  background-color: currentColor;
  transition: 0.2s cubic-bezier(0.22, 0.61, 0.36, 1);
  transition-property: background-color, color, opacity;
  content: "";
}
.btn--t, .btn--t.-secondary, .btn--t.-primary, .btn--t.-warning {
  padding: 0;
  font-weight: inherit;
}
.btn--t::before, .btn--t.-secondary::before, .btn--t.-primary::before, .btn--t.-warning::before {
  opacity: 0;
}
.btn--t:hover::before, .btn--t.-secondary:hover::before, .btn--t.-primary:hover::before, .btn--t.-warning:hover::before {
  opacity: 1;
}
.btn--t:hover, .btn--ta.-secondary:hover, .btn--ta.-primary:hover, .btn--ta.-warning:hover, .btn--t.btn:hover, .btn--t.btn.-secondary:hover, .btn--t.btn.-primary:hover, .btn--t.btn.-warning:hover {
  text-decoration: none;
  background-color: transparent;
  color: var(--color-hover);
}
.btn--t[target=_blank]::after, a .btn--t[target=_blank]::after {
  margin-left: 3px;
  margin-right: 0;
}

/* ============================================================================================== */
/* Icon Menu                                                                                      */
/* ============================================================================================== */
.menu-button {
  position: relative;
  padding: 0;
  pointer-events: auto;
  text-align: center;
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: 0.125em;
  font-size: 0.8125rem;
  font-weight: 500;
  color: currentColor;
  border: none;
}
.menu-button:hover {
  border: none;
}
.menu-button a:hover {
  color: currentColor;
}
.menu-buttona, .menu-button a, .menu-buttonbutton, .menu-button button {
  cursor: pointer;
}
.menu-button a, .menu-button button {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 40px;
  min-height: 40px;
  padding: 0;
  box-sizing: border-box;
  transition: none;
  touch-action: manipulation;
}

/* ------------------------------------------------------------------- */
.close-button {
  position: relative;
  right: 0;
  margin: 0;
  pointer-events: auto;
  z-index: 201;
  font-weight: bolder;
  text-align: center;
  white-space: nowrap;
  letter-spacing: -0.1em;
}
.close-button a, .close-button button {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 40px;
  min-height: 40px;
  margin: auto;
  padding: 0;
  box-sizing: border-box;
  transition: none;
  cursor: pointer;
  border: none;
  touch-action: manipulation;
}
.close-button a:hover, .close-button button:hover {
  color: currentColor;
  border: none;
}

/* ============================================================================================== */
/* Module / document container                                                                    */
/* ============================================================================================== */
/* CMSを利用した投稿記事部分など、プレーンなタグで整形を行う場合のフリーエリア */
.document-container {
  font-size: clamp(1rem, 0.9510869565rem + 0.2173913043vw, 1.125rem);
  overflow-wrap: break-word;
  /*
   * 1. Content sectioning
   * 2. Text content
   * 3. Inline text semantics
   * 4. Image and multimedia
   * 5. Embedded content
   * 6. Demarcating edits
   * 7. Table content
   */
  /* --------------------------------------------------
   * 1. Content sectioning
   * -------------------------------------------------- */
  /* ------------------------------ */
  /* ------------------------------ */
  /* --------------------------------------------------
   * 2. Text content
   * -------------------------------------------------- */
  /* ------------------------------ */
  /* ------------------------------ */
  /* ------------------------------ */
  /* ------------------------------ */
  /* ------------------------------ */
  /* --------------------------------------------------
   * 3. Inline text semantics
   * -------------------------------------------------- */
  /* --------------------------------------------------
   * 4. Image and multimedia
   * -------------------------------------------------- */
  /* --------------------------------------------------
   * 5. Embedded content
   * -------------------------------------------------- */
  /* --------------------------------------------------
   * 6. Demarcating edits
   * -------------------------------------------------- */
  /* --------------------------------------------------
   * 7. Table content
   * -------------------------------------------------- */
}
.document-container h1, .document-container h2, .document-container h3, .document-container h4, .document-container h5, .document-container h6 {
  margin: 1.5em 0 0.5em;
  line-height: 1.5;
  font-size: 135%;
  font-weight: bold;
  font-family: var(--font-ja);
  font-feature-settings: "palt";
}
.document-container h1 {
  font-size: 150%;
  -webkit-text-stroke: 0.02em;
}
.document-container h2 {
  font-size: 125%;
  -webkit-text-stroke: 0.02em;
}
.document-container h3, .document-container h4, .document-container h5, .document-container h6 {
  font-size: 100%;
}
.document-container section > *:last-child {
  margin-bottom: 0;
}
.document-container p {
  line-height: 2;
  margin: 1.25em 0 0;
}
.document-container p:empty {
  display: none;
}
.document-container p:first-child {
  margin-top: 0;
}
.document-container ol, .document-container ul {
  margin: 1.5em 0 0;
  padding-left: 1.25em;
  box-sizing: border-box;
}
.document-container ol {
  list-style-type: decimal;
}
.document-container ul {
  list-style-type: disc;
}
.document-container ul ul, .document-container ul ol, .document-container ol ul, .document-container ol ul {
  margin-top: 0.5em;
}
.document-container li {
  line-height: 1.6;
  margin-top: 0.3em;
  padding: 0;
}
.document-container li::before {
  content: none;
}
.document-container li:first-child {
  margin-top: 0;
}
.document-container dl {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
  margin: 1.5em 0 0;
  line-height: 1.6;
}
.document-container dl > div {
  display: flex;
  gap: 0.5em;
}
.document-container dt {
  min-width: 5em;
  margin: 0;
  padding-right: 0.5em;
  font-weight: 600;
}
.document-container dd {
  margin: 0;
}
.document-container blockquote {
  position: relative;
  margin: 1.5em 0;
  padding: 2em;
  box-sizing: border-box;
}
.document-container blockquote::before {
  position: absolute;
  content: "“";
  left: 0;
  top: -0.25em;
  font-size: 3em;
  opacity: 0.3;
}
.document-container hr {
  margin: 2em 0;
  border: none;
  border-bottom: 1px dashed var(--color-txt);
}
.document-container pre {
  overflow-x: scroll;
  width: 100%;
  margin: 2em 0;
}
.document-container q {
  margin: 1.5em 0.5em;
  quotes: "“" "”";
}
.document-container q:before {
  content: open-quote;
}
.document-container q:after {
  content: close-quote;
}
.document-container b {
  font-weight: 800;
}
.document-container strong {
  font-weight: 800;
}
.document-container em {
  font-style: italic;
}
.document-container a {
  display: inline-block;
  text-decoration: underline;
  text-underline-position: under;
  border: none;
}
.document-container a [data-icon=icon_file-pdf] {
  vertical-align: text-bottom;
}
.document-container img {
  width: auto;
  height: auto;
  max-width: 100%;
}
.document-container figure {
  margin-block: 2.5em;
  margin-inline: 0;
}
.document-container figure > *:first-child {
  margin-block-start: 0;
}
.document-container figure > *:first-child {
  margin-block-end: 0;
}
.document-container figcaption {
  margin-top: 0.5em;
  margin-bottom: 1em;
  font-size: 0.75rem;
  font-style: italic;
  line-height: 1.7;
  color: var(--color-txt-weak);
}
.document-container video {
  width: auto;
  height: auto;
  max-width: 100%;
}
.document-container iframe {
  width: 100%;
}
.document-container table {
  width: 100%;
  margin: 1.5em 0;
  border-collapse: collapse;
  border-block: 1px dashed var(--color-txt);
}
.document-container tr {
  border-block-start: 1px dashed var(--color-txt);
}
.document-container tr:first-child {
  border-block-start: none;
}
.document-container th {
  padding: 1em;
}
.document-container td {
  padding: 1em;
  vertical-align: baseline;
}
.document-container td:first-child {
  padding-inline-start: 0;
  min-width: 5em;
}
.document-container td:last-child {
  padding-inline-end: 0;
}

/* ============================================================================================== */
/* Module / document container WordPress Gutenberg                                                */
/* ============================================================================================== */
/**
 * Colors
 */
/**
 * Breakpoints & Media Queries
 */
/**
 * Colors
 */
/**
 * Fonts & basic variables.
 */
/**
 * Grid System.
 * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/
 */
/**
 * Dimensions.
 */
/**
 * Shadows.
 */
/**
 * Editor widths.
 */
/**
 * Block UI.
 */
/**
 * Border radii.
 */
/**
 * Block paddings.
 */
/**
 * Breakpoint mixins
 */
/**
 * Long content fade mixin
 *
 * Creates a fading overlay to signify that the content is longer
 * than the space allows.
 */
/**
 * Focus styles.
 */
/**
 * Applies editor left position to the selector passed as argument
 */
/**
 * Styles that are reused verbatim in a few places
 */
/**
 * Allows users to opt-out of animations via OS-level preferences.
 */
/**
 * Reset default styles for JavaScript UI based pages.
 * This is a WP-admin agnostic reset
 */
/**
 * Reset the WP Admin page styles for Gutenberg-like pages.
 */
#start-resizable-editor-section {
  display: none;
}

.wp-block-audio figcaption {
  margin-top: 0.5em;
  margin-bottom: 1em;
}

.wp-block-audio audio {
  width: 100%;
  min-width: 300px;
}

.wp-block-button__link {
  color: #fff;
  background-color: #32373c;
  border: none;
  border-radius: 1.55em;
  box-shadow: none;
  cursor: pointer;
  display: inline-block;
  font-size: 1.125em;
  padding: 0.667em 1.333em;
  text-align: center;
  text-decoration: none;
  overflow-wrap: break-word;
}

.wp-block-button__link:hover,
.wp-block-button__link:focus,
.wp-block-button__link:active,
.wp-block-button__link:visited {
  color: #fff;
}

.wp-block-button__link.aligncenter {
  text-align: center;
}

.wp-block-button__link.alignright {
  /*rtl:ignore*/
  text-align: right;
}

.wp-block-button.is-style-squared,
.wp-block-button__link.wp-block-button.is-style-squared {
  border-radius: 0;
}

.wp-block-button.no-border-radius,
.wp-block-button__link.no-border-radius {
  border-radius: 0 !important;
}

.is-style-outline > .wp-block-button__link,
.wp-block-button__link.is-style-outline {
  border: 2px solid;
}

.is-style-outline > .wp-block-button__link:not(.has-text-color),
.wp-block-button__link.is-style-outline:not(.has-text-color) {
  color: #32373c;
}

.is-style-outline > .wp-block-button__link:not(.has-background),
.wp-block-button__link.is-style-outline:not(.has-background) {
  background-color: transparent;
}

.wp-block-buttons .wp-block-button {
  display: inline-block;
  margin-right: 0.5em;
  margin-bottom: 0.5em;
}

.wp-block-buttons .wp-block-button:last-child {
  margin-right: 0;
}

.wp-block-buttons.alignright .wp-block-button {
  /*rtl:ignore*/
  margin-right: 0;
  /*rtl:ignore*/
  margin-left: 0.5em;
}

.wp-block-buttons.alignright .wp-block-button:first-child {
  margin-left: 0;
}

.wp-block-buttons.alignleft .wp-block-button {
  /*rtl:ignore*/
  margin-left: 0;
  /*rtl:ignore*/
  margin-right: 0.5em;
}

.wp-block-buttons.alignleft .wp-block-button:last-child {
  margin-right: 0;
}

.wp-block-button.aligncenter,
.wp-block-buttons.aligncenter {
  text-align: center;
}

.wp-block-calendar {
  text-align: center;
}

.wp-block-calendar th,
.wp-block-calendar tbody td {
  padding: 0.25em;
  border: 1px solid #ddd;
}

.wp-block-calendar tfoot td {
  border: none;
}

.wp-block-calendar table {
  width: 100%;
  border-collapse: collapse;
}

.wp-block-calendar table th {
  font-weight: 400;
  background: #ddd;
}

.wp-block-calendar a {
  text-decoration: underline;
}

.wp-block-calendar table tbody,
.wp-block-calendar table caption {
  color: #40464d;
}

.wp-block-categories.alignleft {
  /*rtl:ignore*/
  margin-right: 2em;
}

.wp-block-categories.alignright {
  /*rtl:ignore*/
  margin-left: 2em;
}

.wp-block-code code {
  white-space: pre-wrap;
  overflow-wrap: break-word;
}

.wp-block-columns {
  display: flex;
  margin-bottom: 20px;
  flex-wrap: wrap;
  /**
  * All Columns Alignment
  */
}

.wp-block-columns.has-background {
  padding: 1.25em 2.375em;
}

.wp-block-columns.are-vertically-aligned-top {
  align-items: flex-start;
}

.wp-block-columns.are-vertically-aligned-center {
  align-items: center;
}

.wp-block-columns.are-vertically-aligned-bottom {
  align-items: flex-end;
}

.wp-block-column {
  flex-grow: 1;
  min-width: 0;
  word-break: break-word;
  overflow-wrap: break-word;
  /**
  * Individual Column Alignment
  */
}

.wp-block-column.is-vertically-aligned-top {
  align-self: flex-start;
}

.wp-block-column.is-vertically-aligned-center {
  align-self: center;
}

.wp-block-column.is-vertically-aligned-bottom {
  align-self: flex-end;
}

.wp-block-column.is-vertically-aligned-top,
.wp-block-column.is-vertically-aligned-center,
.wp-block-column.is-vertically-aligned-bottom {
  width: 100%;
}

.wp-block-cover-image,
.wp-block-cover {
  position: relative;
  background-size: cover;
  background-position: center center;
  min-height: 430px;
  height: 100%;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1em;
  box-sizing: border-box;
  /**
   * Set a default background color for has-background-dim _unless_ it includes another
   * background-color class (e.g. has-green-background-color). The presence of another
   * background-color class implies that another style will provide the background color
   * for the overlay.
   *
   * See:
   *   - Issue with background color specificity: https://github.com/WordPress/gutenberg/issues/26545
   *   - Issue with alternative fix: https://github.com/WordPress/gutenberg/issues/26545
   */
}

.wp-block-cover-image.has-parallax,
.wp-block-cover.has-parallax {
  background-attachment: fixed;
}

@supports (-webkit-overflow-scrolling: touch) {
  .wp-block-cover-image.has-parallax,
  .wp-block-cover.has-parallax {
    background-attachment: scroll;
  }
}
@media (prefers-reduced-motion: reduce) {
  .wp-block-cover-image.has-parallax,
  .wp-block-cover.has-parallax {
    background-attachment: scroll;
  }
}
.wp-block-cover-image.is-repeated,
.wp-block-cover.is-repeated {
  background-repeat: repeat;
  background-size: auto;
}

.wp-block-cover-image.has-background-dim:not([class*=-background-color]),
.wp-block-cover.has-background-dim:not([class*=-background-color]) {
  background-color: #000;
}

.wp-block-cover-image.has-background-dim::before,
.wp-block-cover.has-background-dim::before {
  content: "";
  background-color: inherit;
}

.wp-block-cover-image.has-background-dim:not(.has-background-gradient)::before,
.wp-block-cover-image .wp-block-cover__gradient-background,
.wp-block-cover.has-background-dim:not(.has-background-gradient)::before,
.wp-block-cover .wp-block-cover__gradient-background {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  z-index: 1;
  opacity: 0.5;
}

.wp-block-cover-image.has-background-dim.has-background-dim-10:not(.has-background-gradient)::before,
.wp-block-cover-image.has-background-dim.has-background-dim-10 .wp-block-cover__gradient-background,
.wp-block-cover.has-background-dim.has-background-dim-10:not(.has-background-gradient)::before,
.wp-block-cover.has-background-dim.has-background-dim-10 .wp-block-cover__gradient-background {
  opacity: 0.1;
}

.wp-block-cover-image.has-background-dim.has-background-dim-20:not(.has-background-gradient)::before,
.wp-block-cover-image.has-background-dim.has-background-dim-20 .wp-block-cover__gradient-background,
.wp-block-cover.has-background-dim.has-background-dim-20:not(.has-background-gradient)::before,
.wp-block-cover.has-background-dim.has-background-dim-20 .wp-block-cover__gradient-background {
  opacity: 0.2;
}

.wp-block-cover-image.has-background-dim.has-background-dim-30:not(.has-background-gradient)::before,
.wp-block-cover-image.has-background-dim.has-background-dim-30 .wp-block-cover__gradient-background,
.wp-block-cover.has-background-dim.has-background-dim-30:not(.has-background-gradient)::before,
.wp-block-cover.has-background-dim.has-background-dim-30 .wp-block-cover__gradient-background {
  opacity: 0.3;
}

.wp-block-cover-image.has-background-dim.has-background-dim-40:not(.has-background-gradient)::before,
.wp-block-cover-image.has-background-dim.has-background-dim-40 .wp-block-cover__gradient-background,
.wp-block-cover.has-background-dim.has-background-dim-40:not(.has-background-gradient)::before,
.wp-block-cover.has-background-dim.has-background-dim-40 .wp-block-cover__gradient-background {
  opacity: 0.4;
}

.wp-block-cover-image.has-background-dim.has-background-dim-50:not(.has-background-gradient)::before,
.wp-block-cover-image.has-background-dim.has-background-dim-50 .wp-block-cover__gradient-background,
.wp-block-cover.has-background-dim.has-background-dim-50:not(.has-background-gradient)::before,
.wp-block-cover.has-background-dim.has-background-dim-50 .wp-block-cover__gradient-background {
  opacity: 0.5;
}

.wp-block-cover-image.has-background-dim.has-background-dim-60:not(.has-background-gradient)::before,
.wp-block-cover-image.has-background-dim.has-background-dim-60 .wp-block-cover__gradient-background,
.wp-block-cover.has-background-dim.has-background-dim-60:not(.has-background-gradient)::before,
.wp-block-cover.has-background-dim.has-background-dim-60 .wp-block-cover__gradient-background {
  opacity: 0.6;
}

.wp-block-cover-image.has-background-dim.has-background-dim-70:not(.has-background-gradient)::before,
.wp-block-cover-image.has-background-dim.has-background-dim-70 .wp-block-cover__gradient-background,
.wp-block-cover.has-background-dim.has-background-dim-70:not(.has-background-gradient)::before,
.wp-block-cover.has-background-dim.has-background-dim-70 .wp-block-cover__gradient-background {
  opacity: 0.7;
}

.wp-block-cover-image.has-background-dim.has-background-dim-80:not(.has-background-gradient)::before,
.wp-block-cover-image.has-background-dim.has-background-dim-80 .wp-block-cover__gradient-background,
.wp-block-cover.has-background-dim.has-background-dim-80:not(.has-background-gradient)::before,
.wp-block-cover.has-background-dim.has-background-dim-80 .wp-block-cover__gradient-background {
  opacity: 0.8;
}

.wp-block-cover-image.has-background-dim.has-background-dim-90:not(.has-background-gradient)::before,
.wp-block-cover-image.has-background-dim.has-background-dim-90 .wp-block-cover__gradient-background,
.wp-block-cover.has-background-dim.has-background-dim-90:not(.has-background-gradient)::before,
.wp-block-cover.has-background-dim.has-background-dim-90 .wp-block-cover__gradient-background {
  opacity: 0.9;
}

.wp-block-cover-image.has-background-dim.has-background-dim-100:not(.has-background-gradient)::before,
.wp-block-cover-image.has-background-dim.has-background-dim-100 .wp-block-cover__gradient-background,
.wp-block-cover.has-background-dim.has-background-dim-100:not(.has-background-gradient)::before,
.wp-block-cover.has-background-dim.has-background-dim-100 .wp-block-cover__gradient-background {
  opacity: 1;
}

.wp-block-cover-image.alignleft,
.wp-block-cover-image.alignright,
.wp-block-cover.alignleft,
.wp-block-cover.alignright {
  max-width: 290px;
  width: 100%;
}

.wp-block-cover-image::after,
.wp-block-cover::after {
  display: block;
  content: "";
  font-size: 0;
  min-height: inherit;
}

@supports (position: sticky) {
  .wp-block-cover-image::after,
  .wp-block-cover::after {
    content: none;
  }
}
.wp-block-cover-image.aligncenter,
.wp-block-cover-image.alignleft,
.wp-block-cover-image.alignright,
.wp-block-cover.aligncenter,
.wp-block-cover.alignleft,
.wp-block-cover.alignright {
  display: flex;
}

.wp-block-cover-image .wp-block-cover__inner-container,
.wp-block-cover .wp-block-cover__inner-container {
  width: 100%;
  z-index: 1;
  color: #fff;
}

.wp-block-cover-image p:not(.has-text-color),
.wp-block-cover-image h1:not(.has-text-color),
.wp-block-cover-image h2:not(.has-text-color),
.wp-block-cover-image h3:not(.has-text-color),
.wp-block-cover-image h4:not(.has-text-color),
.wp-block-cover-image h5:not(.has-text-color),
.wp-block-cover-image h6:not(.has-text-color),
.wp-block-cover-image .wp-block-subhead:not(.has-text-color),
.wp-block-cover p:not(.has-text-color),
.wp-block-cover h1:not(.has-text-color),
.wp-block-cover h2:not(.has-text-color),
.wp-block-cover h3:not(.has-text-color),
.wp-block-cover h4:not(.has-text-color),
.wp-block-cover h5:not(.has-text-color),
.wp-block-cover h6:not(.has-text-color),
.wp-block-cover .wp-block-subhead:not(.has-text-color) {
  color: inherit;
}

.wp-block-cover-image.is-position-top-left,
.wp-block-cover.is-position-top-left {
  align-items: flex-start;
  justify-content: flex-start;
}

.wp-block-cover-image.is-position-top-center,
.wp-block-cover.is-position-top-center {
  align-items: flex-start;
  justify-content: center;
}

.wp-block-cover-image.is-position-top-right,
.wp-block-cover.is-position-top-right {
  align-items: flex-start;
  justify-content: flex-end;
}

.wp-block-cover-image.is-position-center-left,
.wp-block-cover.is-position-center-left {
  align-items: center;
  justify-content: flex-start;
}

.wp-block-cover-image.is-position-center-center,
.wp-block-cover.is-position-center-center {
  align-items: center;
  justify-content: center;
}

.wp-block-cover-image.is-position-center-right,
.wp-block-cover.is-position-center-right {
  align-items: center;
  justify-content: flex-end;
}

.wp-block-cover-image.is-position-bottom-left,
.wp-block-cover.is-position-bottom-left {
  align-items: flex-end;
  justify-content: flex-start;
}

.wp-block-cover-image.is-position-bottom-center,
.wp-block-cover.is-position-bottom-center {
  align-items: flex-end;
  justify-content: center;
}

.wp-block-cover-image.is-position-bottom-right,
.wp-block-cover.is-position-bottom-right {
  align-items: flex-end;
  justify-content: flex-end;
}

.wp-block-cover-image.has-custom-content-position.has-custom-content-position .wp-block-cover__inner-container,
.wp-block-cover.has-custom-content-position.has-custom-content-position .wp-block-cover__inner-container {
  margin: 0;
  width: auto;
}

.wp-block-cover__video-background {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  width: 100%;
  height: 100%;
  z-index: 0;
  -o-object-fit: cover;
     object-fit: cover;
}

section.wp-block-cover-image h2,
.wp-block-cover-image-text,
.wp-block-cover-text {
  color: #fff;
}

section.wp-block-cover-image h2 a,
section.wp-block-cover-image h2 a:hover,
section.wp-block-cover-image h2 a:focus,
section.wp-block-cover-image h2 a:active,
.wp-block-cover-image-text a,
.wp-block-cover-image-text a:hover,
.wp-block-cover-image-text a:focus,
.wp-block-cover-image-text a:active,
.wp-block-cover-text a,
.wp-block-cover-text a:hover,
.wp-block-cover-text a:focus,
.wp-block-cover-text a:active {
  color: #fff;
}

.wp-block-cover-image .wp-block-cover.has-left-content {
  justify-content: flex-start;
}

.wp-block-cover-image .wp-block-cover.has-right-content {
  justify-content: flex-end;
}

section.wp-block-cover-image.has-left-content > h2,
.wp-block-cover-image.has-left-content .wp-block-cover-image-text,
.wp-block-cover.has-left-content .wp-block-cover-text {
  margin-left: 0;
  text-align: left;
}

section.wp-block-cover-image.has-right-content > h2,
.wp-block-cover-image.has-right-content .wp-block-cover-image-text,
.wp-block-cover.has-right-content .wp-block-cover-text {
  margin-right: 0;
  text-align: right;
}

section.wp-block-cover-image > h2,
.wp-block-cover-image .wp-block-cover-image-text,
.wp-block-cover .wp-block-cover-text {
  font-size: 2em;
  line-height: 1.25;
  z-index: 1;
  margin-bottom: 0;
  max-width: 580px;
  padding: 0.44em;
  text-align: center;
}

.wp-block[data-align=left] > [data-type="core/embed"],
.wp-block[data-align=right] > [data-type="core/embed"],
.wp-block-embed.alignleft,
.wp-block-embed.alignright {
  max-width: 360px;
  width: 100%;
}

.wp-block[data-align=left] > [data-type="core/embed"] .wp-block-embed__wrapper,
.wp-block[data-align=right] > [data-type="core/embed"] .wp-block-embed__wrapper,
.wp-block-embed.alignleft .wp-block-embed__wrapper,
.wp-block-embed.alignright .wp-block-embed__wrapper {
  min-width: 280px;
}

.wp-block-embed {
  margin-bottom: 1em;
}

.wp-block-embed figcaption {
  margin-top: 0.5em;
  margin-bottom: 1em;
}

.wp-block-embed iframe {
  max-width: 100%;
  height: auto;
}

.wp-block-embed__wrapper {
  position: relative;
}

.wp-has-aspect-ratio .wp-block-embed__wrapper::before {
  content: "";
  display: block;
  padding-top: 50%;
}

.wp-has-aspect-ratio iframe {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  height: 100%;
  width: 100%;
}

.wp-embed-aspect-21-9 .wp-block-embed__wrapper::before {
  padding-top: 42.85%;
}

.wp-embed-aspect-18-9 .wp-block-embed__wrapper::before {
  padding-top: 50%;
}

.wp-embed-aspect-16-9 .wp-block-embed__wrapper::before {
  padding-top: 56.25%;
}

.wp-embed-aspect-4-3 .wp-block-embed__wrapper::before {
  padding-top: 75%;
}

.wp-embed-aspect-1-1 .wp-block-embed__wrapper::before {
  padding-top: 100%;
}

.wp-embed-aspect-9-16 .wp-block-embed__wrapper::before {
  padding-top: 177.77%;
}

.wp-embed-aspect-1-2 .wp-block-embed__wrapper::before {
  padding-top: 200%;
}

.wp-block-file {
  margin-bottom: 1.5em;
}

.wp-block-file.aligncenter {
  text-align: center;
}

.wp-block-file.alignright {
  /*rtl:ignore*/
  text-align: right;
}

.wp-block-file .wp-block-file__button {
  background: #32373c;
  border-radius: 2em;
  color: #fff;
  font-size: 0.8em;
  padding: 0.5em 1em;
}

.wp-block-file a.wp-block-file__button {
  text-decoration: none;
}

.wp-block-file a.wp-block-file__button:hover,
.wp-block-file a.wp-block-file__button:visited,
.wp-block-file a.wp-block-file__button:focus,
.wp-block-file a.wp-block-file__button:active {
  box-shadow: none;
  color: #fff;
  opacity: 0.85;
  text-decoration: none;
}

.wp-block-file * + .wp-block-file__button {
  margin-left: 0.75em;
}

.wp-block-gallery,
.blocks-gallery-grid {
  display: flex;
  flex-wrap: wrap;
  list-style-type: none;
  padding: 0;
  margin: 0;
}

.wp-block-gallery .blocks-gallery-image,
.wp-block-gallery .blocks-gallery-item,
.blocks-gallery-grid .blocks-gallery-image,
.blocks-gallery-grid .blocks-gallery-item {
  margin: 0 1em 1em 0;
  display: flex;
  flex-grow: 1;
  flex-direction: column;
  justify-content: center;
  position: relative;
  width: calc(50% - 1em);
}

.wp-block-gallery .blocks-gallery-image:nth-of-type(even),
.wp-block-gallery .blocks-gallery-item:nth-of-type(even),
.blocks-gallery-grid .blocks-gallery-image:nth-of-type(even),
.blocks-gallery-grid .blocks-gallery-item:nth-of-type(even) {
  margin-right: 0;
}

.wp-block-gallery .blocks-gallery-image figure,
.wp-block-gallery .blocks-gallery-item figure,
.blocks-gallery-grid .blocks-gallery-image figure,
.blocks-gallery-grid .blocks-gallery-item figure {
  margin: 0;
  height: 100%;
}

@supports (position: sticky) {
  .wp-block-gallery .blocks-gallery-image figure,
  .wp-block-gallery .blocks-gallery-item figure,
  .blocks-gallery-grid .blocks-gallery-image figure,
  .blocks-gallery-grid .blocks-gallery-item figure {
    display: flex;
    align-items: flex-end;
    justify-content: flex-start;
  }
}
.wp-block-gallery .blocks-gallery-image img,
.wp-block-gallery .blocks-gallery-item img,
.blocks-gallery-grid .blocks-gallery-image img,
.blocks-gallery-grid .blocks-gallery-item img {
  display: block;
  max-width: 100%;
  height: auto;
  width: 100%;
}

@supports (position: sticky) {
  .wp-block-gallery .blocks-gallery-image img,
  .wp-block-gallery .blocks-gallery-item img,
  .blocks-gallery-grid .blocks-gallery-image img,
  .blocks-gallery-grid .blocks-gallery-item img {
    width: auto;
  }
}
.wp-block-gallery .blocks-gallery-image figcaption,
.wp-block-gallery .blocks-gallery-item figcaption,
.blocks-gallery-grid .blocks-gallery-image figcaption,
.blocks-gallery-grid .blocks-gallery-item figcaption {
  position: absolute;
  bottom: 0;
  width: 100%;
  max-height: 100%;
  overflow: auto;
  padding: 3em 0.77em 0.7em;
  color: #fff;
  text-align: center;
  font-size: 0.8em;
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.7) 0, rgba(0, 0, 0, 0.3) 70%, transparent);
  box-sizing: border-box;
  margin: 0;
}

.wp-block-gallery .blocks-gallery-image figcaption img,
.wp-block-gallery .blocks-gallery-item figcaption img,
.blocks-gallery-grid .blocks-gallery-image figcaption img,
.blocks-gallery-grid .blocks-gallery-item figcaption img {
  display: inline;
}

.wp-block-gallery figcaption,
.blocks-gallery-grid figcaption {
  flex-grow: 1;
}

.wp-block-gallery.is-cropped .blocks-gallery-image a,
.wp-block-gallery.is-cropped .blocks-gallery-image img,
.wp-block-gallery.is-cropped .blocks-gallery-item a,
.wp-block-gallery.is-cropped .blocks-gallery-item img,
.blocks-gallery-grid.is-cropped .blocks-gallery-image a,
.blocks-gallery-grid.is-cropped .blocks-gallery-image img,
.blocks-gallery-grid.is-cropped .blocks-gallery-item a,
.blocks-gallery-grid.is-cropped .blocks-gallery-item img {
  width: 100%;
}

@supports (position: sticky) {
  .wp-block-gallery.is-cropped .blocks-gallery-image a,
  .wp-block-gallery.is-cropped .blocks-gallery-image img,
  .wp-block-gallery.is-cropped .blocks-gallery-item a,
  .wp-block-gallery.is-cropped .blocks-gallery-item img,
  .blocks-gallery-grid.is-cropped .blocks-gallery-image a,
  .blocks-gallery-grid.is-cropped .blocks-gallery-image img,
  .blocks-gallery-grid.is-cropped .blocks-gallery-item a,
  .blocks-gallery-grid.is-cropped .blocks-gallery-item img {
    height: 100%;
    flex: 1;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
.wp-block-gallery.columns-1 .blocks-gallery-image,
.wp-block-gallery.columns-1 .blocks-gallery-item,
.blocks-gallery-grid.columns-1 .blocks-gallery-image,
.blocks-gallery-grid.columns-1 .blocks-gallery-item {
  width: 100%;
  margin-right: 0;
}

@media (min-width: 46.25em) {
  .wp-block-gallery.columns-3 .blocks-gallery-image,
  .wp-block-gallery.columns-3 .blocks-gallery-item,
  .blocks-gallery-grid.columns-3 .blocks-gallery-image,
  .blocks-gallery-grid.columns-3 .blocks-gallery-item {
    width: calc(33.33333% - 0.66667em);
    margin-right: 1em;
  }
  .wp-block-gallery.columns-4 .blocks-gallery-image,
  .wp-block-gallery.columns-4 .blocks-gallery-item,
  .blocks-gallery-grid.columns-4 .blocks-gallery-image,
  .blocks-gallery-grid.columns-4 .blocks-gallery-item {
    width: calc(25% - 0.75em);
    margin-right: 1em;
  }
  .wp-block-gallery.columns-5 .blocks-gallery-image,
  .wp-block-gallery.columns-5 .blocks-gallery-item,
  .blocks-gallery-grid.columns-5 .blocks-gallery-image,
  .blocks-gallery-grid.columns-5 .blocks-gallery-item {
    width: calc(20% - 0.8em);
    margin-right: 1em;
  }
  .wp-block-gallery.columns-6 .blocks-gallery-image,
  .wp-block-gallery.columns-6 .blocks-gallery-item,
  .blocks-gallery-grid.columns-6 .blocks-gallery-image,
  .blocks-gallery-grid.columns-6 .blocks-gallery-item {
    width: calc(16.66667% - 0.83333em);
    margin-right: 1em;
  }
  .wp-block-gallery.columns-7 .blocks-gallery-image,
  .wp-block-gallery.columns-7 .blocks-gallery-item,
  .blocks-gallery-grid.columns-7 .blocks-gallery-image,
  .blocks-gallery-grid.columns-7 .blocks-gallery-item {
    width: calc(14.28571% - 0.85714em);
    margin-right: 1em;
  }
  .wp-block-gallery.columns-8 .blocks-gallery-image,
  .wp-block-gallery.columns-8 .blocks-gallery-item,
  .blocks-gallery-grid.columns-8 .blocks-gallery-image,
  .blocks-gallery-grid.columns-8 .blocks-gallery-item {
    width: calc(12.5% - 0.875em);
    margin-right: 1em;
  }
  .wp-block-gallery.columns-1 .blocks-gallery-image:nth-of-type(1n),
  .wp-block-gallery.columns-1 .blocks-gallery-item:nth-of-type(1n),
  .blocks-gallery-grid.columns-1 .blocks-gallery-image:nth-of-type(1n),
  .blocks-gallery-grid.columns-1 .blocks-gallery-item:nth-of-type(1n) {
    margin-right: 0;
  }
  .wp-block-gallery.columns-2 .blocks-gallery-image:nth-of-type(2n),
  .wp-block-gallery.columns-2 .blocks-gallery-item:nth-of-type(2n),
  .blocks-gallery-grid.columns-2 .blocks-gallery-image:nth-of-type(2n),
  .blocks-gallery-grid.columns-2 .blocks-gallery-item:nth-of-type(2n) {
    margin-right: 0;
  }
  .wp-block-gallery.columns-3 .blocks-gallery-image:nth-of-type(3n),
  .wp-block-gallery.columns-3 .blocks-gallery-item:nth-of-type(3n),
  .blocks-gallery-grid.columns-3 .blocks-gallery-image:nth-of-type(3n),
  .blocks-gallery-grid.columns-3 .blocks-gallery-item:nth-of-type(3n) {
    margin-right: 0;
  }
  .wp-block-gallery.columns-4 .blocks-gallery-image:nth-of-type(4n),
  .wp-block-gallery.columns-4 .blocks-gallery-item:nth-of-type(4n),
  .blocks-gallery-grid.columns-4 .blocks-gallery-image:nth-of-type(4n),
  .blocks-gallery-grid.columns-4 .blocks-gallery-item:nth-of-type(4n) {
    margin-right: 0;
  }
  .wp-block-gallery.columns-5 .blocks-gallery-image:nth-of-type(5n),
  .wp-block-gallery.columns-5 .blocks-gallery-item:nth-of-type(5n),
  .blocks-gallery-grid.columns-5 .blocks-gallery-image:nth-of-type(5n),
  .blocks-gallery-grid.columns-5 .blocks-gallery-item:nth-of-type(5n) {
    margin-right: 0;
  }
  .wp-block-gallery.columns-6 .blocks-gallery-image:nth-of-type(6n),
  .wp-block-gallery.columns-6 .blocks-gallery-item:nth-of-type(6n),
  .blocks-gallery-grid.columns-6 .blocks-gallery-image:nth-of-type(6n),
  .blocks-gallery-grid.columns-6 .blocks-gallery-item:nth-of-type(6n) {
    margin-right: 0;
  }
  .wp-block-gallery.columns-7 .blocks-gallery-image:nth-of-type(7n),
  .wp-block-gallery.columns-7 .blocks-gallery-item:nth-of-type(7n),
  .blocks-gallery-grid.columns-7 .blocks-gallery-image:nth-of-type(7n),
  .blocks-gallery-grid.columns-7 .blocks-gallery-item:nth-of-type(7n) {
    margin-right: 0;
  }
  .wp-block-gallery.columns-8 .blocks-gallery-image:nth-of-type(8n),
  .wp-block-gallery.columns-8 .blocks-gallery-item:nth-of-type(8n),
  .blocks-gallery-grid.columns-8 .blocks-gallery-image:nth-of-type(8n),
  .blocks-gallery-grid.columns-8 .blocks-gallery-item:nth-of-type(8n) {
    margin-right: 0;
  }
}
.wp-block-gallery .blocks-gallery-image:last-child,
.wp-block-gallery .blocks-gallery-item:last-child,
.blocks-gallery-grid .blocks-gallery-image:last-child,
.blocks-gallery-grid .blocks-gallery-item:last-child {
  margin-right: 0;
}

.wp-block-gallery.alignleft,
.wp-block-gallery.alignright,
.blocks-gallery-grid.alignleft,
.blocks-gallery-grid.alignright {
  max-width: 290px;
  width: 100%;
}

.wp-block-gallery.aligncenter .blocks-gallery-item figure,
.blocks-gallery-grid.aligncenter .blocks-gallery-item figure {
  justify-content: center;
}

.wp-block-group {
  box-sizing: border-box;
}

h1.has-background,
h2.has-background,
h3.has-background,
h4.has-background,
h5.has-background,
h6.has-background {
  padding: 1.25em 2.375em;
}

.wp-block-image {
  margin-bottom: 20px;
}

@media (min-width: 46.25em) {
  .wp-block-image {
    margin-bottom: 40px;
    flex-wrap: nowrap;
  }
}
.wp-block-image {
  margin-inline: 0;
}
.wp-block-image img {
  max-width: 100%;
  border-radius: 8px;
}
.wp-block-image.aligncenter {
  text-align: center;
}
.wp-block-image.alignfull img, .wp-block-image.alignwide img {
  width: 100%;
}
.wp-block-image .alignleft, .wp-block-image .alignright, .wp-block-image .aligncenter {
  display: table;
}
.wp-block-image .alignleft > figcaption, .wp-block-image .alignright > figcaption, .wp-block-image .aligncenter > figcaption {
  display: table-caption;
  caption-side: bottom;
}
.wp-block-image .alignleft {
  /*rtl:ignore*/
  float: left;
  /*rtl:ignore*/
  margin-left: 0;
  margin-right: 1em;
  margin-top: 0.5em;
  margin-bottom: 0.5em;
}
.wp-block-image .alignright {
  /*rtl:ignore*/
  float: right;
  /*rtl:ignore*/
  margin-right: 0;
  margin-left: 1em;
  margin-top: 0.5em;
  margin-bottom: 0.5em;
}
.wp-block-image .aligncenter {
  margin-left: auto;
  margin-right: auto;
}

.is-style-rounded img {
  border-radius: 9999px;
}

.is-style-circle-mask img {
  border-radius: 9999px;
}

@supports ((-webkit-mask-image: none) or (mask-image: none)) or (-webkit-mask-image: none) {
  .is-style-circle-mask img {
    /* stylelint-disable */
    -webkit-mask-image: url('data:image/svg+xml;utf8,<svg viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg"><circle cx="50" cy="50" r="50"/></svg>');
    mask-image: url('data:image/svg+xml;utf8,<svg viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg"><circle cx="50" cy="50" r="50"/></svg>');
    /* stylelint-enable */
    mask-mode: alpha;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-position: center;
    mask-position: center;
    border-radius: 0;
  }
}
.wp-block-latest-comments__comment {
  line-height: 1.1;
  list-style: none;
  margin-bottom: 1em;
}

.has-avatars .wp-block-latest-comments__comment {
  min-height: 2.25em;
  list-style: none;
}

.has-avatars .wp-block-latest-comments__comment .wp-block-latest-comments__comment-meta,
.has-avatars .wp-block-latest-comments__comment .wp-block-latest-comments__comment-excerpt {
  margin-left: 3.25em;
}

.has-dates .wp-block-latest-comments__comment,
.has-excerpts .wp-block-latest-comments__comment {
  line-height: 1.5;
}

.wp-block-latest-comments__comment-excerpt p {
  font-size: 0.875em;
  line-height: 1.8;
  margin: 0.36em 0 1.4em;
}

.wp-block-latest-comments__comment-date {
  display: block;
  font-size: 0.75em;
}

.wp-block-latest-comments .avatar,
.wp-block-latest-comments__comment-avatar {
  border-radius: 1.5em;
  display: block;
  float: left;
  height: 2.5em;
  margin-right: 0.75em;
  width: 2.5em;
}

.wp-block-latest-posts.alignleft {
  /*rtl:ignore*/
  margin-right: 2em;
}

.wp-block-latest-posts.alignright {
  /*rtl:ignore*/
  margin-left: 2em;
}

.wp-block-latest-posts.wp-block-latest-posts__list {
  list-style: none;
}

.wp-block-latest-posts.wp-block-latest-posts__list li {
  clear: both;
}

.wp-block-latest-posts.is-grid {
  display: flex;
  flex-wrap: wrap;
  padding: 0;
}

.wp-block-latest-posts.is-grid li {
  margin: 0 1.25em 1.25em 0;
  width: 100%;
}

@media (min-width: 46.25em) {
  .wp-block-latest-posts.columns-2 li {
    width: calc(50% - 1.25em + 0.625em);
  }
  .wp-block-latest-posts.columns-2 li:nth-child(2n) {
    margin-right: 0;
  }
  .wp-block-latest-posts.columns-3 li {
    width: calc(33.3333333333% - 1.25em + 0.4166666667em);
  }
  .wp-block-latest-posts.columns-3 li:nth-child(3n) {
    margin-right: 0;
  }
  .wp-block-latest-posts.columns-4 li {
    width: calc(25% - 1.25em + 0.3125em);
  }
  .wp-block-latest-posts.columns-4 li:nth-child(4n) {
    margin-right: 0;
  }
  .wp-block-latest-posts.columns-5 li {
    width: calc(20% - 1.25em + 0.25em);
  }
  .wp-block-latest-posts.columns-5 li:nth-child(5n) {
    margin-right: 0;
  }
  .wp-block-latest-posts.columns-6 li {
    width: calc(16.6666666667% - 1.25em + 0.2083333333em);
  }
  .wp-block-latest-posts.columns-6 li:nth-child(6n) {
    margin-right: 0;
  }
}
.wp-block-latest-posts__post-date,
.wp-block-latest-posts__post-author {
  display: block;
  color: #555;
  font-size: 0.8125em;
}

.wp-block-latest-posts__post-excerpt {
  margin-top: 0.5em;
  margin-bottom: 1em;
}

.wp-block-latest-posts__featured-image a {
  display: inline-block;
}

.wp-block-latest-posts__featured-image img {
  height: auto;
  width: auto;
}

.wp-block-latest-posts__featured-image.alignleft {
  /*rtl:ignore*/
  margin-right: 1em;
}

.wp-block-latest-posts__featured-image.alignright {
  /*rtl:ignore*/
  margin-left: 1em;
}

.wp-block-latest-posts__featured-image.aligncenter {
  margin-bottom: 1em;
  text-align: center;
}

.block-editor-image-alignment-control__row .components-base-control__field {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.block-editor-image-alignment-control__row .components-base-control__field .components-base-control__label {
  margin-bottom: 0;
}

ol.has-background,
ul.has-background {
  padding: 1.25em 2.375em;
}

.wp-block-media-text {
  /*!rtl:begin:ignore*/
  direction: ltr;
  /*!rtl:end:ignore*/
  display: grid;
  grid-template-columns: 50% 1fr;
  grid-template-rows: auto;
}

.wp-block-media-text.has-media-on-the-right {
  grid-template-columns: 1fr 50%;
}

.wp-block-media-text.is-vertically-aligned-top .wp-block-media-text__content,
.wp-block-media-text.is-vertically-aligned-top .wp-block-media-text__media {
  align-self: start;
}

.wp-block-media-text .wp-block-media-text__content,
.wp-block-media-text .wp-block-media-text__media,
.wp-block-media-text.is-vertically-aligned-center .wp-block-media-text__content,
.wp-block-media-text.is-vertically-aligned-center .wp-block-media-text__media {
  align-self: center;
}

.wp-block-media-text.is-vertically-aligned-bottom .wp-block-media-text__content,
.wp-block-media-text.is-vertically-aligned-bottom .wp-block-media-text__media {
  align-self: end;
}

.wp-block-media-text .wp-block-media-text__media {
  /*!rtl:begin:ignore*/
  grid-column: 1;
  grid-row: 1;
  /*!rtl:end:ignore*/
  margin: 0;
}

.wp-block-media-text .wp-block-media-text__content {
  direction: ltr;
  /*!rtl:begin:ignore*/
  grid-column: 2;
  grid-row: 1;
  /*!rtl:end:ignore*/
  padding: 0 8% 0 8%;
  word-break: break-word;
}

.wp-block-media-text.has-media-on-the-right .wp-block-media-text__media {
  /*!rtl:begin:ignore*/
  grid-column: 2;
  grid-row: 1;
  /*!rtl:end:ignore*/
}

.wp-block-media-text.has-media-on-the-right .wp-block-media-text__content {
  /*!rtl:begin:ignore*/
  grid-column: 1;
  grid-row: 1;
  /*!rtl:end:ignore*/
}

.wp-block-media-text__media img,
.wp-block-media-text__media video {
  max-width: unset;
  width: 100%;
  vertical-align: middle;
}

.wp-block-media-text.is-image-fill figure.wp-block-media-text__media {
  height: 100%;
  min-height: 250px;
  background-size: cover;
}

.wp-block-media-text.is-image-fill figure.wp-block-media-text__media > img {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

/*
* Here we here not able to use a mobile first CSS approach.
* Custom widths are set using inline styles, and on mobile,
* we need 100% width, so we use important to overwrite the inline style.
* If the style were set on mobile first, on desktop styles,
* we would have no way of setting the style again to the inline style.
*/
@media (min-width: 46.25em) {
  .wp-block-media-text.is-stacked-on-mobile {
    grid-template-columns: 100% !important;
  }
  .wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__media {
    grid-column: 1;
    grid-row: 1;
  }
  .wp-block-media-text.is-stacked-on-mobile .wp-block-media-text__content {
    grid-column: 1;
    grid-row: 2;
  }
}
.wp-block-navigation:not(.has-background) .wp-block-navigation__container .wp-block-navigation-link:not(.has-text-color) {
  color: #1e1e1e;
}

.wp-block-navigation:not(.has-background) .wp-block-navigation__container .wp-block-navigation__container {
  background-color: #fff;
}

.items-justified-left > ul {
  justify-content: flex-start;
}

.items-justified-center > ul {
  justify-content: center;
}

.items-justified-right > ul {
  justify-content: flex-end;
}

.wp-block-navigation-link {
  display: flex;
  align-items: center;
  position: relative;
  margin: 0;
}

.wp-block-navigation-link .wp-block-navigation__container:empty {
  display: none;
}

.wp-block-navigation__container {
  list-style: none;
  margin: 0;
  padding-left: 0;
  display: flex;
  flex-wrap: wrap;
}

.is-vertical .wp-block-navigation__container {
  display: block;
}

.has-child > .wp-block-navigation-link__content {
  padding-right: 0.5em;
}

.has-child .wp-block-navigation__container {
  border: 1px solid rgba(0, 0, 0, 0.15);
  background-color: inherit;
  color: inherit;
  position: absolute;
  left: 0;
  top: 100%;
  width: -moz-fit-content;
  width: fit-content;
  z-index: 2;
  opacity: 0;
  transition: opacity 0.1s linear;
  visibility: hidden;
}

.has-child .wp-block-navigation__container > .wp-block-navigation-link > .wp-block-navigation-link__content {
  flex-grow: 1;
}

.has-child .wp-block-navigation__container > .wp-block-navigation-link > .wp-block-navigation-link__submenu-icon {
  padding-right: 0.5em;
}

@media (min-width: 46.25em) {
  .has-child .wp-block-navigation__container {
    left: 1.5em;
  }
  .has-child .wp-block-navigation__container .wp-block-navigation__container {
    left: 100%;
    top: -1px;
  }
  .has-child .wp-block-navigation__container .wp-block-navigation__container::before {
    content: "";
    position: absolute;
    right: 100%;
    height: 100%;
    display: block;
    width: 0.5em;
    background: transparent;
  }
  .has-child .wp-block-navigation__container .wp-block-navigation-link__submenu-icon svg {
    transform: rotate(0);
  }
}
.has-child:hover {
  cursor: pointer;
}

.has-child:hover > .wp-block-navigation__container {
  visibility: visible;
  opacity: 1;
  display: flex;
  flex-direction: column;
}

.has-child:focus-within {
  cursor: pointer;
}

.has-child:focus-within > .wp-block-navigation__container {
  visibility: visible;
  opacity: 1;
  display: flex;
  flex-direction: column;
}

.wp-block-navigation-link__content {
  color: inherit;
  text-decoration: none;
  padding: 0.5em 1em;
}

.wp-block-navigation-link__content + .wp-block-navigation-link__content {
  padding-top: 0;
}

.has-text-color .wp-block-navigation-link__content {
  color: inherit;
}

.wp-block-navigation-link__label {
  word-break: normal;
  overflow-wrap: break-word;
}

.wp-block-navigation-link__submenu-icon {
  height: inherit;
  padding: 0.375em 1em 0.375em 0;
}

.wp-block-navigation-link__submenu-icon svg {
  fill: currentColor;
}

@media (min-width: 46.25em) {
  .wp-block-navigation-link__submenu-icon svg {
    transform: rotate(90deg);
  }
}
.is-small-text {
  font-size: 0.875em;
}

.is-regular-text {
  font-size: 1em;
}

.is-large-text {
  font-size: 2.25em;
}

.is-larger-text {
  font-size: 3em;
}

.has-drop-cap:not(:focus)::first-letter {
  float: left;
  font-size: 8.4em;
  line-height: 0.68;
  font-weight: 100;
  margin: 0.05em 0.1em 0 0;
  text-transform: uppercase;
  font-style: normal;
}

p.has-background {
  padding: 1.25em 2.375em;
}

p.has-text-color a {
  color: inherit;
}

.wp-block-post-author {
  display: flex;
  flex-wrap: wrap;
}

.wp-block-post-author__byline {
  width: 100%;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 0.5em;
}

.wp-block-post-author__avatar {
  margin-right: 1em;
}

.wp-block-post-author__bio {
  margin-bottom: 0.7em;
  font-size: 0.7em;
}

.wp-block-post-author__content {
  flex-grow: 1;
  flex-basis: 0;
}

.wp-block-post-author__name {
  font-weight: bold;
  margin: 0;
}

.wp-block-pullquote {
  padding: 3em 0;
  margin-left: 0;
  margin-right: 0;
  text-align: center;
}

.wp-block-pullquote.alignleft,
.wp-block-pullquote.alignright {
  max-width: 290px;
}

.wp-block-pullquote.alignleft p,
.wp-block-pullquote.alignright p {
  font-size: 1.25em;
}

.wp-block-pullquote p {
  font-size: 1.75em;
  line-height: 1.6;
}

.wp-block-pullquote cite,
.wp-block-pullquote footer {
  position: relative;
}

.wp-block-pullquote .has-text-color a {
  color: inherit;
}

.wp-block-pullquote:not(.is-style-solid-color) {
  background: none;
}

.wp-block-pullquote.is-style-solid-color {
  border: none;
}

.wp-block-pullquote.is-style-solid-color blockquote {
  margin-left: auto;
  margin-right: auto;
  text-align: left;
  max-width: 60%;
}

.wp-block-pullquote.is-style-solid-color blockquote p {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 2em;
}

.wp-block-pullquote.is-style-solid-color blockquote cite {
  text-transform: none;
  font-style: normal;
}

.wp-block-pullquote cite {
  color: inherit;
}

.wp-block-quote.is-style-large,
.wp-block-quote.is-large {
  margin-bottom: 1em;
  padding: 0 1em;
}

.wp-block-quote.is-style-large p,
.wp-block-quote.is-large p {
  font-size: 1.5em;
  font-style: italic;
  line-height: 1.6;
}

.wp-block-quote.is-style-large cite,
.wp-block-quote.is-style-large footer,
.wp-block-quote.is-large cite,
.wp-block-quote.is-large footer {
  font-size: 1.125em;
  text-align: right;
}

.wp-block-rss.alignleft {
  /*rtl:ignore*/
  margin-right: 2em;
}

.wp-block-rss.alignright {
  /*rtl:ignore*/
  margin-left: 2em;
}

.wp-block-rss.is-grid {
  display: flex;
  flex-wrap: wrap;
  padding: 0;
  list-style: none;
}

.wp-block-rss.is-grid li {
  margin: 0 1em 1em 0;
  width: 100%;
}

@media (min-width: 46.25em) {
  .wp-block-rss.columns-2 li {
    width: calc(50% - 1em);
  }
  .wp-block-rss.columns-3 li {
    width: calc(33.3333333333% - 1em);
  }
  .wp-block-rss.columns-4 li {
    width: calc(25% - 1em);
  }
  .wp-block-rss.columns-5 li {
    width: calc(20% - 1em);
  }
  .wp-block-rss.columns-6 li {
    width: calc(16.6666666667% - 1em);
  }
}
.wp-block-rss__item-publish-date,
.wp-block-rss__item-author {
  display: block;
  color: #555;
  font-size: 0.8125em;
}

.wp-block-search .wp-block-search__inside-wrapper {
  display: flex;
  flex: auto;
  flex-wrap: nowrap;
  max-width: 100%;
}

.wp-block-search .wp-block-search__label {
  width: 100%;
}

.wp-block-search .wp-block-search__input {
  flex-grow: 1;
  min-width: 3em;
  border: 1px solid #949494;
}

.wp-block-search .wp-block-search__button {
  margin-left: 0.625em;
  word-break: normal;
}

.wp-block-search .wp-block-search__button svg {
  min-width: 1.5em;
  min-height: 1.5em;
}

.wp-block-search.wp-block-search__button-only .wp-block-search__button {
  margin-left: 0;
}

.wp-block-search.wp-block-search__button-inside .wp-block-search__inside-wrapper {
  padding: 4px;
  border: 1px solid #949494;
}

.wp-block-search.wp-block-search__button-inside .wp-block-search__inside-wrapper .wp-block-search__input {
  border-radius: 0;
  border: none;
  padding: 0 0 0 0.25em;
}

.wp-block-search.wp-block-search__button-inside .wp-block-search__inside-wrapper .wp-block-search__input:focus {
  outline: none;
}

.wp-block-search.wp-block-search__button-inside .wp-block-search__inside-wrapper .wp-block-search__button {
  padding: 0.125em 0.5em;
}

.wp-block-separator.is-style-wide {
  border-bottom-width: 1px;
}

.wp-block-separator.is-style-dots {
  background: none !important;
  border: none;
  text-align: center;
  max-width: none;
  line-height: 1;
  height: auto;
}

.wp-block-separator.is-style-dots::before {
  content: "···";
  color: currentColor;
  font-size: 1.5em;
  letter-spacing: 2em;
  /*rtl:ignore*/
  padding-left: 2em;
  font-family: serif;
}

.wp-block-custom-logo .aligncenter {
  display: table;
}

.wp-block-social-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  padding-left: 0;
  padding-right: 0;
  text-indent: 0;
  margin-left: 0;
}

.wp-block-social-links .wp-social-link a,
.wp-block-social-links .wp-social-link a:hover {
  text-decoration: none;
  border-bottom: 0;
  box-shadow: none;
}

.wp-social-link {
  display: block;
  width: 36px;
  height: 36px;
  border-radius: 9999px;
  margin: 0 8px 8px 0;
  transition: transform 0.1s ease;
}

@media (prefers-reduced-motion: reduce) {
  .wp-social-link {
    transition-duration: 0s;
  }
}
.wp-social-link a {
  padding: 6px;
  display: block;
  line-height: 0;
  transition: transform 0.1s ease;
}

.wp-social-link a,
.wp-social-link a:hover,
.wp-social-link a:active,
.wp-social-link a:visited,
.wp-social-link svg {
  color: currentColor;
  fill: currentColor;
}

.wp-social-link:hover {
  transform: scale(1.1);
}

.wp-block-social-links.aligncenter {
  justify-content: center;
  display: flex;
}

.wp-block-social-links.is-style-logos-only .wp-social-link {
  background: none;
  padding: 4px;
}

.wp-block-social-links.is-style-logos-only .wp-social-link svg {
  width: 28px;
  height: 28px;
}

.wp-block-spacer {
  clear: both;
}

p.wp-block-subhead {
  font-size: 1.1em;
  font-style: italic;
  opacity: 0.75;
}

.wp-block-table {
  overflow-x: auto;
}

.wp-block-table table {
  width: 100%;
}

.wp-block-table .has-fixed-layout {
  table-layout: fixed;
  width: 100%;
}

.wp-block-table .has-fixed-layout td,
.wp-block-table .has-fixed-layout th {
  word-break: break-word;
}

.wp-block-table.alignleft,
.wp-block-table.aligncenter,
.wp-block-table.alignright {
  display: table;
  width: auto;
}

.wp-block-table.alignleft td,
.wp-block-table.alignleft th,
.wp-block-table.aligncenter td,
.wp-block-table.aligncenter th,
.wp-block-table.alignright td,
.wp-block-table.alignright th {
  word-break: break-word;
}

.wp-block-table .has-subtle-light-gray-background-color {
  background-color: #f3f4f5;
}

.wp-block-table .has-subtle-pale-green-background-color {
  background-color: #e9fbe5;
}

.wp-block-table .has-subtle-pale-blue-background-color {
  background-color: #e7f5fe;
}

.wp-block-table .has-subtle-pale-pink-background-color {
  background-color: #fcf0ef;
}

.wp-block-table.is-style-stripes {
  border-spacing: 0;
  border-collapse: inherit;
  background-color: transparent;
  border-bottom: 1px solid #f0f0f0;
}

.wp-block-table.is-style-stripes tbody tr:nth-child(odd) {
  background-color: #f0f0f0;
}

.wp-block-table.is-style-stripes.has-subtle-light-gray-background-color tbody tr:nth-child(odd) {
  background-color: #f3f4f5;
}

.wp-block-table.is-style-stripes.has-subtle-pale-green-background-color tbody tr:nth-child(odd) {
  background-color: #e9fbe5;
}

.wp-block-table.is-style-stripes.has-subtle-pale-blue-background-color tbody tr:nth-child(odd) {
  background-color: #e7f5fe;
}

.wp-block-table.is-style-stripes.has-subtle-pale-pink-background-color tbody tr:nth-child(odd) {
  background-color: #fcf0ef;
}

.wp-block-table.is-style-stripes th,
.wp-block-table.is-style-stripes td {
  border-color: transparent;
}

.wp-block-text-columns {
  display: flex;
}

.wp-block-text-columns.aligncenter {
  display: flex;
}

.wp-block-text-columns .wp-block-column {
  margin: 0 1em;
  padding: 0;
}

.wp-block-text-columns .wp-block-column:first-child {
  margin-left: 0;
}

.wp-block-text-columns .wp-block-column:last-child {
  margin-right: 0;
}

.wp-block-text-columns.columns-2 .wp-block-column {
  width: 50%;
}

.wp-block-text-columns.columns-3 .wp-block-column {
  width: 33.3333333333%;
}

.wp-block-text-columns.columns-4 .wp-block-column {
  width: 25%;
}

.wp-block-video {
  margin-left: 0;
  margin-right: 0;
}

.wp-block-video video {
  max-width: 100%;
}

@supports (position: sticky) {
  .wp-block-video [poster] {
    -o-object-fit: cover;
       object-fit: cover;
  }
}
.wp-block-video.aligncenter {
  text-align: center;
}

.wp-block-video figcaption {
  margin-top: 0.5em;
  margin-bottom: 1em;
}

.wp-block-post-featured-image a {
  display: inline-block;
}

:root {
  /* stylelint-disable function-comma-space-after */
  /* stylelint-enable function-comma-space-after */
}

.has-small-font-size {
  font-size: 0.8125em;
}

.has-regular-font-size,
.has-normal-font-size {
  font-size: 1em;
}

.has-medium-font-size {
  font-size: 1.25em;
}

.has-large-font-size {
  font-size: 2.25em;
}

.has-larger-font-size,
.has-huge-font-size {
  font-size: 2.625em;
}

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

.has-text-align-left {
  /*rtl:ignore*/
  text-align: left;
}

.has-text-align-right {
  /*rtl:ignore*/
  text-align: right;
}

#end-resizable-editor-section {
  display: none;
}

.aligncenter {
  clear: both;
}

.wp-video {
  max-width: 100%;
}

.wp-caption {
  max-width: 100%;
}

/*
 * document elements / headding
 * document elements / note
 * document elements / footnote
 * document elements / table
 * document elements / divider
 * document elements / base,layout block
 *  - type : border 
 *  - type : card 
 *  - option : connect line 
 *  - option : padding
 *  - grid layout
 */
/* headding / 見出しの装飾 --------------------------------- */
.h-t {
  display: flex;
  align-items: center;
  font-size: clamp(1.25rem, 1.1923076923rem + 0.2564102564vw, 1.5rem);
  font-weight: 600;
  font-feature-settings: "palt";
  line-height: 1.3;
}
.h-t.-xs {
  font-size: clamp(0.75rem, 0.7153846154rem + 0.1538461538vw, 0.9rem);
}
.h-t.-s {
  font-size: clamp(1rem, 0.9538461538rem + 0.2051282051vw, 1.2rem);
}
.h-t.-l {
  font-size: clamp(1.5rem, 1.4307692308rem + 0.3076923077vw, 1.8rem);
}
.h-t.-xl {
  font-size: clamp(2.125rem, 2.0269230769rem + 0.4358974359vw, 2.55rem);
}
.h-t.-xxl {
  font-size: clamp(3rem, 2.8615384615rem + 0.6153846154vw, 3.6rem);
}
.h-t.-xxxl {
  font-size: clamp(3.75rem, 3.5769230769rem + 0.7692307692vw, 4.5rem);
}
.h-t > .icon:first-child {
  margin-right: 10px;
}

.h-u {
  position: relative;
  margin-bottom: 1em;
  padding-bottom: 1em;
  text-align: center;
  font-feature-settings: "palt";
  /* width */
}
.h-u::after {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  display: block;
  width: 100px;
  height: var(--borderw);
  margin: auto;
  background: currentColor;
  content: "";
  opacity: 1;
  border-radius: 3px;
}
.h-u.-s::after {
  width: 30px;
}
.h-u.-l::after {
  width: 165px;
}

.h-ut {
  position: relative;
  padding-bottom: 1em;
  font-feature-settings: "palt";
  /* width */
}
.h-ut > * {
  display: block;
}
.h-ut::after {
  position: relative;
  display: inline-block;
  width: 100px;
  height: var(--borderw);
  margin: auto;
  background: currentColor;
  transform: translateY(0.25em);
  content: "";
  opacity: 1;
  border-radius: 3px;
  vertical-align: middle;
}
.h-ut.-s::after {
  width: 30px;
}
.h-ut.-l::after {
  width: 165px;
}
.h-ut.-vs::after {
  vertical-align: top;
}
.h-ut.-vl::after {
  vertical-align: bottom;
}

/* --- */
.h-dot {
  position: relative;
  padding-left: 1.75em;
}
.h-dot::before {
  position: absolute;
  right: auto;
  left: 0.15em;
  top: 0;
  bottom: 0;
  display: block;
  width: 1em;
  height: 1em;
  margin: auto;
  content: "";
  box-sizing: border-box;
  border-radius: 50%;
  border: 0.33em double;
}

/* --- */
.-mark {
  position: relative;
  display: inline;
  background-image: linear-gradient(transparent calc(100% - 0.5em), rgba(130, 158, 162, 0.25) 1px);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  transition: background-size 0.5s cubic-bezier(0.46, 0.03, 0.52, 0.96);
}

/* note / 注釈・脚注 --------------------------------- */
.note {
  font-size: clamp(0.65625rem, 0.6346153846rem + 0.0961538462vw, 0.75rem);
  line-height: 1.8;
}
[lang=en] .note {
  line-height: 1.4;
}
.note.-l {
  font-size: clamp(0.71875rem, 0.6826923077rem + 0.1602564103vw, 0.875rem);
}

/* footnote / 脚注（リスト） --------------------------------- */
.footnote {
  position: relative;
  display: flex;
  flex-direction: column;
  margin: 20px 0;
  padding-left: 0;
  font-size: clamp(0.65625rem, 0.6346153846rem + 0.0961538462vw, 0.75rem);
  line-height: 2;
  list-style: none;
  counter-reset: footnote-num;
  font-feature-settings: "palt";
}
[lang=en] .footnote {
  line-height: 1.6;
}
.footnote li {
  position: relative;
  display: inline-block;
  padding-left: 0.9375rem;
}
.footnote:last-child {
  margin-bottom: 0;
}
.footnote li:last-child {
  margin-bottom: 0;
}
.footnote li::before {
  position: absolute;
  left: 0;
  content: "※ ";
  white-space: nowrap;
}
.footnote li.order {
  padding-left: 1.5625rem;
}
.footnote li.order::before {
  counter-increment: footnote-num;
  content: "※" counter(footnote-num) ". ";
}
.footnote.-inline {
  display: block;
  padding-left: 0;
}
.footnote.-inline li {
  display: inline;
  padding-left: 0;
}
.footnote.-inline li::before {
  position: relative;
  right: 0;
  margin-right: 0.0625rem;
}

.order-footnote {
  position: relative;
  display: flex;
  flex-direction: column;
  margin-bottom: 40px;
  padding-left: 0;
  font-size: clamp(0.625rem, 0.5961538462rem + 0.1282051282vw, 0.75rem);
  line-height: 1.8;
  list-style: none;
  counter-reset: footnote-num;
  font-feature-settings: "palt";
}
.order-footnote li {
  position: relative;
  display: inline-block;
  padding-left: 1.625rem;
}
.order-footnote li:last-child {
  margin-bottom: 0;
}
.order-footnote li::before {
  position: absolute;
  right: calc(100% + 0.53125rem);
  counter-increment: footnote-num;
  content: "※" counter(footnote-num) ". ";
  white-space: nowrap;
}
.order-footnote.-inline {
  display: block;
  padding-left: 0;
}
.order-footnote.-inline li {
  display: inline;
  padding-left: 0;
}
.order-footnote.-inline li::before {
  position: relative;
  right: 0;
  margin-right: 0.15625rem;
}

/* table / 表 --------------------------------- */
.table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
}
.table th {
  font-family: var(--font-m);
  font-weight: 500;
}
.table thead {
  color: var(--color-accent);
}
.table thead tr th, .table thead tr td {
  border-bottom: 1px solid var(--color-accent-bg);
}

/* divider / 分割線 --------------------------------- */
.divider {
  border: none;
  border-top: var(--borderw) solid;
  margin: 30px 0;
}
.divider.-dotted {
  border-top: var(--borderw) dotted;
}
.divider.-dashed {
  border-top: var(--borderw) dashed;
}
.divider.-double {
  border-top: calc(var(--borderw) * 2) double;
}
.divider.-inherit {
  margin: inherit;
}
.divider.-xs {
  margin: 10px 0;
}
.divider.-s {
  margin: 20px 0;
}
.divider.-r {
  margin: 30px 0;
}
.divider.-l {
  margin: 40px 0;
}
.divider.-xl {
  margin: 50px 0;
}
.divider.-xxl {
  margin: 60px 0;
}

/* base,layout --------------------------------------------- */
.c-section {
  margin-top: clamp(3.75rem, 3.1730769231rem + 2.5641025641vw, 6.25rem);
}
.c-section--0 {
  margin-top: 0;
}
.c-section--xxs {
  margin-top: clamp(0.625rem, 0.5528846154rem + 0.3205128205vw, 0.9375rem);
}
.c-section--xs {
  margin-top: clamp(0.9375rem, 0.7932692308rem + 0.641025641vw, 1.5625rem);
}
.c-section--s {
  margin-top: clamp(1.875rem, 1.5865384615rem + 1.2820512821vw, 3.125rem);
}
.c-section--m {
  margin-top: clamp(5.625rem, 5.0480769231rem + 2.5641025641vw, 8.125rem);
}
.c-section--l {
  margin-top: clamp(7.5rem, 6.9230769231rem + 2.5641025641vw, 10rem);
}
.c-section--xl {
  margin-top: clamp(9.375rem, 8.7980769231rem + 2.5641025641vw, 11.875rem);
}
.c-section--xxl {
  margin-top: clamp(11.25rem, 10.8173076923rem + 1.9230769231vw, 13.125rem);
}

.c-section--0 > *:first-child,
.c-section--xxs > *:first-child,
.c-section--xs > *:first-child,
.c-section--s > *:first-child,
.c-section > *:first-child,
.c-section--m > *:first-child,
.c-section--ml > *:first-child,
.c-section--l > *:first-child,
.c-section--xl > *:first-child,
.c-section--xxl > *:first-child {
  margin-top: 0;
}

/* type : border */
.c-section--border {
  padding: clamp(1.25rem, 1.1057692308rem + 0.641025641vw, 1.875rem);
  box-sizing: border-box;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 5px;
}
.c-section--border.-primary {
  border-color: var(--color-accent);
}
.c-section--border.-secondary {
  border-color: var(--color-txt);
}

.c-section--border > *:first-child {
  margin-top: 0;
}

/* type : border */
.c-section--fill {
  padding: clamp(1.25rem, 1.1057692308rem + 0.641025641vw, 1.875rem);
  box-sizing: border-box;
  border-radius: 5px;
  background-color: var(--color-warm-bg);
}
.c-section--fill > *:first-child {
  margin-top: 0;
}

/* type : sub border */
.c-section--subborder {
  display: flow-root;
  margin-left: 20px;
  padding: 0 0 0 20px;
  border-left: 1px solid var(--color-accent);
  box-sizing: border-box;
  font-size: 1.25rem;
}
.c-section--subborder > *:first-child {
  margin-top: 0;
}

/* ============================================================================================== */
/* Icon                                                                                           */
/* ============================================================================================== */
/* 
 * アイコンは基本的に単色で線と塗りだけで構成されています。
 * アイコンにtransitionを適用するためには予めSVGをHTML内に記述し、use要素を使用する方法がありますが、ページ内に直接SVGで定義する必要があります。
 * そのためJavaScriptでSVGアイコンのデータを定義し、特定の要素の独自データ属性があれば動的にSVGを記述する方法としています。
 * 
 */
/* ---------------------------------------------------------------------- */
.active .icon img,
.active .icon svg,
a:hover .icon img,
a:hover .icon svg {
  opacity: 1;
}

[data-icon],
.icon {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  letter-spacing: 0;
  line-height: 0;
  fill: currentColor;
  stroke-width: 1;
  width: 24px;
  height: 24px;
}

svg.icon,
.icon svg {
  width: 100%;
  height: 100%;
}

/* ---------------------------------------------------------------------- */
/* Inline svg default styles */
/* 
 * SVG内の要素に対して使用するクラス。
 */
/* 線の基本設定 */
.svg-line {
  fill: none;
  stroke: currentColor;
  stroke-width: inherit;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-miterlimit: 10;
}

/* 線 丸キャップ 丸角 */
.svg-line-round {
  fill: none;
  stroke: currentColor;
  stroke-width: inherit;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-miterlimit: 10;
}

/* 破線 丸キャップ 丸角 */
.svg-line-dash-round {
  fill: none;
  stroke: currentColor;
  stroke-width: inherit;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-miterlimit: 10;
  stroke-dasharray: 1.25, 1.25;
}

/* 線あり塗あり */
.svg-line-fill {
  fill: currentColor;
  stroke: currentColor;
  stroke-width: inherit;
  stroke-miterlimit: 10;
}

/* 線 キャップ無し 角 */
.svg-line-edge {
  fill: none;
  stroke: currentColor;
  stroke-width: inherit;
  stroke-linejoin: round;
  stroke-miterlimit: 10;
}

/* 塗のみ */
.svg-fill-only {
  fill: currentColor;
}

/* 塗無し */
.svg-fill-none {
  fill: none !important;
}

/* 塗りの上にくる要素の色 */
.svg-secondary-color {
  color: #fff;
}

/* ---------------------------------------------------------------------- */
/* weight */
/* ---------------------------------------------------------------------- */
/*
 * 線の太さの指定（絶対値）
 */
.icon.-w100 svg,
.icon.-w100 use {
  stroke-width: 0.2 !important;
}

.icon.-w200 svg,
.icon.-w200 use {
  stroke-width: 0.4 !important;
}

.icon.-w300 svg,
.icon.-w300 use {
  stroke-width: 0.6 !important;
}

.icon.-w400 svg,
.icon.-w400 use {
  stroke-width: 0.8 !important;
}

.icon.-w500 svg,
.icon.-w500 use {
  stroke-width: 1 !important;
}

.icon.-w600 svg,
.icon.-w600 use {
  stroke-width: 1.2 !important;
}

.icon.-w700 svg,
.icon.-w700 use {
  stroke-width: 1.4 !important;
}

.icon.-w800 svg,
.icon.-w800 use {
  stroke-width: 1.6 !important;
}

.icon.-w900 svg,
.icon.-w900 use {
  stroke-width: 2 !important;
}

/* ---------------------------------------------------------------------- */
/* size */
/* ---------------------------------------------------------------------- */
/*
 * サイズの指定（絶対値）
 */
.icon.-xxs {
  width: 16px !important;
  height: 16px !important;
}

.icon.-xs {
  width: 20px !important;
  height: 20px !important;
}

.icon.-s {
  width: 24px !important;
  height: 24px !important;
}

.icon.-m {
  width: 36px !important;
  height: 36px !important;
}

.icon.-l {
  width: 48px !important;
  height: 48px !important;
}

.icon.-xl {
  width: 60px !important;
  height: 60px !important;
}

.icon.-xxl {
  width: 72px !important;
  height: 72px !important;
}

/* ------------------------------------------------------------------- */
.toggleIcons {
  position: relative;
}

.toggleIcons__icon {
  display: block;
  transition: 0.3s cubic-bezier(0.7, -0.6, 0.3, 1.5);
  transition-property: transform, opacity;
}
.toggleIcons__icon:nth-child(1) {
  transform: rotate(0deg);
  opacity: 1;
}
.toggleIcons__icon:nth-child(2) {
  transform: rotate(125deg);
  opacity: 0;
}
.-show .toggleIcons__icon:nth-child(1) {
  transform: rotate(-125deg);
  opacity: 0;
}
.-show .toggleIcons__icon:nth-child(2) {
  transform: rotate(0deg);
  opacity: 1;
}
.toggleIcons__icon + .toggleIcons__icon {
  position: absolute;
  left: 0;
  top: 0;
}

/* ============================================================================================== */
/* Indicator                                                                                      */
/* ============================================================================================== */
/* ============================================================================================== */
/* Loading Progress bar                                                                           */
/* ============================================================================================== */
.progress {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  transition: all 0.25s ease-out 0.5s;
  z-index: 10000;
}
.progress.progress-complete {
  top: -5px;
}
.progress.progress-complete + .indicator span {
  opacity: 0;
}

.progress--inner {
  display: block;
  width: 0;
  height: 5px;
  transition: all 3s cubic-bezier(0.22, 0.61, 0.36, 1);
  background: var(--color-accent);
}
.progress.progress-complete .progress--inner {
  transition-duration: 0.5s;
}

/* ============================================================================================== */
/* UI / Input(text fields & controls)                                                             */
/* ============================================================================================== */
input,
textarea,
select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 0;
  padding: 10px 15px;
  outline: solid transparent;
  box-sizing: border-box;
  border: 2px solid rgba(0, 0, 0, 0.2);
  border-radius: 8px;
  background-color: rgba(0, 0, 0, 0);
  font-family: var(--system-fonts);
  font-size: 1.6rem;
  transition: 0.2s ease;
  transition-property: background, color, opacity;
  line-height: 1.5;
  color: var(--color-main);
}
input:hover,
textarea:hover,
select:hover {
  border-color: var(--color-main);
}
input:focus,
textarea:focus,
select:focus {
  background: rgba(0, 0, 0, 0);
  border-color: var(--input-color-main);
  outline: none;
}
input[readonly],
textarea[readonly],
select[readonly] {
  border: 1px dashed rgba(0, 0, 0, 0.25);
  box-shadow: none;
  background-image: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
input[readonly]:hover,
textarea[readonly]:hover,
select[readonly]:hover {
  border-color: rgba(0, 0, 0, 0.5);
}
input[readonly]:focus,
textarea[readonly]:focus,
select[readonly]:focus {
  border-color: rgba(0, 0, 0, 0.5);
  box-shadow: none !important;
}

input:focus::-webkit-input-placeholder,
textarea:focus::-webkit-input-placeholder {
  color: transparent;
}
input:focus::-moz-placeholder,
textarea:focus::-moz-placeholder {
  color: transparent;
}
input:focus:-ms-input-placeholder,
textarea:focus:-ms-input-placeholder {
  color: transparent;
}
input:valid,
textarea:valid {
  background-color: #fff;
}
input:invalid,
textarea:invalid {
  box-shadow: none;
}
input:disabled,
textarea:disabled,
option:disabled,
optgroup:disabled,
select:disabled:disabled {
  background: #f1f1f1;
  border: 1px solid rgba(0, 0, 0, 0) !important;
  cursor: not-allowed;
}

::-webkit-input-placeholder {
  color: #999;
}

::-moz-placeholder {
  color: #999;
}

:-ms-input-placeholder {
  color: #999;
}

/* ----------------------------------------------------------
 * 
 * textarea element
 *
 * ---------------------------------------------------------- */
textarea {
  font-family: var(--system-fonts) !important;
}

/* ----------------------------------------------------------
 * 
 * input element : text
 *
 * ---------------------------------------------------------- */
[type=text] {
  font-family: var(--system-fonts) !important;
}

/* ----------------------------------------------------------
 * 
 * input element : checkbox, radio
 *
 * ---------------------------------------------------------- */
[type=radio],
[type=checkbox] {
  overflow: hidden;
  width: 0;
  height: 0;
  border: none;
}
[type=radio] + label,
[type=checkbox] + label {
  position: relative;
  display: inline-flex;
  align-items: center;
  font-weight: 500;
  cursor: pointer;
}
[type=radio] + label .control,
[type=checkbox] + label .control {
  position: relative;
  display: inline-block;
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  margin-right: 10px;
  border: 2px solid rgba(0, 0, 0, 0.3);
  box-sizing: border-box;
  vertical-align: middle;
  transition: all 0.2s ease;
}
[type=radio] + label .control::before, [type=radio] + label .control::after,
[type=checkbox] + label .control::before,
[type=checkbox] + label .control::after {
  position: absolute;
  content: "";
  display: inline-block;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  margin: auto;
  box-sizing: border-box;
  transition: all 0.2s ease-in-out;
}
[type=radio] + label .control::before,
[type=checkbox] + label .control::before {
  display: none;
}
[type=radio] + label .control::after,
[type=checkbox] + label .control::after {
  opacity: 0;
}
[type=radio] + label:hover,
[type=checkbox] + label:hover {
  color: #000;
}
[type=radio] + label:hover .control,
[type=checkbox] + label:hover .control {
  border: 2px solid #000;
}
[type=radio]:checked + label .control,
[type=checkbox]:checked + label .control {
  border: 2px solid var(--input-color-main);
  opacity: 1;
  color: #000;
  opacity: 1;
}
[type=radio]:checked + label .control::after,
[type=checkbox]:checked + label .control::after {
  color: var(--input-color-main);
  opacity: 1;
}
[type=radio]:focus + label,
[type=checkbox]:focus + label {
  outline: 1px dashed;
}
[type=radio]:focus, [type=radio]:focus-visible,
[type=checkbox]:focus,
[type=checkbox]:focus-visible {
  outline: none;
}

[type=radio] + label .control {
  border-radius: 50%;
}
[type=radio] + label .control::after {
  width: 62.5%;
  height: 62.5%;
  background: var(--input-color-main);
  transform: scale(1.2, 1.2);
  border-radius: 50%;
}
[type=radio]:checked + label .control::after {
  background: var(--input-color-main);
  transform: scale(1, 1);
  transition-timing-function: cubic-bezier(0.22, 0.61, 0.36, 1);
}

[type=checkbox] + label .control {
  border-radius: 3px;
}
[type=checkbox] + label .control::after {
  top: -15%;
  width: 40%;
  height: 80%;
  border-right: 2px solid #FFF;
  border-bottom: 2px solid #FFF;
  transform: scale(1.2, 1.2) rotate(45deg);
}
[type=checkbox]:checked + label .control {
  background: var(--input-color-main);
}
[type=checkbox]:checked + label .control::after {
  transform: scale(1, 1) rotate(45deg);
  transition-timing-function: cubic-bezier(0.22, 0.61, 0.36, 1);
}

/* disabled */
[type=radio]:disabled + label,
[type=checkbox]:disabled + label {
  cursor: not-allowed;
  color: var(--color-txt-weak);
  opacity: 0.7;
}
[type=radio]:disabled + label:hover,
[type=checkbox]:disabled + label:hover {
  color: var(--color-txt-weak);
}
[type=radio]:disabled + label .control,
[type=checkbox]:disabled + label .control {
  border-color: #ccc;
  background-color: #ccc;
}
[type=radio]:disabled + label:hover .control,
[type=checkbox]:disabled + label:hover .control {
  border-color: #ccc;
  background-color: #ccc;
}
[type=radio]:disabled + label .control,
[type=checkbox]:disabled + label .control {
  background: #ccc;
  border-color: #ccc;
}

[type=radio]:disabled + label .control::after {
  background: #fff;
}

[type=checkbox]:disabled + label .control::after {
  background: #ccc;
  border-color: #fff;
}

/* error */
.error[type=radio] + label .control::after {
  background-color: var(--input-error);
}
.error[type=radio]:checked + label .control::after {
  background-color: var(--input-error);
}
.error[type=radio]:checked + label .control {
  border-color: var(--input-error);
}

.error[type=checkbox]:checked + label .control {
  background-color: var(--input-error);
}
.error[type=checkbox]:checked:checked + label .control {
  background-color: var(--input-error);
}
.error[type=checkbox]:checked:checked + label .control {
  border-color: var(--input-error);
}

/* ----------------------------------------------------------
 * 
 * input element : file
 *
 * ---------------------------------------------------------- */
[type=file] {
  font-size: 1.2rem;
  padding: 5px 0;
  border: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
[type=file]:hover::before {
  border-color: black;
}
[type=file]:disabled {
  color: #ccc;
  background-color: transparent;
}

.error[type=file] {
  background-color: transparent;
}

[type=file] + label .control:after {
  background: #fff;
}

/* 
 * 以下は JavaScript を使ってカスタマイズしたタイプ
 */
.input--file {
  position: relative;
}
.input--file input[type=file] {
  display: none;
  border: none;
  padding: 0;
}

.input--file__label {
  display: inline-block;
  padding: 0.25em 1em;
  border-radius: 5px;
  box-sizing: border-box;
  background-color: rgba(0, 0, 0, 0.3);
  border: none;
  cursor: pointer;
  white-space: nowrap;
}
.input--file.-selected .input--file__label {
  display: none;
}

/* UI wrapper */
.input--file__props-wrapper {
  display: flex;
  align-items: center;
}

/* props */
.input--file__props {
  display: inline-block;
  box-sizing: border-box;
  border-bottom: 1px solid #000;
  padding: 0.25em 0;
  white-space: nowrap;
  text-overflow: ellipsis;
  display: inline-block;
  overflow: hidden;
  overflow-y: visible;
}
.input--file__props:empty {
  border: none;
  display: block;
  padding: 0;
}

/* remove */
.input--file__remove {
  position: relative;
  display: none;
  border-radius: 5px;
  border-radius: 50%;
  padding: 0;
  box-sizing: border-box;
  background-color: #7e7e7e;
  cursor: pointer;
}
.input--file__remove:before, .input--file__remove:after {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: block;
  width: 10px;
  height: 1px;
  margin: auto;
  background-color: #fff;
  transform-origin: 50% 50%;
  content: "";
}
.input--file__remove:before {
  transform: rotate(45deg);
}
.input--file__remove:after {
  transform: rotate(-45deg);
}
.input--file__remove.active {
  display: block;
  width: 18px;
  height: 18px;
  margin: 0 0 0 0.5em;
  transition: background-color 0.2s ease-in-out;
}
.input--file__remove.active:hover {
  background-color: #333;
}

/* error */
.input--file__errorfield {
  padding: 0.25em 0;
  color: var(--input-error);
}
.input--file__errorfield:empty {
  padding: 0;
}

.input--file input[type=file]:invalid ~ .input--file__label,
.input--file input[type=file].error ~ .input--file__label {
  background-color: var(--input-error-bg);
  color: var(--input-error);
}

.input--file input[type=file]:invalid ~ .input--file__props-wrapper .input--file input[type=file].error ~ .input--file__props-wrapper .input--file__remove {
  background-color: var(--input-error);
}

/* disable */
.input--file input[type=file]:disabled ~ .input--file__label {
  color: #999;
  background-color: #ccc;
  cursor: not-allowed;
}

/* ----------------------------------------------------------
 * 
 * input element : color
 *
 * ---------------------------------------------------------- */
[type=color] {
  width: 80px;
  height: 40px;
  border-radius: 10px;
  border-width: 2px;
  padding: 5px;
  box-sizing: border-box;
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
[type=color]::-webkit-color-swatch-wrapper {
  padding: 0;
}
[type=color]::-webkit-color-swatch {
  border: none;
  border-radius: 5px;
}
[type=color]:disabled {
  opacity: 0.5;
}
[type=color].error {
  background-color: transparent;
}

/* ----------------------------------------------------------
 * 
 * input element : range
 *
 * ---------------------------------------------------------- */
[type=range] {
  width: 100%;
  height: 40px;
  padding: 0;
  border: none;
  cursor: pointer;
  background: transparent;
  -webkit-appearance: range;
  -moz-appearance: range;
  appearance: range;
  /* track styles */
  /* thumb styles */
  /* state */
  /* error */
}
[type=range]::-webkit-slider-runnable-track {
  width: 100%;
  height: 5px;
  background: rgba(0, 0, 0, 0.15);
  border-radius: 5px;
  border: none;
}
[type=range]::-moz-range-track {
  width: 100%;
  height: 5px;
  background: rgba(0, 0, 0, 0.15);
  border-radius: 5px;
  border: none;
}
[type=range]::-ms-track {
  width: 100%;
  height: 5px;
  background: rgba(0, 0, 0, 0.15);
  border-radius: 5px;
  border: none;
}
[type=range]::-ms-fill-upper {
  background: rgba(0, 0, 0, 0.1);
}
[type=range]::-ms-fill-lower {
  background: rgba(0, 0, 0, 0.1);
}
[type=range]::-webkit-slider-thumb {
  background: var(--input-color-main);
  box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.2);
  border: none;
  height: 40px;
  width: 10px;
  margin-top: -18px;
  border-radius: 5px;
  -webkit-appearance: none;
  -webkit-transition: 0.2s ease-out;
  transition: 0.2s ease-out;
  -webkit-transition-property: box-shadow, transform, width;
  transition-property: box-shadow, transform, width;
}
[type=range]::-moz-range-thumb {
  background: var(--input-color-main);
  box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.2);
  border: none;
  height: 40px;
  width: 10px;
  border-radius: 5px;
  -moz-transition: 0.2s ease-out;
  transition: 0.2s ease-out;
  -moz-transition-property: box-shadow, transform, width;
  transition-property: box-shadow, transform, width;
}
[type=range]::-ms-thumb {
  background: #000;
  border: none;
  height: 40px;
  width: 10px;
  border-radius: 5px;
}
[type=range]:valid {
  background: transparent;
}
[type=range]:focus {
  border: none !important;
  box-shadow: none !important;
}
[type=range]:hover {
  background: transparent;
}
[type=range]:hover::-moz-range-thumb {
  box-shadow: 10px 10px 15px rgba(0, 0, 0, 0.25);
}
[type=range]:hover::-webkit-slider-thumb {
  box-shadow: 10px 10px 15px rgba(0, 0, 0, 0.25);
}
[type=range]:hover::-ms-track {
  background: var(--input-color-main-bg);
}
[type=range]:disabled {
  background: transparent;
  /* track */
  /* thumb */
}
[type=range]:disabled::-webkit-slider-runnable-track {
  background: rgba(0, 0, 0, 0.1);
}
[type=range]:disabled::-moz-range-track {
  background: rgba(0, 0, 0, 0.1);
}
[type=range]:disabled::-ms-track {
  background: rgba(0, 0, 0, 0.1);
}
[type=range]:disabled::-webkit-slider-thumb {
  box-shadow: 0 0 0 rgba(0, 0, 0, 0.2);
  background: #ccc;
  cursor: not-allowed;
}
[type=range]:disabled::-moz-range-thumb {
  box-shadow: 0 0 0 rgba(0, 0, 0, 0.2);
  background: #ccc;
  cursor: not-allowed;
}
[type=range]:disabled::-ms-thumb {
  background: #ccc;
  cursor: not-allowed;
}
[type=range].error {
  background: transparent;
  /* track */
  /* thumb */
}
[type=range].error::-webkit-slider-runnable-track {
  background-color: var(--input-error-bg);
}
[type=range].error::-moz-range-track {
  background-color: var(--input-error-bg);
}
[type=range].error::-ms-track {
  background-color: var(--input-error-bg);
}
[type=range].error::-moz-range-thumb {
  background-color: var(--input-error);
  box-shadow: 5px 5px 10px var(--input-error-bg);
}
[type=range].error::-webkit-slider-thumb {
  background-color: var(--input-error);
  box-shadow: 5px 5px 10px var(--input-error-bg);
}
[type=range].error::-ms-thumb {
  background-color: var(--input-error);
}

/* ----------------------------------------------------------
 * 
 * input element : search
 *
 * ---------------------------------------------------------- */
[type=search] {
  border-radius: 60px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

/* ----------------------------------------------------------
 * 
 * input element : reset
 *
 * ---------------------------------------------------------- */
[type=reset],
[type=reset]:valid {
  cursor: pointer;
  /* btn */
}
/* ----------------------------------------------------------
 * 
 * input element : submit
 *
 * ---------------------------------------------------------- */
[type=submit],
[type=submit]:valid {
  color: #fff;
  background-color: var(--input-color-main);
  cursor: pointer;
  /* btn */
}
[type=submit].btn::before,
[type=submit]:valid.btn::before {
  opacity: 0;
}
[type=submit].btn:hover::before,
[type=submit]:valid.btn:hover::before {
  opacity: 0;
}
[type=submit].error,
[type=submit]:valid.error {
  color: #fff;
  background-color: var(--input-error);
}

/* ----------------------------------------------------------
 * 
 * input element : image
 *
 * ---------------------------------------------------------- */
[type=image],
[type=image]:valid {
  color: #fff;
  background-color: #000;
}
[type=image].error,
[type=image]:valid.error {
  color: #fff;
  background-color: var(--input-error);
}

/* ----------------------------------------------------------
 * 
 * input element : toggle switch (checkbox)
 *
 * ---------------------------------------------------------- */
.input-toggle[type=checkbox] {
  display: none;
  /* errorのスタイルは未定義 */
}
.input-toggle[type=checkbox] + label {
  --knob-size: 24px;
  --knob-padding: 4px;
  position: relative;
  display: inline-flex;
  justify-content: space-between;
  min-width: 60px;
  height: 30px;
  background: #aeaeae;
  border-radius: 20px;
  text-align: left;
  cursor: pointer;
  transition: 0.3s cubic-bezier(0.03, 0.48, 0.43, 1.18);
}
.input-toggle[type=checkbox] + label::after {
  position: absolute;
  display: inline-block;
  inset: 0 auto 0 var(--knob-padding);
  width: var(--knob-size);
  height: var(--knob-size);
  margin: auto;
  background: #fff;
  box-shadow: 0 2px 3px rgba(0, 0, 0, 0.25);
  border-radius: 100%;
  transition: 0.3s cubic-bezier(0.65, 0.05, 0.36, 1);
  transition-property: background-color, transform, inset;
  content: "";
}
.input-toggle[type=checkbox] + label .input-toggle-button__lbl {
  display: flex;
  align-items: center;
  flex-grow: 1;
  height: 100%;
  margin: 0 auto;
  padding: 0 5px;
  pointer-events: none;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  transition: opacity 0.2s ease-out;
}
.input-toggle[type=checkbox] + label .input-toggle-button__lbl.-true {
  padding-left: 10px;
  opacity: 0;
}
.input-toggle[type=checkbox] + label .input-toggle-button__lbl.-false {
  padding-right: 10px;
  opacity: 0.5;
}
.input-toggle[type=checkbox]:checked + label {
  background: var(--input-color-main-active);
  color: #fff;
}
.input-toggle[type=checkbox]:checked + label::after {
  left: calc(100% - var(--knob-size) - var(--knob-padding));
}
.input-toggle[type=checkbox]:checked + label .input-toggle-button__lbl.-true {
  opacity: 1;
}
.input-toggle[type=checkbox]:checked + label .input-toggle-button__lbl.-false {
  opacity: 0;
}
.input-toggle[type=checkbox]:disabled + .input-toggle-button {
  cursor: not-allowed;
  opacity: 0.3;
}
.input-toggle[type=checkbox]:disabled + .input-toggle-button::after {
  box-shadow: none;
}

/* ----------------------------------------------------------
 * 
 * select element
 *
 * ---------------------------------------------------------- */
.input--select-wrap {
  position: relative;
}
.input--select-wrap::before {
  content: "";
  position: absolute;
  width: 24px;
  height: 24px;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0.3;
  z-index: 2;
  transition: 0.2s ease;
  pointer-events: none;
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20version%3D%221.1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20width%3D%2224px%22%20height%3D%2224px%22%20viewBox%3D%220%200%2024%2024%22%20style%3D%22overflow%3Avisible%3Benable-background%3Anew%200%200%2024%2024%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cpolyline%20class%3D%22st0%22%20style%3D%22fill-rule%3Aevenodd%3Bclip-rule%3Aevenodd%3Bfill%3Anone%3Bstroke%3A%234c5769%3Bstroke-width%3A1.6%3Bstroke-linecap%3Around%3Bstroke-linejoin%3Around%3Bstroke-miterlimit%3A10%3B%22%20points%3D%2214.73%2C10.69%2012%2C13.73%209.27%2C10.69%22%2F%3E%3C%2Fsvg%3E");
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: center;
}
.input--select-wrap:hover::before {
  opacity: 1;
}
.input--select-wrap:hover:disabled::before {
  color: rgba(0, 0, 0, 0.3);
}
.input--select-wrap select {
  position: relative;
  z-index: 1;
  padding-right: 30px;
}
.input--select-wrap:has(.error)::before {
  color: var(--input-error);
}

/* ----------------------------------------------------------
 * 
 * progress element
 *
 * ---------------------------------------------------------- */
progress {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none; /* Firefox also renders a border */
  width: 100%;
  height: 20px;
  color: var(--input-color-main);
}

progress::-webkit-progress-bar {
  background-color: #e5e5e5;
}

progress::-webkit-progress-value {
  background: var(--input-color-main);
}

progress::-moz-progress-bar {
  background: var(--input-color-main);
}

/* ----------------------------------------------------------
 * 
 * meter element
 *
 * ---------------------------------------------------------- */
meter {
  display: block;
  margin-top: 10px;
  border: none;
  width: 100%;
  height: 20px;
  /* for Firefox */
  background: #e5e5e5;
  outline: none;
}

meter::-webkit-meter-inner-element {
  display: block;
}

meter::-webkit-meter-bar {
  border-radius: 0;
  border: none;
  background: #e5e5e5;
}

meter::-webkit-meter-optimum-value {
  background: rgb(125, 196, 0);
  border-radius: 0;
}

meter::-webkit-meter-suboptimum-value {
  background: rgb(255, 173, 67);
  border-radius: 0;
}

meter::-webkit-meter-even-less-good-value {
  background: rgb(255, 80, 80);
  border-radius: 0;
}

meter:-moz-meter-optimum::-moz-meter-bar {
  background: rgb(125, 196, 0);
}

meter:-moz-meter-sub-optimum::-moz-meter-bar {
  background: rgb(255, 173, 67);
}

meter:-moz-meter-sub-sub-optimum::-moz-meter-bar {
  background: rgb(255, 80, 80);
}

/* ----------------------------------------------------------
 * 
 * button element
 *
 * ---------------------------------------------------------- */
button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 10px 20px;
  box-sizing: border-box;
  border: var(--borderw) solid;
  border-radius: 5px;
  background-color: transparent;
  cursor: pointer;
  color: inherit;
  transition: 0.2s ease-out;
  transition-property: box-shadow, background-color, color, border-color;
}
button:hover {
  color: var(--color-hover);
}
button[disabled] {
  cursor: not-allowed;
  color: #999;
  background-color: #f1f1f1;
  border-color: transparent;
  box-shadow: none;
}

/* ----------------------------------------------------------
 * 
 * error
 *
 * ---------------------------------------------------------- */
.error {
  color: rgb(255, 0, 0);
  line-height: 1.4;
}

button.error,
input.error,
select.error,
textarea.error,
.error input,
.error select,
.error textarea {
  background: rgba(255, 0, 0, 0.05);
  color: rgb(255, 0, 0);
  border-color: rgb(255, 0, 0);
}

button.error:focus,
input.error:focus,
select.error:focus,
textarea.error:focus,
.error input:focus,
.error select:focus,
.error textarea:focus {
  background: rgb(255, 255, 255);
  border-color: rgb(255, 0, 0) !important;
  box-shadow: inset 0 0 0 1px rgb(255, 0, 0) !important;
}

/* ----------------------------------------------------------
 * 
 * password strength
 *
 * ---------------------------------------------------------- */
.pw-strength-outer {
  position: relative;
}

.pw-strength-label {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.pw-strength-result {
  position: relative;
  right: 0;
  top: 0;
  height: 3px;
  width: 80px;
  background: #ddd;
  border-radius: 5px;
  overflow: hidden;
}

.pw-strength-result:before {
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  content: "";
  width: 0%;
  height: 100%;
  background: #999;
  transition: 0.2s ease-out;
}

.pw-strength-result.score1:before {
  width: 25%;
  background: rgb(255, 86, 86);
}

.pw-strength-result.score2:before {
  width: 50%;
  background: rgb(255, 162, 0);
}

.pw-strength-result.score3:before {
  width: 75%;
  background: rgb(86, 183, 255);
}

.pw-strength-result.score4:before {
  width: 100%;
  background: rgb(98, 189, 0);
}

/* ----------------------------------------------------------
 * 
 * state: width
 *
 * ---------------------------------------------------------- */
input .-w10p,
select .-w10p,
textarea .-w10p {
  width: 10%;
}
input .-w20p,
select .-w20p,
textarea .-w20p {
  width: 20%;
}
input .-w30p,
select .-w30p,
textarea .-w30p {
  width: 30%;
}
input .-w40p,
select .-w40p,
textarea .-w40p {
  width: 40%;
}
input .-w50p,
select .-w50p,
textarea .-w50p {
  width: 50%;
}
input .-w60p,
select .-w60p,
textarea .-w60p {
  width: 60%;
}
input .-w70p,
select .-w70p,
textarea .-w70p {
  width: 70%;
}
input .-w80p,
select .-w80p,
textarea .-w80p {
  width: 80%;
}
input .-w90p,
select .-w90p,
textarea .-w90p {
  width: 90%;
}
input .-w100p,
select .-w100p,
textarea .-w100p {
  width: 100%;
}
input .-w1em,
select .-w1em,
textarea .-w1em {
  width: 1em;
}
input .-w2em,
select .-w2em,
textarea .-w2em {
  width: 2em;
}
input .-w3em,
select .-w3em,
textarea .-w3em {
  width: 3em;
}
input .-w4em,
select .-w4em,
textarea .-w4em {
  width: 4em;
}
input .-w5em,
select .-w5em,
textarea .-w5em {
  width: 5em;
}
input .-w6em,
select .-w6em,
textarea .-w6em {
  width: 6em;
}
input .-w7em,
select .-w7em,
textarea .-w7em {
  width: 7em;
}
input .-w8em,
select .-w8em,
textarea .-w8em {
  width: 8em;
}
input .-w9em,
select .-w9em,
textarea .-w9em {
  width: 9em;
}
input .-w10em,
select .-w10em,
textarea .-w10em {
  width: 10em;
}

.oft {
  display: block;
  overflow: hidden;
}

.oft__anm {
  display: block;
}
.inview.-unshow .oft__anm {
  opacity: 0;
  animation: none;
}
.inview.-show .oft__anm {
  animation: 1s cubic-bezier(0.77, 0, 0.18, 1) var(--delay, 0s) 1 both showOftText, 1s linear var(--delay, 0s) 1 both animate_color;
}

.oft__color {
  color: inherit;
}
a:hover .oft__color {
  color: inherit;
}

.inview {
  position: relative;
}
.inview .inview__obj {
  opacity: 0;
}
.inview.-show .inview__obj {
  transition: opacity 1s cubic-bezier(0.22, 0.61, 0.36, 1);
  opacity: 1;
}
.inview.-show .inview__maskobj {
  transition: opacity 1s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.inview.inviewMask {
  position: relative;
}
.inview.inviewMask .inviewMask__img {
  -webkit-mask-image: linear-gradient(90deg, #000 0, #000 50%, transparent 100%);
  mask-image: linear-gradient(90deg, #000 0, #000 50%, transparent 100%);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 200% 100%;
  mask-size: 200% 100%;
  -webkit-mask-position: 200% 0;
  mask-position: 200% 0;
}
.inview.inviewMask.-show .inviewMask__img {
  will-change: -webkit-mask, mask, animation;
  animation: 1.5s cubic-bezier(0.65, 0.05, 0.36, 1) var(--delay, 0s) 1 normal forwards maskFadeIn;
}
.inview.-animationFinish .image-mask-svg {
  display: none;
}

.image-mask-svg {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 60;
  pointer-events: none;
}
.image-mask-svg path {
  fill: var(--color-bg);
}

@keyframes maskFadeIn {
  0% {
    -webkit-mask-position: 200% 0;
    mask-position: 200% 0;
  }
  100% {
    -webkit-mask-position: 0 0;
    mask-position: 0 0;
  }
}
@keyframes maskFadeOut {
  0% {
    -webkit-mask-position: 0 0;
    mask-position: 0 0;
  }
  100% {
    -webkit-mask-position: 200% 0;
    mask-position: 200% 0;
  }
}
/* ============================================================================================== */
/* Letter, glyph                                                                                  */
/* ============================================================================================== */
/*
 * テキスト・文字に関するタグの基本設定
 * タグなので本来はglobalに書きますがテキスト関連ということでここで基本設定を行っています。
 *
 * Layout / global-footer
 *  - genelic class
 *  - Text align
 *  - Break
 */
/* ----------------------------------------------------------------------------------------
 *
 * ウェブフォント
 *
 * ----------------------------------------------------------------------------------------*/
@font-face {
  font-family: "Zen Kaku Gothic Antique", serif;
  font-style: normal;
  font-weight: normal;
  font-display: block;
}
/* ----------------------------------------------------------------------------------------
 *
 * 基本のフォント設定
 *
 * ----------------------------------------------------------------------------------------*/
body {
  font-weight: normal;
  font-family: var(--font-primaly);
  font-weight: 400;
  color: var(--color-txt);
}

input,
textarea,
select {
  font-family: var(--system-fonts);
}

main {
  width: 100%;
  height: auto;
  line-height: 2;
  font-size: clamp(0.8125rem, 0.7692307692rem + 0.1923076923vw, 1rem);
}
[lang=en] main {
  line-height: 1.6;
}

ruby {
  ruby-align: center;
}

ruby rt {
  font-size: 0.5625rem;
}

.no-deco a,
.no-deco {
  text-decoration: none;
}

.no-deco a:hover,
.no-deco:hover {
  text-decoration: none;
}

/* ----------------------------------------------------------------------------------------
 *
 * genelic class / 汎用クラス
 *
 * ----------------------------------------------------------------------------------------*/
.kerning,
.kerning--palt {
  font-feature-settings: "palt"; /* 役物半角 */
  /* font-feature-settings: 'pwid';*/
  /* font-feature-settings: 'pkna';*/
}

.kerning--pwid {
  /*font-feature-settings: 'palt';*/
  font-feature-settings: "pwid";
  /*font-feature-settings: 'pkna';*/
}

.tcu {
  -webkit-text-combine: horizontal;
  -ms-text-combine-horizontal: all;
  text-combine-upright: all;
}

.b {
  font-weight: 600;
}

.ib {
  display: inline-block;
}

.uppercase {
  text-transform: uppercase;
}

.lowercase {
  text-transform: lowercase;
}

.capitalize {
  text-transform: capitalize;
}

/* ----------------------------------------------------------------------------------------*/
.overflow-ellipsis {
  white-space: nowrap;
  text-overflow: ellipsis;
  display: inline-block;
  overflow: hidden;
  overflow-y: visible;
  width: 100%;
}

/* ----------------------------------------------------------------------------------------*/
/* ----------------------------------------------------------------------------------------
 *
 * genelic class / フォント指定
 *
 * ----------------------------------------------------------------------------------------*/
/* セリフ系フォント（欧文優先） */
/* サンセリフ系フォント（欧文優先） */
/* Condensed （長体） */
.-cnd {
  font-family: sans-serif;
  font-weight: inherit;
}

.b.-cnd {
  font-family: sans-serif;
  font-weight: inherit;
}

.t.-italic {
  font-style: italic !important;
}

/* ----------------------------------------------------------------------- */
/* Text align */
.t.-center {
  text-align: center;
}
.t.-right {
  text-align: right;
}
.t.-left {
  text-align: left;
}
.t.-justify {
  text-align: justify;
}
.t.-vertical {
  writing-mode: inherit;
}

/* ----------------------------------------------------------------------- */
/* Size */
.t.-fs-xs {
  font-size: 60%;
}
.t.-fs-s {
  font-size: 80%;
}
.t.-fs-l {
  font-size: 120%;
}
.t.-fs-xl {
  font-size: 140%;
}

/* ----------------------------------------------------------------------- */
/* Break */
br.tb {
  display: none;
}

br.pc {
  display: none;
}

br.sp {
  display: inline-block;
}

@media (min-width: 46.25em) {
  br.sp {
    display: none;
  }
  br.tb {
    display: inline-block;
  }
}
@media (min-width: 75em) {
  br.sp {
    display: none;
  }
  br.tb {
    display: none;
  }
  br.pc {
    display: inline-block;
  }
}
/* ----------------------------------------------------------------------- */
/* Color */
.color--disable {
  color: var(--color-disable) !important;
}

.color--primary {
  color: var(--color-primary) !important;
}

.color--secondary {
  color: var(--color-secondary) !important;
}

.color--important {
  color: var(--color-important) !important;
}

.color--warning {
  color: var(--color-warning) !important;
}

.color--current {
  color: var(--color-accent) !important;
}

.color--inherit {
  color: inherit !important;
}

.color--animation-loop {
  animation: 1s linear var(--delay, 0s) infinite both animate_color_loop !important;
}

/* ============================================================================================== */
/* UI Ppaging                                                                                     */
/* ============================================================================================== */
.paging {
  margin: 0 auto 40px;
  text-align: center;
}

/* not plugin ------------------------------- */
.page-numbers {
  display: inline-flex;
  flex-wrap: wrap;
  list-style: none;
  padding-left: 0;
  list-style: none;
}

.page-numbers li {
  margin: 0.5em;
}

.page-numbers li > * {
  display: block;
  padding: 1em;
  border: 1px solid rgba(0, 0, 0, 0.1);
  line-height: 1;
  min-width: 1em;
  text-align: center;
  box-sizing: border-box;
  border-radius: 5px;
}

.page-numbers a {
  text-decoration: none;
}

.page-numbers .current {
  background-color: var(--base-color);
  border-color: transparent;
  color: #fff;
  pointer-events: none;
}

.page-numbers a:hover {
  color: #fff;
  background-color: rgb(0, 0, 0);
}

.paging-detail {
  display: flex;
  justify-content: space-between;
  list-style: none;
  padding-left: 0;
  width: 100%;
}

/* ============================================================================================== */
/* Table                                                                                          */
/* ============================================================================================== */
/* ---------------------------------------------------------------------------------------------- */
/* standart                                                                                       */
/* ---------------------------------------------------------------------------------------------- */
.table {
  line-height: 1.6;
}
.table__item {
  display: flex;
  justify-content: space-between;
  padding: 1em 0;
  box-sizing: border-box;
  border-top: var(--borderw, 1px) dashed;
  position: relative;
}
@media (min-width: 61.25em) {
  .table__item {
    display: grid;
    grid-template-columns: repeat(14, 1fr);
    gap: 30px;
  }
}
.table__item:last-child {
  border-bottom: var(--borderw, 1px) dashed;
}
.table.-s .table__item {
  padding: 15px 0;
}
.table.-s .table__item::after {
  height: calc(100% - 20px);
}
.table.-l .table__item {
  padding: 25px 0;
}
.table__lbl {
  flex-shrink: 0;
  width: clamp(75px, 25%, 150px);
  box-sizing: border-box;
}
@media (min-width: 61.25em) {
  .table__lbl {
    width: auto;
    grid-row: 1;
    grid-column: 1/span 2;
  }
}
.table__des {
  flex-grow: 1;
  margin: 0;
}
.table__des > *:first-child {
  margin-top: 0;
}
@media (min-width: 61.25em) {
  .table__des {
    grid-row: 1;
    grid-column: 3/-1;
  }
}

/* ---------------------------------------------------------------------------------------------- */
/* difinition                                                                                     */
/* ---------------------------------------------------------------------------------------------- */
.defTable {
  line-height: 1.6;
}
.defTable__item {
  padding: 1em 0;
  box-sizing: border-box;
  border-bottom: var(--borderw, 1px) solid;
}
@media (min-width: 61.25em) {
  .defTable__item {
    display: grid;
    grid-template-columns: repeat(14, 1fr);
    gap: 30px;
  }
}
.defTable__item:first-child {
  border-top: var(--borderw, 1px) solid;
}
.defTable__lbl {
  flex-shrink: 0;
  width: clamp(75px, 25%, 150px);
  box-sizing: border-box;
}
@media (min-width: 61.25em) {
  .defTable__lbl {
    grid-row: 1;
    grid-column: 1/span 2;
  }
}
.defTable__des {
  flex-grow: 1;
  margin-top: 10px;
  margin-left: 0;
}
.defTable__des > *:first-child {
  margin-top: 0;
}
@media (min-width: 46.25em) {
  .defTable__des {
    grid-row: 1;
    grid-column: 3/-1;
  }
}

/* ============================================================================================== */
/* wrap-line                                                                                      */
/* ============================================================================================== */
.js-wrap-g,
.js-lwrap-g {
  opacity: 1 !important;
  transition: none !important;
}

.js-wrap,
.js-wrap-line {
  overflow: hidden;
  white-space: nowrap;
  scrollbar-width: none;
}
.js-wrap::-webkit-scrollbar,
.js-wrap-line::-webkit-scrollbar {
  display: none;
}

.js-wrap-line {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
}

.js-wrap .word,
.js-wrap .char,
.js-wrap-line .word,
.js-wrap-line .char {
  display: inline-block;
}

.js-wrap .char:empty,
.js-wrap-line .char:empty {
  display: none;
}

.js-wrap .word,
.js-wrap-line .word {
  white-space: nowrap;
}

.js-wrap .word-space,
.js-wrap-line .word-space {
  display: inline;
}

.text-wrapped .-show .js-wrap .word,
.text-wrapped .-show .js-wrap .char,
.text-wrapped .-show .js-wrap-line .word,
.text-wrapped .-show .js-wrap-line .char {
  will-change: transform;
}

.eraseStart .js-wrap .word,
.eraseStart .js-wrap .char,
.eraseStart .js-wrap-line .word,
.eraseStart .js-wrap-line .char {
  animation: 0.5s cubic-bezier(0.65, 0.05, 0.36, 1) 0s 1 hideOftText;
  animation-delay: var(--delay, 0s);
}

.-end-intro .inview .js-wrap .word,
.-end-intro .inview .js-wrap .char,
.-end-intro .inview .js-wrap-line .word,
.-end-intro .inview .js-wrap-line .char {
  animation: 0s 1 hideOftText;
  animation-fill-mode: forwards;
}

.-end-intro .inview.-show .js-wrap .word,
.-end-intro .inview.-show .js-wrap .char,
.-end-intro .inview.-show .js-wrap-line .word,
.-end-intro .inview.-show .js-wrap-line .char {
  animation: 1s cubic-bezier(0.17, 0.84, 0.44, 1) 0.2s 1 showOftText, 1s cubic-bezier(0.17, 0.84, 0.44, 1) 0.2s 1 animate_color;
  animation-delay: var(--delay, 0s);
  animation-fill-mode: both;
}

/* ============================================================================================== */
/* Module / UI Accordion                                                                          */
/* ============================================================================================== */
.ui-accordion {
  --duration: 0.4s;
}

.ui-accordion--item {
  position: relative;
  border-top: 1px solid;
}
.ui-accordion--item.uia--show {
  border-color: var(--color-main);
}

.ui-accordion--trigger {
  position: relative;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.79, 0.14, 0.15, 0.86);
}

.ui-accordion--contents {
  overflow: hidden;
  padding: 0;
  height: var(--height, 0);
  transition: var(--duration) cubic-bezier(0.77, 0, 0.18, 1);
  transition-property: height, opacity, padding;
  will-change: height, opacity, padding;
}
.uia--hide .ui-accordion--contents {
  opacity: 0;
  padding: 0;
}
.uia--show .ui-accordion--contents {
  opacity: 1;
}

.ui-accordion--icon {
  position: relative;
  display: inline-block;
  width: 24px;
  height: 24px;
  margin: auto 10px auto auto;
  transform: translateY(0);
  transform-origin: 50% 50%;
  transition: transform 0.25s ease-out;
}
.ui-accordion--icon::before, .ui-accordion--icon::after {
  position: absolute;
  content: "";
  width: 2px;
  height: 13px;
  background-color: currentColor;
  transform-origin: 50% 50%;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  transition: transform var(--duration) cubic-bezier(0.65, 0.05, 0.36, 1);
}
.ui-accordion--icon::before {
  transform: rotate(90deg);
}
.ui-accordion--icon::after {
  transform: rotate(0deg);
}
.uia--show .ui-accordion--icon::before {
  transform: rotate(270deg);
}
.uia--show .ui-accordion--icon::after {
  transform: rotate(270deg);
}

/* ============================================================================================== */
/* UI Carousel                                                                                    */
/* ============================================================================================== */
/* 
 * スワイプなどの機能は無い単純な左右無限のカルーセルです。
 * スワイプ機能を有する場合は現在 Swiper を使用しています。 _ui-swiperを参照してください。
 */
.carousel {
  position: relative;
  overflow: hidden;
  text-align: right;
}

.carousel__container {
  overflow: hidden;
  display: block;
  width: 100%;
  height: 200px;
  position: relative;
}

.carousel__item {
  float: left;
  display: block;
  line-height: 0;
  left: -1px;
  position: absolute;
  width: 66.666%;
}
.carousel__item img {
  display: block;
  width: calc(100% - 1px);
}

/* ============================================================================================== */
/* Module / Modal                                                                                 */
/* ============================================================================================== */
[data-modal] {
  position: fixed;
  inset: 0 0 0 auto;
  width: 100%;
  height: 90dvh;
  margin: auto;
  padding: 0;
  pointer-events: none;
  z-index: 1002;
  overflow: hidden;
}
:where(.text-wrapped) [data-modal] {
  display: none;
}
@media (min-width: 75em) {
  [data-modal] {
    overflow-y: hidden;
    max-height: 100vh;
  }
}
[data-modal].-ready {
  display: block;
}
@media (min-width: 75em) {
  [data-modal].-showModal {
    overflow-y: auto;
  }
}
[data-modal].-showModal .modal-scroll-container__outer {
  pointer-events: auto;
}
[data-modal].-showModal .modal-scroll-container__inner {
  pointer-events: auto;
}
[data-modal].-hideModal {
  display: none;
  pointer-events: none;
}
[data-modal].-small {
  max-width: 800px;
}
[data-modal] .modal__ttl {
  font-size: 140%;
  font-weight: bold;
}
[data-modal] img {
  display: block;
  width: 100%;
  border-radius: 5px;
}

@media screen and (max-height: 414px) and (max-width: 896px) and (orientation: landscape) {
  [data-modal] {
    max-height: 100lvh;
  }
}
.modal-scroll-container {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 100%;
  margin: 0 auto;
  padding: 0;
  box-sizing: border-box;
  overflow-y: auto;
  overflow-x: hidden;
  /* overscroll-behavior: contain; */
  border-radius: 10px 0 0 10px;
  vertical-align: middle;
  pointer-events: none;
}
.modal-scroll-container__outer {
  transition-duration: 0.3s;
  transition-timing-function: cubic-bezier(0.6, 0, 0.7, 0.2);
  transition-property: transform, opacity;
  transform: translate3d(0, clamp(40px, -6.9565217391px + 13.0434782609vw, 160px), 0);
  position: relative;
  box-sizing: border-box;
  overflow: auto;
  overflow-x: hidden;
  width: calc(100% - var(--ghw));
  height: 100%;
  margin-left: auto;
  border-radius: 10px 0 0 10px;
  pointer-events: none;
  opacity: 0;
}
@media (min-width: 90em) {
  .modal-scroll-container__outer {
    max-width: 2000px;
  }
}
.-showModal .modal-scroll-container__outer {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  transition-duration: 0.6s;
  transition-timing-function: cubic-bezier(0, 0.8, 0, 1), cubic-bezier(0.2, 0.4, 0.4, 1);
}
.modal-scroll-container__inner {
  position: relative;
  inset: 0;
  display: flex;
  justify-content: center;
  flex-direction: column;
  width: 100%;
  min-height: 90vh;
  margin: 0 auto;
  padding: 30px 0;
  background-color: var(--color-bg);
  border-radius: 10px 0 0 10px;
  line-height: 2;
}
.modal-scroll-container__inner .btn .icon {
  margin-left: 0;
}
@media (min-width: 46.25em) {
  .modal-scroll-container__inner {
    padding: 60px 0;
  }
}
@media (min-width: 61.25em) {
  .modal-scroll-container__inner {
    padding: 40px 0;
  }
}

/* ----------------------------------------------------------------------------- */
[data-modal-close] {
  position: absolute;
  top: 30px;
  right: 20px;
  cursor: pointer;
  z-index: 5;
  border: none;
  padding: 0;
}
[data-modal-close] i {
  width: 48px;
  height: 48px;
}
@media (min-width: 61.25em) {
  [data-modal-close] {
    top: 40px;
    right: 40px;
  }
}
[data-modal].-showModal [data-modal-close] {
  pointer-events: auto;
}

/* ----------------------------------------------------------------------------- */
[data-modal-overlay] {
  position: fixed;
  inset: 0;
  display: block;
  width: 100%;
  height: 100vh;
  opacity: 0;
  background-color: var(--color-overlay);
  z-index: -1;
  pointer-events: none;
  transition: opacity 0.5s cubic-bezier(0.17, 0.84, 0.44, 1);
}
.-showModal [data-modal-overlay] {
  opacity: 0.5;
  pointer-events: auto;
}

/* --------------------------------- */
[data-toggle] {
  cursor: pointer;
}

html.-show-modal body {
  /*overflow: hidden;*/
}

/* ----------------------------------------------------------------------------- */
/* Effects                                                                       */
/* ----------------------------------------------------------------------------- */
[data-modal] .modal-oft {
  display: block;
  overflow: hidden;
}

[data-modal] .modal-oft__anm {
  display: block;
  animation-fill-mode: both;
}

.-show-modal [data-modal] .modal-oft {
  opacity: 1;
}
.-show-modal [data-modal] .modal-oft__anm {
  opacity: 1;
  animation: 0.8s cubic-bezier(0.77, 0, 0.18, 1) calc(var(--delay, 0s) + 0.3s) 1 both showModalOftText, 0.8s linear calc(var(--delay, 0s) + 0.3s) 1 both animate_color;
}
.-show-modal [data-modal] .js-wrap .word, .-show-modal [data-modal] .js-wrap .char, .-show-modal [data-modal] .js-wrap-line .word, .-show-modal [data-modal] .js-wrap-line .char {
  padding-right: 0.025em;
}
.-show-modal [data-modal] .js-wrap .word, .-show-modal [data-modal] .js-wrap .char, .-show-modal [data-modal] .js-wrap-line .word, .-show-modal [data-modal] .js-wrap-line .char {
  animation: 0.8s cubic-bezier(0.77, 0, 0.18, 1) calc(var(--delay, 0s) / 2) 1 both showModalOftText, 0.8s linear calc(var(--delay, 0s) / 2) 1 both animate_color;
}

@keyframes hideModalOftText {
  0% {
    transform: translate3d(0, 0, 0);
  }
  100% {
    transform: translate3d(0, -100%, 0);
  }
}
@keyframes showModalOftText {
  0% {
    transform: translate3d(0, 100%, 0);
  }
  100% {
    transform: translate3d(0, 0, 0);
  }
}
/* ============================================================================================== */
/* Module / UI Tooltip                                                                            */
/* ============================================================================================== */
/*
 * 1. Hide by default
 * 2. Position
 * 3. Dimensions
 * 4. Style
 */
[uk-tooltip] {
  cursor: help;
}

.uk-tooltip {
  display: none;
  position: absolute;
  z-index: 1030;
  box-sizing: border-box;
  max-width: 220px;
  padding: 15px 18px;
  background: #fff;
  border-radius: 5px;
  color: #333;
  font-size: 1.2rem;
  line-height: 1.6;
  box-shadow: 5px 5px 15px rgba(0, 0, 0, 0.1);
}

/* Show */
.uk-tooltip.uk-active {
  display: block;
}

/* Direction */
[class*=uk-tooltip-top] {
  margin-top: -10px;
}

[class*=uk-tooltip-bottom] {
  margin-top: 10px;
}

[class*=uk-tooltip-left] {
  margin-left: -10px;
}

[class*=uk-tooltip-right] {
  margin-left: 10px;
}

/* ============================================================================================== */
/* UI Popup Menus                                                                                 */
/* ============================================================================================== */
.popup {
  position: relative;
}
.popup .ui--icon {
  position: absolute;
  right: 10px;
  left: auto;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 12px;
  height: 12px;
}
.popup .ui--icon::before, .popup .ui--icon::after {
  position: absolute;
  display: block;
  content: "";
  width: 8px;
  height: 1px;
  background-color: #000;
  transform-origin: 50% 50%;
  background-color: currentColor;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  transition: transform 0.15s cubic-bezier(0.77, 0, 0.18, 1);
}
.popup .ui--icon::before {
  transform: translateX(-1.75px) rotate(60deg);
}
.popup .ui--icon::after {
  transform: translateX(1.75px) rotate(-60deg);
}
.popup .ui--icon.-active .popup .ui--icon::before {
  transform: translateX(-1.75px) rotate(-60deg);
}
.popup .ui--icon.-active .popup .ui--icon::after {
  transform: translateX(1.75px) rotate(60deg);
}

.popup__trigger {
  display: inline-block;
  position: relative;
  z-index: 105;
  white-space: nowrap;
  cursor: pointer;
  padding: 8px 4px;
  text-decoration: none;
  line-height: 1;
  border-radius: 5px;
  border: none;
}
.popup__trigger:hover {
  text-decoration: none;
}

.popup__target {
  position: absolute;
  display: none;
  z-index: 110;
  top: calc(100% + 3px);
  right: 0;
  left: 50%;
  transform-origin: center 0%;
  width: 100%;
  min-width: 260px;
  text-align: left;
  border-radius: max(5px, var(--borderrad) / 2);
  background-color: var(--color-bg);
  border: max(2px, var(--borderw) / 2) solid;
  transition: transform 0.2s cubic-bezier(0.17, 0.84, 0.44, 1);
}
.popup__target ul {
  list-style: none;
  padding: 5px 0;
  margin: 0;
}
.popup__target li {
  padding: 0;
}
.popup__target li a {
  cursor: pointer;
  border: none;
}
.popup__target li a.-selected {
  background-color: transparent;
  font-weight: bold;
  pointer-events: none;
  opacity: 0.4;
}
.popup__target li a:hover {
  text-decoration: none;
}
.popup__target li::before {
  content: none;
}
.popup.-active .popup__target {
  display: block;
}
.popup__target a, .popup__target .label {
  padding: 15px;
  display: inline-block;
  width: 100%;
  box-sizing: border-box;
  line-height: 1.25;
}
.popup__target .item {
  padding: 20px 0;
}
.popup__target .item :first-child {
  border-top: none;
}
.popup__target .item a:hover {
  background-color: rgba(0, 0, 0, 0.05);
}
.popup__target .title {
  margin-bottom: 5px;
  letter-spacing: 0.05em;
}

.popup__target--items {
  min-width: initial;
}

/* ============================================================================================== */
/* UI Popup SelectMenus                                                                           */
/* ============================================================================================== */
.popup-select {
  display: none;
}

/* ============================================================================================== */
/* UI Inline sider navigation                                                                     */
/* ============================================================================================== */
/*
.slide-local-nav {
    position: relative;
}

.slide-local-nav-inner {
    overflow-x: auto;
    overflow-y: hidden;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
}

.slide-local-nav__body {
    display: flex;
    align-items: center;
    list-style: none;
    margin: 0;
    padding: 0;
    height: 40px;
}

.slide-local-nav__cell {
    margin-right: 20px;
}

.slide-local-nav__cell:first-child {
    margin-left: 10px;
}

.slide-local-nav__cell:last-child {
    padding-right: 10px;
}

.slide-local-nav__cell .current {
    color: #fff;
    font-weight: bolder;
}

.slide-local-nav__arrow {
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    top: 0;
    width: 20px;
    height: 40px;
    transition: opacity 0s ease-out;
    background-color: rgb(88,88,88);
    color: #fff;
} 

.slide-local-nav__arrow:before {
    position: absolute;
    display: block;
    content: "";
    width: 10px;
    height: 100%;
    pointer-events: none;
}

.slide-local-nav__arrow.-left {
    left: 0;
}

.slide-local-nav__arrow.-left:before {
    left: 100%;
    background: -webkit-linear-gradient(90deg, rgba(0,0,0,0.1), rgba(0,0,0,0) 100%);
    background:         linear-gradient(90deg, rgba(0,0,0,0.1), rgba(0,0,0,0) 100%);
}

.slide-local-nav__arrow.-right {
    right: 0;
}

.slide-local-nav__arrow.-right:before {
    right: 100%;
    background: -webkit-linear-gradient(90deg, rgba(0,0,0,0), rgba(0,0,0,0.1) 100%);
    background:         linear-gradient(90deg, rgba(0,0,0,0), rgba(0,0,0,0.1) 100%);
}

.slide-local-nav__arrow.-hide {
    pointer-events: none;
    opacity: 0;
}

.slide-local-nav__arrow svg {
    width: 15px;
    height: 15px;
    stroke-width: 2;
}


@include mq(tb3) {
    .slide-local-nav {
        background-color: transparent;
    }

    .slide-local-nav-inner {
        display: flex;
        align-items: center;
    }

    .slide-local-nav__cell:last-child {
        padding-right: 0;
    }

}

*/
.globalWrapper {
  position: relative;
  overflow: hidden;
}

.gh {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  margin: 0 auto;
  z-index: 100;
  pointer-events: none;
  transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
  transition: all 0.45s cubic-bezier(0.65, 0.05, 0.36, 1);
  transition-property: transform, opacity, width;
}

.gh,
.-show .gh,
.-hide .gh {
  pointer-events: none;
}

.-show .gh {
  pointer-events: auto;
}

.gh a {
  transition: all 0.2s ease-in-out;
  text-decoration: none;
}
.gh a:hover {
  color: var(--color-link);
}
.gh .anm {
  opacity: 0;
  transition: opacity 0.5s cubic-bezier(0.65, 0.05, 0.36, 1);
}
.gh__logoWrap {
  position: absolute;
  top: 60px;
  right: 30px;
  z-index: 90;
  margin: 0;
  transform: translate3d(0, 0, 0);
  transition: all 0.45s cubic-bezier(0.65, 0.05, 0.36, 1);
}
.gh__logo {
  margin: 0;
  pointer-events: auto;
  cursor: pointer;
}
.gh__logo a {
  display: block;
  width: clamp(35px, 33.0434782609px + 0.5434782609vw, 40px);
  height: auto;
  transition: all 0.2s ease-in-out;
  pointer-events: none;
}
.gh__logo a:hover {
  color: inherit;
}
.gh__logo a i {
  display: block;
  width: 100%;
  height: 100%;
}
.gh__pageTitle {
  display: none;
}
.gh__info {
  display: none;
}

.-show .gh .anm {
  opacity: 1;
}

.gh--inner {
  position: relative;
  width: 100%;
  height: 100%;
  padding: 0;
  box-sizing: border-box;
  z-index: 200;
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;
  vertical-align: middle;
  -webkit-overflow-scrolling: touch;
  opacity: 0;
  background: #fff;
  border-radius: var(--borderrad);
  transform: translateX(100%);
  transition: 0.5s cubic-bezier(0.65, 0.05, 0.36, 1);
  transition-property: background, opacity, transform;
}
.gh--innerContents {
  margin: 0 auto;
  padding: 160px 0 200px;
}
.gh--inner__logo {
  margin: 0 auto 160px;
  text-align: center;
}
.gh--inner__logo a {
  display: block;
  width: clamp(35px, 33.0434782609px + 0.5434782609vw, 40px);
  height: auto;
  margin: 0 auto;
}
.gh--inner__logo i {
  display: block;
  width: 100%;
  height: 100%;
}
.gh--innerWrap {
  width: calc(100% - 20px);
  height: calc(100% - 40px);
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  margin: auto;
}
.gh--inner__toggle {
  display: none !important;
  position: fixed;
  top: 50px;
  right: 30px;
  z-index: 202;
  opacity: 0;
  transition: 1s ease;
}
.-show .gh--inner__toggle {
  display: block !important;
  opacity: 1;
}
.-show .gh--inner__toggle .menu-button__icon-wrap {
  transform: translateY(0px) !important;
}
.gh--inner__toggle .icon {
  width: 32px;
  height: 32px;
}
.gh--inner__toggle svg {
  width: 32px;
  height: 32px;
}

.-show .gh--inner {
  display: block;
  transform: translateX(0);
  opacity: 1;
  transition-timing-function: cubic-bezier(0.17, 0.84, 0.44, 1);
  -ms-overflow-style: none;
  scrollbar-width: none;
  /* animation */
  animation: navOpen 0.8s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
  animation-fill-mode: both;
  /**/
}

.-show .gh--inner::-webkit-scrollbar {
  display: none;
}

.-hide .gh--inner {
  animation: navClose 0.8s cubic-bezier(0.165, 0.84, 0.44, 1) 0s;
  animation-fill-mode: both;
}

@keyframes navOpen {
  0% {
    opacity: 0;
    transform: scale(0.9);
    transform-origin: center center;
  }
  100% {
    opacity: 1;
    transform: scale(1);
    transform-origin: center center;
  }
}
@keyframes navClose {
  0% {
    opacity: 1;
    transform: scale(1);
    transform-origin: center center;
  }
  100% {
    opacity: 0;
    transform: scale(0.9);
    transform-origin: center center;
  }
}
.pc .gh--inner {
  transition: none;
}

.global-nav {
  text-align: center;
}

.g-nav {
  list-style: none;
}
.g-nav__list.main {
  display: flex;
  flex-direction: column;
  gap: 15px;
  margin-bottom: 30px;
}
.g-nav__list.main .g-nav__li a {
  font-size: clamp(1.0625rem, 0.9891304348rem + 0.3260869565vw, 1.25rem);
}
.g-nav__list.sub {
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin-bottom: 30px;
}
.g-nav__list.sub .g-nav__li a {
  font-size: 14px;
}
.g-nav__list.sns {
  display: flex;
  justify-content: center;
  gap: 18px;
}
.g-nav__li {
  padding-left: 0;
}
.g-nav__li::before {
  content: none;
}
.g-nav__li a {
  font-weight: 500;
  text-decoration: none;
  position: relative;
}

@media (min-width: 75em) {
  .globalWrapper {
    overflow: visible;
    display: flex;
  }
  .gh {
    position: sticky;
    max-width: 220px;
    bottom: 0;
    margin: 0;
    pointer-events: auto;
  }
  .gh .anm {
    opacity: 1;
  }
  .gh__logoWrap {
    position: fixed;
    top: 20px;
    right: 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40px;
  }
  .gh__logo {
    pointer-events: none;
  }
  .gh__logo a {
    pointer-events: auto;
  }
  .gh__pageTitle {
    display: block;
    font-size: 16px;
    font-weight: 500;
    writing-mode: vertical-rl;
    margin: 0;
  }
  .gh__info {
    display: block;
  }
  .gh__info .info--tel {
    font-weight: 500;
    font-size: 24px;
    margin-bottom: 5px;
    display: block;
  }
  .gh__info small {
    font-size: 12px;
  }
  .gh--inner {
    width: 300px;
    display: flex;
    align-items: flex-end;
    margin: 0;
    padding: 0 0 40px 40px;
    transform: translateX(0);
    opacity: 1;
    z-index: 201;
    overflow: visible;
    background-color: transparent;
    transition: none;
  }
  .gh--innerWrap {
    width: 100%;
    height: 100%;
  }
  .gh--innerContents {
    padding: 0;
    margin: 0;
  }
  .gh--inner__logo {
    display: none;
  }
  .global-nav {
    text-align: left;
  }
  .g-nav__list.main {
    gap: 24px;
  }
  .g-nav__list.sub {
    gap: 14px;
  }
  .g-nav__list.sub .g-nav__li a {
    font-size: 13px;
  }
  .g-nav__list.sns {
    justify-content: flex-start;
    margin-bottom: 30px;
  }
  .g-nav__list.sns li a:after {
    content: none !important;
  }
  .g-nav__list.sns li a .icon {
    transition: inherit;
    transform: scale(1);
  }
  .g-nav__list.sns li a:hover .icon {
    transform: scale(1.2);
  }
  .g-nav__li a {
    padding-bottom: 6px;
  }
  .g-nav__li a:hover {
    color: #000;
  }
}
.site-subheader {
  position: fixed;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  width: calc(100% - 20px);
  margin: 0 auto calc(env(safe-area-inset-bottom, 21px) + 5px);
  padding: 15px 0;
  box-sizing: border-box;
  z-index: 200;
  pointer-events: auto;
  transition: all 0.5s cubic-bezier(0.17, 0.84, 0.44, 1) 1s;
  background-color: rgb(255, 255, 255);
  border-radius: var(--borderrad);
  pointer-events: auto;
  transform: translate3d(0, 0, 0);
  box-shadow: 20px 20px 60px rgba(68, 68, 68, 0.8);
}
.site-subheader__sub-list {
  display: flex;
  align-items: center;
  justify-content: space-between;
  list-style: none;
  padding-left: 0;
  text-align: center;
  transform: translateX(5px);
  margin: 0 auto;
}
.site-subheader__sub-li {
  width: 50%;
  padding: 0;
  margin: 0;
}
.site-subheader__sub-li:after {
  content: "";
  width: 1px;
  height: 40px;
  background-color: var(--color-line);
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}
.site-subheader__sub-li:last-child:after {
  content: none;
}
.site-subheader__sub-li .icon {
  width: 24px;
  height: 24px;
  transition: inherit;
  animation: subHeaderMenuAnime 6s linear infinite alternate;
}
@keyframes subHeaderMenuAnime {
  0% {
    transform: rotate(0deg) scale(1);
  }
  22% {
    transform: rotate(0deg) scale(1.1);
  }
  24% {
    transform: rotate(-8deg) scale(1.2);
  }
  26% {
    transform: rotate(0deg) scale(1.4);
  }
  28% {
    transform: rotate(6deg) scale(1.5);
  }
  30% {
    transform: rotate(-4deg) scale(1.3);
  }
  32% {
    transform: rotate(0deg) scale(1.2);
  }
  34% {
    transform: rotate(8deg) scale(1.1);
  }
  36% {
    transform: rotate(0deg) scale(1.05);
  }
  100% {
    transform: rotate(0deg) scale(1);
  }
}
.site-subheader__sub-li:nth-child(1) .icon {
  animation-delay: 0s;
}
.site-subheader__sub-li:nth-child(2) .icon {
  animation-delay: 0.2s;
}
.site-subheader__sub-li:nth-child(3) .icon {
  animation-delay: 0.4s;
}
.site-subheader__sub-li .icon svg {
  width: 100%;
  height: 100%;
}
.site-subheader__sub-li .lbl {
  display: inline-block;
  font-size: clamp(0.59375rem, 0.4836956522rem + 0.4891304348vw, 0.875rem);
  transition: inherit;
  margin-top: 5px;
  white-space: nowrap;
}
.site-subheader__sub-li:before {
  content: none;
}
.site-subheader__sub-a {
  display: flex !important;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  transition: inherit;
  transition-duration: 0.4s;
  transition-timing-function: cubic-bezier(0.17, 0.84, 0.44, 1);
  transition-property: opacity, color, transform;
  text-decoration: none;
}

.sp.scroll-y-end:not(.-show) .site-subheader {
  transform: translate3d(0, 0, 0);
}

.-show .site-subheader {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.-show .site-subheader__sub-li .icon {
  animation-play-state: paused;
}

@media (min-width: 75em) {
  .site-subheader {
    left: auto;
    bottom: 0;
    max-width: none;
    width: auto;
    background-color: transparent;
    border-radius: none;
    padding: 10px 20px 40px;
    box-shadow: none;
    transform: translate3d(0, 0, 0);
    margin-bottom: 0;
  }
  .site-subheader__sub-list {
    flex-direction: column;
  }
  .site-subheader__sub-li {
    margin-bottom: 30px;
    width: 100%;
  }
  .site-subheader__sub-li.li--tel {
    margin-bottom: 0;
  }
  .site-subheader__sub-li:after {
    content: none;
  }
  .site-subheader__sub-a .icon {
    animation: none;
    padding-right: 5px;
  }
  .site-subheader__sub-a .lbl {
    writing-mode: vertical-rl;
    padding-right: 5px;
    position: relative;
    transition: inherit;
  }
  .site-subheader__sub-a .lbl::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 1px;
    height: 0;
    transition: 0.4s cubic-bezier(0.17, 0.84, 0.44, 1);
    background-color: var(--color-txt);
  }
  .site-subheader__sub-a:hover .icon {
    transform: scale(1.2);
  }
  .site-subheader__sub-a:hover .lbl:after {
    height: 100%;
  }
}
/* outsideHour */
.outsideHourToggle {
  display: none !important;
}

.insideHourAnchor {
  display: flex !important;
}

.-outsideHour .outsideHourToggle {
  display: flex !important;
}
.-outsideHour .insideHourAnchor {
  display: none !important;
}

.menu-button {
  position: relative;
  pointer-events: auto;
  z-index: 201;
  cursor: pointer;
  position: relative;
  display: block;
  margin: auto;
  padding: 0;
  overflow: hidden;
  box-sizing: border-box;
  transition: all 0.5s cubic-bezier(0.17, 0.84, 0.44, 1) !important;
  transition-delay: 0s;
}
.menu-button__icon-wrap {
  position: relative;
  display: block;
  height: 24px;
  width: 24px;
}
.menu-button__icon {
  transition: background-color 0.2s cubic-bezier(0.65, 0.05, 0.36, 1);
}
.menu-button__icon:before, .menu-button__icon:after {
  transition-duration: 0.2s;
  transition-timing-function: cubic-bezier(0.65, 0.05, 0.36, 1);
  transition-property: background-color, top, left, width, transform;
  box-sizing: border-box;
}
.menu-button__icon, .menu-button__icon:before, .menu-button__icon:after {
  position: absolute;
  display: block;
  height: 1px;
  width: 24px;
  padding: 0;
  background: currentColor;
  text-indent: -200px;
}
.menu-button__icon {
  position: relative;
}
.menu-button__icon {
  top: calc(50% - 1px);
  left: 0;
  right: 0;
  margin: 0 auto;
  transform-origin: center 15px;
}
.menu-button__icon:before {
  top: -6px;
  content: "";
  transform-origin: center center;
}
.menu-button__icon:after {
  width: 16px;
  top: 6px;
  content: "";
  transform-origin: center center;
}
.menu-button a:hover {
  color: currentColor;
}

.-show .menu-button__icon-wrap {
  transform: translateY(5px) !important;
}

.-show .menu-button__icon,
.-show .menu-button__icon:before,
.-show .menu-button__icon:after {
  left: 0px;
}

.-show .menu-button__icon {
  left: -10px;
  transform: translateX(10px);
  background-color: rgba(255, 255, 255, 0);
}

.-show .menu-button__icon:before {
  transform: rotate(45deg) translate(6.5px, 2.5px);
  width: 18px;
}

.-show .menu-button__icon:after {
  transform: rotate(-45deg) translate(6px, -2px);
  width: 18px;
}

@media (min-width: 75em) {
  .menu {
    display: none;
  }
}
.overlay {
  position: fixed;
  height: 100vh;
  width: 100%;
  top: 0;
  right: 0;
  opacity: 0;
  visibility: hidden;
  transition: 0.5s cubic-bezier(0.65, 0.05, 0.36, 1);
  transition-property: opacity, visibility;
  background: rgba(0, 0, 0, 0.2);
  z-index: 10;
}

.-show .overlay {
  opacity: 1;
  visibility: visible;
  cursor: pointer;
  transition-timing-function: cubic-bezier(0.17, 0.84, 0.44, 1);
}

[class*=w-state] {
  position: static;
  margin-right: auto;
  margin-left: auto;
}

.w-state {
  --w-state-padding: clamp(40px, 26.1538461538px + 3.8461538462vw, 100px);
  width: calc(100% - var(--w-state-padding) - env(safe-area-inset-left) - env(safe-area-inset-right));
}

/* 
 * document wrapper
 */
[documentContent] {
  padding: 0 0 env(safe-area-inset-left);
  counter-reset: sectionNum;
}
@media (min-width: 75em) {
  [documentContent] {
    width: calc(100% - 220px);
  }
}

/* precedes language --------------------------------------------- */
/* anchor offset ------------------------------------------------- */
/* Loading Animations -------------------------------------------- */
/* main-document-module.cscc の body-overlay に記述 */
/* inview -------------------------------------------------------------------------- */
.inview .inview__item {
  opacity: 0;
  transform: translateY(20px);
  transition-duration: 0.6s, 0.6s;
  transition-property: opacity, transform;
  transition-timing-function: linear, cubic-bezier(0.47, 0, 0.75, 0.72);
}

.inview.-show .inview__item {
  opacity: 1;
  transform: translateY(0);
}

/* mask*/
.txtMask {
  /*
  background-image: linear-gradient(30deg,currentColor,currentColor 47.5%,rgba(141,141,141,.5) 52.5%,rgba(141,141,141,.5));
  background-position: 0 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  background-size: 300% 200%;
  transition: background-position .4s ease-out 1s;*/
  transition: filter 0.4s ease-out 1s;
  will-change: -webkit-mask, mask, animation;
}

.-show .inview__item .txtMask {
  animation: txtMask 1s cubic-bezier(0.65, 0.05, 0.36, 1) var(--delay, 0s) 1 normal forwards;
}

@keyframes txtMask {
  0% {
    filter: blur(30px);
  }
  100% {
    filter: blur(0);
  }
}
/*.inview__item.sectionBody__imgWrap .sub__img {
	opacity: 0;
	transition-delay: .4s;
	transition-duration: .6s;
}

.-show .sectionBody__imgWrap .sub__img {
	opacity: 1;
}*/
.inview.inviewMask .inviewMask__img {
  -webkit-mask-image: linear-gradient(90deg, #000 0, #000 50%, transparent 100%);
  mask-image: linear-gradient(90deg, #000 0, #000 50%, transparent 100%);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 200% 100%;
  mask-size: 200% 100%;
  -webkit-mask-position: 200% 0;
  mask-position: 200% 0;
}

.inview.inviewMask img.inviewMask__img {
  filter: blur(30px);
  opacity: 0;
  transition-duration: 1.5s, 1s;
  transition-property: filter, opacity;
  transition-timing-function: 0.8s linear, cubic-bezier(0.47, 0, 0.75, 0.72);
}

.inview.-show .inviewMask .inviewMask__img,
.inview.inviewMask.-show .inviewMask__img {
  will-change: -webkit-mask, mask, animation;
  animation: 1.5s cubic-bezier(0.65, 0.05, 0.36, 1) var(--delay, 0s) 1 normal forwards maskFadeIn;
}

.inview.-show .inviewMask .inviewMask__img img {
  opacity: 1;
  filter: blur(0);
}

.image-mask-svg {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 60;
  pointer-events: none;
}

.image-mask-svg path {
  fill: var(--color-bg);
}

@keyframes maskFadeIn {
  0% {
    -webkit-mask-position: 200% 0;
    mask-position: 200% 0;
  }
  100% {
    -webkit-mask-position: 0 0;
    mask-position: 0 0;
  }
}
@keyframes maskFadeOut {
  0% {
    -webkit-mask-position: 0 0;
    mask-position: 0 0;
  }
  100% {
    -webkit-mask-position: 200% 0;
    mask-position: 200% 0;
  }
}
/* ============================================================================================== */
/* Module / Form                                                                                  */
/* ============================================================================================== */
/* ----------------------------------------------- */
/* form layout */
/* ------------------------------- */
.inputItemBlock {
  margin-top: 25px;
}
.inputItemBlock:first-child {
  margin-top: 0;
}

/* ------------------------------- */
.input-lbl {
  display: inline-flex;
  align-items: center;
  padding-bottom: 5px;
  font-weight: bold;
}
.input-lbl::before {
  content: "任意";
  color: #fff;
  text-indent: 0;
  margin-right: 8px;
  font-size: 12px;
  background-color: var(--color-txt-weak);
  padding: 0 8px;
  border-radius: 5px;
}
.input-lbl.-no-lbl::before {
  content: none;
}
.required .input-lbl::before {
  content: "必須";
  color: #fff;
  text-indent: 0;
  margin-right: 8px;
  font-size: 12px;
  background-color: var(--color-important);
  padding: 0 8px;
  border-radius: 5px;
}

/* ------------------------------- */
.input-elm > *:first-child {
  margin-top: 0;
}

.input-elm .error-message {
  display: block;
  padding: 0.75em 0 0;
}

.input-grp {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 20px;
}
.input-grp > * {
  margin: 0;
}

/* ------------------------------- */
.controlBlock {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 20px;
  padding: 10px 0;
}

.controlBlock__item {
  display: inline-flex;
  align-items: center;
  margin: 0;
  padding: 0;
  white-space: nowrap;
}
.controlBlock__item::before {
  content: none;
}

/* ------------------------------- */
.input-note {
  margin: 10px 0;
  color: var(--color-txt-weak);
  font-size: 1.05rem;
  line-height: 1.5;
}
.input-note:first-child {
  margin-top: 0;
  padding-top: 7px;
}
.input-note:last-child {
  margin-bottom: 0;
}

/* ------------------------------- */
.mp-input.-w10p {
  width: 10%;
}
.mp-input.-w20p {
  width: 20%;
}
.mp-input.-w30p {
  width: 30%;
}
.mp-input.-w40p {
  width: 40%;
}
.mp-input.-w50p {
  width: 50%;
}
.mp-input.-w60p {
  width: 60%;
}
.mp-input.-w70p {
  width: 70%;
}
.mp-input.-w80p {
  width: 80%;
}
.mp-input.-w90p {
  width: 90%;
}
.mp-input.-w100p {
  width: 100%;
}

/* ------------------------------- */
.mp-textarea {
  min-height: 10em;
}

/* ------------------------------- */
.input-definition {
  position: relative;
  margin: 0;
}
.input-definition > div {
  position: relative;
}
.input-definition dt {
  position: absolute;
  display: inline-block;
  margin: 0;
  padding: 0 5px;
  top: -0.7em;
  left: 5px;
  font-size: 1.2rem;
  line-height: 1;
  z-index: 2;
  transition: 0.2s ease;
  pointer-events: none;
  background-color: rgb(255, 255, 255);
}
.input-definition label {
  pointer-events: auto;
}
.input-definition dd {
  margin-left: 0;
}

.input-definition .input--select-wrap:hover::after {
  color: rgb(0, 0, 0);
}

.input-definition .input--select-wrap:hover:disabled::after {
  color: rgba(0, 0, 0, 0.3);
}

/* ------------------------------- */
.mp-form-footer {
  display: flex;
  justify-content: center;
}
.mp-form-footer .paging {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.mp-form-footer .paging__item {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0;
}
.mp-form-footer .paging__item::before {
  content: none;
}

/* ---------------------------------------------------------------------- */
/* confirm */
/* ---------------------------------------------------------------------- */
.mp-confirm-table {
  display: block;
  width: 100%;
}
.mp-confirm-table tr {
  display: block;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}
.mp-confirm-table th {
  display: block;
  width: 180px;
  padding: 10px 10px 0 0;
  box-sizing: border-box;
  text-align: left;
  font-size: 1.1rem;
  font-weight: 400;
  color: #999;
}
.mp-confirm-table td {
  display: block;
  padding: 0 0 10px 0;
  box-sizing: border-box;
  font-size: 1.3rem;
  font-weight: 500;
}

.mp-status-preview {
  margin-bottom: 40px;
  padding: 20px 0;
}
.mp-status-preview .mp-confirm-table {
  font-weight: normal;
}
.mp-status-preview .mp-confirm-table th {
  font-weight: normal;
  font-size: 1.3rem;
  color: #555;
  width: 150px;
}
.mp-status-preview .mp-confirm-table td {
  font-weight: 300;
  font-size: 1.3rem;
  color: #555;
}
.mp-status-preview .mp-confirm-table .txt {
  display: block;
  margin-bottom: 0.5em;
}
.mp-status-preview .mp-confirm-table .btn {
  position: absolute;
  right: 0;
  top: 10px;
}

/* ============================================================================================== */
/* Layout - main / document transition                                                            */
/* ============================================================================================== */
/* Event
 * - .eraseStart
 * - .onloadstart
 * - .onloadajaxcontent
 * - .onready
 * - .onloadcomplete
 * Intro
 */
/* -------------------------------------------------- */
.-end-intro .eraseStart #async-container {
  animation: hideContents var(--erase-animation-time, 1s) cubic-bezier(0.17, 0.84, 0.44, 1) 1;
}
.-end-intro .onloadcomplete #async-container {
  animation: showContents var(--erase-animation-time, 1s) cubic-bezier(0.17, 0.84, 0.44, 1) 1;
  cursor: auto;
}
@keyframes hideContents {}
@keyframes showContents {}
/* -------------------------------------------------- */
.page-transition-cover {
  position: fixed;
  left: 0;
  top: 0;
  bottom: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 100dvh;
  z-index: 999;
  perspective: 1;
  opacity: 1;
  transition: none;
  color: var(--color-primary);
}
.page-transition-cover .indicator {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  margin: auto;
  transition: 0.25s ease 0.5s;
  opacity: 1;
  z-index: 1000;
  animation: 0.5s steps(2) 0s infinite indicator_animation;
}
.page-transition-cover .image-mask-svg__elm {
  transition: 0.5s ease-out;
  transition-property: fill, stroke, opacity;
}
.page-transition-cover .image-mask-svg__elm.fill {
  fill: var(--color-bg);
}
.page-transition-cover .image-mask-svg__elm.line {
  stroke-width: 10;
  stroke: var(--color-main);
}
.page-transition-cover.-finish {
  transition: opacity 0.25s ease-out;
  pointer-events: none;
}
.page-transition-cover.-finish .image-mask-svg__elm {
  opacity: 0;
}
.page-transition-cover.-finish .indicator {
  opacity: 0;
}
.-end-intro .onloadcomplete ~ .page-transition-cover {
  cursor: auto;
}
.-end-intro .onloadcomplete ~ .page-transition-cover .indicator {
  opacity: 0;
  transition-delay: 0s;
  color: var(--color-primary);
}

@keyframes hidePage {
  0% {
    transform: translate3d(0, 100%, 0);
  }
  100% {
    transform: translate3d(0, 0, 0);
  }
}
@keyframes showPage {
  0% {
    transform: translate3d(0, 0, 0);
  }
  100% {
    transform: translate3d(0, -100%, 0);
  }
}
/* ---------------------------------------------------------------------------------------------------- */
body {
  opacity: 0;
}

body.domContentLoaded {
  opacity: 1;
}

.first-transition-cover {
  position: fixed;
  left: 0;
  top: 0;
  bottom: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100vh;
  background-color: var(--color-bg);
  color: var(--color-primary);
  z-index: 2000;
}
.-end-intro .first-transition-cover {
  transition: opacity 0.8s cubic-bezier(0.17, 0.84, 0.44, 1);
  pointer-events: none;
  opacity: 0;
}
.first-transition-cover .first-transition-cover__logo {
  width: 80px;
  height: 80px;
  overflow: hidden;
}
.first-transition-cover .first-transition-cover__logo svg {
  display: block;
  padding: 0;
  animation: 0.5s steps(1) 0s infinite indicator_animation;
}

@keyframes indicator_animation {
  0%, 100% {
    transform: rotate(5deg);
  }
  50% {
    transform: rotate(-5deg);
  }
}
.Gf {
  position: relative;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 0.875rem;
  letter-spacing: 0.05em;
  padding: 60px clamp(30px, 18.4615384615px + 3.2051282051vw, 80px) clamp(120px, 133.8461538462px - 3.8461538462vw, 60px);
  padding-bottom: 120px;
}
.Gf:after {
  content: "";
  width: calc(100% - 60px);
  height: 3px;
  position: absolute;
  right: 0;
  left: 0;
  top: 0;
  display: block;
  margin: auto;
  background-image: url(../../../../assets/img/global/img_line.png);
  background-size: auto 100%;
  background-repeat: repeat-x;
}
.Gf > * {
  margin: 0;
}
.Gf .GfNav {
  line-height: 2.2;
}
.Gf .GfNav__item {
  padding: 0;
}
.Gf .GfNav__item::before {
  content: none;
}
.Gf .GfNav__item.meta--main {
  font-size: clamp(0.8125rem, 0.7880434783rem + 0.1086956522vw, 0.875rem);
  font-weight: 500;
}
.Gf .GfNav__item.meta--main a {
  text-decoration: none;
}
.Gf .GfNav__item.meta--sub {
  font-size: 12px;
}
.Gf .GfNav__item.meta--sub a {
  text-decoration: underline;
}
.GfOtherWrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.GfOther {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 20px;
  align-items: center;
  margin-top: 60px;
  margin-bottom: 30px;
}
.GfOther > * {
  margin: 0;
}
.GfRelated {
  display: flex;
  align-items: center;
}
.GfRelated__list {
  display: flex;
  align-items: center;
  gap: clamp(20px, 15.3846153846px + 1.2820512821vw, 40px);
  margin: 0;
}
.GfRelated__item {
  height: clamp(20px, 18.8461538462px + 0.3205128205vw, 25px);
  list-style: none;
  padding: 0;
}
.GfRelated__item:before {
  content: none;
}
.GfRelated__item img {
  height: 100%;
  width: auto;
}
.GfRelated__a {
  height: 100%;
  display: inline-block;
}
.GfOther {
  display: flex;
  align-items: center;
}
.GfOther__list {
  display: flex;
  align-items: center;
  gap: 20px;
  margin: 0;
}
.GfOther__item {
  height: clamp(20px, 18.8461538462px + 0.3205128205vw, 25px);
  list-style: none;
  padding: 0;
}
.GfOther__item:before {
  content: none;
}
.GfOther__a {
  font-size: 12px;
}
.Gf .pageFooterDeco {
  width: 100%;
  position: absolute;
  bottom: 0;
  right: 0;
  margin: auto;
  z-index: -1;
  opacity: 0.15;
  overflow: hidden;
}
.Gf .pageFooterDeco__01 {
  width: 280%;
  margin-left: -80%;
}
@media (min-width: 46.25em) {
  .Gf {
    flex-direction: row;
    justify-content: space-between;
    gap: 20px;
  }
  .Gf .GfNav {
    gap: 20px;
  }
  .Gf .GfNav p {
    margin-top: 0;
  }
  .Gf .GfOther {
    margin-top: 0;
    margin-bottom: 0;
  }
}
@media (min-width: 75em) {
  .Gf {
    padding-bottom: 30px;
  }
  .Gf:after {
    content: none;
  }
  .GfNav {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 0.5em 1em;
    align-items: center;
    line-height: 1.4;
    width: 100%;
  }
  .Gf .pageFooterDeco {
    max-width: calc(100% - 160px);
  }
  .Gf .pageFooterDeco__01 {
    width: 100%;
    margin-left: auto;
  }
}

/* sp / pc --------------------------------------- */
.spOnly {
  display: block;
}

.pcOnly {
  display: none !important;
}

@media (min-width: 75em) {
  .spOnly {
    display: none !important;
  }
  .pcOnly {
    display: block !important;
  }
}
/* globalWrapper --------------------------------------- */
.homeHeaderDeco {
  display: none;
}

.pageHeaderDecoWrapper {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  margin: auto;
  z-index: 0;
  overflow: hidden;
  width: 100%;
  height: 150vh;
}
.pageHeaderDeco {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  margin: auto;
  z-index: -1;
  transform: scale(1.15) translateX(20px);
  transition: 6s transform ease 0.3s;
  /* animation */
}
.pageHeaderDeco__01, .pageHeaderDeco__02 {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  margin: auto;
  opacity: 0;
}
.pageHeaderDeco__01 {
  animation: pageHeaderCloud01 90s linear infinite alternate;
  transform: translateY(-25%);
  transition: 2s opacity ease 0.3s;
}
.pageHeaderDeco__02 {
  animation: pageHeaderCloud02 180s linear infinite alternate;
  transform: translateY(0);
  transition: 5s opacity ease 1s;
}
@keyframes pageHeaderCloud01 {
  0% {
    transform: translateY(-25%);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes pageHeaderCloud02 {
  0% {
    transform: translateY(0);
  }
  100% {
    transform: translateY(-50%);
  }
}

@media (min-width: 75em) {
  .pageHeaderDeco {
    transform: scale(1.05) translateX(20px);
    /* animation */
  }
  .pageHeaderDeco__01 {
    transform: translateY(-20%);
    animation: pageHeaderCloud01 80s linear infinite alternate;
  }
  .pageHeaderDeco__02 {
    transform: translateY(-50%);
    animation: pageHeaderCloud02 180s linear infinite alternate;
  }
  @keyframes pageHeaderCloud01 {
    0% {
      transform: translateY(-20%);
    }
    100% {
      transform: translateY(-40%);
    }
  }
  @keyframes pageHeaderCloud02 {
    0% {
      transform: translateY(-50%);
    }
    100% {
      transform: translateY(0%);
    }
  }
}
.load .pageHeaderDeco {
  transform: scale(1) translateX(0);
}
.load .pageHeaderDeco__01, .load .pageHeaderDeco__02 {
  opacity: 0.15;
}

/* section --------------------------------------- */
.SectionContainer section {
  width: calc(100% - 60px);
  margin-right: auto;
  margin-left: auto;
  margin-bottom: clamp(100px, 86.1538461538px + 3.8461538462vw, 160px);
  box-sizing: border-box;
}
.SectionContainer section__ttl {
  margin-bottom: clamp(20px, 15.3846153846px + 1.2820512821vw, 40px) !important;
  font-size: clamp(1.5rem, 1.4134615385rem + 0.3846153846vw, 1.875rem) !important;
  font-weight: 400;
}
.SectionContainer section.wide {
  width: calc(100% - 10px);
}
.SectionContainer .sectionHeader__ttl {
  font-size: clamp(1.125rem, 1.0961538462rem + 0.1282051282vw, 1.25rem);
  font-weight: 500;
  margin: 0 0 40px;
}
.SectionContainer .sectionHeader__ttl a {
  text-decoration: none;
}
.SectionContainer .sectionBody__txtInner + .btnWrap {
  margin-top: clamp(30px, 27.6923076923px + 0.641025641vw, 40px);
}
.SectionContainer.subpage .pageHeader {
  width: calc(100% - 60px);
  box-sizing: border-box;
  margin-right: auto;
  margin-left: auto;
  padding-bottom: clamp(120px, 110.7692307692px + 2.5641025641vw, 160px);
  padding-top: clamp(200px, 176.9230769231px + 6.4102564103vw, 300px);
}
.SectionContainer.subpage .pageHeader__ttlWrap {
  text-align: center;
  margin: 0 auto;
}
.SectionContainer.subpage .pageHeader__ttl {
  color: rgba(68, 68, 68, 0.8);
  font-size: 18px;
  writing-mode: vertical-rl;
  padding-bottom: 60px;
  position: relative;
  display: inline-block;
  margin-top: 0;
  margin-bottom: 120px;
  white-space: nowrap;
  text-align: start;
}
.SectionContainer.subpage .pageHeader__ttl:after {
  content: "";
  width: 50px;
  height: 3px;
  position: absolute;
  right: 0;
  left: 0;
  bottom: 0;
  display: block;
  margin: 0 auto;
  background-image: url(../../../../assets/img/global/img_line.png);
  background-size: auto 100%;
  background-repeat: repeat-x;
}
.SectionContainer.subpage .pageHeader__copy {
  font-size: clamp(1.25rem, 0.9615384615rem + 1.2820512821vw, 2.5rem);
  text-align: center;
  margin-top: 0;
  margin-bottom: clamp(40px, 33.0769230769px + 1.9230769231vw, 70px);
}
.SectionContainer.subpage .pageHeader p:not(:first-child) {
  margin-top: clamp(30px, 27.6923076923px + 0.641025641vw, 40px);
}
.SectionContainer.subpage .contentsBody {
  overflow: hidden;
}
.SectionContainer.subpage .contentsBody .section__ttl {
  font-size: clamp(1.25rem, 1.1923076923rem + 0.2564102564vw, 1.5rem);
  margin-bottom: clamp(40px, 33.0769230769px + 1.9230769231vw, 70px);
}
.SectionContainer.subpage .contentsBody .section__ttl small {
  font-size: clamp(0.75rem, 0.7067307692rem + 0.1923076923vw, 0.9375rem);
  font-weight: 400;
  margin-bottom: 5px;
  display: block;
  width: 100%;
}
.SectionContainer.subpage .contentsBody .section__subTtl {
  font-size: clamp(0.9375rem, 0.8942307692rem + 0.1923076923vw, 1.125rem);
}
@media (min-width: 75em) {
  .SectionContainer section, .SectionContainer section.wide {
    width: calc(100% - 220px);
    margin-left: 0;
    padding: 0 5vw;
  }
  .SectionContainer.subpage .pageHeader {
    width: calc(100% - 220px);
    margin-left: 0;
    padding-right: 5vw;
    padding-left: 5vw;
  }
  .SectionContainer.subpage .pageHeader__ttlWrap {
    text-align: left;
  }
  .SectionContainer.subpage .pageHeader__ttl {
    writing-mode: horizontal-tb;
    padding-bottom: 0;
    margin-bottom: 30px;
    font-size: 15px;
  }
  .SectionContainer.subpage .pageHeader__ttl:after {
    display: none;
  }
  .SectionContainer.subpage .pageHeader__copy {
    text-align: left;
  }
}

/* flow --------------------------------------- */
.flow__list {
  counter-reset: number 0;
}
.flow__item {
  display: flex;
  flex-wrap: wrap;
  margin-top: 0;
  padding-bottom: clamp(30px, 27.6923076923px + 0.641025641vw, 40px);
  padding-left: clamp(55px, 50.3846153846px + 1.2820512821vw, 75px);
  box-sizing: border-box;
  position: relative;
}
.flow__item:last-child {
  padding-bottom: 0;
}
.flow__item:last-child:after {
  display: none;
}
.flow__item:before {
  counter-increment: number 1;
  content: counter(number, cjk-ideographic) "";
  font-weight: 500;
  font-size: 14px;
  width: 36px;
  height: 36px;
  line-height: 36px;
  text-align: center;
  color: #fff;
  position: absolute;
  left: 0;
  top: 0;
  background-image: url(../../../../../assets/img/funeral/img_sangebg.png);
  background-size: 100%;
  -webkit-mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%3E%3Cpath%20d%3D%22M17.1101%2022.0151C17.3372%2022.0151%2017.5476%2021.8947%2017.6589%2021.6967C18.577%2020.0653%2019.4237%2018.3139%2020.0086%2016.5416C20.4919%2015.077%2020.7549%2013.5156%2020.5547%2011.9863C20.3227%2010.214%2019.4642%208.57461%2018.2928%207.24209C17.0175%205.79144%2015.3248%204.83563%2013.931%203.51736C13.3238%202.94303%2012.7441%202.32296%2012.2348%201.65612C12.1141%201.49809%2011.8856%201.49809%2011.7649%201.65612C11.2556%202.32296%2010.676%202.94303%2010.0687%203.51736C8.67494%204.83563%206.9822%205.79144%205.70696%207.24209C4.53556%208.57461%203.67698%2010.214%203.44501%2011.9863C3.24484%2013.5156%203.50782%2015.077%203.99113%2016.5416C4.57597%2018.3139%205.42276%2020.0653%206.34079%2021.6967C6.45217%2021.8947%206.66254%2022.0151%206.88967%2022.0151H17.1101Z%22%2F%3E%3C%2Fsvg%3E");
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%3E%3Cpath%20d%3D%22M17.1101%2022.0151C17.3372%2022.0151%2017.5476%2021.8947%2017.6589%2021.6967C18.577%2020.0653%2019.4237%2018.3139%2020.0086%2016.5416C20.4919%2015.077%2020.7549%2013.5156%2020.5547%2011.9863C20.3227%2010.214%2019.4642%208.57461%2018.2928%207.24209C17.0175%205.79144%2015.3248%204.83563%2013.931%203.51736C13.3238%202.94303%2012.7441%202.32296%2012.2348%201.65612C12.1141%201.49809%2011.8856%201.49809%2011.7649%201.65612C11.2556%202.32296%2010.676%202.94303%2010.0687%203.51736C8.67494%204.83563%206.9822%205.79144%205.70696%207.24209C4.53556%208.57461%203.67698%2010.214%203.44501%2011.9863C3.24484%2013.5156%203.50782%2015.077%203.99113%2016.5416C4.57597%2018.3139%205.42276%2020.0653%206.34079%2021.6967C6.45217%2021.8947%206.66254%2022.0151%206.88967%2022.0151H17.1101Z%22%2F%3E%3C%2Fsvg%3E");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: auto;
  mask-size: auto;
}
.flow__item:after {
  content: "";
  width: 1px;
  height: calc(100% - 50px);
  background-color: rgba(121, 154, 196, 0.6);
  position: absolute;
  bottom: 10px;
  left: 18px;
  margin: auto;
}
.flow__term {
  font-weight: 500;
}

/* enicido --------------------------------------- */
.enichidoSection {
  display: flex;
  flex-direction: column-reverse;
  padding-top: 100px;
  border-top: 1px dotted var(--color-line);
  gap: clamp(15px, 2.3076923077px + 3.5256410256vw, 70px);
}
.enichidoSection .section__ttl {
  margin-top: 0;
  margin-bottom: 20px !important;
  font-size: clamp(1.5rem, 1.4134615385rem + 0.3846153846vw, 1.875rem) !important;
  font-weight: 400;
}
.enichidoSection .section__ttl span {
  font-size: clamp(0.8125rem, 0.7836538462rem + 0.1282051282vw, 0.9375rem) !important;
  font-weight: 400;
  display: block;
}
.enichidoSection .section__txt {
  margin-bottom: clamp(20px, 15.3846153846px + 1.2820512821vw, 40px) !important;
}
.enichidoSection .section__img img {
  border-radius: var(--borderrad);
}
.enichidoSection .btnWrap .btn .icon:only-child {
  margin-left: 0;
}
@media (min-width: 75em) {
  .enichidoSection {
    gap: 70px;
    flex-direction: row;
    align-items: center;
    gap: 70px;
  }
  .enichidoSection .section__ttl {
    padding-bottom: 15px;
    border-bottom: 1px solid var(--color-line);
  }
}

/* news --------------------------------------- */
.newsHeadline {
  list-style: none;
}
.newsHeadline__item {
  list-style: none;
  padding: 0;
  width: 100%;
}
.newsHeadline__item:before {
  display: none;
}
.newsHeadline__item .new {
  position: absolute;
  top: -10px;
  left: -10px;
  z-index: 1;
  display: none;
}
.newsHeadline__a {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  text-decoration: none;
  padding: 10px 0;
  border-bottom: 1px dotted var(--color-line);
  position: relative;
}
.newsHeadline__a .more__ico {
  display: none;
  position: absolute;
  right: 10px;
  top: 0;
  bottom: 0;
  margin: auto;
  transform: translateX(-10px);
  transition: 0.6s cubic-bezier(0.17, 0.84, 0.44, 1);
}
.newsHeadline__a:hover .more__ico {
  transform: translateX(0);
}
.newsHeadline__a:hover .newsHeadline__thumb img {
  transform: scale(1.1);
}
.newsHeadline__thumb {
  border-radius: var(--borderrad);
  aspect-ratio: 1/1;
  width: 95px;
  height: 95px;
  margin-right: 20px;
  overflow: hidden;
  position: relative;
}
.newsHeadline__thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  transition: 1.2s cubic-bezier(0.17, 0.84, 0.44, 1);
  transform: scale(1);
}
.newsHeadline__meta {
  text-align: left;
  width: calc(100% - 115px);
}
.newsHeadline__catList {
  display: flex;
  gap: 5px;
  list-style: none;
}
.newsHeadline__catItem {
  list-style: none;
  text-align: center;
  padding: 5px 10px;
  border: 1px solid var(--color-txt-weak);
  border-radius: 10px;
  font-size: clamp(0.6875rem, 0.6586538462rem + 0.1282051282vw, 0.8125rem);
  line-height: 1;
}
.newsHeadline__catItem:before {
  display: none;
}
.newsHeadline__dat {
  display: flex;
  align-items: center;
  font-size: clamp(0.8125rem, 0.7836538462rem + 0.1282051282vw, 0.9375rem);
  margin: 3px 0 0;
}
.newsHeadline__datJy {
  font-size: clamp(0.6875rem, 0.6586538462rem + 0.1282051282vw, 0.8125rem);
}
.newsHeadline__ttl {
  font-weight: 500;
  font-size: clamp(0.8125rem, 0.7836538462rem + 0.1282051282vw, 0.9375rem);
  margin: 3px 0 0;
  line-height: 1.8;
}
@media (min-width: 46.25em) {
  .newsHeadline__a .more__ico {
    display: inline-block;
  }
}
@media (min-width: 75em) {
  .newsHeadline__item {
    margin-bottom: 0;
  }
  .newsHeadline__a {
    padding: 20px;
  }
  .newsHeadline .newsHeadline__catItem {
    padding: 8px 30px;
  }
}
@media (min-width: 90em) {
  .newsHeadline__a .more__ico {
    display: none;
  }
}

/* swiper --------------------------------------- */
.swiper, .swiper01, .swiper02, .swiper03 {
  overflow: visible !important;
}
.swiper-wrapper, .swiper01-wrapper, .swiper02-wrapper, .swiper03-wrapper {
  list-style: none;
}
.swiper-slide, .swiper01-slide, .swiper02-slide, .swiper03-slide {
  list-style: none;
  padding-left: 0;
}
.swiper-slide:before, .swiper01-slide:before, .swiper02-slide:before, .swiper03-slide:before {
  display: none;
}
.swiper-slide img, .swiper01-slide img, .swiper02-slide img, .swiper03-slide img {
  border-radius: var(--borderrad);
}
@media (min-width: 75em) {
  .swiper:before, .swiper01:before, .swiper02:before, .swiper03:before {
    content: "";
    background-color: #fff;
    width: 100%;
    height: 100%;
    position: absolute;
    left: -100%;
    top: 0;
    bottom: 0;
    margin: auto;
    z-index: 5;
  }
  .swiper:after, .swiper01:after, .swiper02:after, .swiper03:after {
    content: "";
    background: linear-gradient(to right, #fff, transparent);
    width: 15px;
    height: 100%;
    position: absolute;
    left: -20px;
    top: 0;
    bottom: 0;
    margin: auto;
    z-index: 5;
  }
}

/* declaration --------------------------------------- */
.warning__txtLink .warning__a {
  font-weight: 500;
  text-decoration: none;
  padding-bottom: 10px;
  border-bottom: 1px solid currentColor;
  transition: 0.4s cubic-bezier(0.17, 0.84, 0.44, 1);
  font-size: 13px;
}
.warning__txtLink .warning__a .more__ico {
  transform: translateX(0);
  transition: all 0.4s cubic-bezier(0.17, 0.84, 0.44, 1);
}
.warning__txtLink .warning__a:hover {
  border-bottom: transparent;
}
.warning__txtLink .warning__a:hover .more__ico {
  transform: translateX(5px);
}

.declaration__block {
  padding: clamp(20px, 17.6923076923px + 0.641025641vw, 30px);
  border: 2px dotted var(--color-line);
  border-radius: var(--borderrad);
  position: relative;
}
.declaration__block .warning__ico {
  position: absolute;
  top: -20px;
  left: 20px;
  background-color: var(--color-bg);
  border-radius: 100px;
  border: 2px solid #A6001C;
  width: 32px;
  height: 32px;
  text-align: center;
  margin-right: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  outline: 5px solid #fff;
}
.declaration__block .warning__ico svg {
  color: #A6001C;
  width: 24px;
  height: 24px;
}
.declaration__txtWrap {
  display: flex;
  flex-direction: column;
  gap: 15px;
}
.declaration__ttl {
  margin-top: 0;
  display: flex;
  align-items: center;
  font-size: clamp(0.9375rem, 0.8942307692rem + 0.1923076923vw, 1.125rem);
}
.declaration__txt {
  margin-top: 10px;
}
@media (min-width: 75em) {
  .declaration__block .warning__ico {
    left: 25px;
  }
}

/* splide --------------------------------------- */
/* pickupMenuSection ------------------------------- */
.pickupMenuSection .sectionBody__pickupList {
  width: 100%;
}
.pickupMenuSection .sectionBody__pickupItem {
  list-style: none;
  width: 100%;
  padding: 0;
  border-bottom: 1px solid var(--color-txt-weak);
}
.pickupMenuSection .sectionBody__pickupItem:before {
  display: none;
}
.pickupMenuSection .sectionBody__pickupItem:first-child {
  border-top: 1px solid var(--color-txt-weak);
}
.pickupMenuSection .sectionBody__pickupAnchor {
  display: block;
  width: 100%;
  padding: clamp(40px, 26.1538461538px + 3.8461538462vw, 100px) 0;
  text-decoration: none;
  cursor: pointer;
}
.pickupMenuSection .sectionBody__pickupTtl {
  font-weight: 400;
  font-size: clamp(1.5rem, 1.3557692308rem + 0.641025641vw, 2.125rem);
  text-align: left;
  margin-top: 0;
  margin-bottom: 10px;
}
.pickupMenuSection .sectionBody__pickupTxtWrap {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
.pickupMenuSection .sectionBody__pickupTxtWrap .btnWrap {
  width: 100%;
}
.pickupMenuSection .sectionBody__pickupTxtWrap .btnWrap .btn .icon:only-child {
  margin-right: 0;
}
.pickupMenuSection .sectionBody__pickupTxt {
  margin-top: 0;
}
@media (min-width: 46.25em) {
  .pickupMenuSection .sectionBody__pickupAnchor {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
  }
  .pickupMenuSection .sectionBody__pickupTxtWrap {
    width: calc(50% - 60px);
    justify-content: flex-end;
    text-align: right;
  }
}
@media (min-width: 75em) {
  .pickupMenuSection .sectionBody__pickupTtl {
    margin-bottom: 0;
  }
  .pickupMenuSection .sectionBody__pickupTxtWrap {
    text-align: right;
    margin-left: 0;
    justify-content: flex-end;
    gap: 10px;
    width: 50%;
  }
}
@media (min-width: 100em) {
  .pickupMenuSection .sectionBody__pickupTxtWrap {
    gap: 0;
  }
  .pickupMenuSection .sectionBody .btnWrap {
    width: auto;
    margin-left: 40px;
    margin-top: 0;
  }
}

/* contactMenu --------------------------------------- */
.contactMenuSection .sectionBody__contactList {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  justify-content: space-between;
  position: relative;
}
.contactMenuSection .sectionBody__contactList:after {
  content: "";
  order: 2;
  display: block;
}
.contactMenuSection .sectionBody__contactItem {
  list-style: none;
  padding: 0;
  margin-bottom: 40px;
  width: 100%;
}
.contactMenuSection .sectionBody__contactItem:before {
  display: none;
}
.contactMenuSection .sectionBody__contactItem .iconWrap {
  margin-bottom: clamp(15px, 9.2307692308px + 1.6025641026vw, 40px);
}
.contactMenuSection .sectionBody__contactItem .contactIcon {
  width: 48px;
  height: 48px;
}
.contactMenuSection .sectionBody__contactItem.item__tel .tel {
  font-weight: 500;
  font-size: 28px;
  margin: 0;
  line-height: 1;
}
.contactMenuSection .sectionBody__contactTtl {
  font-weight: 500;
  font-size: clamp(1rem, 0.9711538462rem + 0.1282051282vw, 1.125rem);
}
.contactMenuSection .sectionBody__contactTxtInner {
  margin-bottom: 20px;
}
.contactMenuSection .sectionBody__contactTxt {
  font-size: clamp(0.8125rem, 0.7836538462rem + 0.1282051282vw, 0.9375rem);
  margin-top: 10px;
}
.contactMenuSection .sectionBody .btnWrap .more__ico,
.contactMenuSection .sectionBody .btnWrap .down__ico {
  margin-left: 0;
}
@media (min-width: 61.25em) {
  .contactMenuSection .sectionBody__contactItem {
    width: 33.333%;
    padding: 0 20px;
    box-sizing: border-box;
  }
}
