@charset "UTF-8";
/*$fs-level-1: clamp(1rem, 1rem + 0.40vw, 1.15rem);
$fs-level-2: clamp(1.10rem, 1rem + 0.40vw, 1.35rem);
$fs-level-3: clamp(1.20rem, 1rem + 0.75vw, 1.55rem);
$fs-level-4: clamp(1.30rem, 1rem + 1.10vw, 1.80rem);
$fs-level-5: clamp(1.45rem, 1rem + 1.60vw, 2.10rem);
$fs-level-6: clamp(1.70rem, 1rem + 2.10vw, 2.40rem);
$fs-level-7: clamp(2.00rem, 1rem + 2.80vw, 2.90rem);
$fs-level-8: clamp(2.30rem, 1rem + 3.50vw, 3.40rem);
$fs-level-9: clamp(2.70rem, 1rem + 4.30vw, 4.00rem);

$fs-body:    clamp(0.9rem, 0.864rem + 0.18vw, 1rem);
$fs-body-sm: clamp(0.8rem, 0.764rem + 0.18vw, 0.9rem);
$fs-caption: clamp(0.7rem, 0.664rem + 0.18vw, 0.8rem);

$space-1: clamp(0.6rem, 0.455rem + 0.73vw, 1rem);
$space-2: clamp(1.2rem, 0.909rem + 1.45vw, 2rem);
$space-3: clamp(1.8rem, 1.364rem + 2.18vw, 3rem);
$space-4: clamp(2.4rem, 1.818rem + 2.91vw, 4rem);
$space-5: clamp(3rem, 2.273rem + 3.64vw, 5rem);
$space-6: clamp(3.6rem, 2.727rem + 4.36vw, 6rem);*/
.old * {
  box-sizing: unset;
}
.old *::before, .old *::after {
  box-sizing: unset;
}

heml {
  font-size: 16px !important;
}

body {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 16px !important;
  color: #293436;
  line-height: 1.8;
}

.section-heading {
  text-align: center;
  margin-bottom: clamp(38.4px, 29.088px + 2.91vw, 64px);
}

.section-heading__main-en {
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: clamp(27.2px, 16px + 2.1vw, 38.4px);
  font-weight: 300;
  line-height: 1.1;
  letter-spacing: 0.075em;
  text-transform: uppercase;
  color: #7b5aa8;
  margin-bottom: 0.5em;
}

.section-heading__sub-ja {
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.12em;
}

.section-heading__lead {
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  margin-top: 2em;
}

.button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-weight: 500;
  min-width: 10em;
  padding: 0.9em 3.6em 0.9em 2.4em;
  border-radius: 100vmax;
  text-decoration: none;
  letter-spacing: 0.075em;
  white-space: nowrap;
  transition: transform 0.15s ease, box-shadow 0.15s ease, opacity 0.15s ease, background-position 0.35s ease-out;
}
.button::after {
  content: "";
  position: absolute;
  right: 1.4em;
  width: 1.2em;
  height: 1.2em;
  background-color: currentColor;
  border-radius: 50%;
  -webkit-mask-image: url("data:image/svg+xml;utf8,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2064%2064'%3E%3Cpath%20d='M0%2032A32%2032%200%201%200%2032%200%2032%2032%200%200%200%200%2032zm29.21-12.36%2014.805%2012.534-14.805%2012.52a2%202%200%201%201-2.583-3.055l11.195-9.467-11.196-9.479a2%202%200%201%201%202.585-3.052z'%20fill='%23000'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml;utf8,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2064%2064'%3E%3Cpath%20d='M0%2032A32%2032%200%201%200%2032%200%2032%2032%200%200%200%200%2032zm29.21-12.36%2014.805%2012.534-14.805%2012.52a2%202%200%201%201-2.583-3.055l11.195-9.467-11.196-9.479a2%202%200%201%201%202.585-3.052z'%20fill='%23000'/%3E%3C/svg%3E");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
  transition: right 0.15s ease-out;
}
@media (any-hover: hover) {
  .button:hover {
    transform: translateY(-0.06em);
    opacity: 0.9;
  }
  .button:hover::after {
    right: 1.2em;
  }
}
.button.purple {
  background-image: linear-gradient(90deg, #7b5aa8, rgb(96.182967033, 55.9392857143, 151.0607142857));
  background-size: 180% 100%;
  background-position: 0 0;
}
.button.purple:hover {
  background-position: 100% 0;
}
.button.purple {
  color: white;
}

.floating-buttons {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
  position: fixed;
  right: 1em;
  bottom: 1em;
  z-index: 120;
}

.floating-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 180px;
  aspect-ratio: 1;
  border-radius: 999px;
  overflow: hidden;
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 0.85rem;
  letter-spacing: 0.16em;
  text-decoration: none;
  cursor: pointer;
  color: #6a6479;
  background-image: linear-gradient(90deg, #e4b3d3, #f3c7aa);
  box-shadow: 0 0.4rem 1.2rem rgba(0, 0, 0, 0.18);
  position: relative;
}
.floating-button::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background-color: #ffffff;
  border: 1px solid #e0d7ea;
  opacity: 1;
  transition: opacity 0.25s ease-out, border-color 0.25s ease-out;
}
.floating-button img {
  position: relative;
  z-index: 1;
}
.floating-button:hover {
  color: #ffffff;
  transform: translateY(-0.08rem);
  box-shadow: 0 0.9rem 2.1rem rgba(0, 0, 0, 0.3);
}
.floating-button:hover::before {
  opacity: 0;
  border-color: transparent;
}
@media (max-width: 575px) {
  .floating-button {
    display: none;
    /*right: 1.2em;
    bottom: 1.2em;
    width: 10em;*/
  }
}

ul.disc li {
  display: flex;
}
ul.disc li::before {
  content: "・";
  padding-right: 0.25em;
}

ul.note li {
  display: flex;
}
ul.note li::before {
  content: "※";
  padding-right: 0.5em;
}

.container {
  width: min(1120px, 90%);
  margin-inline: auto;
}

.container-narrow {
  width: min(960px, 90%);
  margin-inline: auto;
}

.use-wbr {
  word-break: keep-all;
  overflow-wrap: anywhere;
}

.marker-yellow {
  background: linear-gradient(transparent 60%, #ffff00 60%);
}

.site-subpage-header__bg {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, rgb(136.3571428571, 106.6964285714, 176.8035714286), #7b5aa8);
}
.site-subpage-header__image-layer {
  position: absolute;
  inset: 0;
  background-repeat: no-repeat;
  background-size: cover;
  opacity: 0.5;
  pointer-events: none;
}
.site-subpage-header__inner {
  position: relative;
  padding: clamp(57.6px, 43.632px + 4.36vw, 96px) 5%;
  text-align: center;
  color: white;
}
.site-subpage-header__title {
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: clamp(27.2px, 16px + 2.1vw, 38.4px);
  font-weight: 300;
  letter-spacing: 0.05em;
  margin: 0 0 0.6em;
}
.site-subpage-header__subtitle {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  font-weight: 600;
  letter-spacing: 0.18em;
  margin: 0;
}
.site-subpage-header.site-subpage-header--no-bg .site-subpage-header__bg {
  background-color: #e8e1ed;
  background-image: url(../img/catalog_bg_pattern.svg);
  background-position: center;
  background-repeat: repeat;
  background-size: 5vw;
}
.site-subpage-header.site-subpage-header--no-bg .site-subpage-header__inner {
  color: #293436;
}
.site-subpage-header.site-subpage-header--no-bg .site-subpage-header__title {
  color: #7b5aa8;
  margin-bottom: 0.1em;
}
.site-subpage-header.site-subpage-header--no-bg .site-subpage-header__inner {
  padding: clamp(28.8px, 21.824px + 2.18vw, 48px) 5%;
}

/* リードセクション */
.site-lead {
  width: 100%;
  background-color: #fff;
}
.site-lead__inner {
  max-width: 800px;
  margin: 0 auto;
  padding: 3.8em 5% 3.6em;
  text-align: center;
}
.site-lead__heading {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 1.4em;
  line-height: 1.6;
  margin: 0 0 1.4em;
}
.site-lead__text {
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  line-height: 1.9;
  margin: 0 0 2.2em;
}
.site-lead__actions {
  display: flex;
  justify-content: center;
  gap: 1.4em;
}
@media (max-width: 767px) {
  .site-lead__inner {
    padding: 3em 6% 3em;
  }
  .site-lead__heading {
    font-size: 1.15em;
  }
  .site-lead__text {
    font-size: 0.9em;
  }
  .site-lead__actions {
    flex-direction: column;
    gap: 0.8em;
  }
}

/* 共通ボタン */
.site-button {
  display: inline-block;
  padding: 0.7em 2.4em;
  border-radius: 999px;
  font-size: 0.9em;
  letter-spacing: 0.08em;
  text-decoration: none;
  border: 1px solid transparent;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.site-button--primary {
  background-color: #f5f2f7;
  border-color: #f5f2f7;
  color: #fff;
}
.site-button--primary:hover {
  background-color: rgb(230.4285714286, 223.0571428571, 235.3428571429);
  border-color: rgb(230.4285714286, 223.0571428571, 235.3428571429);
}
.site-button--secondary {
  background-color: #fff;
  border-color: #f5f2f7;
  color: #f5f2f7;
}
.site-button--secondary:hover {
  background-color: #f7f3fb;
}

.flower-bg {
  position: relative;
  overflow: hidden;
}
.flower-bg::before, .flower-bg::after {
  content: "";
  display: block;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  transform: translateX(-50%);
}
.flower-bg::before {
  background-image: url("../img/flower_01.png");
  width: clamp(15rem, 9.545rem + 27.27vw, 30rem);
  aspect-ratio: 1081/345;
  top: 3%;
  left: 75%;
}
.flower-bg::after {
  background-image: url("../img/flower_02.png");
  width: clamp(12rem, 7.636rem + 21.82vw, 24rem);
  aspect-ratio: 837/205;
  bottom: 3%;
  left: 20%;
}
.flower-bg > div {
  position: relative;
  z-index: 1;
}

/* USER GUIDE 帯 */
.site-user-guide {
  width: 100%;
  background-color: #f5f2f7;
}
.site-user-guide__inner {
  max-width: 1120px;
  margin: 0 auto;
  padding: 3.5em 5% 3.8em;
  text-align: center;
}
.site-user-guide__title {
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: 1.4em;
  letter-spacing: 0.16em;
  margin: 0 0 0.4em;
}
.site-user-guide__subtitle {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 0.9em;
  margin: 0 0 2.6em;
}
.site-user-guide__items {
  display: flex;
  justify-content: center;
  gap: 3.2em;
  flex-wrap: wrap;
}
.site-user-guide__item {
  width: 8.5em;
  text-decoration: none;
  color: #293436;
}
.site-user-guide__icon {
  width: 5em;
  height: 5em;
  margin: 0 auto 0.8em;
  border-radius: 50%;
  border: 1px solid #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.8em;
  background-color: rgba(255, 255, 255, 0.2);
}
.site-user-guide__label {
  font-size: 0.85em;
}
@media (max-width: 767px) {
  .site-user-guide__items {
    gap: 2em;
  }
}

.site-header {
  background-color: #ffffff;
  border-bottom: 1px solid #e5e5e5;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
}
.site-header__inner {
  display: grid;
  grid-template-columns: 1fr 1.5fr 1fr;
  align-items: center;
  column-gap: 0.5em;
  padding: 0.6em 5%;
}
.site-header__toggle-wrapper {
  display: flex;
}
.site-header__toggle {
  justify-self: start;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  cursor: pointer;
  font-size: 9px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding-top: 0.5em;
}
.site-header__toggle-line {
  display: block;
  width: 20px;
  height: 1px;
  background-color: #333333;
}
.site-header__toggle-label {
  font-size: 0.8em;
  line-height: 1;
  text-indent: 0.1em;
  margin-top: 0.5em;
  color: #333333;
}
.site-header__brand {
  justify-self: center;
  display: flex;
  align-items: center;
}
.site-header__logo {
  display: inline-flex;
  align-items: center;
}
.site-header__logo-img {
  display: block;
  max-height: 40px;
}
.site-header__actions {
  justify-self: end;
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
}
.site-header__contact {
  display: inline-flex;
  align-items: center;
  gap: 0.75em;
  background-image: linear-gradient(90deg, rgb(132.8696808511, 107.8856382979, 80.6303191489), rgb(101.1303191489, 82.1143617021, 61.3696808511));
  background-size: 180% 100%;
  background-position: 0 0;
  padding: 0.75em 1.75em;
  border-radius: 999px;
  color: white;
  font-size: 13px;
  text-decoration: none;
  letter-spacing: 0.06em;
  transition: background-position 0.3s;
}
.site-header__contact-icon {
  width: 21px;
  aspect-ratio: 1;
  background-color: white;
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%23202020' stroke-miterlimit='10' stroke-width='3' d='M2 12l30 29 30-29M42 31.6L62 52M2 52l20-20.4' stroke-linejoin='round' stroke-linecap='round'%3E%3C/path%3E%3Cpath fill='none' stroke='%23202020' stroke-miterlimit='10' stroke-width='3' d='M2 12h60v40H2z' stroke-linejoin='round' stroke-linecap='round'%3E%3C/path%3E%3C/svg%3E");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
}
.site-header__contact-label {
  white-space: nowrap;
}
.site-header__contact:visited, .site-header__contact:link, .site-header__contact:active {
  color: white;
}
@media (any-hover: hover) {
  .site-header__contact:hover {
    background-position: 100% 0;
  }
}
.site-header__icon-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  aspect-ratio: 1;
  border-radius: 50%;
  border: 1px solid #755F47;
  background-color: white;
}
.site-header__icon {
  display: block;
  width: 18px;
  height: 18px;
  background-color: #755F47;
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath d='M58.9 47l-10.4-6.8a4.8 4.8 0 0 0-6.5 1.3c-2.4 2.9-5.3 7.7-16.2-3.2S19.6 24.4 22.5 22a4.8 4.8 0 0 0 1.3-6.5L17 5.1c-.9-1.3-2.1-3.4-4.9-3S2 6.6 2 15.6s7.1 20 16.8 29.7S39.5 62 48.4 62s13.2-8 13.5-10-1.7-4.1-3-5z' fill='none' stroke='%23202020' stroke-miterlimit='10' stroke-width='3' stroke-linejoin='round' stroke-linecap='round'%3E%3C/path%3E%3C/svg%3E");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: 18px 18px;
}

html.is-drawer-open {
  overflow: hidden;
}

.site-drawer-nav {
  position: fixed;
  inset: 0;
  z-index: 200;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.25s ease;
}
.site-drawer-nav__backdrop {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.5);
}
.site-drawer-nav__panel {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  max-width: 480px;
  height: 100%;
  background-color: #ffffff;
  box-shadow: 4px 0 12px rgba(0, 0, 0, 0.18);
  display: flex;
  flex-direction: column;
  transform: translateX(-100%);
  transition: transform 0.25s ease;
}
.site-drawer-nav__close {
  width: 28px;
  height: 28px;
  border: none;
  background: none;
  position: relative;
  cursor: pointer;
  margin: 1.2em 1.2em 0;
}
.site-drawer-nav__close-line {
  position: absolute;
  inset: 50% 0 0 0;
  margin: auto;
  width: 100%;
  height: 2px;
  background-color: #555555;
  transform-origin: center;
}
.site-drawer-nav__close-line:first-child {
  transform: translateY(-50%) rotate(45deg);
}
.site-drawer-nav__close-line:last-child {
  transform: translateY(-50%) rotate(-45deg);
}
.site-drawer-nav__group-list {
  list-style: none;
  margin: 1.2em 2em 0 2em;
  padding: 0 1em 0 0;
  flex: 1 1 auto;
  overflow-y: auto;
}
.site-drawer-nav__group {
  border-bottom: 1px solid #f1f1f1;
}
.site-drawer-nav__group-toggle {
  width: 100%;
  padding: 0.75em 0 0.25em;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border: none;
  background: none;
  cursor: pointer;
  font-size: 15px;
  font-weight: 600;
  color: #222222;
  text-align: left;
}
.site-drawer-nav__group-title {
  flex: 1 1 auto;
}
.site-drawer-nav__group-icon {
  flex: 0 0 auto;
  width: 12px;
  height: 12px;
  margin-left: 8px;
  position: relative;
}
.site-drawer-nav__group-icon::before, .site-drawer-nav__group-icon::after {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  background-color: #777777;
  border-radius: 1px;
}
.site-drawer-nav__group-icon::before {
  width: 12px;
  height: 1px;
}
.site-drawer-nav__group-icon::after {
  width: 1px;
  height: 12px;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.site-drawer-nav__group-panel {
  overflow: hidden;
  max-height: 0;
  padding: 0 0 0.5em;
  transition: max-height 0.25s ease;
}
.site-drawer-nav__link {
  display: block;
  padding: 0.5em 0 0.5em 1em;
  font-size: 13px;
  line-height: 1.7;
  color: #555555;
}
.site-drawer-nav__link:hover {
  color: #b48c6b;
}
.site-drawer-nav__sns {
  background-color: #f5f2f7;
  border-top: 1px solid #eeeeee;
  padding: 1em;
}
.site-drawer-nav__sns-list {
  list-style: none;
  display: flex;
  justify-content: space-around;
  align-items: center;
  gap: 0.8em;
  margin: 0;
  padding: 0;
}
.site-drawer-nav__sns-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.site-drawer-nav__sns-icon {
  display: block;
  width: 24px;
  height: 24px;
}
.site-drawer-nav.is-open {
  pointer-events: auto;
  opacity: 1;
}
.site-drawer-nav.is-open .site-drawer-nav__panel {
  transform: translateX(0);
}
.site-drawer-nav.is-open .site-drawer-nav__group.is-open .site-drawer-nav__group-icon::after {
  opacity: 0;
  transform: rotate(90deg);
}

@media (max-width: 767px) {
  body {
    padding-top: 60px;
  }
  .site-header__actions {
    margin-right: -10%;
  }
  .site-header__contact {
    padding: 0;
    width: min(10vw, 41px);
    aspect-ratio: 1;
    border-radius: 50%;
    background-color: #ffffff;
    justify-content: center;
  }
  .site-header__contact-label {
    display: none;
  }
  .site-header__contact-icon {
    width: 51.219512%;
    aspect-ratio: 1;
    background-size: 86%;
  }
}
@media (min-width: 768px) {
  body {
    padding-top: 72px;
  }
  .site-header__logo-img {
    max-height: 52px;
  }
  .site-header__icon-button {
    display: none;
  }
  .site-header__contact {
    display: inline-flex;
  }
  .site-drawer-nav__group-toggle {
    font-size: 16px;
  }
  .site-drawer-nav__link {
    font-size: 14px;
    padding-left: 1.4em;
  }
}
body.admin-bar .site-header {
  top: 46px;
}
body.admin-bar .site-drawer-nav__panel {
  top: 46px;
  height: calc(100% - 46px);
}
@media screen and (min-width: 783px) {
  body.admin-bar .site-header {
    top: 32px;
  }
  body.admin-bar .site-drawer-nav__panel {
    top: 32px;
    height: calc(100% - 32px);
  }
}
@media screen and (max-width: 600px) {
  body.admin-bar #wpadminbar {
    position: fixed;
  }
}

.hero {
  position: relative;
  color: #ffffff;
  background-color: #120f16;
  min-height: min(720px, 100vh);
  display: flex;
  align-items: center;
  overflow: hidden;
}

.hero__bg {
  position: absolute;
  inset: 0;
  overflow: hidden;
  z-index: 0;
}

/* 共通：動画ラッパー */
.hero__video-wrap {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none; /* ユーザー操作無効化 */
}

/* PC用動画設定 (16:9) */
.hero__video-wrap--pc {
  width: 100vw;
  height: 56.25vw; /* 9/16 * 100 */
  min-height: 100vh;
  min-width: 177.78vh; /* 16/9 * 100 */
  /* スマホサイズでは非表示 */
}
@media (max-width: 575px) {
  .hero__video-wrap--pc {
    display: none;
  }
}

/* スマホ用動画設定 (9:16 縦長Shorts) */
.hero__video-wrap--sp {
  /* PCサイズでは非表示 */
  display: none;
  /* スマホサイズで表示 */
}
@media (max-width: 575px) {
  .hero__video-wrap--sp {
    display: block;
    /* 縦長動画を画面いっぱいにカバーさせる計算 */
    /* 基本は横幅100vwに合わせる */
    width: 100vw;
    height: 177.78vw; /* 16/9 * 100 (縦横比逆転) */
    /* ただし、画面が細長い場合は高さ基準で調整 */
    min-height: 100vh;
    min-width: 56.25vh; /* 9/16 * 100 */
  }
}

.hero__video {
  width: 100%;
  height: 100%;
}

.hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, rgba(10, 7, 14, 0.85) 0%, rgba(10, 7, 14, 0.5) 45%, rgba(10, 7, 14, 0.8) 100%);
  z-index: 1;
}

/* 以下、コンテンツ部分は元のまま */
.hero__inner {
  position: relative;
  z-index: 2;
  padding: 4em 0 4em;
}

.hero__content {
  max-width: 540px;
  will-change: transform;
}
.hero__content::before {
  content: "";
  display: block;
  width: 18em;
  aspect-ratio: 527/125;
  background-image: url("../img/welcome.svg?2");
  background-repeat: no-repeat;
  background-size: contain;
  margin-bottom: 2em;
}

.hero__kicker {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 78%;
  letter-spacing: 0.18em;
  color: #e5d3bf;
  margin-bottom: 0.7em;
}

.hero__title {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: clamp(190%, 3.4vw, 260%);
  line-height: 1.3;
  letter-spacing: 0.14em;
  margin-bottom: 0.4em;
}

.hero__lead {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 82%;
  line-height: 1.9;
  letter-spacing: 0.06em;
  color: #f4ece2;
  margin-bottom: 1.8em;
}

.hero__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8em;
}

.hero-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 180px;
  padding: 0.9em 1.8em;
  border-radius: 999px;
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 82%;
  letter-spacing: 0.12em;
  text-decoration: none;
  transition: background-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.hero-btn--primary {
  background-color: #b48c6b;
  color: #ffffff;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.3);
}

.hero-btn--primary:hover {
  background-color: #c79a74;
  transform: translateY(-1px);
}

.hero-btn--ghost {
  border: 1px solid rgba(255, 255, 255, 0.7);
  color: #ffffff;
  background-color: rgba(0, 0, 0, 0.1);
}

.hero-btn--ghost:hover {
  background-color: rgba(0, 0, 0, 0.25);
}

/* ===== Responsive ===== */
@media (max-width: 767px) {
  .hero__inner {
    padding: 4em 0 3em;
  }
  .hero__content {
    max-width: 100%;
  }
  .hero__title {
    font-size: clamp(170%, 5vw, 210%);
    letter-spacing: 0.1em;
  }
  .hero__lead {
    font-size: 80%;
  }
}
@media (max-width: 575px) {
  .hero__inner {
    width: 92%;
  }
  .u-sm-only {
    display: inline;
  }
}
.headline-news {
  background-color: #f5f2f7;
  padding: 1.5em 0;
}
.headline-news__inner {
  display: flex;
  align-items: center;
  gap: 32px;
}
.headline-news__label {
  order: 1;
  color: #7b5aa8;
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: clamp(20.8px, 16px + 1.1vw, 28.8px);
  font-weight: 600;
  letter-spacing: 0.05em;
  flex-shrink: 0;
}
.headline-news__more {
  order: 3;
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
}
.headline-news__more a {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  background-color: #7b5aa8;
  color: white;
  min-width: 10em;
  padding: 0.45em 3.6em 0.45em 2em;
  border-radius: 100vmax;
  text-decoration: none;
  letter-spacing: 0.075em;
  white-space: nowrap;
  transition: transform 0.15s ease, box-shadow 0.15s ease, opacity 0.15s ease, background-position 0.35s ease-out;
}
.headline-news__more a::after {
  content: "";
  position: absolute;
  right: 1.4em;
  width: 1.2em;
  height: 1.2em;
  background-color: currentColor;
  border-radius: 50%;
  -webkit-mask-image: url("data:image/svg+xml;utf8,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2064%2064'%3E%3Cpath%20d='M0%2032A32%2032%200%201%200%2032%200%2032%2032%200%200%200%200%2032zm29.21-12.36%2014.805%2012.534-14.805%2012.52a2%202%200%201%201-2.583-3.055l11.195-9.467-11.196-9.479a2%202%200%201%201%202.585-3.052z'%20fill='%23000'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml;utf8,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2064%2064'%3E%3Cpath%20d='M0%2032A32%2032%200%201%200%2032%200%2032%2032%200%200%200%200%2032zm29.21-12.36%2014.805%2012.534-14.805%2012.52a2%202%200%201%201-2.583-3.055l11.195-9.467-11.196-9.479a2%202%200%201%201%202.585-3.052z'%20fill='%23000'/%3E%3C/svg%3E");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
  transition: right 0.15s ease-out;
}
.headline-news__more a:hover {
  opacity: 0.9;
}
.headline-news__more a:hover::after {
  right: 1.2em;
}
.headline-news__items {
  order: 2;
  position: relative;
  flex: 1 1 auto;
}
.headline-news__item {
  display: flex;
  gap: 4%;
  /*opacity: 0;
  transform: translateY(8px);
  pointer-events: none;*/
  text-decoration: none;
  color: inherit;
  transition: opacity 0.4s ease, transform 0.4s ease;
  /*&.is-active {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }*/
}
@media (max-width: 767px) {
  .headline-news__inner {
    flex-wrap: wrap;
    gap: 0.75em;
  }
  .headline-news__label {
    flex: 1 1 auto;
  }
  .headline-news__more {
    order: 2;
  }
  .headline-news__items {
    order: 3;
    flex: 0 0 100;
    width: 100%;
  }
  .headline-news__item {
    gap: 1.5em;
  }
}
@media (min-width: 768px) {
  .headline-news__items {
    overflow: hidden;
    height: 1.5em;
  }
  .headline-news__item {
    align-items: center;
    position: absolute;
    inset: 0;
  }
  .headline-news__title {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}

.banner-section {
  padding: clamp(19.2px, 14.544px + 1.45vw, 32px) 5%;
}
.banner-section__inner {
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1em 1.5em;
}
.banner-section__inner a {
  display: block;
  max-width: 640px;
  margin: 0;
}
@media (max-width: 767px) {
  .banner-section__inner {
    flex-direction: column;
  }
}

.topics-section {
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
  background-color: #fcfcfd;
}
.topics-section .topics-row {
  display: flex;
  flex-wrap: wrap;
  column-gap: 4%;
  row-gap: clamp(28.8px, 21.824px + 2.18vw, 48px);
  /*&--main {
    margin-bottom: v.$space-3;
  }*/
}
.topics-section .topics-card {
  flex: 0 0 48%;
  transition: box-shadow 0.25s ease, transform 0.25s ease;
}
.topics-section .topics-card__link {
  display: block;
  color: inherit;
  text-decoration: none;
}
.topics-section .topics-card__link .topics-card__image {
  border-radius: 1.2em;
  overflow: hidden;
}
.topics-section .topics-card__link .topics-card__image img {
  aspect-ratio: 890/472;
  object-fit: cover;
}
.topics-section .topics-card__link-store .topics-card__image img {
  object-position: 0% 50%;
}
.topics-section .topics-card__link-exhibition .topics-card__image img {
  object-position: 50% 35%;
}
.topics-section .topics-card__link-initial .topics-card__image img {
  object-position: 50% 42%;
}
.topics-section .topics-card__image--placeholder {
  width: 100%;
  padding-top: 65%;
  background-color: #f3f0f7;
  border-radius: 1.2em;
  overflow: hidden;
  position: relative;
}
.topics-section .topics-card__image--placeholder::before {
  content: "Image";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(11.2px, 10.624px + 0.18vw, 12.8px);
  letter-spacing: 0.12em;
  color: #b5a9c8;
  border: 1px dashed #d6cfe5;
}
.topics-section .topics-card__image--placeholder img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.topics-section .topics-card__body {
  text-align: center;
}
.topics-section .topics-card__title {
  font-size: clamp(16px, 16px + 0.4vw, 18.4px);
  font-weight: 600;
  margin-top: 1.25em;
}
.topics-section .topics-card__title--accent {
  color: #a24acb;
}
.topics-section .topics-card__text {
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  line-height: 1.8;
}
.topics-section .topics-card:hover {
  /*.topics-card__image {
    box-shadow: 0 1.4em 2.8em rgba(178, 153, 200, 0.35);
  }*/
}
.topics-section .topics-row--sub {
  justify-content: space-between;
}
.topics-section .topics-mini {
  flex: 0 0 22%;
  min-width: 0;
  max-width: none;
  text-align: center;
}
.topics-section .topics-mini__link {
  display: block;
  text-decoration: none;
  color: inherit;
}
.topics-section .topics-mini__image {
  border-radius: 1.2em;
  overflow: hidden;
}
.topics-section .topics-mini__image--placeholder {
  width: 100%;
  padding-top: 75%;
  border-radius: 1.2em;
  background-color: #f3f0f7;
  position: relative;
  overflow: hidden;
}
.topics-section .topics-mini__image--placeholder::before {
  content: "Image";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 75%;
  letter-spacing: 0.12em;
  color: #b5a9c8;
  border: 1px dashed #d6cfe5;
}
.topics-section .topics-mini__label {
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  font-weight: 500;
  line-height: 1.6;
  margin-top: 1em;
}
@media (max-width: 767px) {
  .topics-section .topics-card {
    flex: 0 0 100%;
  }
  .topics-section .topics-row--sub {
    justify-content: center;
  }
  .topics-section .topics-mini {
    flex: 0 0 48%;
  }
}

.lineup {
  background-color: #ffffff;
  overflow: hidden;
}
.lineup__hero {
  width: 100%;
  padding: clamp(6em, 4.545em + 7.27vw, 10em) 0;
  background-image: url("../img/lineup.jpg");
  background-position: 85% 85%;
  background-repeat: no-repeat;
  background-size: cover;
}
.lineup__hero p {
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: clamp(19.2px, 16px + 0.75vw, 24.8px);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  width: min(1120px, 90%);
  padding-right: 30%;
  margin-inline: auto;
}
.lineup__hero p span {
  background-color: white;
}
.lineup__inner {
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
  text-align: center;
}
.lineup__btn {
  font-size: clamp(16px, 16px + 0.4vw, 18.4px);
  font-weight: 500;
  background-color: #7b5aa8;
  color: white;
}
.lineup__heading {
  margin-bottom: 4%;
}
.lineup__filters {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.75em 0.5em;
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  margin-bottom: clamp(38.4px, 29.088px + 2.91vw, 64px);
}
.lineup__filter {
  min-width: 9em;
  background-color: #ffffff;
  letter-spacing: 0.08em;
  border: 1px solid;
}
.lineup__filter:hover {
  background-color: #fefbff;
  box-shadow: 0 0.45em 1.4em rgba(126, 103, 163, 0.25);
  transform: translateY(-0.06em);
}
.lineup__palette {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.9em 1em;
}
@media (max-width: 1279px) {
  .lineup__palette {
    max-width: 600px;
    margin-inline: auto;
  }
}
.lineup__color {
  width: 7.2em;
  border-radius: 100vmax;
  border: none;
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  color: #ffffff;
  cursor: pointer;
  text-decoration: none;
  box-shadow: 0 0.35em 0.9em rgba(0, 0, 0, 0.18);
  transition: transform 0.15s ease, box-shadow 0.15s ease, opacity 0.15s ease;
}
.lineup__color:hover {
  transform: translateY(-0.1em);
  box-shadow: 0 0.6em 1.4em rgba(0, 0, 0, 0.24);
  opacity: 0.95;
}
.lineup__color--black {
  background-color: #232222;
}
.lineup__color--blue {
  background-color: #355fae;
}
.lineup__color--green {
  background-color: #3a9b7a;
}
.lineup__color--brown {
  background-color: #8c5c32;
}
.lineup__color--orange {
  background-color: #f29a3f;
}
.lineup__color--red {
  background-color: #d93a3f;
}
.lineup__color--pink {
  background-color: #f47aaa;
}
.lineup__color--purple {
  background-color: #af9cbc;
}
.lineup__color--mint {
  background-color: #7bd6cf;
}
.lineup__color--white {
  background-color: #d6d2c9;
  color: #574f46;
}
.lineup__image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  transform: scale(1.01);
}

@media (max-width: 575px) {
  .lineup__hero {
    background-size: min(150%, 575px);
    background-position: 100% 100%;
  }
  .lineup__filters {
    flex-direction: column;
  }
  .lineup__filter {
    justify-content: center;
    min-width: 0;
  }
  .lineup__filter-label {
    text-align: center;
  }
  .lineup__palette {
    gap: 1em 3.125%;
  }
  .lineup__color {
    width: 17.5%;
  }
}
.lineup__girls {
  background: linear-gradient(90deg, #fef3f7 0%, #fff7f9 50%, #fffaf5 100%);
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
}

.lineup__boys {
  background: linear-gradient(90deg, #f4f6ff 0%, #f2fbff 50%, #f5fbff 100%);
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
}

.lineup-collection__layout {
  display: flex;
  align-items: stretch;
}
.lineup-collection__photo {
  aspect-ratio: 3/4;
  border-radius: 1.6em;
  overflow: hidden;
  box-shadow: 0 0.6em 1.8em rgba(0, 0, 0, 0.2);
}
.lineup-collection__side {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  align-self: stretch;
  row-gap: 1.8em;
}
.lineup-collection__card {
  aspect-ratio: 3/4;
  border-radius: 1.4em;
  margin-top: auto;
  overflow: hidden;
  box-shadow: 0 0.6em 1.8em rgba(0, 0, 0, 0.2);
}
.lineup-collection .illust {
  position: relative;
}
.lineup-collection .illust::after {
  content: "";
  display: block;
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
}
.lineup__girls .lineup-collection__text::after {
  aspect-ratio: 288/333;
  background-image: url("../img/lineup_girls_illust_01.png");
}
.lineup__girls .lineup-collection__main::after {
  aspect-ratio: 193/199;
  background-image: url("../img/lineup_girls_illust_02.png");
}
.lineup__girls .lineup-collection__side::after {
  aspect-ratio: 178/284;
  background-image: url("../img/lineup_girls_illust_03.png");
}
.lineup__boys .lineup-collection__text::after {
  aspect-ratio: 315/311;
  background-image: url("../img/lineup_boys_illust_01.png");
}
.lineup__boys .lineup-collection__main::after {
  aspect-ratio: 223/218;
  background-image: url("../img/lineup_boys_illust_02.png");
}

.lineup__sub-en {
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: clamp(27.2px, 16px + 2.1vw, 38.4px);
  line-height: 1.1;
  letter-spacing: 0.08em;
}
.lineup__sub-en--girls {
  color: #ca93c0;
}
.lineup__sub-en--boys {
  color: #6678b5;
}

.lineup__sub-ja {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  max-width: 28em;
  margin: clamp(9.6px, 7.28px + 0.73vw, 16px) 0 clamp(19.2px, 14.544px + 1.45vw, 32px);
}

.lineup__cta {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  font-weight: 500;
  padding: 1em 2.5em;
  border-radius: 0.9em;
  letter-spacing: 0.025em;
  text-decoration: none;
  color: #ffffff;
  box-shadow: 0 0.6em 1.8em rgba(0, 0, 0, 0.2);
  background-size: 200% 100%;
  background-position: 0 0;
  transition: background-position 0.4s ease-out, transform 0.15s ease, box-shadow 0.15s ease, opacity 0.15s ease;
}
.lineup__cta::after {
  content: "";
  flex: 0 0 auto;
  margin-left: 0.7em;
  width: 1.4em;
  height: 1.4em;
  background-color: currentColor;
  -webkit-mask-image: url("data:image/svg+xml;utf8,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2064%2064'%3E%3Cpath%20d='M0%2032A32%2032%200%201%200%2032%200%2032%2032%200%200%200%200%2032zm29.21-12.36%2014.805%2012.534-14.805%2012.52a2%202%200%201%201-2.583-3.055l11.195-9.467-11.196-9.479a2%202%200%201%201%202.585-3.052z'%20fill='%23000'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml;utf8,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2064%2064'%3E%3Cpath%20d='M0%2032A32%2032%200%201%200%2032%200%2032%2032%200%200%200%200%2032zm29.21-12.36%2014.805%2012.534-14.805%2012.52a2%202%200%201%201-2.583-3.055l11.195-9.467-11.196-9.479a2%202%200%201%201%202.585-3.052z'%20fill='%23000'/%3E%3C/svg%3E");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
}
.lineup__cta:hover {
  background-position: 100% 0;
  transform: translateY(-0.08em);
  box-shadow: 0 0.9em 2.2em rgba(0, 0, 0, 0.25);
  opacity: 0.96;
}
.lineup__cta--girls {
  background-image: linear-gradient(90deg, #e5a9d9, #ffbaae);
}
.lineup__cta--boys {
  background-image: linear-gradient(90deg, #93a7da, #7bbadf);
}

@media (min-width: 768px) {
  .lineup-collection__layout {
    gap: 4%;
  }
  .lineup-collection__main {
    flex: 0 0 48%;
    padding-bottom: 5%;
  }
  .lineup-collection__side {
    flex: 0 0 48%;
  }
  .lineup-collection__card {
    order: 2;
    width: 60%;
    position: relative;
  }
  .lineup-collection__text {
    order: 1;
  }
  .lineup__girls .lineup-collection__card {
    left: -15%;
  }
  .lineup__girls .lineup-collection__text::after {
    width: 10em;
    top: -20%;
    left: 110%;
  }
  .lineup__girls .lineup-collection__main::after {
    width: 3em;
    bottom: -5%;
    right: 10%;
  }
  .lineup__girls .lineup-collection__side::after {
    width: 5em;
    bottom: 5%;
    left: 55%;
  }
  .lineup__boys .lineup-collection__layout {
    flex-direction: row-reverse;
  }
  .lineup__boys .lineup-collection__card {
    right: -15%;
  }
  .lineup__boys .lineup-collection__side {
    align-items: flex-end;
  }
  .lineup__boys .lineup-collection__text {
    text-align: left;
  }
  .lineup__boys .lineup-collection__text::after {
    width: 7em;
    bottom: -60%;
    left: -15%;
  }
  .lineup__boys .lineup-collection__main::after {
    width: 5em;
    bottom: -8%;
    left: 25%;
  }
}
@media (max-width: 767px) {
  .lineup__girls, .lineup__boys {
    background: white;
    padding: 0 0 clamp(48px, 36.368px + 3.64vw, 80px);
  }
  .lineup-collection__layout {
    flex-direction: column;
    max-width: 460px;
    margin: 0 auto;
  }
  .lineup-collection__main, .lineup-collection__side {
    flex: 0 0 auto;
    width: 100%;
  }
  .lineup-collection__main {
    padding-right: 35%;
    padding-left: 10%;
  }
  .lineup-collection__side {
    align-items: center;
    text-align: center;
  }
  .lineup-collection__card {
    margin-top: -35%;
    margin-right: 10%;
    margin-left: 60%;
  }
}
.lineup-series {
  padding: 6% 0 8%;
  background-color: #ffffff;
}

.series-row {
  padding: 3% 0 3.2%;
  border-top: 1px solid #e0e0e0;
}
.series-row:last-child {
  border-bottom: 1px solid #e0e0e0;
}
.series-row__head {
  margin-bottom: 2%;
}
.series-row__title-en {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-weight: 600;
  font-size: 1.05rem;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  margin-bottom: 0.3em;
}
.series-row__title-ja {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 0.8rem;
  letter-spacing: 0.18em;
  color: #666666;
  margin-bottom: 0.9em;
}
.series-row__lead {
  font-size: 0.78rem;
  line-height: 1.9;
  color: #777777;
}
.series-row__colors {
  margin-top: 2.4%;
  display: flex;
  flex-wrap: wrap;
  column-gap: 2%;
  row-gap: 1.4em;
}

.series-item {
  flex: 0 0 auto;
  width: 90px;
  text-decoration: none;
  color: inherit;
  font-size: 0.7rem;
  text-align: center;
}
.series-item__image {
  position: relative;
  width: 100%;
  padding-top: 90%;
  margin-bottom: 0.4em;
  overflow: hidden;
}
.series-item__image img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.series-item__image-placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.65rem;
  letter-spacing: 0.12em;
  color: #b3b3b3;
  border: 1px dashed #cccccc;
}
.series-item__name {
  margin-bottom: 0.1em;
}
.series-item__note {
  font-size: 0.65rem;
  color: #999999;
}

@media (max-width: 767px) {
  .series-row {
    padding: 4% 0 4.4%;
  }
  .series-row__colors {
    column-gap: 3%;
  }
  .series-item {
    width: 22%;
  }
}
@media (max-width: 575px) {
  .lineup-series {
    padding: 8% 0 10%;
  }
  .series-row__head {
    margin-bottom: 3%;
  }
  .series-item {
    width: 31%;
  }
}
/* ===== Catalog banner ===== */
.catalog-banner {
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
  background-color: #e8e1ed;
  background-image: url(../img/catalog_bg_pattern.svg);
  background-position: center;
  background-repeat: repeat;
  background-size: 5vw;
}
.catalog-banner__inner {
  text-align: center;
}
.catalog-banner {
  /* 大きい画像 */
}
.catalog-banner__hero {
  border-radius: 2.2em;
}
.catalog-banner__image {
  position: relative;
  aspect-ratio: 16/6;
  overflow: hidden;
  background-color: #f6f2fb;
}
.catalog-banner__image::before {
  content: "Image";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  letter-spacing: 0.14em;
  color: #b9a7d0;
  border-radius: inherit;
  border: 1px dashed #d7cbe7;
}
.catalog-banner {
  /* CTA ボタン */
}
.catalog-banner__cta-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.4em 2.2em;
}
.catalog-banner__cta {
  font-size: min(4.2vw, 1.1em);
  font-weight: 500;
  background-color: #ffffff;
  background-image: linear-gradient(90deg, rgba(255, 255, 255, 0), rgba(181, 142, 210, 0.18));
  background-size: 180% 100%;
  background-position: 0 0;
  margin-top: clamp(28.8px, 21.824px + 2.18vw, 48px);
}
.catalog-banner__cta::after {
  background-color: #7b5aa8;
}
.catalog-banner__cta:hover {
  background-position: 100% 0;
}

/* ===== ABOUT US ===== */
.about-block {
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
  background-color: #ffffff;
  text-align: center;
  /* 3カラム */
}
.about-block__features {
  margin-top: 5%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  column-gap: 3%;
  row-gap: clamp(28.8px, 21.824px + 2.18vw, 48px);
}
.about-block__image {
  position: relative;
  aspect-ratio: 4/3;
  border-radius: 1.6em;
  overflow: hidden;
  background-color: #f5f5f7;
}
.about-block__image::before {
  content: "Image";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  letter-spacing: 0.14em;
  color: #c1b8cf;
  border-radius: inherit;
  border: 1px dashed #ddd6e6;
}

/* 各ボックス */
.about-feature {
  flex: 0 0 31%;
  max-width: 360px;
}
.about-feature__image {
  border-radius: 1.6em;
  overflow: hidden;
}
.about-feature__image img {
  aspect-ratio: 16/9;
  object-fit: cover;
}
.about-feature__title {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: clamp(16px, 16px + 0.4vw, 18.4px);
  font-weight: 600;
  letter-spacing: 0.08em;
  margin-top: 1em;
  margin-bottom: 0.6em;
}
.about-feature__text {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
}

/* レスポンシブ */
@media (max-width: 767px) {
  .about-feature {
    flex: 0 0 100%;
  }
}
/* ===== STORE LIST ===== */
.store-section {
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
  background-color: #f7f3ec;
  text-align: center;
}
.store-section .section-heading__main-en {
  color: #755F47;
}
.store-section .section-heading__sub-ja {
  color: #755F47;
}
.store-section .section-heading__lead {
  color: #755F47;
}
.store-section__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 2em 6%;
  max-width: 960px;
  margin: 5% auto 0;
}
.store-section__image {
  position: relative;
  aspect-ratio: 4/3;
  border-radius: 1.6em;
  overflow: hidden;
  background-color: #f5f5f7;
}
.store-section__image::before {
  content: "Image";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  letter-spacing: 0.14em;
  color: #c7c0b8;
  border-radius: inherit;
  border: 1px dashed #e0d7cc;
}

/* 店舗カード */
.store-card {
  flex: 0 0 47%;
  max-width: none;
  display: flex;
  align-items: center;
  gap: 5%;
  text-align: left;
}
.store-card__media {
  flex: 1 1 auto;
  align-self: flex-start;
}
.store-card__media img {
  aspect-ratio: 670/549;
  object-fit: cover;
  border-radius: 1em;
}
.store-card__body {
  flex: 0 0 9em;
}
.store-card__name {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  font-weight: 600;
  letter-spacing: 0.05em;
  color: #755F47;
  margin-bottom: 1.2em;
  white-space: nowrap;
}
.store-card__period {
  font-size: clamp(11.2px, 10.624px + 0.18vw, 12.8px);
  line-height: 1.5;
  letter-spacing: 0.05em;
  background-color: #755F47;
  color: white;
  margin-top: -0.5em;
  margin-bottom: 1.2em;
  padding: 0.5em;
  border-radius: 0.5em;
  text-align: center;
}
.store-card__period span {
  display: inline-block;
  text-align: left;
}
.store-card__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8em 1em;
}
.store-card__btn {
  font-size: clamp(11.2px, 10.624px + 0.18vw, 12.8px);
  font-weight: 600;
  min-width: 15em;
}
.store-card__btn--info {
  color: #755F47;
  background-color: white;
  box-shadow: 0 0.4em 1.2em rgba(185, 158, 126, 0.18);
  border: 1px solid #755F47;
}
.store-card__btn--reserve {
  color: #ffffff;
  background-color: #755F47;
  background-size: 180% 100%;
  background-position: 0 0;
  box-shadow: 0 0.6em 1.6em rgba(182, 140, 93, 0.28);
}
.store-card__btn--reserve:hover {
  background-position: 100% 0;
  box-shadow: 0 0.9em 2em rgba(182, 140, 93, 0.36);
}
.store-card__comment {
  color: #755F47;
  font-size: clamp(11.2px, 10.624px + 0.18vw, 12.8px);
  font-weight: 500;
  text-align: center;
  margin-top: 0.75em;
}

/* レスポンシブ */
@media (max-width: 767px) {
  .store-section__list {
    max-width: 480px;
  }
  .store-card {
    flex: 0 0 100%;
    max-width: none;
  }
}
/* ===== CUSTOMER'S VOICE ===== */
.voice-section {
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
  background-color: #ffffff;
  text-align: center;
}
.voice-section__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  column-gap: 4%;
  row-gap: clamp(28.8px, 21.824px + 2.18vw, 48px);
}
.voice-section__image {
  position: relative;
  aspect-ratio: 4/3;
  border-radius: 1.6em;
  overflow: hidden;
  background-color: #f5f5f7;
}
.voice-section__image::before {
  content: "Image";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  letter-spacing: 0.14em;
  color: #c1b8cf;
  border-radius: inherit;
  border: 1px dashed #ddd6e6;
}
.voice-section__more {
  margin-top: clamp(28.8px, 21.824px + 2.18vw, 48px);
}

.voice-card {
  flex: 0 0 30%;
  max-width: 340px;
  text-align: left;
}
.voice-card__image {
  margin-bottom: 1em;
}
.voice-card__body {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
}
.voice-card__name {
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  font-weight: 600;
  letter-spacing: 0.08em;
}
.voice-card__summary {
  font-size: clamp(11.2px, 10.624px + 0.18vw, 12.8px);
  font-weight: 500;
  display: flex;
  gap: 0.4em;
  padding: 0.6em 1.6em;
  margin: 1em 0;
  background-color: #f4f1ec;
  letter-spacing: 0.06em;
}
.voice-card__text {
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
}
.voice-card__more {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: clamp(11.2px, 10.624px + 0.18vw, 12.8px);
  border: 1px solid #293436;
  padding: 0.45em 3.6em 0.45em 2em;
  border-radius: 100vmax;
  text-decoration: none;
  letter-spacing: 0.075em;
  white-space: nowrap;
  margin: 1.5em 0 0 auto;
  transition: transform 0.15s ease, box-shadow 0.15s ease, opacity 0.15s ease, background-position 0.35s ease-out;
}
.voice-card__more::after {
  content: "";
  position: absolute;
  right: 1.4em;
  width: 1.2em;
  height: 1.2em;
  background-color: currentColor;
  border-radius: 50%;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='%236a6479' d='M32 0a32 32 0 1 0 32 32A32.001 32.001 0 0 0 32 0zm16 34H34v14a2 2 0 1 1-4 0V34H16a2 2 0 0 1 0-4h14V16a2 2 0 1 1 4 0v14h14a2 2 0 0 1 0 4z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='%236a6479' d='M32 0a32 32 0 1 0 32 32A32.001 32.001 0 0 0 32 0zm16 34H34v14a2 2 0 1 1-4 0V34H16a2 2 0 0 1 0-4h14V16a2 2 0 1 1 4 0v14h14a2 2 0 0 1 0 4z'/%3E%3C/svg%3E");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
  transition: transform 0.15s ease-out;
}
.voice-card__more:hover {
  transform: translateY(-0.06em);
  opacity: 0.9;
}
.voice-card__more:hover::after {
  transform: scale(1.1);
}

/* MORE ボタン */
.voice-more-btn {
  min-width: 220px;
}

/* レスポンシブ */
@media (max-width: 767px) {
  .voice-card {
    flex: 0 0 46%;
  }
}
@media (max-width: 575px) {
  .voice-card {
    flex: 0 0 100%;
  }
}
.voice-modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 200;
}

.voice-modal.is-open {
  display: flex;
}

.voice-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
}

.voice-modal__dialog {
  position: relative;
  z-index: 1;
  max-width: 720px;
  width: min(90%, 720px);
  max-height: 90vh;
  padding: 2rem;
  background: #fff;
  border-radius: 1.2rem;
  overflow-y: auto;
}

.voice-modal__close {
  position: absolute;
  top: 0.2em;
  right: 0.5em;
  border: none;
  background: none;
  font-size: 2.4em;
  line-height: 1;
  cursor: pointer;
}

.voice-modal__loading {
  display: flex;
  justify-content: center;
  gap: 0.3rem;
  padding: 2rem 0;
}

.voice-modal__loading span {
  width: 0.4rem;
  height: 0.4rem;
  border-radius: 999px;
  background-color: #b48c6b;
  animation: voice-loading-bounce 0.9s infinite ease-in-out;
}

.voice-modal__loading span:nth-child(2) {
  animation-delay: 0.15s;
}

.voice-modal__loading span:nth-child(3) {
  animation-delay: 0.3s;
}

@keyframes voice-loading-bounce {
  0%, 80%, 100% {
    transform: translateY(0);
    opacity: 0.4;
  }
  40% {
    transform: translateY(-0.4rem);
    opacity: 1;
  }
}
/* ===== Voice modal layout ===== */
/* モーダル本体は既にある前提で、レイアウトだけ追加 */
.voice-modal__dialog {
  position: relative;
  z-index: 1;
  max-width: 980px;
  width: min(96%, 980px);
  max-height: 90vh;
  padding: 3em;
  background: #ffffff;
  border-radius: 1.6rem;
  overflow: hidden; /* 内側ラッパでスクロールさせる */
}

/* 内側をスクロールさせるラッパ */
.voice-modal__inner {
  display: flex;
  align-items: center;
  gap: 3rem;
  max-height: calc(90vh - 3rem); /* paddingぶん差し引き */
  overflow-y: auto;
}

/* 左右カラム */
.voice-modal-article {
  display: contents; /* 中身のラッパとして扱うだけ */
}

.voice-modal-article__image {
  flex: 0 0 46%;
}

.voice-modal-article__image img {
  display: block;
  width: 100%;
  height: auto;
}

.voice-modal-article__content {
  flex: 1 1 0;
  text-align: left;
}

/* テキスト周り */
.voice-modal-article__name {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 1.2rem;
  letter-spacing: 0.18em;
  margin-bottom: 0.8rem;
}

.voice-modal-article__meta {
  display: inline-flex;
  gap: 0.4em;
  padding: 0.6rem 1.6rem;
  margin-bottom: 1.6rem;
  background-color: #f4f1ec;
  font-size: 0.85rem;
  letter-spacing: 0.12em;
}

.voice-modal-article__body {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 0.9rem;
  line-height: 2;
  color: #555555;
}

/* SP レイアウト */
@media (max-width: 767px) {
  .voice-modal__dialog {
    padding: 1.6rem 1.4rem;
    max-height: 92vh;
  }
  .voice-modal__inner {
    flex-direction: column;
    gap: 1.6rem;
    max-height: calc(92vh - 2.4rem);
  }
  .voice-modal-article__image {
    flex: 0 0 auto;
  }
  .voice-modal-article__content {
    flex: 0 0 auto;
  }
}
.about-us-intro {
  padding: 80px 0 96px;
  background-color: #ffffff;
  text-align: center;
}
.about-us-intro__catch {
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: clamp(23.2px, 16px + 1.6vw, 33.6px);
  line-height: 1.7;
  letter-spacing: 0.08em;
  color: #b68b4c;
  margin-bottom: 32px;
}
.about-us-intro__lead, .about-us-intro__text {
  line-height: 2;
  color: #555555;
}
.about-us-intro__lead {
  margin-bottom: 8px;
}
.about-us-intro__text {
  margin-bottom: 40px;
}
.about-us-intro__slider {
  margin: 0 auto;
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.06);
}
.about-us-intro__slider .slick-dots {
  bottom: auto;
}
.about-us-intro__slider .slick-dots li {
  margin: 0;
}
.about-us-intro__slider .slick-dots li button:before {
  color: #7b5aa8;
  font-size: 8px;
}
.about-us-intro__slider .slick-dots li.slick-active button:before {
  color: #7b5aa8;
}
.about-us-intro__slide img {
  display: block;
  width: 100%;
  height: auto;
}
@media (max-width: 767px) {
  .about-us-intro {
    padding: 56px 0 72px;
  }
  .about-us-intro__slider {
    border-radius: 18px;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.05);
  }
}

.about-us-message {
  padding: 80px 0 96px;
  background-color: #f5f2f7;
}
.about-us-message__title {
  margin: 0 0 40px;
  text-align: center;
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: clamp(23.2px, 16px + 1.6vw, 33.6px);
  letter-spacing: 0.12em;
  color: #7b5aa8;
}
.about-us-message__list {
  display: flex;
  flex-direction: column;
}
.about-us-message__item {
  display: flex;
  align-items: center;
  gap: 5% 2em;
  padding: 0 0 2em;
  margin: 0 auto 2em;
  border-bottom: 1px solid #7b5aa8;
}
.about-us-message__item:first-child {
  border-top: 1px solid #7b5aa8;
  padding-top: 2em;
}
.about-us-message__image {
  flex: 0 0 38.2%;
  overflow: hidden;
}
.about-us-message__image img {
  display: block;
  width: 100%;
  height: auto;
}
.about-us-message__body {
  flex: 1 1 auto;
}
.about-us-message__heading {
  color: #7b5aa8;
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: clamp(19.2px, 16px + 0.75vw, 24.8px);
  margin: 0 0 12px;
}
.about-us-message__text {
  font-size: 0.95rem;
  line-height: 2;
  color: #555555;
}
@media (max-width: 767px) {
  .about-us-message {
    padding: 56px 0 72px;
  }
  .about-us-message__item {
    flex-direction: column;
    align-items: flex-start;
    padding: 24px 20px;
  }
  .about-us-message__image {
    width: 100%;
    margin: 0 0 20px;
    flex: 0 0 auto;
  }
}

.about-us-video {
  padding: 80px 0 96px;
  background-color: #ffffff;
  text-align: center;
}
.about-us-video__frame {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  margin: 0 auto 40px;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.18);
  overflow: hidden;
}
.about-us-video__frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.about-us-video__text {
  max-width: 720px;
  margin: 0 auto;
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: clamp(1em, 0.945em + 0.27vw, 1.15em);
  line-height: 2.4;
  color: #555555;
}
.about-us-video__text p + p {
  margin-top: 8px;
}
@media (max-width: 767px) {
  .about-us-video {
    padding: 56px 0 72px;
  }
  .about-us-video__frame {
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.16);
    margin-bottom: 32px;
  }
  .about-us-video__text {
    text-align: left;
  }
}

.feature-intro {
  padding: 3.5em 0 4em;
}
.feature-intro__inner {
  text-align: center;
}
.feature-intro__headline {
  margin-bottom: 2.4em;
}
.feature-intro__kicker {
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  margin: 0 0 0.4em;
}
.feature-intro__title {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 1.5em;
  margin: 0;
}
.feature-intro__title-em {
  color: #7b5aa8;
}
.feature-intro__content {
  display: grid;
  grid-template-columns: 146px auto auto;
  justify-content: center;
  gap: 1.5em;
  margin-top: 2.2em;
  padding: 1.5em;
  border: 0.5em solid #f5f2f7;
  border-radius: 1.5em;
}
.feature-intro__image {
  position: relative;
}
.feature-intro__image img {
  display: block;
  width: 100%;
  height: auto;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.feature-intro__badge {
  display: flex;
  align-self: center;
  justify-content: center;
  align-items: center;
  width: 100%;
  background-color: #7b5aa8;
  color: #fff;
  border-radius: 1em;
  padding: 0.9em 1.5em;
  text-align: center;
}
.feature-intro__badge::before, .feature-intro__badge::after {
  content: "";
  display: block;
  background-image: url(../img/laurel.svg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  width: 1.5em;
  aspect-ratio: 24/65;
}
.feature-intro__badge::after {
  transform: scaleX(-1);
}
.feature-intro__badge-text {
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  font-weight: 600;
  margin: 0 1em;
  line-height: 1.7;
  white-space: nowrap;
}
.feature-intro__points {
  justify-self: flex-start;
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  font-weight: 500;
}
.feature-intro__list {
  list-style: none;
  padding: 0;
  margin: 0;
  text-align: left;
}
.feature-intro__item {
  display: flex;
  column-gap: 0.5em;
  position: relative;
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  line-height: 1.8;
}
.feature-intro__item + .feature-intro__item {
  margin-top: 0.6em;
}
.feature-intro__item::before {
  content: "";
  display: inline-block;
  background-color: #7b5aa8;
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='none' stroke='%23202020' stroke-miterlimit='10' stroke-width='4' d='M15.74 30l12 14 34-42' stroke-linejoin='round' stroke-linecap='round'/%3E%3Cpath d='M53.443 32A26.002 26.002 0 1 1 27.75 10a25.914 25.914 0 0 1 10 1.993' fill='none' stroke='%23202020' stroke-miterlimit='10' stroke-width='4' stroke-linejoin='round' stroke-linecap='round'/%3E%3C/svg%3E");
  mask-position: center;
  mask-repeat: no-repeat;
  mask-size: contain;
  width: 1.5em;
  height: 1.5em;
  padding-top: 0.1em;
  position: relative;
  top: 0.1em;
}
@media (max-width: 1023px) {
  .feature-intro__content {
    grid-template-columns: 146px auto;
    grid-template-rows: auto auto;
  }
  .feature-intro__image {
    grid-row: 1/3;
  }
}
@media (max-width: 767px) {
  .feature-intro__badge, .feature-intro__points {
    justify-self: center;
  }
  .feature-intro__list {
    text-align: left;
  }
}
@media (max-width: 575px) {
  .feature-intro__content {
    grid-template-columns: 18vw auto;
    grid-template-rows: auto auto;
    grid-column-gap: 0.5em;
  }
  .feature-intro__image {
    grid-row: auto;
  }
  .feature-intro__image img {
    top: auto;
    bottom: 0;
    transform: translateY(0);
  }
  .feature-intro__points {
    grid-column: 1/3;
  }
}
@media (max-width: 479px) {
  .feature-intro__badge {
    font-size: 3.4vw;
  }
}

/* BASIC FEATURE 機能01〜05 */
.feature-section {
  width: 100%;
  background-color: #fff;
}
.feature-section__inner {
  padding: 0 0 4.4em;
}

.feature-card {
  padding-top: clamp(3em, 16vw, 5em);
  position: relative;
}
.feature-card + .feature-card {
  margin-top: 3.4em;
}
.feature-card__inner {
  background-color: #f5f2f7;
  border-radius: clamp(1.2em, 6.4vw, 2em);
  box-shadow: 0 0.25em 0.9em rgba(0, 0, 0, 0.03);
  padding: 3em 7%;
  text-align: left;
}
.feature-card__head {
  background-color: #f5f2f7;
  text-align: center;
  font-size: clamp(0.6em, 3.2vw, 1em);
  width: 10em;
  line-height: 1;
  aspect-ratio: 1;
  border-radius: 50%;
  padding-top: 2.5em;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
.feature-card__label {
  display: inline-block;
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 125%;
  color: #7b5aa8;
  margin: 0 0 0.6em;
  position: relative;
  padding-bottom: 0.6em;
}
.feature-card__label span {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 200%;
  font-weight: 500;
  padding-right: 0.15em;
  padding-left: 0.25em;
  vertical-align: text-bottom;
}
.feature-card__title {
  color: #7b5aa8;
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: clamp(1.25em, 5.2vw, 1.5em);
  font-weight: 700;
  line-height: 1.7;
  max-width: 100%;
  margin: 0 0 0.5em;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
.feature-card__body {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 5%;
  position: relative;
}
.feature-card__body p span {
  color: #7b5aa8;
  font-weight: 500;
}
.feature-card__body p + p, .feature-card__body p + figure {
  margin-top: 1em;
}
.feature-card__body figure img {
  margin-right: auto;
  margin-left: auto;
}
.feature-card__body figure + h2, .feature-card__body figure + p {
  margin-top: 1em;
}
.feature-card__body img + p, .feature-card__body img + img {
  margin-top: 1em;
}
.feature-card__text {
  flex: 0 0 55.2%;
}
.feature-card__image {
  flex: 1 1 auto;
}
.feature-card__image p {
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
}
.feature-card__image__wrap {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
  margin-bottom: 0.5em;
}
.feature-card img {
  display: block;
  width: 100%;
  height: auto;
}
.feature-card.feature-card--05 .feature-card__image {
  margin-bottom: -3em;
}
@media (min-width: 768px) {
  .feature-card--reverse .feature-card__body {
    flex-direction: row-reverse;
  }
}
@media (max-width: 767px) {
  .feature-card__inner {
    border-radius: 1.6em;
    padding: 2.5em 8% 2.7em;
  }
  .feature-card__body {
    flex-direction: column;
    align-items: flex-start;
    gap: 1.8em;
  }
  .feature-card__text, .feature-card__image {
    flex: 1 1 auto;
    width: 100%;
  }
  .feature-card__image__wrap {
    flex-direction: row;
  }
  .feature-card.feature-card--02 .feature-card__image img, .feature-card.feature-card--03 .feature-card__image img {
    width: 61.8%;
  }
  .feature-card.feature-card--05 .feature-card__image {
    margin-bottom: -2.7em;
  }
}
@media (max-width: 575px) {
  .feature-card__inner {
    padding: 2.3em 8% 2.5em;
  }
}

.company-intro {
  padding: 96px 0 112px;
  background-color: #faf8f5;
}
.company-intro__title {
  margin: 0 0 56px;
  text-align: center;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: clamp(27.2px, 16px + 2.1vw, 38.4px);
  letter-spacing: 0.12em;
  color: #b68b4c;
}
.company-intro__content {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5%;
}
.company-intro__image {
  flex: 1 1 auto;
  max-width: 500px;
  border-radius: 32px;
  overflow: hidden;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.14);
}
.company-intro__image img {
  display: block;
  width: 100%;
  height: auto;
}
.company-intro__text-block {
  flex: 0 0 auto;
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  line-height: 2;
  color: #555555;
}
.company-intro__lead {
  margin: 0 0 32px;
}
.company-intro__signature {
  margin: 0;
  text-align: right;
}
@media (max-width: 767px) {
  .company-intro {
    padding: 72px 0 88px;
  }
  .company-intro__title {
    margin-bottom: 40px;
    font-size: clamp(23.2px, 16px + 1.6vw, 33.6px);
  }
  .company-intro__content {
    flex-direction: column;
    gap: 32px;
  }
  .company-intro__image {
    width: 100%;
    flex: 0 0 auto;
    border-radius: 24px;
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.12);
  }
  .company-intro__text-block {
    font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  }
}

.company-profile {
  padding: 64px 0 96px;
  background-color: #ffffff;
}
.company-profile__title {
  margin: 0 0 32px;
  font-size: clamp(19.2px, 16px + 0.75vw, 24.8px);
  font-weight: 700;
}
.company-profile__table {
  width: 100%;
  border-collapse: collapse;
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  color: #555555;
}
.company-profile__table th, .company-profile__table td {
  padding: 14px 16px;
  border-top: 1px solid #dddddd;
}
.company-profile__table th {
  width: 22%;
  white-space: nowrap;
  font-weight: 700;
  text-align: left;
}
.company-profile__table td {
  width: 78%;
}
.company-profile__table td a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 0.12em;
}
.company-profile__table tr:last-child th, .company-profile__table tr:last-child td {
  border-bottom: 1px solid #dddddd;
}
.company-profile__affiliations {
  margin: 0;
  padding: 0;
  list-style: none;
}
.company-profile__affiliations li + li {
  margin-top: 4px;
}
@media (max-width: 767px) {
  .company-profile {
    padding: 48px 0 72px;
  }
  .company-profile th, .company-profile td {
    padding: 10px 8px;
  }
  .company-profile th {
    width: 30%;
  }
  .company-profile td {
    width: 70%;
    font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  }
}

/* ===============================
   Exhibition page local colors
   =============================== */
/* ===============================
   Exhibition intro block
   =============================== */
.exhibition-intro {
  max-width: 960px;
  margin: 0 auto;
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
  text-align: center;
}
.exhibition-intro__image {
  margin: 0 auto clamp(38.4px, 29.088px + 2.91vw, 64px);
}
.exhibition-intro__image picture,
.exhibition-intro__image img {
  display: block;
  max-width: 100%;
  height: auto;
  margin: 0 auto;
}
.exhibition-intro__message {
  margin: 0 auto clamp(38.4px, 29.088px + 2.91vw, 64px);
  max-width: 46rem;
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  line-height: 2;
  color: #293436;
}
.exhibition-intro__lead {
  margin: 0 0 clamp(19.2px, 14.544px + 1.45vw, 32px);
}
.exhibition-intro__note {
  margin: 0;
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  line-height: 1.9;
  color: rgb(76.8210526316, 97.4315789474, 101.1789473684);
}
.exhibition-intro__note .is-red,
.exhibition-intro__note .red {
  color: #b51c22;
}
.exhibition-intro__nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: clamp(19.2px, 14.544px + 1.45vw, 32px);
}

.exhibition-nav__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 260px;
  padding: clamp(9.6px, 7.28px + 0.73vw, 16px) clamp(19.2px, 14.544px + 1.45vw, 32px);
  border-radius: 3px;
  border: 1px solid #293436;
  background-color: #fff;
  color: #293436;
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  text-decoration: none;
  letter-spacing: 0.08em;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.exhibition-nav__btn--outline {
  background-color: transparent;
}
@media (any-hover: hover) {
  .exhibition-nav__btn:hover, .exhibition-nav__btn:focus-visible {
    border-color: #b51c22;
    color: #b51c22;
  }
}

/* ===============================
   Map + text nav
   =============================== */
.exhibition-region__map {
  max-width: 576px;
  margin: 0 auto clamp(48px, 36.368px + 3.64vw, 80px);
  position: relative;
}
.exhibition-region__note {
  position: absolute;
  font-size: min(0.85em, 3vw);
  color: #999;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 50%;
  aspect-ratio: 4/3;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
.exhibition-region__map svg {
  display: block;
  width: 100%;
  height: auto;
}

#map .cls-1 {
  fill: #c7615f;
}
#map .cls-2 {
  fill: #5c89b9;
}
#map .cls-3 {
  fill: #eaae56;
}
#map .cls-4 {
  fill: #9c8bc0;
}
#map .cls-5 {
  fill: #595757;
}
#map .cls-6 {
  fill: #4ca09c;
}
#map .cls-7 {
  fill: #8fccdd;
}
#map .cls-8 {
  fill: #95ca92;
}
#map .map-region {
  transition: filter 0.25s ease, opacity 0.25s ease, transform 0.25s ease;
  transform-origin: center;
}
#map a {
  cursor: pointer;
  text-decoration: none;
}
#map a:hover .map-region,
#map a:focus-visible .map-region {
  filter: brightness(1.06);
  opacity: 0.9;
  transform: translateY(-2px);
}

.region-nav {
  max-width: 44em;
  margin: 0 auto clamp(48px, 36.368px + 3.64vw, 80px);
  padding: 0;
  list-style: none;
  border-top: 1px solid #e3e3e3;
}
.region-nav__row {
  display: flex;
  align-items: center;
  gap: 2rem;
  padding: 1rem 0;
  border-bottom: 1px solid #e3e3e3;
}
.region-nav__label {
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  flex: 0 0 12em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.6em 1em;
  border-radius: 3px;
  color: #ffffff;
  text-decoration: none;
  letter-spacing: 0.12em;
}
.region-nav__prefs {
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  line-height: 1.25;
  flex: 1 1 auto;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75em 1.5em;
}
.region-nav__pref-link {
  position: relative;
  white-space: nowrap;
  color: #555555;
  text-decoration: none;
  cursor: pointer;
  padding-bottom: 1px;
}
.region-nav__pref-link::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background-color: currentColor;
  opacity: 0;
  transform: scaleX(0.7);
  transform-origin: center;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.region-nav__pref-link:hover, .region-nav__pref-link:focus-visible {
  color: #222222;
}
.region-nav__pref-link:hover::after, .region-nav__pref-link:focus-visible::after {
  opacity: 1;
  transform: scaleX(1);
}
.region-nav__pref-link.no-link {
  color: #aaa;
  cursor: default;
  pointer-events: none;
}
.region-nav__pref-link.no-link::after {
  opacity: 0;
  transform: scaleX(0.7);
}
.region-nav__row--hokkaido .region-nav__label {
  background-color: #8fccdd;
}
.region-nav__row--hokuriku .region-nav__label {
  background-color: #4ca09c;
}
.region-nav__row--kanto .region-nav__label {
  background-color: #95ca92;
}
.region-nav__row--tokai .region-nav__label {
  background-color: #eaae56;
}
.region-nav__row--kansai .region-nav__label {
  background-color: #9c8bc0;
}
.region-nav__row--chugoku .region-nav__label {
  background-color: #c7615f;
}
.region-nav__row--kyushu .region-nav__label {
  background-color: #5c89b9;
}

/* ===============================
   Exhibition region block
   =============================== */
.exhibition-list__inner {
  padding: 0 0 clamp(38.4px, 29.088px + 2.91vw, 64px);
}
.exhibition-list__title {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5em 1em;
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  font-weight: 600;
  width: 100%;
  margin: 0 auto 2em;
  padding: 0.75em 1.5em;
  background-color: #293436;
  letter-spacing: 0.1em;
  text-align: center;
}
.exhibition-list__title span {
  display: inline-block;
  background-color: white;
  color: #293436;
  max-width: 12em;
  width: 100%;
  padding: 0.25em 1em;
  vertical-align: middle;
  border-radius: 0.4em;
}
.exhibition-list__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
}
.exhibition-list {
  /* ===============================
     Exhibition card
     =============================== */
}
.exhibition-list .exhibition-card {
  font-size: 0.95rem;
  display: flex;
  flex-direction: column;
  width: 100%;
  background-color: #ffffff;
  border: 1px solid #999;
  border-radius: 0.5em;
  box-shadow: 0 0.1em 0.4em rgba(0, 0, 0, 0.08);
  overflow: hidden;
}
.exhibition-list .exhibition-card__pref {
  font-weight: 600;
  letter-spacing: 0.15em;
  padding: 0.5em 0.6em 0.5em 0.75em;
  text-align: center;
}
.exhibition-list .exhibition-card__body {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 1em;
}
.exhibition-list .exhibition-card__title {
  font-weight: 600;
  margin: 0 0 0.5em;
}
.exhibition-list .exhibition-card__dates {
  font-size: 0.9em;
  margin-bottom: 1em;
}
.exhibition-list .exhibition-card__dates-time .weekday--sat {
  color: #2980b9;
}
.exhibition-list .exhibition-card__dates-time .weekday--sun, .exhibition-list .exhibition-card__dates-time .hday {
  color: #b51c22;
}
.exhibition-list .exhibition-card__dates .overdate {
  text-decoration: line-through;
}
.exhibition-list .exhibition-card__address {
  font-size: 0.9em;
  margin-top: auto;
}
.exhibition-list .exhibition-card__address a {
  display: inline-block;
  color: #b51c22;
}
.exhibition-list .exhibition-card__address a .icon {
  display: inline-block;
  background-color: #b51c22;
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath d='M32 2A24 24 0 0 0 8 26c0 .8 0 1.6.1 2.3v.3C10.1 47.6 32 62 32 62s21.9-14.6 23.8-33.3v-.4c.1-.8.1-1.5.1-2.3A24 24 0 0 0 32 2zm0 36a12 12 0 1 1 12-12 12 12 0 0 1-12 12z' fill='%23202020'/%3E%3C/svg%3E");
  mask-position: center;
  mask-repeat: no-repeat;
  mask-size: contain;
  width: 1.5em;
  aspect-ratio: 1;
  vertical-align: middle;
  position: relative;
  top: -0.15em;
  margin-right: 0.15em;
}
.exhibition-list .exhibition-card__parking-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.6em;
  font-weight: 600;
  width: 2em;
  aspect-ratio: 1;
  margin-right: 0.5em;
  border-radius: 50%;
  border-width: 0.2em;
  border-style: solid;
  text-indent: 0.1em;
  position: relative;
  top: -0.15em;
}
.exhibition-list .exhibition-card__parking-text {
  font-size: 0.9em;
}
.exhibition-list .exhibition-card__image {
  margin-top: 0.6em;
}
.exhibition-list .exhibition-card__image img {
  display: block;
  width: 100%;
  aspect-ratio: 1.732;
  border-radius: 0.5em;
  object-fit: cover;
}
.exhibition-list .exhibition-card__btn {
  font-size: 0.9em;
  font-weight: 500;
  border: 1px solid;
  padding-top: 0.75em;
  padding-bottom: 0.75em;
  margin-top: 1em;
}
.exhibition-list .exhibition-card--pref {
  box-shadow: none;
  border: 1px solid #e0e0e0;
  padding: 12px;
  align-items: center;
  justify-content: center;
  line-height: 1.8;
  letter-spacing: 0.05em;
  position: relative;
}
.exhibition-list .exhibition-card--pref .exhibition-card__pref-label {
  color: white;
  font-size: 2em;
  letter-spacing: 0.15em;
  text-align: center;
}
.exhibition-list .exhibition-card--pref .exhibition-card__pref-label::before {
  content: attr(data-label);
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: 500%;
  font-weight: 100;
  letter-spacing: -0.1em;
  white-space: nowrap;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.exhibition-list .exhibition-card--pref .exhibition-card__pref-label span {
  position: relative;
}
.exhibition-list--hokkaido {
  background-color: rgba(143, 204, 221, 0.2);
}
.exhibition-list--hokkaido > .exhibition-list__title {
  background-color: #8fccdd;
  color: #fff;
}
.exhibition-list--hokkaido .exhibition-card {
  border-color: #8fccdd;
}
.exhibition-list--hokkaido .exhibition-card__pref {
  background-color: #8fccdd;
  color: #fff;
}
.exhibition-list--hokkaido .exhibition-card__parking-icon {
  color: #8fccdd;
  border-color: #8fccdd;
}
.exhibition-list--hokkaido .exhibition-card__btn {
  transition: background-color 0.15s ease-out, color 0.15s ease-out, border-color 0.15s ease-out, right 0.15s ease-out;
}
@media (any-hover: hover) {
  .exhibition-list--hokkaido .exhibition-card__btn:hover {
    background-color: #8fccdd;
    color: #fff;
    border-color: #8fccdd;
  }
}
.exhibition-list--hokkaido .exhibition-card--pref {
  background-color: rgba(143, 204, 221, 0.5);
}
.exhibition-list--hokkaido .exhibition-card--pref .exhibition-card__pref-label::before {
  color: rgba(143, 204, 221, 0.2);
}
.exhibition-list--hokuriku {
  background-color: rgba(76, 160, 156, 0.2);
}
.exhibition-list--hokuriku > .exhibition-list__title {
  background-color: #4ca09c;
  color: #fff;
}
.exhibition-list--hokuriku .exhibition-card {
  border-color: #4ca09c;
}
.exhibition-list--hokuriku .exhibition-card__pref {
  background-color: #4ca09c;
  color: #fff;
}
.exhibition-list--hokuriku .exhibition-card__parking-icon {
  color: #4ca09c;
  border-color: #4ca09c;
}
.exhibition-list--hokuriku .exhibition-card__btn {
  transition: background-color 0.15s ease-out, color 0.15s ease-out, border-color 0.15s ease-out, right 0.15s ease-out;
}
@media (any-hover: hover) {
  .exhibition-list--hokuriku .exhibition-card__btn:hover {
    background-color: #4ca09c;
    color: #fff;
    border-color: #4ca09c;
  }
}
.exhibition-list--hokuriku .exhibition-card--pref {
  background-color: rgba(76, 160, 156, 0.5);
}
.exhibition-list--hokuriku .exhibition-card--pref .exhibition-card__pref-label::before {
  color: rgba(76, 160, 156, 0.2);
}
.exhibition-list--kanto {
  background-color: rgba(149, 202, 146, 0.2);
}
.exhibition-list--kanto > .exhibition-list__title {
  background-color: #95ca92;
  color: #fff;
}
.exhibition-list--kanto .exhibition-card {
  border-color: #95ca92;
}
.exhibition-list--kanto .exhibition-card__pref {
  background-color: #95ca92;
  color: #fff;
}
.exhibition-list--kanto .exhibition-card__parking-icon {
  color: #95ca92;
  border-color: #95ca92;
}
.exhibition-list--kanto .exhibition-card__btn {
  transition: background-color 0.15s ease-out, color 0.15s ease-out, border-color 0.15s ease-out, right 0.15s ease-out;
}
@media (any-hover: hover) {
  .exhibition-list--kanto .exhibition-card__btn:hover {
    background-color: #95ca92;
    color: #fff;
    border-color: #95ca92;
  }
}
.exhibition-list--kanto .exhibition-card--pref {
  background-color: rgba(149, 202, 146, 0.5);
}
.exhibition-list--kanto .exhibition-card--pref .exhibition-card__pref-label::before {
  color: rgba(149, 202, 146, 0.2);
}
.exhibition-list--tokai {
  background-color: rgba(234, 174, 86, 0.2);
}
.exhibition-list--tokai > .exhibition-list__title {
  background-color: #eaae56;
  color: #fff;
}
.exhibition-list--tokai .exhibition-card {
  border-color: #eaae56;
}
.exhibition-list--tokai .exhibition-card__pref {
  background-color: #eaae56;
  color: #fff;
}
.exhibition-list--tokai .exhibition-card__parking-icon {
  color: #eaae56;
  border-color: #eaae56;
}
.exhibition-list--tokai .exhibition-card__btn {
  transition: background-color 0.15s ease-out, color 0.15s ease-out, border-color 0.15s ease-out, right 0.15s ease-out;
}
@media (any-hover: hover) {
  .exhibition-list--tokai .exhibition-card__btn:hover {
    background-color: #eaae56;
    color: #fff;
    border-color: #eaae56;
  }
}
.exhibition-list--tokai .exhibition-card--pref {
  background-color: rgba(234, 174, 86, 0.5);
}
.exhibition-list--tokai .exhibition-card--pref .exhibition-card__pref-label::before {
  color: rgba(234, 174, 86, 0.2);
}
.exhibition-list--kansai {
  background-color: rgba(156, 139, 192, 0.2);
}
.exhibition-list--kansai > .exhibition-list__title {
  background-color: #9c8bc0;
  color: #fff;
}
.exhibition-list--kansai .exhibition-card {
  border-color: #9c8bc0;
}
.exhibition-list--kansai .exhibition-card__pref {
  background-color: #9c8bc0;
  color: #fff;
}
.exhibition-list--kansai .exhibition-card__parking-icon {
  color: #9c8bc0;
  border-color: #9c8bc0;
}
.exhibition-list--kansai .exhibition-card__btn {
  transition: background-color 0.15s ease-out, color 0.15s ease-out, border-color 0.15s ease-out, right 0.15s ease-out;
}
@media (any-hover: hover) {
  .exhibition-list--kansai .exhibition-card__btn:hover {
    background-color: #9c8bc0;
    color: #fff;
    border-color: #9c8bc0;
  }
}
.exhibition-list--kansai .exhibition-card--pref {
  background-color: rgba(156, 139, 192, 0.5);
}
.exhibition-list--kansai .exhibition-card--pref .exhibition-card__pref-label::before {
  color: rgba(156, 139, 192, 0.2);
}
.exhibition-list--chugoku-shikoku {
  background-color: rgba(199, 97, 95, 0.2);
}
.exhibition-list--chugoku-shikoku > .exhibition-list__title {
  background-color: #c7615f;
  color: #fff;
}
.exhibition-list--chugoku-shikoku .exhibition-card {
  border-color: #c7615f;
}
.exhibition-list--chugoku-shikoku .exhibition-card__pref {
  background-color: #c7615f;
  color: #fff;
}
.exhibition-list--chugoku-shikoku .exhibition-card__parking-icon {
  color: #c7615f;
  border-color: #c7615f;
}
.exhibition-list--chugoku-shikoku .exhibition-card__btn {
  transition: background-color 0.15s ease-out, color 0.15s ease-out, border-color 0.15s ease-out, right 0.15s ease-out;
}
@media (any-hover: hover) {
  .exhibition-list--chugoku-shikoku .exhibition-card__btn:hover {
    background-color: #c7615f;
    color: #fff;
    border-color: #c7615f;
  }
}
.exhibition-list--chugoku-shikoku .exhibition-card--pref {
  background-color: rgba(199, 97, 95, 0.5);
}
.exhibition-list--chugoku-shikoku .exhibition-card--pref .exhibition-card__pref-label::before {
  color: rgba(199, 97, 95, 0.2);
}
.exhibition-list--kyushu {
  background-color: rgba(92, 137, 185, 0.2);
}
.exhibition-list--kyushu > .exhibition-list__title {
  background-color: #5c89b9;
  color: #fff;
}
.exhibition-list--kyushu .exhibition-card {
  border-color: #5c89b9;
}
.exhibition-list--kyushu .exhibition-card__pref {
  background-color: #5c89b9;
  color: #fff;
}
.exhibition-list--kyushu .exhibition-card__parking-icon {
  color: #5c89b9;
  border-color: #5c89b9;
}
.exhibition-list--kyushu .exhibition-card__btn {
  transition: background-color 0.15s ease-out, color 0.15s ease-out, border-color 0.15s ease-out, right 0.15s ease-out;
}
@media (any-hover: hover) {
  .exhibition-list--kyushu .exhibition-card__btn:hover {
    background-color: #5c89b9;
    color: #fff;
    border-color: #5c89b9;
  }
}
.exhibition-list--kyushu .exhibition-card--pref {
  background-color: rgba(92, 137, 185, 0.5);
}
.exhibition-list--kyushu .exhibition-card--pref .exhibition-card__pref-label::before {
  color: rgba(92, 137, 185, 0.2);
}

/* ===============================
   Exhibition contact block
   =============================== */
.exhibition-contact {
  padding: clamp(48px, 36.368px + 3.64vw, 80px) clamp(9.6px, 7.28px + 0.73vw, 16px);
  background-color: #fff;
}
.exhibition-contact__inner {
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  max-width: 960px;
  margin: 0 auto;
  padding: clamp(28.8px, 21.824px + 2.18vw, 48px) clamp(28.8px, 21.824px + 2.18vw, 48px);
  border: 0.1em solid #7b5aa8;
  border-radius: 1.5em;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(28.8px, 21.824px + 2.18vw, 48px);
}
.exhibition-contact__image {
  flex: 0 0 auto;
}
.exhibition-contact__image img {
  display: block;
  width: 120px;
  height: auto;
}
.exhibition-contact__body {
  flex: 0 0 auto;
  text-align: center;
  color: #293436;
}
.exhibition-contact__label {
  margin: 0 0 clamp(9.6px, 7.28px + 0.73vw, 16px);
  letter-spacing: 0.12em;
  font-weight: 500;
  color: #7b5aa8;
  border-bottom: 1px solid #7b5aa8;
  display: inline-block;
  padding-bottom: 0.4em;
}
.exhibition-contact__tel {
  margin: 0 0 0.25em;
  font-size: 1.5em;
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  letter-spacing: 0.08em;
}
.exhibition-contact__tel-note {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 0.75em;
}
.exhibition-contact__time {
  font-size: 1.15em;
  color: #7b5aa8;
  margin: 0 0 0.5em;
}
.exhibition-contact__time::before {
  content: "";
  display: inline-block;
  background-color: #7b5aa8;
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Ccircle cx='32' cy='32' r='30' fill='none' stroke='%23202020' stroke-linecap='round' stroke-miterlimit='10' stroke-width='3' stroke-linejoin='round'/%3E%3Cpath fill='none' stroke='%23202020' stroke-linecap='round' stroke-miterlimit='10' stroke-width='3' d='M32 10v23l13 7' stroke-linejoin='round'/%3E%3C/svg%3E");
  mask-position: center;
  mask-repeat: no-repeat;
  mask-size: contain;
  width: 1.25em;
  aspect-ratio: 1;
  margin-right: 0.5em;
  vertical-align: middle;
  position: relative;
  top: -0.1em;
}
.exhibition-contact__mail {
  margin: 0;
  letter-spacing: 0.08em;
}

/* ===============================
   Responsive
   =============================== */
@media (max-width: 575px) {
  .exhibition-intro__nav {
    flex-direction: column;
    align-items: stretch;
  }
  .exhibition-intro__nav .exhibition-nav__btn {
    width: 100%;
  }
  .exhibition-contact__inner {
    flex-direction: column;
    text-align: center;
  }
  .exhibition-card__header {
    flex-direction: column;
    align-items: flex-start;
  }
}
@media (max-width: 595.5555555556px) {
  .exhibition-card {
    max-width: 400px;
    margin-inline: auto;
  }
}
@media (min-width: 595.5555555556px) {
  .exhibition-list .exhibition-card--pref {
    writing-mode: vertical-rl;
    text-orientation: upright;
  }
}
.store-hero__head {
  background-color: #f4f1e8;
}
.store-hero__title-block {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75em 0.5em;
  width: min(1120px, 90%);
  margin: 0 auto;
  padding: 1em 0;
  text-align: left;
}
.store-hero__eyebrow {
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: clamp(20.8px, 16px + 1.1vw, 28.8px);
  line-height: 1;
  letter-spacing: 0.05em;
}
.store-hero__title {
  margin: 0;
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: clamp(16px, 16px + 0.4vw, 18.4px);
  line-height: 1;
  letter-spacing: 0.12em;
}
.store-hero__visual {
  width: 100%;
  overflow: hidden;
  height: clamp(160px, 50vw, 480px);
}
.store-hero__visual img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
.store-reserve {
  background-color: #f7f9fc;
}
.store-reserve__inner {
  padding: 40px 0 64px;
  text-align: center;
}
.store-reserve__alert {
  color: crimson;
  margin-bottom: 2em;
}
.store-reserve__message {
  margin-bottom: 2em;
}
.store-reserve__lead {
  margin: 0 0 0.5em;
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  letter-spacing: 0.2em;
  line-height: 2;
  margin-bottom: 1em;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
.store-reserve__lead span {
  border-bottom: 0.2em dotted #755F47;
  padding: 0 0 0.2em 0.2em;
}
.store-reserve__note {
  margin: 0;
  font-size: clamp(11.2px, 10.624px + 0.18vw, 12.8px);
  color: #777;
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
}
.store-reserve__buttons {
  display: flex;
  justify-content: center;
  gap: 24px;
  flex-wrap: wrap;
}
.store-reserve__btn {
  min-width: 260px;
  padding: 14px 28px;
  font-size: clamp(16px, 16px + 0.4vw, 18.4px);
  border-radius: 0.5em;
  text-decoration: none;
  border: 1px solid #755F47;
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  letter-spacing: 0.08em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.12);
  transition: opacity 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease;
}
.store-reserve__btn:hover {
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18);
  transform: translateY(-1px);
  opacity: 0.8;
}
.store-reserve__btn--primary {
  background-color: #755F47;
  color: #fff;
}
.store-reserve__btn--outline {
  background-color: #fff;
  color: #755F47;
}
@media (max-width: 575px) {
  .store-reserve__buttons {
    gap: 12px;
  }
  .store-reserve__btn {
    width: 100%;
    min-width: 0;
  }
}

.store-detail {
  color: #293436;
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  padding: 4em 0 1em;
}
.store-detail__title {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: clamp(19.2px, 16px + 0.75vw, 24.8px);
  font-weight: 600;
  letter-spacing: 0.12em;
  line-height: 1.5;
  text-align: center;
  margin-bottom: 1.5em;
}
.store-detail__info-block {
  display: block;
}
@media (min-width: 768px) {
  .store-detail__info-block {
    display: flex;
    column-gap: 4%;
  }
}
.store-detail__info {
  display: flex;
  flex-direction: column;
  margin-bottom: 3em;
}
@media (max-width: 767px) {
  .store-detail__info {
    row-gap: 3em;
  }
}
@media (min-width: 768px) {
  .store-detail__info {
    flex: 0 0 48%;
    justify-content: space-between;
    row-gap: 1.5em;
  }
}
.store-detail__side {
  display: flex;
  flex-direction: column;
  margin-bottom: 3em;
}
@media (max-width: 767px) {
  .store-detail__side {
    row-gap: 3em;
  }
}
@media (min-width: 768px) {
  .store-detail__side {
    flex: 1 1 auto;
    justify-content: space-between;
    row-gap: 1.5em;
  }
}
@media (min-width: 768px) {
  .store-detail__route-map {
    margin-bottom: 0;
  }
}
.store-detail__route-map img {
  display: block;
  width: 100%;
  height: auto;
}
.store-detail__map {
  background-color: #f2f2f2;
}
.store-detail__map iframe {
  display: block;
  width: 100%;
  aspect-ratio: 1000/618;
  border: 0;
}
.store-detail__calendar-title {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  font-weight: 500;
  text-align: center;
  margin: 0 0 0.5em;
}
.store-detail__calendar-frame {
  background-color: #fff;
  border: 1px solid #e0e0e0;
  overflow: hidden;
}
.store-detail__calendar-frame iframe {
  display: block;
  width: 100%;
  height: 260px;
  border: 0;
}
.store-detail__calendar-note {
  margin-top: 4px;
  font-size: clamp(11.2px, 10.624px + 0.18vw, 12.8px);
}
.store-detail__photos {
  display: flex;
}
@media (max-width: 575px) {
  .store-detail__photos {
    display: block;
  }
}
.store-detail__photo--front, .store-detail__photo--factory {
  display: flex;
  flex-direction: column;
}
.store-detail__photo-inner {
  width: 100%;
  overflow: hidden;
}
.store-detail__photo-inner picture,
.store-detail__photo-inner img {
  display: block;
  width: 100%;
  height: 100%;
}
.store-detail__photo-inner img {
  object-fit: contain;
}
.store-detail__photo {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  margin-bottom: 3em;
}
.store-detail__photo-body {
  display: flex;
  align-items: stretch;
}
.store-detail__photo-body picture,
.store-detail__photo-body img {
  display: block;
  width: 100%;
  height: auto;
}
.store-detail__caption {
  margin-top: 8px;
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  text-align: center;
}
@media (min-width: 576px) {
  .store-detail.main-branch .store-detail__photos {
    column-gap: 4%;
  }
  .store-detail.main-branch .store-detail__photos .store-detail__photo--front {
    flex: 0 0 calc(96% * 480px / 1002.7329192547px);
  }
  .store-detail.main-branch .store-detail__photos .store-detail__photo--factory {
    flex: 0 0 calc(96% * 522.7329192547px / 1002.7329192547px);
  }
  .store-detail.main-branch .store-detail__photos .store-detail__photo-inner {
    height: 320px;
  }
}
.store-detail.asakusa-branch .store-detail__side {
  justify-content: flex-start;
  row-gap: 3em;
}

.store-info-table {
  width: 100%;
  border-collapse: collapse;
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
}
.store-info-table th,
.store-info-table td {
  border: 1px solid #ddd;
}
.store-info-table th {
  padding: 1em;
  vertical-align: top;
  text-align: left;
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-weight: 600;
  white-space: nowrap;
}
.store-info-table td {
  padding: 1em;
}
.store-info-table__map-link {
  display: inline-block;
  margin-left: 4px;
  vertical-align: text-bottom;
}
.store-info-table__map-link img {
  width: 3em;
  height: auto;
}

.for-customers {
  padding: 56px 0 72px;
}
.for-customers__message-card {
  font-size: clamp(0.7em, 0.591em + 0.55vw, 1em);
  padding: 1.5em;
  margin-bottom: 4em;
  background-color: #fff;
  border-radius: 2em;
  box-shadow: 0 0.5em 2em rgba(0, 0, 0, 0.1);
  position: relative;
}
.for-customers__message {
  text-align: center;
  line-height: 3;
  padding: clamp(3em, 2.273em + 3.64vw, 5em) 1.5em;
  border: 1px solid rgba(194, 161, 108, 0.6);
}
.for-customers__message p {
  position: relative;
  z-index: 1;
}
.for-customers__message p .sign {
  display: inline-block;
  width: 12em;
  margin: 2.5em 0 0;
}
.for-customers__message__frame01, .for-customers__message__frame02 {
  width: 100%;
  height: 50%;
  position: absolute;
}
.for-customers__message__frame01::before, .for-customers__message__frame01::after, .for-customers__message__frame02::before, .for-customers__message__frame02::after {
  content: "";
  background-color: white;
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20data-name%3D%22%E5%88%9D%E3%82%81%E3%81%BE%E3%81%97%E3%81%A6%22%20viewBox%3D%220%200%2063.95%2069.91%22%3E%3Cpath%20d%3D%22M5.82%2050.15c1.45-5.05%202.96-10.09%205.36-14.8.83-1.64%201.8-3.2%202.98-4.6%201.46-1.73%203.35-2.74%205.63-2.89%201.19-.08%202.17.22%202.83%201.38.9%201.57%202.15%202.79%204.01%203.19.66.14%201.24.46%201.57%201.1.05.1.15.2.31.09-1.71-4.34-5.01-6.12-9.5-6.02.2-.18.46-.28.74-.37%201.4-.45%202.84-.63%204.29-.78%202.14-.23%204.24-.35%206.06%201.2.7.6%201.62.92%202.56.92%201.58%200%203.11.1%204.41%201.19-.93-1.62-2.23-2.82-3.84-3.67-.83-.43-1.77-.81-2.67-.6-1.89.45-3.78.62-5.7.54-.3-.01-.58.08-.86.14-.25.05-.53.01-.8.01%201.87-.37%203.39-1.26%204.55-2.73.35-.44.65-.92%201.17-1.19.09-.05.23-.13.09-.28-.09-.1-.19-.13-.32-.06-.39.2-.81.32-1.25.39-1.66.25-3.04%201.08-4.1%202.34-.57.68-1.2%201.21-1.99%201.55-2.14.91-4.32%201.75-6.3%203.23.05-.57.43-.75.64-1.05%201.72-2.37%203.56-4.64%205.64-6.7%201.13-1.11%202.15-2.34%203.46-3.24%201.95-1.33%204.09-2.23%206.44-2.57%201.85-.27%203.13.33%203.95%202.09a7.01%207.01%200%200%200%202.16%202.65c1%20.75%202.11%201.37%202.64%202.71.36-2.8-2.54-6.05-6.71-7.68%201.59-.51%203.05-.07%204.43.79.29.18.6.33.91.47%201.34.6%202.73.85%204.21.79.89-.04%201.82-.18%202.67.29.14.08.33.25.43.01.11-.26-.19-.25-.33-.32-.86-.4-1.66-.91-2.44-1.45-1.56-1.09-3.33-1.78-5.22-1.48-1.5.24-3%20.4-4.51.52-1.47.12-2.9.32-4.31.74-.84.25-1.6.72-2.48.84%201.71-1.18%203.43-2.33%205.17-3.44%202.65-1.69%205.4-3.18%208.41-4.13%202.35-.74%204.54-.81%206.31%201.43.87%201.11%202.25%201.48%203.61%201.75.59.11%201.21.21%201.56.77.08.12.09.33.27.24.21-.11.05-.29-.02-.4-.79-1.19-1.64-2.34-2.83-3.17-1.42-.98-3.05-1.26-4.72-1.33-.78-.03-1.55%200-2.33%200%202.47-.98%204.93-1.94%207.54-2.39%201.15-.2%202.29-.44%203.45-.58%201.47-.18%202.87.18%204.21.75.92.39%201.84.5%202.83.44%201.12-.07%202.22-.42%203.36-.31.2.02.35-.07.48-.25-1.27-.43-2.47-.92-3.66-1.48-.77-.36-1.66-.62-2.48-.47-1.79.34-3.53.9-5.35%201.11-1.34.15-2.67.43-4.11.66.83-.45%201.58-.83%202.3-1.26.75-.45%201.28-1.15%201.91-1.74.43-.4.74-.95%201.38-1.05.13-.02.19-.12.14-.2-.05-.1-.2-.24-.26-.22-.74.22-1.59.07-2.24.54-.82.58-1.53%201.28-2.09%202.15-.64.97-1.52%201.67-2.64%202.1-2.86%201.08-5.74%202.09-8.53%203.35-.79.36-1.59.66-2.39.99.99-1.03%201.68-2.28%202.85-3.1%201.77-1.23%202.86-2.9%203.17-5.08.1-.73.28-1.49.85-2.06.13-.13.26-.25.05-.43-.18-.15-.25.05-.35.12-1.07.81-1.98%201.8-2.9%202.78-.95%201.01-1.63%202.23-1.81%203.6-.23%201.84-1.33%203.02-2.62%204.16-1.33%201.18-2.85%202.06-4.35%202.99-1.33.82-2.65%201.67-3.97%202.51.98-1.61%201.84-3.28%202.95-4.78%201.1-1.47%201.87-3.03%201.89-4.96.01-1.28.12-2.59.52-3.84.09-.29.37-.66.09-1.01-.16-.02-.18.08-.22.17-.38%201.04-1.04%201.92-1.69%202.8-.56.76-1.28%201.41-1.66%202.31-.64%201.53-.85%203.12-.8%204.76.07%202.05-.86%203.71-2.13%205.17-.93%201.06-1.99%202.01-3.01%202.98-1.56%201.49-3.1%203-4.47%204.67-1.83%202.23-3.61%204.51-5.13%206.98-.33.54-.71%201.04-1.06%201.56.11-.59.29-1.14.5-1.68%201.09-2.85%201.61-5.87%202.53-8.76.41-1.3%201.02-2.45%202.37-3.1.73-.36%201.32-.99%201.83-1.68.77-1.05%201.3-2.23%202.04-3.3.17-.24.26-.55.65-.52.18.02.29-.07.21-.27-.05-.12-.14-.14-.29-.08-2.17.72-4.08%201.73-5.06%204.01-.53%201.22-.92%202.53-1.84%203.56-.09-.14-.05-.28-.01-.41.33-1.18.5-2.38.71-3.58.29-1.7.35-3.45%201.04-5.07.28-.68.5-1.38.59-2.1.31-2.38-.48-4.46-1.87-6.34-.39-.53-.92-.95-1.39-1.42-.06.05-.12.1-.17.15%201%201.29%201.04%202.72.77%204.24-.32%201.8-.17%203.54.55%205.26.38.92.59%201.93.46%202.95-.18%201.36-.39%202.71-.57%204.07-.05.37-.11.72-.35%201.07-.2-.36-.12-.69-.19-1-.41-1.99-1.27-3.83-1.94-5.73-.82-2.31-3.73-4.27-6.21-4.3.91.72%201.4%201.63%201.91%202.55.76%201.37%201.73%202.57%203.2%203.3.7.35%201.43.81%201.79%201.58%201.11%202.35%201.52%204.82.98%207.37-.62%202.96-1.45%205.87-2.48%208.71-.34.93-.71%201.86-1.29%202.83-.11-.96.09-1.75%200-2.57-.15-1.27-.29-2.53-.58-3.77-.44-1.9-1.16-3.71-1.14-5.73.01-1.31-.61-2.54-1.58-3.53-1.06-1.08-2.46-1.58-3.76-2.23-.44-.22-.91-.49-1.47-.47.03.11.03.17.06.2%201.7%201.23%202.67%202.93%203.29%204.91.34%201.06.92%202.03%201.88%202.72.77.55%201.49%201.16%201.79%202.16.3%201.01.59%202.01.79%203.04.39%202.01.6%204.04.12%206.07-.73%203.13-2.12%206.03-3.14%209.07-.04-1%200-1.99-.05-2.98-.13-2.34-.64-4.63-.6-6.99.04-2.59-1.27-4.61-3.16-6.24-.43-.37-.91-.82-1.58-.87%201.32%201.27%201.71%202.85%201.81%204.6.09%201.48.58%202.85%201.66%203.96.71.73%201.2%201.64%201.26%202.65.14%202.26.55%204.52.18%206.79-.24%201.46-.46%202.91-1.03%204.3.09-1.47-.18-2.91-.29-4.36-.22-2.87-1.69-4.78-4.69-5.53-.12-.03-.26-.22-.36%200-.07.16.08.25.2.35.66.54%201.09%201.24%201.45%202.01.53%201.14%201.19%202.19%202.11%203.07.49.47.95%201.04%201.08%201.73.31%201.66.25%203.34-.05%205-.32%201.76-.66%203.51-.95%205.27-.35%202.12-.65%204.25-.96%206.38-.24%201.62-.46%203.25-.67%204.88-.03.19-.08.43.18.69.36-1.48.53-2.9.69-4.32.31-2.73.92-5.35%202.41-7.69.75-1.19%201.39-2.5%203.02-2.76%201.68-.27%203.13-.97%204.32-2.27.51-.56%201.22-1.07%202.23-.62-.2-.37-.41-.44-.65-.48-.5-.09-1-.21-1.5-.27-1.93-.21-3.62.2-4.76%201.94-1.51%202.28-3.26%204.41-4.29%207%20.15-1.19.41-2.35.57-3.53.38-2.86%201.04-5.63%202.54-8.13%201.05-1.74%202.22-3.32%204.25-4.08%202-.75%203.82-.94%205.42.86.59.67%201.47.98%202.33%201.11%201.17.17%202.22.51%203.11%201.4.17-.6-.36-.77-.56-1.09-.87-1.39-1.89-2.75-3.58-3.08-2.12-.42-4.27-.28-6.35.41-.27.09-.55.18-.82.28.98-.9%202.11-1.53%203.29-2.04%201.9-.83%203.83-1.58%205.99-1.38%201.04.1%202.01-.11%202.93-.7.76-.48%201.48-1.06%202.42-1.29-.44-.46-.96-.36-1.42-.37-1.46-.02-2.9.23-4.11%201.07-.76.52-1.52.93-2.4%201.17-2.08.56-4.05%201.37-5.88%202.53-.42.27-.78.67-1.43.84.34-.42.58-.73.82-1.04.68-.88%201.36-1.72%202.4-2.23.47-.23.92-.53%201.31-.92%201.3-1.32%201.98-3.06%203.15-4.46-.34-.23-.54%200-.74.1-.48.24-.93.56-1.42.78-1.96.88-3.09%202.47-3.82%204.42-.24.64-.44%201.28-.88%201.84-.94%201.18-1.79%202.44-2.75%203.61-.94%201.15-1.7%202.41-2.36%203.78-.05-.08-.08-.11-.07-.12Z%22%20style%3D%22fill%3A%23c2a16c%3Bopacity%3A.6%22%2F%3E%3C%2Fsvg%3E");
  background-position: center;
  background-repeat: no-repeat;
  background-size: 90%;
  display: block;
  width: 5em;
  aspect-ratio: 64/70;
}
.for-customers__message__frame01::before, .for-customers__message__frame02::before {
  position: absolute;
  top: 0.8em;
  left: 1.1em;
}
.for-customers__message__frame01::after, .for-customers__message__frame02::after {
  position: absolute;
  top: 0.8em;
  right: 1.1em;
  transform: scaleX(-1);
}
.for-customers__message__frame01 span, .for-customers__message__frame02 span {
  display: block;
  background-color: white;
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20data-name%3D%22%E5%88%9D%E3%82%81%E3%81%BE%E3%81%97%E3%81%A6%22%20viewBox%3D%220%200%2074.02%2011.06%22%3E%3Cpath%20d%3D%22M71.68%204.87c-.88-.26-1.74-.21-2.61.05-.42.13-.83.3-1.29.3-1.34%200-2.68-.01-4.03%200%20.18-.05.36-.09.54-.15.26-.09.47-.25.76-.29%201.3-.16%202.54-.54%203.68-1.2.44-.26.87-.54%201.31-.81-.02-.04-.03-.08-.05-.12-1.05-.02-2.09.03-3.07.51-.64.31-1.15.81-1.75%201.16-1.12.65-2.37.87-3.67.86-1.09-.01-2.19-.03-3.38.1.66-.4%201.24-.67%201.91-.75%201.23-.16%202.21-.73%202.94-1.8.42-.6.9-1.2%201.54-1.61.1-.06.29-.13.22-.28-.07-.15-.25-.07-.38-.03-.69.2-1.37.39-2.06.6-.36.11-.67.3-.96.56-.56.5-1.02%201.09-1.46%201.69-.14.19-.26.44-.45.55-.6.33-1.17.73-1.87.82-.55.07-1.07.29-1.62.31-1.64.05-3.29-.13-4.93.11.06-.04.16-.09.15-.11-.04-.18-.22-.02-.31-.13.3.05.58-.03.85-.13.73-.27%201.44-.6%202.24-.7%201.33-.15%202.19-.92%202.75-2.12.34-.73.75-1.42%201.34-1.99.07-.06.19-.13.1-.25-.07-.09-.15%200-.23.03-.58.25-1.15.5-1.74.73-1.36.51-2.1%201.63-2.81%202.8-.1.17-.18.4-.33.5-.85.54-1.71%201.06-2.76%201.08-.52.01-1.03.04-1.55.06-.95.05-1.91.01-2.88.01%201.05-.42%202.09-.77%203.16-1%20.51-.11.92-.38%201.25-.78.54-.65%201.06-1.32%201.58-1.98.06-.08.2-.18.07-.35-.49.25-.99.45-1.51.59-.96.25-1.68.81-2.27%201.59-.42.56-.87%201.09-1.55%201.38-.57.24-1.17.4-1.77.48-1.79.24-3.6.1-5.4.26.7-.12%201.44-.13%202.06-.51.66-.4%201.36-.57%202.11-.64.56-.06.99-.33%201.33-.78.62-.83%201.05-1.78%201.6-2.65.04-.06.05-.13-.05-.22-.64.35-1.29.72-1.94%201.07-.88.47-1.49%201.19-1.96%202.06-.07.13-.12.31-.23.35-.58.23-1.05.68-1.68.82-2.09.46-4.18.41-6.26.04-1-.18-1.83-.66-2.38-1.59-.42-.71-.96-1.33-1.72-1.71-.65-.33-1.31-.66-1.96-.98-.08-.04-.17-.13-.32%200%20.75.72%201.15%201.68%201.74%202.52.48.7%201.11%201.14%201.97%201.25.37.04.76.06%201.08.21.35.16.68.35%201.06.43.37.07.72.21%201.1.24-1.89.04-3.79.08-5.64-.35-.88-.21-1.77-.43-2.31-1.31-.57-.93-1.36-1.62-2.44-1.93-.41-.12-.81-.3-1.19-.48-.12-.06-.24-.17-.42-.08.45.79.95%201.54%201.51%202.25.46.59%201.08.86%201.79%201.02.51.12%201.05.13%201.54.33.63.25%201.25.48%201.76.45-1.17%200-2.51.02-3.85%200-.63-.01-1.26%200-1.88-.15-1.23-.29-2.36-.72-2.92-2-.04-.1-.14-.19-.19-.29-.81-1.63-2.5-1.96-3.92-2.69.43.76.92%201.46%201.28%202.24.59%201.26%201.65%201.92%202.92%202.16%201.08.21%202.02.87%203.15.85-.94-.01-1.87%200-2.79-.02-1.37-.03-2.75-.02-4.11-.26-1.07-.19-1.99-.65-2.62-1.61-.5-.76-1.11-1.43-1.96-1.82-.73-.33-1.51-.54-2.27-.78-.09-.03-.2-.05-.27.05.01.14.14.17.22.24.6.51%201.19%201.04%201.62%201.72.26.41.59.7%201.01.89.56.26%201.14.46%201.74.59.18.04.37.07.52.19.52.41%201.13.6%201.76.78-.11%200-.2.01-.29%200-1.44-.26-2.9-.26-4.36-.34-1.03-.05-2.04-.27-2.88-.87a7.966%207.966%200%200%200-2.9-1.33c-.61-.15-1.25-.09-1.88.05%201%20.59%201.94%201.27%203.13%201.43.94.13%201.89.24%202.75.8-1.12%200-2.21-.06-3.29.02-.74.06-1.45%200-2.16-.13a4.59%204.59%200%200%200-2.24.09c-.75.22-1.5.46-2.28.6-.19.04-.43-.01-.58.24.41.24.87.23%201.29.31.7.14%201.39.4%202.1.35.84-.06%201.66-.31%202.41-.7.62-.32%201.27-.5%201.97-.48%201%20.02%202.01-.01%203.01.02.33.01.59-.2.91-.17.7.06%201.39.12%202.06.18-.4.04-.84-.03-1.28.05-.91.18-1.77.58-2.71.62-.91.04-1.65.41-2.33.96-.23.19-.46.4-.72.54-.5.26-.81.7-1.21%201.09.08.03.12.06.15.06C7.26%208.54%208.73%208%209.99%206.97c.88-.72%201.84-1.21%202.98-1.26%201.31-.05%202.63-.18%203.95-.11.96.05%201.92.01%202.98.01-.41.07-.72.02-1.04.08-1.02.18-1.93.69-2.95.86-.93.16-1.68.7-2.3%201.42-.4.47-.75.98-1.06%201.51-.18.3-.5.5-.57.9.07%200%20.12%200%20.15-.01.71-.39%201.44-.77%202.13-1.2.88-.54%201.74-1.11%202.39-1.94.19-.25.38-.52.68-.7.95-.56%201.99-.73%203.05-.73.98%200%201.96-.01%202.94-.02-1%20.22-1.88.69-2.74%201.17-1.43.8-2.04%202.34-2.82%203.7%201.67-.59%202.98-1.62%203.81-3.18.52-.99%201.37-1.34%202.36-1.56.21-.05.44-.03.7-.13%201.67-.02%203.34-.04%205-.07.33%200%20.66%200%20.97-.12.17-.07.35-.09.48.1-.11.12-.24.12-.37.14-.56.06-1.09.23-1.58.51-.34.19-.7.34-1.07.41-.79.16-1.41.58-1.96%201.16-.72.75-1.26%201.63-1.88%202.46-.13.17-.3.33-.36.64.36-.19.64-.37.94-.47%201.48-.53%202.58-1.52%203.35-2.88.47-.82%201.23-1.25%202.09-1.47%201.48-.38%203-.46%204.62-.41-.52.16-.95.26-1.3.56-.44.39-.94.7-1.47.95-.37.18-.72.41-.98.75-.64.84-1.07%201.8-1.49%202.76-.02.05%200%20.11%200%20.21.91-.38%201.68-.9%202.31-1.63.46-.54.72-1.19%201.03-1.82.66-1.36%201.96-1.75%203.32-1.83.85-.05%201.71-.05%202.57-.03.2%200%20.4%200%20.6.01.38.15.76.3%201.15.45.64.24%201.04.69%201.23%201.33.3.99.87%201.81%201.71%202.41.46.34.95.64%201.56.75-.39-.78-.74-1.52-1.12-2.24-.38-.72-.88-1.31-1.72-1.5-.25-.06-.42-.23-.6-.39-.48-.43-1.03-.69-1.63-.79%201.23.03%202.46.11%203.68.32%201.33.23%202.48.72%203.09%202.06.28.62.78%201.06%201.29%201.48.73.6%201.64.86%202.48%201.26.07.03.15.07.2%200%20.09-.12-.04-.18-.1-.24-.54-.62-.99-1.3-1.42-2-.65-1.04-1.47-1.87-2.76-2.07-.21-.03-.43%200-.63-.11-.66-.35-1.32-.68-2.1-.65%201.77.16%203.52-.14%205.29%200%201.09.08%202.11.34%203.07.87.28.16.51.35.66.65.81%201.72%202.2%202.79%203.9%203.52.13.05.25.13.42%200-.67-.84-1.28-1.68-1.86-2.55-.32-.48-.68-.98-1.24-1.16-1.14-.38-2.12-1.14-3.34-1.34%201.01.04%202.01.12%203.01.1%201.13-.02%202.17.3%203.22.65.32.11.57.31.81.55.57.57%201.03%201.24%201.67%201.74.89.68%201.97%201.05%202.89%201.67.05.03.11.04.17-.07-.17-.28-.33-.6-.53-.89-.95-1.35-2.08-2.54-3.72-2.97-1.12-.29-2.2-.8-3.36-.91.31%200%20.63-.02.95-.01.26%200%20.5-.18.76-.05.3.15.61.14.93.12%201.03-.06%202.06-.05%203.09-.09.41-.02.81-.05%201.22-.08.01.02.02.03.02.03l.17.03c.96.18%201.9.43%202.63%201.13.64.61%201.39%201.04%202.21%201.37.74.3%201.51.25%202.4.35-.17-.19-.25-.29-.34-.37-.81-.66-1.66-1.27-2.54-1.84-.17-.11-.36-.17-.56-.19-.96-.05-1.9-.18-2.82-.46-.02%200-.03%200-.05-.01.15.02.3.03.45.01%201.03-.1%202.06-.06%203.09-.08.62-.01%201.23.04%201.82.23%201.1.36%202.22.56%203.37.46.82-.07%201.62-.29%202.38-.71-.78-.21-1.57-.4-2.35-.63Z%22%20style%3D%22fill%3A%23c2a16c%3Bopacity%3A.6%22%2F%3E%3C%2Fsvg%3E");
  background-position: center;
  background-repeat: no-repeat;
  background-size: 90%;
  width: 7.4em;
  aspect-ratio: 74/11;
  position: absolute;
  top: 0.95em;
  left: 50%;
  transform: translateX(-50%);
}
.for-customers__message__frame01 {
  top: 0;
  right: 0;
  left: 0;
}
.for-customers__message__frame02 {
  right: 0;
  bottom: 0;
  left: 0;
  transform: rotate(180deg);
}
.for-customers__links {
  display: grid;
  gap: 24px;
}
@media (min-width: 768px) {
  .for-customers__links {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.for-customers__link {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2em 1em;
  border-radius: 1em;
  color: #fff;
  text-decoration: none;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.for-customers__link::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgb(136.3571428571, 106.6964285714, 176.8035714286), #7b5aa8);
  opacity: 0.5;
  transition: opacity 0.25s ease;
}
.for-customers__link-label {
  position: relative;
  font-size: clamp(16px, 16px + 0.4vw, 18.4px);
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-weight: 600;
  text-align: center;
  transition: transform 0.25s ease;
}
.for-customers__link--craft {
  background-image: url("../img/for-customers/for-customers-links_01.jpg");
}
.for-customers__link--basic {
  background-image: url("../img/for-customers/for-customers-links_02.jpg");
}
.for-customers__link--story {
  background-image: url("../img/for-customers/for-customers-links_03.jpg");
}
.for-customers__link:hover, .for-customers__link:focus-visible {
  transform: translateY(-4px);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.16);
}
.for-customers__link:hover::before, .for-customers__link:focus-visible::before {
  opacity: 0.3;
}
.for-customers__link:hover-label, .for-customers__link:focus-visible-label {
  transform: translateY(-1px);
}

.for-customers-breather {
  width: 100%;
  height: clamp(10em, 6.364em + 18.18vw, 20em);
}
.for-customers-breather img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 100% 85%;
}

.for-customers-stores {
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
  background-color: #f6f2fb;
}
.for-customers-stores__inner {
  text-align: center;
}
.for-customers-stores__head {
  margin-bottom: clamp(28.8px, 21.824px + 2.18vw, 48px);
}
.for-customers-stores__title {
  font-size: clamp(23.2px, 16px + 1.6vw, 33.6px);
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-weight: 500;
  line-height: 1.5;
  color: #7b5aa8;
  margin-bottom: 0.75em;
}
.for-customers-stores__lead {
  margin: 0;
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  line-height: 2;
}
.for-customers-stores__cards {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 1.5em;
}
.for-customers-stores__card {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 160px;
  text-decoration: none;
  color: inherit;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.for-customers-stores__card:hover {
  transform: translateY(-3px);
}
.for-customers-stores__card-figure {
  margin: 0 0 12px;
  width: 100%;
}
.for-customers-stores__card-figure picture,
.for-customers-stores__card-figure img {
  display: block;
  width: 100%;
  max-width: 220px;
  height: auto;
  border-radius: 12px;
}
.for-customers-stores__card-label {
  margin: 0;
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-weight: 600;
}

.for-customers-support {
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
}
.for-customers-support__inner {
  text-align: center;
}
.for-customers-support__head {
  margin-bottom: clamp(28.8px, 21.824px + 2.18vw, 48px);
}
.for-customers-support__title {
  font-size: clamp(23.2px, 16px + 1.6vw, 33.6px);
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-weight: 500;
  line-height: 1.5;
  color: #7b5aa8;
  margin-bottom: 0.75em;
}
.for-customers-support__lead {
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  line-height: 2;
}
.for-customers-support__links {
  margin-top: 40px;
  display: grid;
  gap: 16px;
}
@media (min-width: 768px) {
  .for-customers-support__links {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.for-customers-support__link {
  color: #fff;
  font-weight: 600;
}
.for-customers-support__link--order {
  background-color: #9b87c8;
}
.for-customers-support__link--qa {
  background-color: #e9a6c2;
}
.for-customers-support__link--voice {
  background-color: #e4c26c;
}
.for-customers-support__link:hover, .for-customers-support__link:focus-visible {
  transform: translateY(-4px);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.16);
}

.for-users {
  background-color: #f7f4fb;
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
}
.for-users__inner {
  max-width: 960px;
  margin: 0 auto;
}
.for-users__message-card {
  font-size: clamp(0.7em, 0.591em + 0.55vw, 1em);
  padding: 1.5em;
  margin-bottom: 4em;
  background-color: #fff;
  border-radius: 2em;
  box-shadow: 0 0.5em 2em rgba(0, 0, 0, 0.1);
  position: relative;
}
.for-users__message {
  text-align: center;
  line-height: 3;
  padding: clamp(3em, 2.273em + 3.64vw, 5em) 1.5em;
  border: 1px solid rgba(123, 90, 168, 0.3);
}
.for-users__message p {
  letter-spacing: 0.075em;
  position: relative;
  z-index: 1;
}
.for-users__message p .sign {
  display: inline-block;
  width: 12em;
  margin: 2.5em 0 0;
}
.for-users__message__frame01, .for-users__message__frame02 {
  width: 100%;
  height: 50%;
  position: absolute;
}
.for-users__message__frame01::before, .for-users__message__frame01::after, .for-users__message__frame02::before, .for-users__message__frame02::after {
  content: "";
  background-color: #fff;
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20data-name%3D%22%E5%88%9D%E3%82%81%E3%81%BE%E3%81%97%E3%81%A6%22%20viewBox%3D%220%200%2063.95%2069.91%22%3E%3Cpath%20d%3D%22M5.82%2050.15c1.45-5.05%202.96-10.09%205.36-14.8.83-1.64%201.8-3.2%202.98-4.6%201.46-1.73%203.35-2.74%205.63-2.89%201.19-.08%202.17.22%202.83%201.38.9%201.57%202.15%202.79%204.01%203.19.66.14%201.24.46%201.57%201.1.05.1.15.2.31.09-1.71-4.34-5.01-6.12-9.5-6.02.2-.18.46-.28.74-.37%201.4-.45%202.84-.63%204.29-.78%202.14-.23%204.24-.35%206.06%201.2.7.6%201.62.92%202.56.92%201.58%200%203.11.1%204.41%201.19-.93-1.62-2.23-2.82-3.84-3.67-.83-.43-1.77-.81-2.67-.6-1.89.45-3.78.62-5.7.54-.3-.01-.58.08-.86.14-.25.05-.53.01-.8.01%201.87-.37%203.39-1.26%204.55-2.73.35-.44.65-.92%201.17-1.19.09-.05.23-.13.09-.28-.09-.1-.19-.13-.32-.06-.39.2-.81.32-1.25.39-1.66.25-3.04%201.08-4.1%202.34-.57.68-1.2%201.21-1.99%201.55-2.14.91-4.32%201.75-6.3%203.23.05-.57.43-.75.64-1.05%201.72-2.37%203.56-4.64%205.64-6.7%201.13-1.11%202.15-2.34%203.46-3.24%201.95-1.33%204.09-2.23%206.44-2.57%201.85-.27%203.13.33%203.95%202.09a7.01%207.01%200%200%200%202.16%202.65c1%20.75%202.11%201.37%202.64%202.71.36-2.8-2.54-6.05-6.71-7.68%201.59-.51%203.05-.07%204.43.79.29.18.6.33.91.47%201.34.6%202.73.85%204.21.79.89-.04%201.82-.18%202.67.29.14.08.33.25.43.01.11-.26-.19-.25-.33-.32-.86-.4-1.66-.91-2.44-1.45-1.56-1.09-3.33-1.78-5.22-1.48-1.5.24-3%20.4-4.51.52-1.47.12-2.9.32-4.31.74-.84.25-1.6.72-2.48.84%201.71-1.18%203.43-2.33%205.17-3.44%202.65-1.69%205.4-3.18%208.41-4.13%202.35-.74%204.54-.81%206.31%201.43.87%201.11%202.25%201.48%203.61%201.75.59.11%201.21.21%201.56.77.08.12.09.33.27.24.21-.11.05-.29-.02-.4-.79-1.19-1.64-2.34-2.83-3.17-1.42-.98-3.05-1.26-4.72-1.33-.78-.03-1.55%200-2.33%200%202.47-.98%204.93-1.94%207.54-2.39%201.15-.2%202.29-.44%203.45-.58%201.47-.18%202.87.18%204.21.75.92.39%201.84.5%202.83.44%201.12-.07%202.22-.42%203.36-.31.2.02.35-.07.48-.25-1.27-.43-2.47-.92-3.66-1.48-.77-.36-1.66-.62-2.48-.47-1.79.34-3.53.9-5.35%201.11-1.34.15-2.67.43-4.11.66.83-.45%201.58-.83%202.3-1.26.75-.45%201.28-1.15%201.91-1.74.43-.4.74-.95%201.38-1.05.13-.02.19-.12.14-.2-.05-.1-.2-.24-.26-.22-.74.22-1.59.07-2.24.54-.82.58-1.53%201.28-2.09%202.15-.64.97-1.52%201.67-2.64%202.1-2.86%201.08-5.74%202.09-8.53%203.35-.79.36-1.59.66-2.39.99.99-1.03%201.68-2.28%202.85-3.1%201.77-1.23%202.86-2.9%203.17-5.08.1-.73.28-1.49.85-2.06.13-.13.26-.25.05-.43-.18-.15-.25.05-.35.12-1.07.81-1.98%201.8-2.9%202.78-.95%201.01-1.63%202.23-1.81%203.6-.23%201.84-1.33%203.02-2.62%204.16-1.33%201.18-2.85%202.06-4.35%202.99-1.33.82-2.65%201.67-3.97%202.51.98-1.61%201.84-3.28%202.95-4.78%201.1-1.47%201.87-3.03%201.89-4.96.01-1.28.12-2.59.52-3.84.09-.29.37-.66.09-1.01-.16-.02-.18.08-.22.17-.38%201.04-1.04%201.92-1.69%202.8-.56.76-1.28%201.41-1.66%202.31-.64%201.53-.85%203.12-.8%204.76.07%202.05-.86%203.71-2.13%205.17-.93%201.06-1.99%202.01-3.01%202.98-1.56%201.49-3.1%203-4.47%204.67-1.83%202.23-3.61%204.51-5.13%206.98-.33.54-.71%201.04-1.06%201.56.11-.59.29-1.14.5-1.68%201.09-2.85%201.61-5.87%202.53-8.76.41-1.3%201.02-2.45%202.37-3.1.73-.36%201.32-.99%201.83-1.68.77-1.05%201.3-2.23%202.04-3.3.17-.24.26-.55.65-.52.18.02.29-.07.21-.27-.05-.12-.14-.14-.29-.08-2.17.72-4.08%201.73-5.06%204.01-.53%201.22-.92%202.53-1.84%203.56-.09-.14-.05-.28-.01-.41.33-1.18.5-2.38.71-3.58.29-1.7.35-3.45%201.04-5.07.28-.68.5-1.38.59-2.1.31-2.38-.48-4.46-1.87-6.34-.39-.53-.92-.95-1.39-1.42-.06.05-.12.1-.17.15%201%201.29%201.04%202.72.77%204.24-.32%201.8-.17%203.54.55%205.26.38.92.59%201.93.46%202.95-.18%201.36-.39%202.71-.57%204.07-.05.37-.11.72-.35%201.07-.2-.36-.12-.69-.19-1-.41-1.99-1.27-3.83-1.94-5.73-.82-2.31-3.73-4.27-6.21-4.3.91.72%201.4%201.63%201.91%202.55.76%201.37%201.73%202.57%203.2%203.3.7.35%201.43.81%201.79%201.58%201.11%202.35%201.52%204.82.98%207.37-.62%202.96-1.45%205.87-2.48%208.71-.34.93-.71%201.86-1.29%202.83-.11-.96.09-1.75%200-2.57-.15-1.27-.29-2.53-.58-3.77-.44-1.9-1.16-3.71-1.14-5.73.01-1.31-.61-2.54-1.58-3.53-1.06-1.08-2.46-1.58-3.76-2.23-.44-.22-.91-.49-1.47-.47.03.11.03.17.06.2%201.7%201.23%202.67%202.93%203.29%204.91.34%201.06.92%202.03%201.88%202.72.77.55%201.49%201.16%201.79%202.16.3%201.01.59%202.01.79%203.04.39%202.01.6%204.04.12%206.07-.73%203.13-2.12%206.03-3.14%209.07-.04-1%200-1.99-.05-2.98-.13-2.34-.64-4.63-.6-6.99.04-2.59-1.27-4.61-3.16-6.24-.43-.37-.91-.82-1.58-.87%201.32%201.27%201.71%202.85%201.81%204.6.09%201.48.58%202.85%201.66%203.96.71.73%201.2%201.64%201.26%202.65.14%202.26.55%204.52.18%206.79-.24%201.46-.46%202.91-1.03%204.3.09-1.47-.18-2.91-.29-4.36-.22-2.87-1.69-4.78-4.69-5.53-.12-.03-.26-.22-.36%200-.07.16.08.25.2.35.66.54%201.09%201.24%201.45%202.01.53%201.14%201.19%202.19%202.11%203.07.49.47.95%201.04%201.08%201.73.31%201.66.25%203.34-.05%205-.32%201.76-.66%203.51-.95%205.27-.35%202.12-.65%204.25-.96%206.38-.24%201.62-.46%203.25-.67%204.88-.03.19-.08.43.18.69.36-1.48.53-2.9.69-4.32.31-2.73.92-5.35%202.41-7.69.75-1.19%201.39-2.5%203.02-2.76%201.68-.27%203.13-.97%204.32-2.27.51-.56%201.22-1.07%202.23-.62-.2-.37-.41-.44-.65-.48-.5-.09-1-.21-1.5-.27-1.93-.21-3.62.2-4.76%201.94-1.51%202.28-3.26%204.41-4.29%207%20.15-1.19.41-2.35.57-3.53.38-2.86%201.04-5.63%202.54-8.13%201.05-1.74%202.22-3.32%204.25-4.08%202-.75%203.82-.94%205.42.86.59.67%201.47.98%202.33%201.11%201.17.17%202.22.51%203.11%201.4.17-.6-.36-.77-.56-1.09-.87-1.39-1.89-2.75-3.58-3.08-2.12-.42-4.27-.28-6.35.41-.27.09-.55.18-.82.28.98-.9%202.11-1.53%203.29-2.04%201.9-.83%203.83-1.58%205.99-1.38%201.04.1%202.01-.11%202.93-.7.76-.48%201.48-1.06%202.42-1.29-.44-.46-.96-.36-1.42-.37-1.46-.02-2.9.23-4.11%201.07-.76.52-1.52.93-2.4%201.17-2.08.56-4.05%201.37-5.88%202.53-.42.27-.78.67-1.43.84.34-.42.58-.73.82-1.04.68-.88%201.36-1.72%202.4-2.23.47-.23.92-.53%201.31-.92%201.3-1.32%201.98-3.06%203.15-4.46-.34-.23-.54%200-.74.1-.48.24-.93.56-1.42.78-1.96.88-3.09%202.47-3.82%204.42-.24.64-.44%201.28-.88%201.84-.94%201.18-1.79%202.44-2.75%203.61-.94%201.15-1.7%202.41-2.36%203.78-.05-.08-.08-.11-.07-.12Z%22%20style%3D%22fill%3A%237b5aa8%3Bopacity%3A.6%22%2F%3E%3C%2Fsvg%3E");
  background-position: center;
  background-repeat: no-repeat;
  background-size: 90%;
  display: block;
  width: 5em;
  aspect-ratio: 64/70;
}
.for-users__message__frame01::before, .for-users__message__frame02::before {
  position: absolute;
  top: 0.8em;
  left: 1.1em;
}
.for-users__message__frame01::after, .for-users__message__frame02::after {
  position: absolute;
  top: 0.8em;
  right: 1.1em;
  transform: scaleX(-1);
}
.for-users__message__frame01 span, .for-users__message__frame02 span {
  display: block;
  background-color: #fff;
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20data-name%3D%22%E5%88%9D%E3%82%81%E3%81%BE%E3%81%97%E3%81%A6%22%20viewBox%3D%220%200%2074.02%2011.06%22%3E%3Cpath%20d%3D%22M71.68%204.87c-.88-.26-1.74-.21-2.61.05-.42.13-.83.3-1.29.3-1.34%200-2.68-.01-4.03%200%20.18-.05.36-.09.54-.15.26-.09.47-.25.76-.29%201.3-.16%202.54-.54%203.68-1.2.44-.26.87-.54%201.31-.81-.02-.04-.03-.08-.05-.12-1.05-.02-2.09.03-3.07.51-.64.31-1.15.81-1.75%201.16-1.12.65-2.37.87-3.67.86-1.09-.01-2.19-.03-3.38.1.66-.4%201.24-.67%201.91-.75%201.23-.16%202.21-.73%202.94-1.8.42-.6.9-1.2%201.54-1.61.1-.06.29-.13.22-.28-.07-.15-.25-.07-.38-.03-.69.2-1.37.39-2.06.6-.36.11-.67.3-.96.56-.56.5-1.02%201.09-1.46%201.69-.14.19-.26.44-.45.55-.6.33-1.17.73-1.87.82-.55.07-1.07.29-1.62.31-1.64.05-3.29-.13-4.93.11.06-.04.16-.09.15-.11-.04-.18-.22-.02-.31-.13.3.05.58-.03.85-.13.73-.27%201.44-.6%202.24-.7%201.33-.15%202.19-.92%202.75-2.12.34-.73.75-1.42%201.34-1.99.07-.06.19-.13.1-.25-.07-.09-.15%200-.23.03-.58.25-1.15.5-1.74.73-1.36.51-2.1%201.63-2.81%202.8-.1.17-.18.4-.33.5-.85.54-1.71%201.06-2.76%201.08-.52.01-1.03.04-1.55.06-.95.05-1.91.01-2.88.01%201.05-.42%202.09-.77%203.16-1%20.51-.11.92-.38%201.25-.78.54-.65%201.06-1.32%201.58-1.98.06-.08.2-.18.07-.35-.49.25-.99.45-1.51.59-.96.25-1.68.81-2.27%201.59-.42.56-.87%201.09-1.55%201.38-.57.24-1.17.4-1.77.48-1.79.24-3.6.1-5.4.26.7-.12%201.44-.13%202.06-.51.66-.4%201.36-.57%202.11-.64.56-.06.99-.33%201.33-.78.62-.83%201.05-1.78%201.6-2.65.04-.06.05-.13-.05-.22-.64.35-1.29.72-1.94%201.07-.88.47-1.49%201.19-1.96%202.06-.07.13-.12.31-.23.35-.58.23-1.05.68-1.68.82-2.09.46-4.18.41-6.26.04-1-.18-1.83-.66-2.38-1.59-.42-.71-.96-1.33-1.72-1.71-.65-.33-1.31-.66-1.96-.98-.08-.04-.17-.13-.32%200%20.75.72%201.15%201.68%201.74%202.52.48.7%201.11%201.14%201.97%201.25.37.04.76.06%201.08.21.35.16.68.35%201.06.43.37.07.72.21%201.1.24-1.89.04-3.79.08-5.64-.35-.88-.21-1.77-.43-2.31-1.31-.57-.93-1.36-1.62-2.44-1.93-.41-.12-.81-.3-1.19-.48-.12-.06-.24-.17-.42-.08.45.79.95%201.54%201.51%202.25.46.59%201.08.86%201.79%201.02.51.12%201.05.13%201.54.33.63.25%201.25.48%201.76.45-1.17%200-2.51.02-3.85%200-.63-.01-1.26%200-1.88-.15-1.23-.29-2.36-.72-2.92-2-.04-.1-.14-.19-.19-.29-.81-1.63-2.5-1.96-3.92-2.69.43.76.92%201.46%201.28%202.24.59%201.26%201.65%201.92%202.92%202.16%201.08.21%202.02.87%203.15.85-.94-.01-1.87%200-2.79-.02-1.37-.03-2.75-.02-4.11-.26-1.07-.19-1.99-.65-2.62-1.61-.5-.76-1.11-1.43-1.96-1.82-.73-.33-1.51-.54-2.27-.78-.09-.03-.2-.05-.27.05.01.14.14.17.22.24.6.51%201.19%201.04%201.62%201.72.26.41.59.7%201.01.89.56.26%201.14.46%201.74.59.18.04.37.07.52.19.52.41%201.13.6%201.76.78-.11%200-.2.01-.29%200-1.44-.26-2.9-.26-4.36-.34-1.03-.05-2.04-.27-2.88-.87a7.966%207.966%200%200%200-2.9-1.33c-.61-.15-1.25-.09-1.88.05%201%20.59%201.94%201.27%203.13%201.43.94.13%201.89.24%202.75.8-1.12%200-2.21-.06-3.29.02-.74.06-1.45%200-2.16-.13a4.59%204.59%200%200%200-2.24.09c-.75.22-1.5.46-2.28.6-.19.04-.43-.01-.58.24.41.24.87.23%201.29.31.7.14%201.39.4%202.1.35.84-.06%201.66-.31%202.41-.7.62-.32%201.27-.5%201.97-.48%201%20.02%202.01-.01%203.01.02.33.01.59-.2.91-.17.7.06%201.39.12%202.06.18-.4.04-.84-.03-1.28.05-.91.18-1.77.58-2.71.62-.91.04-1.65.41-2.33.96-.23.19-.46.4-.72.54-.5.26-.81.7-1.21%201.09.08.03.12.06.15.06C7.26%208.54%208.73%208%209.99%206.97c.88-.72%201.84-1.21%202.98-1.26%201.31-.05%202.63-.18%203.95-.11.96.05%201.92.01%202.98.01-.41.07-.72.02-1.04.08-1.02.18-1.93.69-2.95.86-.93.16-1.68.7-2.3%201.42-.4.47-.75.98-1.06%201.51-.18.3-.5.5-.57.9.07%200%20.12%200%20.15-.01.71-.39%201.44-.77%202.13-1.2.88-.54%201.74-1.11%202.39-1.94.19-.25.38-.52.68-.7.95-.56%201.99-.73%203.05-.73.98%200%201.96-.01%202.94-.02-1%20.22-1.88.69-2.74%201.17-1.43.8-2.04%202.34-2.82%203.7%201.67-.59%202.98-1.62%203.81-3.18.52-.99%201.37-1.34%202.36-1.56.21-.05.44-.03.7-.13%201.67-.02%203.34-.04%205-.07.33%200%20.66%200%20.97-.12.17-.07.35-.09.48.1-.11.12-.24.12-.37.14-.56.06-1.09.23-1.58.51-.34.19-.7.34-1.07.41-.79.16-1.41.58-1.96%201.16-.72.75-1.26%201.63-1.88%202.46-.13.17-.3.33-.36.64.36-.19.64-.37.94-.47%201.48-.53%202.58-1.52%203.35-2.88.47-.82%201.23-1.25%202.09-1.47%201.48-.38%203-.46%204.62-.41-.52.16-.95.26-1.3.56-.44.39-.94.7-1.47.95-.37.18-.72.41-.98.75-.64.84-1.07%201.8-1.49%202.76-.02.05%200%20.11%200%20.21.91-.38%201.68-.9%202.31-1.63.46-.54.72-1.19%201.03-1.82.66-1.36%201.96-1.75%203.32-1.83.85-.05%201.71-.05%202.57-.03.2%200%20.4%200%20.6.01.38.15.76.3%201.15.45.64.24%201.04.69%201.23%201.33.3.99.87%201.81%201.71%202.41.46.34.95.64%201.56.75-.39-.78-.74-1.52-1.12-2.24-.38-.72-.88-1.31-1.72-1.5-.25-.06-.42-.23-.6-.39-.48-.43-1.03-.69-1.63-.79%201.23.03%202.46.11%203.68.32%201.33.23%202.48.72%203.09%202.06.28.62.78%201.06%201.29%201.48.73.6%201.64.86%202.48%201.26.07.03.15.07.2%200%20.09-.12-.04-.18-.1-.24-.54-.62-.99-1.3-1.42-2-.65-1.04-1.47-1.87-2.76-2.07-.21-.03-.43%200-.63-.11-.66-.35-1.32-.68-2.1-.65%201.77.16%203.52-.14%205.29%200%201.09.08%202.11.34%203.07.87.28.16.51.35.66.65.81%201.72%202.2%202.79%203.9%203.52.13.05.25.13.42%200-.67-.84-1.28-1.68-1.86-2.55-.32-.48-.68-.98-1.24-1.16-1.14-.38-2.12-1.14-3.34-1.34%201.01.04%202.01.12%203.01.1%201.13-.02%202.17.3%203.22.65.32.11.57.31.81.55.57.57%201.03%201.24%201.67%201.74.89.68%201.97%201.05%202.89%201.67.05.03.11.04.17-.07-.17-.28-.33-.6-.53-.89-.95-1.35-2.08-2.54-3.72-2.97-1.12-.29-2.2-.8-3.36-.91.31%200%20.63-.02.95-.01.26%200%20.5-.18.76-.05.3.15.61.14.93.12%201.03-.06%202.06-.05%203.09-.09.41-.02.81-.05%201.22-.08.01.02.02.03.02.03l.17.03c.96.18%201.9.43%202.63%201.13.64.61%201.39%201.04%202.21%201.37.74.3%201.51.25%202.4.35-.17-.19-.25-.29-.34-.37-.81-.66-1.66-1.27-2.54-1.84-.17-.11-.36-.17-.56-.19-.96-.05-1.9-.18-2.82-.46-.02%200-.03%200-.05-.01.15.02.3.03.45.01%201.03-.1%202.06-.06%203.09-.08.62-.01%201.23.04%201.82.23%201.1.36%202.22.56%203.37.46.82-.07%201.62-.29%202.38-.71-.78-.21-1.57-.4-2.35-.63Z%22%20style%3D%22fill%3A%237b5aa8%3Bopacity%3A.6%22%2F%3E%3C%2Fsvg%3E");
  background-position: center;
  background-repeat: no-repeat;
  background-size: 90%;
  width: 7.4em;
  aspect-ratio: 74/11;
  position: absolute;
  top: 0.95em;
  left: 50%;
  transform: translateX(-50%);
}
.for-users__message__frame01 {
  top: 0;
  right: 0;
  left: 0;
}
.for-users__message__frame02 {
  right: 0;
  bottom: 0;
  left: 0;
  transform: rotate(180deg);
}
.for-users__links {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(2, 1fr);
  gap: 0.5em 1.33333333%;
  max-width: 600px;
  margin: 40px auto 0;
}
.for-users__link {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: min(3vw, 1em);
  color: #fff;
  text-decoration: none;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.for-users__link::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0.6;
  transition: opacity 0.25s ease;
}
.for-users__link-label {
  position: relative;
  font-size: clamp(16px, 16px + 0.4vw, 18.4px);
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-weight: 600;
  text-align: center;
  line-height: 1.8;
  transition: transform 0.25s ease;
}
.for-users__link--handling {
  grid-column: span 2/span 2;
  background: linear-gradient(135deg, rgba(162, 133, 206, 0.85), rgba(123, 90, 168, 0.95));
}
.for-users__link--warranty {
  grid-row-start: 2;
  background: linear-gradient(135deg, rgba(116, 167, 204, 0.9), rgba(88, 186, 201, 0.95));
}
.for-users__link--repair {
  grid-row-start: 2;
  background: linear-gradient(135deg, rgba(232, 143, 156, 0.9), rgba(228, 121, 145, 0.95));
}
.for-users__link:hover, .for-users__link:focus-visible {
  transform: translateY(-4px);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.16);
}
.for-users__link:hover::before, .for-users__link:focus-visible::before {
  opacity: 0.4;
}
.for-users__link:hover-label, .for-users__link:focus-visible-label {
  transform: translateY(-1px);
}

.for-users-care {
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
}
.for-users-care__inner {
  text-align: center;
}
.for-users-care__head {
  margin-bottom: clamp(28.8px, 21.824px + 2.18vw, 48px);
}
.for-users-care__title {
  font-size: clamp(23.2px, 16px + 1.6vw, 33.6px);
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-weight: 500;
  line-height: 1.5;
  color: #7b5aa8;
  margin-bottom: 0.75em;
}
.for-users-care__lead {
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  line-height: 2;
}
.for-users-care__image {
  border-radius: 1.5em;
  margin-bottom: clamp(28.8px, 21.824px + 2.18vw, 48px);
  overflow: hidden;
}
.for-users-care__image img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}
.for-users-care__links {
  font-size: min(3.6vw, 1em);
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 1em;
}
.for-users-care__link .button {
  border: 0.1em solid #7b5aa8;
  color: #7b5aa8;
  width: 100%;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}
.for-users-care__link .button:hover, .for-users-care__link .button:focus-visible {
  transform: translateY(-3px);
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.12);
  background-color: #fbf8ff;
}
.for-users-care__icon {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 3.5em;
  aspect-ratio: 1;
  border-radius: 50%;
  background-color: #7b5aa8;
  position: absolute;
}
.for-users-care__icon::before {
  content: "";
  display: block;
  background-color: white;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 163.39'%3E%3Cpath d='M26.54 126.66c-5.52 0-10.02 4.5-10.02 10.02s4.49 10.02 10.02 10.02 10.02-4.5 10.02-10.02-4.49-10.02-10.02-10.02ZM26.54 138.9c-1.22 0-2.22-1-2.22-2.22s1-2.22 2.22-2.22 2.22 1 2.22 2.22-1 2.22-2.22 2.22Z'/%3E%3Cpath d='M75.82 126.66c-5.52 0-10.02 4.5-10.02 10.02s4.49 10.02 10.02 10.02 10.02-4.5 10.02-10.02-4.49-10.02-10.02-10.02ZM75.82 138.9c-1.22 0-2.22-1-2.22-2.22s1-2.22 2.22-2.22 2.22 1 2.22 2.22-1 2.22-2.22 2.22Z'/%3E%3Cpath d='M196.14 41.96c-5.77-20.37-16.07-25.6-23.69-26.39-2.69-.28-5.26-.05-7.71.62-1.66-2.6-3.67-4.96-6.03-7.03-6.71-5.9-15.77-9.15-25.51-9.15-.35 0-.7.01-1.04.02-.03 0-.06 0-.09 0H38.33s-.09 0-.13 0C19.22.58 0 14.09 0 38.84v5.52h0v119.03h159.31c3.63 0 7.41-1.91 9.48-6.74 5.6-2.64 11.69-8.2 17.34-18.95 6.47-12.3 11.07-29 12.96-47.04 1.89-18.04.84-35.33-2.95-48.7ZM154.28 17.15c.91.94 1.73 1.95 2.48 3.02.29.42.57.85.84 1.29.85 1.4 1.56 2.91 2.14 4.5 0 0 0 0 0 0 .17.48.33.96.48 1.46.33 1.08.6 2.19.8 3.35 0 0 0 0 0 0 .26 1.43.42 2.91.49 4.45.02.54.04 1.09.04 1.64v2.82h0v8.05h-58.91v-3.35h-.06v-5.52c0-.5.02-.99.04-1.48.28-6.13 2.28-12.35 6.14-17.41 5.71-7.15 14.59-10.75 23.12-11.08.44-.01.87-.03 1.32-.03 7.6 0 14.58 2.47 19.67 6.95.49.43.96.89 1.41 1.36 0 0 0 0 0 0ZM102.63 56.55h5.84v98h-5.84V56.55ZM117.31 153.57V56.55h44.22v73.55h0v8.91h0v6.82h0v1.84c0 .98-.06 1.87-.16 2.66-.02.17-.05.33-.08.49-.39 2.37-1.19 3.73-1.98 3.73h-41.99v-.99ZM170.38 52.13v-9.93h0v-1.96c2.89 4.83 8.4 19.66 5.44 47.98-1.17 11.15-3.19 19.99-5.44 26.85v-62.95ZM8.85 154.53V44.36h0v-5.52c0-19.97 15.3-29.53 29.55-29.98h69.07c-7.59 6.1-12.96 15.3-13.65 27.35-.01.23-.02.47-.03.7-.03.64-.05 1.28-.05 1.93v5.52h0v110.17H8.85ZM191.33 89.85c-1.76 16.83-6.17 32.94-12.1 44.22-2.22 4.23-5.2 8.81-8.85 12.13v-2.7h0v-6.23h0v-3.39c5.66-9.05 11.06-24.42 13.2-44.83 2.1-20.06.04-33.68-2.05-41.57-1.25-4.72-4.81-15.78-10.69-16.39-.27-.03-.54-.03-.82 0-.17-1.33-.41-2.63-.7-3.89 0 0 0 0 0 0-.3-1.29-.68-2.53-1.1-3.75.68-.11 1.37-.18 2.08-.18.45 0 .9.02 1.35.07 9.47.99 14.47 11.84 17 20.76 3.47 12.26 4.45 28.94 2.69 45.77Z'/%3E%3C/svg%3E");
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 163.39'%3E%3Cpath d='M26.54 126.66c-5.52 0-10.02 4.5-10.02 10.02s4.49 10.02 10.02 10.02 10.02-4.5 10.02-10.02-4.49-10.02-10.02-10.02ZM26.54 138.9c-1.22 0-2.22-1-2.22-2.22s1-2.22 2.22-2.22 2.22 1 2.22 2.22-1 2.22-2.22 2.22Z'/%3E%3Cpath d='M75.82 126.66c-5.52 0-10.02 4.5-10.02 10.02s4.49 10.02 10.02 10.02 10.02-4.5 10.02-10.02-4.49-10.02-10.02-10.02ZM75.82 138.9c-1.22 0-2.22-1-2.22-2.22s1-2.22 2.22-2.22 2.22 1 2.22 2.22-1 2.22-2.22 2.22Z'/%3E%3Cpath d='M196.14 41.96c-5.77-20.37-16.07-25.6-23.69-26.39-2.69-.28-5.26-.05-7.71.62-1.66-2.6-3.67-4.96-6.03-7.03-6.71-5.9-15.77-9.15-25.51-9.15-.35 0-.7.01-1.04.02-.03 0-.06 0-.09 0H38.33s-.09 0-.13 0C19.22.58 0 14.09 0 38.84v5.52h0v119.03h159.31c3.63 0 7.41-1.91 9.48-6.74 5.6-2.64 11.69-8.2 17.34-18.95 6.47-12.3 11.07-29 12.96-47.04 1.89-18.04.84-35.33-2.95-48.7ZM154.28 17.15c.91.94 1.73 1.95 2.48 3.02.29.42.57.85.84 1.29.85 1.4 1.56 2.91 2.14 4.5 0 0 0 0 0 0 .17.48.33.96.48 1.46.33 1.08.6 2.19.8 3.35 0 0 0 0 0 0 .26 1.43.42 2.91.49 4.45.02.54.04 1.09.04 1.64v2.82h0v8.05h-58.91v-3.35h-.06v-5.52c0-.5.02-.99.04-1.48.28-6.13 2.28-12.35 6.14-17.41 5.71-7.15 14.59-10.75 23.12-11.08.44-.01.87-.03 1.32-.03 7.6 0 14.58 2.47 19.67 6.95.49.43.96.89 1.41 1.36 0 0 0 0 0 0ZM102.63 56.55h5.84v98h-5.84V56.55ZM117.31 153.57V56.55h44.22v73.55h0v8.91h0v6.82h0v1.84c0 .98-.06 1.87-.16 2.66-.02.17-.05.33-.08.49-.39 2.37-1.19 3.73-1.98 3.73h-41.99v-.99ZM170.38 52.13v-9.93h0v-1.96c2.89 4.83 8.4 19.66 5.44 47.98-1.17 11.15-3.19 19.99-5.44 26.85v-62.95ZM8.85 154.53V44.36h0v-5.52c0-19.97 15.3-29.53 29.55-29.98h69.07c-7.59 6.1-12.96 15.3-13.65 27.35-.01.23-.02.47-.03.7-.03.64-.05 1.28-.05 1.93v5.52h0v110.17H8.85ZM191.33 89.85c-1.76 16.83-6.17 32.94-12.1 44.22-2.22 4.23-5.2 8.81-8.85 12.13v-2.7h0v-6.23h0v-3.39c5.66-9.05 11.06-24.42 13.2-44.83 2.1-20.06.04-33.68-2.05-41.57-1.25-4.72-4.81-15.78-10.69-16.39-.27-.03-.54-.03-.82 0-.17-1.33-.41-2.63-.7-3.89 0 0 0 0 0 0-.3-1.29-.68-2.53-1.1-3.75.68-.11 1.37-.18 2.08-.18.45 0 .9.02 1.35.07 9.47.99 14.47 11.84 17 20.76 3.47 12.26 4.45 28.94 2.69 45.77Z'/%3E%3C/svg%3E");
  mask-size: 60%;
  -webkit-mask-size: 60%;
  mask-position: center;
  -webkit-mask-position: center;
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  width: 3em;
  aspect-ratio: 1;
}
.for-users-care__label {
  font-weight: 600;
  white-space: normal;
}
@media (max-width: 767px) {
  .for-users-care__links {
    flex-direction: column;
  }
  .for-users-care__link {
    padding-left: 2em;
    width: 100%;
    max-width: 25em;
  }
  .for-users-care__link .button {
    padding-left: 3em;
  }
  .for-users-care__icon {
    left: -2em;
  }
}
@media (min-width: 768px) {
  .for-users-care__link {
    flex: 0 0 19.3em;
    min-width: 19.3em;
    padding-top: 2em;
  }
  .for-users-care__link .button {
    padding-top: 2em;
    padding-bottom: 1em;
  }
  .for-users-care__icon {
    top: -2em;
  }
}

.for-users-breather {
  width: 100%;
  height: clamp(10em, 6.364em + 18.18vw, 20em);
}
.for-users-breather img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 85%;
}

.for-users-voice {
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
}
.for-users-voice__inner {
  max-width: 1120px;
  margin: 0 auto;
  text-align: center;
}
.for-users-voice__head {
  margin-bottom: clamp(28.8px, 21.824px + 2.18vw, 48px);
}
.for-users-voice__lead {
  margin: 0;
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  line-height: 2.2;
}
.for-users-voice__cards {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 1.5em;
}
.for-users-voice__card {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 160px;
  text-decoration: none;
  color: inherit;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  position: relative;
}
.for-users-voice__card:hover {
  transform: translateY(-3px);
}
.for-users-voice__card-figure {
  margin: 0 0 12px;
  width: 100%;
  border-radius: 1em;
  overflow: hidden;
}
.for-users-voice__card-figure picture,
.for-users-voice__card-figure img {
  display: block;
  width: 100%;
  max-width: 220px;
  aspect-ratio: 439/370;
  object-fit: cover;
}
.for-users-voice__card-figure--insta {
  position: relative;
}
.for-users-voice__card-figure--insta::before {
  content: "";
  display: block;
  background: radial-gradient(circle at 33% 100%, #fed373 4%, #f15245 30%, #d92e7f 62%, #9b36b7 85%, #515ecf);
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
  opacity: 0.8;
}
.for-users-voice__insta-icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.for-users-voice__insta-icon::after {
  content: "";
  display: block;
  background-image: url("../img/Instagram_Glyph_White.svg");
  width: 3em;
  aspect-ratio: 1;
}
.for-users-voice__card-label {
  margin: 0;
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-weight: 600;
}

.six-years {
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
  background-color: #f7f4fb;
}
.six-years__head {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1em 2em;
  background-color: white;
  padding: clamp(19.2px, 14.544px + 1.45vw, 32px) clamp(28.8px, 21.824px + 2.18vw, 48px);
  margin-bottom: clamp(28.8px, 21.824px + 2.18vw, 48px);
  border: 0.2em solid #7b5aa8;
  border-radius: 1.5em;
}
.six-years__medal img {
  max-width: 275px;
}
.six-years__title {
  font-size: clamp(19.2px, 16px + 0.75vw, 24.8px);
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-weight: 700;
  line-height: 1.65;
  color: #7b5aa8;
  margin: 0 0 0.5em;
}
.six-years__lead {
  margin: 0;
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
}
@media (max-width: 767px) {
  .six-years__head {
    flex-direction: column;
    text-align: center;
  }
}
.six-years__body {
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  display: grid;
  gap: clamp(28.8px, 21.824px + 2.18vw, 48px);
  align-items: stretch;
  background-color: #fff;
  padding: clamp(28.8px, 21.824px + 2.18vw, 48px);
  margin-top: clamp(28.8px, 21.824px + 2.18vw, 48px);
  border-radius: 1.5em;
  box-shadow: 0 1em 3em rgba(0, 0, 0, 0.06);
}
@media (min-width: 768px) {
  .six-years__body {
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  }
}
.six-years__list {
  display: grid;
  grid-template-columns: 6.4em minmax(0, 1fr);
  gap: 0.5em 0;
}
.six-years__list:not(:last-child) {
  margin-bottom: 1.5em;
}
@media (max-width: 575px) {
  .six-years__list {
    grid-template-columns: 100%;
  }
}
.six-years__term {
  font-weight: 700;
  color: #7b5aa8;
  word-break: keep-all;
  overflow-wrap: anywhere;
  margin: 0;
}
.six-years__desc {
  font-size: 0.9em;
  line-height: 1.9;
  margin: 0;
}
.six-years__desc strong {
  font-size: 1.15em;
  font-weight: 500;
}
.six-years__example {
  font-size: 0.9em;
  background-color: rgba(123, 90, 168, 0.1);
  border-radius: 1em;
  padding: 1em 1.5em 1em 3.5em;
  margin-bottom: 1.5em;
  text-indent: -2em;
}
.six-years__example p {
  word-break: keep-all;
  overflow-wrap: anywhere;
}
.six-years__exception {
  font-weight: 700;
  color: #7b5aa8;
}
.six-years__photo {
  margin: 0;
  border-radius: 1em;
  overflow: hidden;
  background-color: #fff;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.06);
}
.six-years__photo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.six-years__proof {
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  margin-top: clamp(28.8px, 21.824px + 2.18vw, 48px);
  display: grid;
  gap: clamp(19.2px, 14.544px + 1.45vw, 32px);
}
@media (min-width: 768px) {
  .six-years__proof {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
.six-years__proof-item {
  background-color: #fff;
  border-radius: 24px;
  padding: clamp(19.2px, 14.544px + 1.45vw, 32px);
  text-align: center;
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.04);
}
.six-years__proof-figure {
  margin: 0 0 1em;
}
.six-years__proof-figure img {
  display: block;
  width: 100%;
  max-width: 330px;
  aspect-ratio: 1.618;
  object-fit: contain;
  margin-inline: auto;
}
.six-years__proof-title {
  font-weight: 700;
  color: #7b5aa8;
  margin: 0 0 0.5em;
}
.six-years__proof-text {
  font-size: 0.9em;
  line-height: 1.9;
  margin: 0;
}

.six-years-flow {
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
}
.six-years-flow__inner {
  text-align: center;
}
.six-years-flow__head {
  margin-bottom: clamp(28.8px, 21.824px + 2.18vw, 48px);
}
.six-years-flow__title {
  font-size: clamp(23.2px, 16px + 1.6vw, 33.6px);
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-weight: 500;
  line-height: 1.5;
  color: #7b5aa8;
  margin-bottom: 0.75em;
}
.six-years-flow__steps {
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 2em;
}
@media (min-width: 768px) {
  .six-years-flow__steps {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
.six-years-flow__step {
  position: relative;
  background-color: #f7f4fb;
  border-radius: 1.5em;
  padding: 1.5em;
  box-shadow: 0 0.75em 1.625em rgba(0, 0, 0, 0.04);
}
@media (min-width: 768px) {
  .six-years-flow__step:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 50%;
    right: -1.3333em;
    width: 1em;
    height: 1em;
    border-top: 0.25em solid #7b5aa8;
    border-right: 0.25em solid #7b5aa8;
    transform: translateY(-50%) rotate(45deg);
  }
}
.six-years-flow__figure {
  max-width: 257px;
  margin: 0 auto -1.5em;
  border-radius: 0.5em;
  overflow: hidden;
  background-color: #fff;
}
.six-years-flow__figure img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}
.six-years-flow__num {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 1.15em;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: #7b5aa8;
  color: white;
  width: 2.5em;
  aspect-ratio: 1;
  border-radius: 50%;
  margin: 0 0 0.75em;
}
.six-years-flow__label {
  font-size: 1.12em;
  font-weight: 700;
  color: #7b5aa8;
  margin: 0 0 0.5em;
}
.six-years-flow__text {
  font-size: 0.9em;
  margin: 0;
}
@media (max-width: 1023px) {
  .six-years-flow__text br {
    display: none;
  }
}
.six-years-flow__note {
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1em 2em;
  margin-top: clamp(28.8px, 21.824px + 2.18vw, 48px);
  padding: 1em 1.5em;
  border-radius: 24px;
  background-color: #f8f5fb;
  text-align: left;
}
@media (max-width: 575px) {
  .six-years-flow__note {
    flex-direction: column;
  }
}
.six-years-flow__note-title {
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 1.15em;
  font-weight: 700;
  color: #7b5aa8;
  margin: 0;
  white-space: nowrap;
}
.six-years-flow__note-list {
  font-size: 0.9em;
  margin: 0;
}

.six-years-pack {
  background-color: #f7f9fc;
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
}
.six-years-pack__head {
  text-align: center;
  margin-bottom: clamp(28.8px, 21.824px + 2.18vw, 48px);
}
.six-years-pack__title {
  font-size: clamp(23.2px, 16px + 1.6vw, 33.6px);
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-weight: 500;
  line-height: 1.5;
  color: #7b5aa8;
  margin: 0;
}
.six-years-pack__body {
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  display: grid;
  gap: clamp(28.8px, 21.824px + 2.18vw, 48px);
  align-items: center;
}
@media (min-width: 768px) {
  .six-years-pack__body {
    grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
  }
}
.six-years-pack__text {
  font-size: 0.95em;
}
.six-years-pack__list {
  margin: 0;
}
.six-years-pack__list li + li {
  margin-top: 0.5em;
}
.six-years-pack__photos {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1em;
  width: 100%;
  max-width: 428px;
  margin-inline: auto;
}
.six-years-pack__photo {
  aspect-ratio: 4/3;
  border-radius: 0.5em;
  background-color: #fff;
  box-shadow: 0 0.625em 1.375em rgba(0, 0, 0, 0.04);
  margin: 0;
  overflow: hidden;
  position: relative;
}
.six-years-pack__photo img {
  display: block;
  width: 120%;
  max-width: none;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.six-years-pack__photo:nth-child(2) img {
  width: 140%;
}

.six-years-contact {
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
}
.six-years-contact__banner {
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  background-color: #7b5aa8;
  color: #fff;
  display: grid;
  align-items: center;
  justify-content: center;
  gap: 1.5em 5%;
  text-align: center;
  padding: clamp(19.2px, 14.544px + 1.45vw, 32px) clamp(19.2px, 14.544px + 1.45vw, 32px);
  margin-bottom: 3em;
  border-radius: 1.5em;
}
.six-years-contact__banner-title {
  font-size: clamp(19.2px, 16px + 0.75vw, 24.8px);
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-weight: 600;
  line-height: 1.5;
}
.six-years-contact__banner-title br {
  display: none;
}
.six-years-contact__tel {
  line-height: 1;
  letter-spacing: 0.05em;
}
.six-years-contact__tel-inner {
  display: inline-grid;
  gap: 0.5em;
  text-align: left;
}
.six-years-contact__tel-icon {
  grid-row: span 3/span 3;
  width: 3em;
  position: relative;
}
.six-years-contact__tel-icon::before {
  content: "";
  display: block;
  width: 3em;
  aspect-ratio: 1;
  border-radius: 50%;
  background-color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.six-years-contact__tel-icon::after {
  content: "";
  display: block;
  width: 3em;
  aspect-ratio: 1;
  border-radius: 50%;
  background-color: #7b5aa8;
  mask: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath d='M48.5 40.2a4.8 4.8 0 0 0-6.5 1.3c-2.4 2.9-5.3 7.7-16.2-3.2S19.6 24.4 22.5 22a4.8 4.8 0 0 0 1.3-6.5L17 5.1c-.9-1.3-2.1-3.4-4.9-3S2 6.6 2 15.6s7.1 20 16.8 29.7S39.5 62 48.4 62s13.2-8 13.5-10-1.7-4-3-4.9z' fill='%23202020'/%3E%3C/svg%3E");
  -webkit-mask: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath d='M48.5 40.2a4.8 4.8 0 0 0-6.5 1.3c-2.4 2.9-5.3 7.7-16.2-3.2S19.6 24.4 22.5 22a4.8 4.8 0 0 0 1.3-6.5L17 5.1c-.9-1.3-2.1-3.4-4.9-3S2 6.6 2 15.6s7.1 20 16.8 29.7S39.5 62 48.4 62s13.2-8 13.5-10-1.7-4-3-4.9z' fill='%23202020'/%3E%3C/svg%3E");
  mask-size: 55%;
  -webkit-mask-size: 55%;
  mask-position: center;
  -webkit-mask-position: center;
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.six-years-contact__tel-label {
  margin: 0;
}
.six-years-contact__tel-number {
  grid-column-start: 2;
  font-size: 2.4em;
  font-family: "Noto Sans JP", "Source Han Sans JP", "Source Han Sans", "Gen Shin Gothic", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-weight: 700;
}
.six-years-contact__tel-time {
  grid-column-start: 2;
  grid-row-start: 3;
}
.six-years-contact__button .button {
  font-size: clamp(16px, 16px + 0.4vw, 18.4px);
  background-color: white;
  color: #7b5aa8;
}
.six-years-contact__note {
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  text-align: center;
  line-height: 2;
}
@media (max-width: 575px) {
  .six-years-contact__banner {
    grid-template-rows: repeat(3, auto);
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  .six-years-contact__banner {
    grid-template-columns: repeat(2, auto);
    grid-template-rows: repeat(2, auto);
  }
  .six-years-contact__banner-text {
    text-align: center;
    grid-column: 1/span 2;
  }
}
@media (min-width: 1024px) {
  .six-years-contact__banner {
    grid-template-columns: repeat(3, auto);
  }
  .six-years-contact__banner-text br {
    display: block;
  }
}

.craftsman-hero {
  position: relative;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding-inline: 5%;
  overflow: hidden;
}
.craftsman-hero__bg {
  position: absolute;
  inset: 0;
  z-index: -2;
}
.craftsman-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.craftsman-hero__inner {
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: min(4.5vw, 1em);
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
}
.craftsman-hero__overlay {
  position: absolute;
  inset: 0;
  background: rgba(68, 68, 68, 0.67);
  z-index: -1;
}
.craftsman-hero__head {
  margin-bottom: clamp(19.2px, 14.544px + 1.45vw, 32px);
}
.craftsman-hero__title {
  font-size: clamp(17.6px, 16px + 0.4vw, 21.6px);
  font-weight: 500;
  text-align: left;
  margin: 0;
}
.craftsman-hero__body {
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  line-height: 2.4;
  margin-top: clamp(19.2px, 14.544px + 1.45vw, 32px);
}
.craftsman-hero__text {
  margin: 0 0 1.5em;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
.craftsman-hero__sign {
  font-size: 1.25em;
  text-align: right;
  margin: 0;
}
.craftsman-hero__sign-name {
  font-weight: 600;
  letter-spacing: 0.2em;
}

.craftsman-story {
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
  overflow: hidden;
}
.craftsman-story__row {
  display: flex;
  flex-direction: column;
  gap: clamp(28.8px, 21.824px + 2.18vw, 48px);
}
.craftsman-story__row:not(:last-child) {
  margin-bottom: clamp(38.4px, 29.088px + 2.91vw, 64px);
}
@media (min-width: 768px) {
  .craftsman-story__row {
    flex-direction: row;
    align-items: center;
    gap: clamp(38.4px, 29.088px + 2.91vw, 64px);
  }
}
.craftsman-story__row--hero-image {
  position: relative;
  align-items: stretch;
}
.craftsman-story__col--text {
  flex: 1 1 0;
}
.craftsman-story__col--image {
  flex: 1 1 0;
}
@media (max-width: 767px) {
  .craftsman-story__row--hero-image .craftsman-story__col--image {
    margin-right: calc((100vw - 100%) / -2);
  }
}
@media (min-width: 768px) {
  .craftsman-story__row--hero-image .craftsman-story__col--image {
    position: relative;
    flex: 0 0 60%;
    max-width: 60%;
    padding-bottom: 2em;
    margin-right: calc((100vw - 100%) / -2);
  }
}
@media (min-width: 768px) {
  .craftsman-story__row--reverse {
    flex-direction: row-reverse;
  }
}
@media (min-width: 768px) {
  .craftsman-story__row--reverse .craftsman-story__col--image {
    flex: 0 0 min(38.2%, 320px);
    max-width: min(38.2%, 320px);
  }
}
.craftsman-story__eyebrow {
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  letter-spacing: 0.2em;
  margin: 0 0 0.5em;
}
.craftsman-story__title {
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: clamp(43.2px, 16px + 4.3vw, 64px);
  line-height: 1.2;
  color: #7b5aa8;
  margin: 0 0 0.75em;
}
@media (max-width: 767px) {
  .craftsman-story__title span {
    display: inline-block;
  }
}
@media (min-width: 768px) {
  .craftsman-story__title {
    white-space: nowrap;
  }
  .craftsman-story__title span {
    display: block;
  }
}
.craftsman-story__lead, .craftsman-story__subtitle {
  font-size: clamp(19.2px, 16px + 0.75vw, 24.8px);
  font-weight: 500;
  line-height: 1.7;
  color: #7b5aa8;
  margin: 0 0 0.5em;
}
@media (max-width: 767px) {
  .craftsman-story__lead span {
    display: inline-block;
  }
}
@media (min-width: 768px) {
  .craftsman-story__lead {
    white-space: nowrap;
  }
  .craftsman-story__lead span {
    display: block;
  }
}
.craftsman-story__subtitle span {
  display: inline-block;
}
.craftsman-story__text {
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  line-height: 2.1;
  margin: 0;
}
.craftsman-story__text + .craftsman-story__text {
  margin-top: 1.5em;
}
.craftsman-story__text br {
  display: none;
}
@media (min-width: 768px) {
  .craftsman-story__text br {
    display: inline;
  }
}
.craftsman-story__photo {
  height: 100%;
  margin: 0;
}
.craftsman-story__photo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 65% 60%;
}
.craftsman-story__product {
  margin: 0;
}
.craftsman-story {
  /* 1枚目の写真（右カラム・全幅化） */
}
.craftsman-story__row--hero-image .craftsman-story__photo {
  width: 100%;
  max-width: none;
  border-radius: 1em 0 0 1em;
  overflow: hidden;
}
.craftsman-story {
  /* 2枚目の商品写真（ランドセル） */
}
.craftsman-story__product {
  max-width: 320px;
  margin-inline: auto;
}
@media (max-width: 767px) {
  .craftsman-story__product {
    width: 50%;
  }
}

.craftsman-interview {
  padding: clamp(48px, 36.368px + 3.64vw, 80px) 0;
  background-color: #fbf8ec;
  color: #7a6762;
}
.craftsman-interview__head {
  margin-bottom: clamp(28.8px, 21.824px + 2.18vw, 48px);
}
.craftsman-interview__head-photo {
  background-position: 50% 25%;
  background-repeat: no-repeat;
  background-size: cover;
}
.craftsman-interview__head-photo::before {
  content: "";
  display: block;
  width: 100%;
  aspect-ratio: 6/7;
  max-height: 576px;
}
.craftsman-interview__title {
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: clamp(43.2px, 16px + 4.3vw, 64px);
  letter-spacing: 0.08em;
  margin: 0;
}
.craftsman-interview__title-jp {
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: clamp(16px, 16px + 0.4vw, 18.4px);
  font-weight: 600;
  letter-spacing: 0.16em;
  margin-top: 0.5em;
}
.craftsman-interview__catch {
  font-size: clamp(16px, 16px + 0.4vw, 18.4px);
  line-height: 2.4;
  letter-spacing: 0.1em;
  margin: clamp(28.8px, 21.824px + 2.18vw, 48px) 0 0;
  text-decoration: underline;
  text-underline-offset: 0.5rem;
}
.craftsman-interview__lead {
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: clamp(16px, 16px + 0.4vw, 18.4px);
  font-weight: 500;
  line-height: 2;
  max-width: 36em;
  margin: clamp(38.4px, 29.088px + 2.91vw, 64px) auto;
  text-align: center;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
.craftsman-interview__item {
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  position: relative;
}
.craftsman-interview__card {
  background-color: rgba(255, 255, 255, 0.9);
  border-radius: 1em;
  padding: clamp(19.2px, 14.544px + 1.45vw, 32px) clamp(28.8px, 21.824px + 2.18vw, 48px);
  box-shadow: 0 1em 2em rgba(0, 0, 0, 0.06);
  position: relative;
  z-index: 1;
}
.craftsman-interview__question {
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: clamp(19.2px, 16px + 0.75vw, 24.8px);
  font-weight: 600;
  margin: 0 0 1em;
  line-height: 1.7;
  word-break: keep-all;
  overflow-wrap: anywhere;
  position: relative;
}
.craftsman-interview__question::before {
  content: "──";
}
.craftsman-interview__text {
  line-height: 2.1;
  margin: 0;
}
@media (max-width: 767px) {
  .craftsman-interview__head-text {
    text-align: center;
    margin-bottom: clamp(48px, 36.368px + 3.64vw, 80px);
  }
  .craftsman-interview__head-photo {
    aspect-ratio: 4/3;
    max-width: 400px;
    margin: 0 auto;
  }
  .craftsman-interview__item {
    margin-bottom: 5vw;
  }
  .craftsman-interview__card {
    width: 95%;
    margin-bottom: -3vw;
  }
  .craftsman-interview__photo {
    width: 95%;
  }
  .craftsman-interview__item01 .craftsman-interview__photo {
    margin-left: auto;
  }
  .craftsman-interview__item02 .craftsman-interview__card {
    margin-left: auto;
  }
  .craftsman-interview__item03 .craftsman-interview__photo {
    margin-left: auto;
  }
}
@media (min-width: 768px) {
  .craftsman-interview__head {
    display: flex;
    align-items: center;
    column-gap: 5%;
  }
  .craftsman-interview__head-text {
    flex: 0 0 auto;
    padding: clamp(28.8px, 21.824px + 2.18vw, 48px) 0;
  }
  .craftsman-interview__head-photo {
    position: relative;
    flex: 1 1 0;
    margin-right: calc((100vw - 100%) / -2);
  }
  .craftsman-interview__item {
    display: flex;
  }
  .craftsman-interview__photo {
    align-self: stretch;
  }
  .craftsman-interview__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .craftsman-interview__item01 {
    justify-content: flex-end;
    align-items: flex-start;
    margin-bottom: clamp(28.8px, 21.824px + 2.18vw, 48px);
  }
  .craftsman-interview__item01 .craftsman-interview__card {
    flex: 0 0 min(50vw, 40em);
    max-width: min(50vw, 40em);
    margin: 0 max(-19.8vw, 100vw - (40em + 61.8vw + 8vw)) clamp(28.8px, 21.824px + 2.18vw, 48px) 0;
  }
  .craftsman-interview__item01 .craftsman-interview__photo {
    flex: 0 0 61.8vw;
    max-width: 61.8vw;
    padding-top: clamp(28.8px, 21.824px + 2.18vw, 48px);
  }
  .craftsman-interview__item02 {
    flex-direction: row-reverse;
    justify-content: flex-end;
    align-items: flex-end;
    margin-bottom: clamp(28.8px, 21.824px + 2.18vw, 48px);
  }
  .craftsman-interview__item02 .craftsman-interview__card {
    flex: 0 0 min(50vw, 40em);
    max-width: min(50vw, 40em);
    margin: clamp(28.8px, 21.824px + 2.18vw, 48px) 0 0 max(-12.7vw, 100vw - (40em + 57.7vw + 5vw));
  }
  .craftsman-interview__item02 .craftsman-interview__photo {
    flex: 0 0 57.7vw;
    max-width: 57.7vw;
    padding-bottom: clamp(48px, 36.368px + 3.64vw, 80px);
  }
  .craftsman-interview__item03 {
    justify-content: flex-end;
    align-items: flex-end;
  }
  .craftsman-interview__item03 .craftsman-interview__card {
    flex: 0 0 min(50vw, 40em);
    max-width: min(50vw, 40em);
    margin: clamp(28.8px, 21.824px + 2.18vw, 48px) max(-25.7vw, 100vw - (40em + 70.7vw + 5vw)) 0 0;
  }
  .craftsman-interview__item03 .craftsman-interview__photo {
    flex: 0 0 70.7vw;
    max-width: 70.7vw;
    padding-bottom: clamp(48px, 36.368px + 3.64vw, 80px);
  }
}
.craftsman-interview__separator {
  width: min(50%, 378px);
  margin: clamp(48px, 36.368px + 3.64vw, 80px) auto;
}
.craftsman-interview {
  /* MESSAGEカード */
}
.craftsman-interview__message {
  width: min(90%, 960px);
  margin: clamp(48px, 36.368px + 3.64vw, 80px) auto 0;
  text-align: center;
  background-color: #fff;
  border-radius: 1.5em;
  padding: clamp(28.8px, 21.824px + 2.18vw, 48px) 5%;
  box-shadow: 0 1em 2.4em rgba(0, 0, 0, 0.06);
}
.craftsman-interview__message-label {
  font-family: "Noto Serif JP", "Source Han Serif JP", "Source Han Serif", "Gen Mincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  font-size: clamp(23.2px, 16px + 1.6vw, 33.6px);
  font-weight: 300;
  line-height: 1.1;
  letter-spacing: 0.075em;
  text-transform: uppercase;
  color: #7b5aa8;
  margin-bottom: 0.5em;
}
.craftsman-interview__message-sub {
  font-size: clamp(12.8px, 12.224px + 0.18vw, 14.4px);
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.12em;
}
.craftsman-interview__message-body {
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  line-height: 2.1;
  margin-top: 2em;
  text-align: left;
}

.initial_simulator {
  display: flex;
  flex-direction: row-reverse;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  column-gap: 2em;
  width: min(1120px, 90%);
  margin: 0 auto;
}
.initial_simulator__text-area {
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
}
.initial_simulator__notes {
  width: min(1120px, 90%);
  margin: 2em auto 3em;
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  text-align: center;
}
.initial_simulator__notes .note {
  display: inline-block;
  text-align: left;
  line-height: 1.5;
}

.is-preview-wrap {
  position: relative;
  max-width: 600px;
}
.is-preview-wrap .sim-bag-wrap .sim-bag {
  aspect-ratio: 600/480;
  object-fit: cover;
}
.is-preview-wrap .is-letters-wrap {
  position: absolute;
  top: 44%;
  left: 50.35%;
  display: flex;
  width: 17.1429%;
  gap: 0;
  align-items: center;
  justify-content: center;
  transform: translate(-50%, -50%);
  pointer-events: none;
}
.is-preview-wrap .is-letters-wrap .is-letter {
  flex: 1 1 0;
  display: block;
  max-width: 33.3333333333%;
  opacity: 1;
  transition: opacity 0.2s;
  margin-left: -6.9%;
}
.is-preview-wrap .is-letters-wrap .is-letter:first-child {
  margin-left: 0;
}
.is-preview-wrap .is-letters-wrap .is-letter.hidden {
  opacity: 0;
  width: 0;
  max-width: 0;
  margin-left: 0;
}

.initial-select {
  text-align: left;
}
.initial-select p {
  font-size: clamp(14.4px, 13.824px + 0.18vw, 16px);
  margin-bottom: 1em;
}
.initial-select .ul {
  display: inline-block;
  background: linear-gradient(transparent 30%, #f8e180 30%);
  padding: 0 0.5em;
  font-size: clamp(16px, 16px + 0.4vw, 18.4px);
  letter-spacing: 0.1em;
  margin-bottom: 1em;
}
.initial-select__step01 {
  margin-bottom: 2em;
}
.initial-select__step01-select {
  display: flex;
  flex-wrap: nowrap;
  margin-top: 0.5em;
  margin-bottom: 0.5em;
}
.initial-select__step01-select p {
  flex: 0 0 10em;
  width: 10em;
  margin-left: 1em;
  margin-bottom: 0;
}
.initial-select__step01-select select {
  flex: 1 1 0;
  width: 100%;
  padding: 0.5em;
  border: solid 1px #ccc;
}
.initial-select__step02 {
  margin-bottom: 2em;
}
.initial-select__step02-select {
  display: flex;
  flex-wrap: nowrap;
  column-gap: 0.5em;
  margin-top: 0.5em;
  margin-bottom: 0.5em;
}
.initial-select__step02-select select {
  flex: 1 1 0;
  font-size: clamp(16px, 16px + 0.4vw, 18.4px);
  padding: 0.5em;
  border: solid 1px #ccc;
}

#initial-box {
  border: 1px solid black;
  text-align: center;
  font-size: 17px;
  letter-spacing: 0;
  width: 365px;
  height: 43px;
  line-height: 43px;
  border-radius: 6px;
  margin-top: 33px;
}

/* ===== Footer ===== */
.sp-bottom-cta {
  display: none;
}
@media (max-width: 575px) {
  .sp-bottom-cta {
    display: flex;
    justify-content: space-around;
    background-color: black;
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    height: 14vw;
    z-index: 100;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.25s ease;
  }
}
.sp-bottom-cta a {
  display: flex;
  flex-direction: column;
  flex: 1 1 0;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  font-size: clamp(0.5em, 0.188em + 1.56vw, 0.75em);
  font-weight: 600;
  text-decoration: none;
  margin-bottom: 0.2em;
  color: white;
  position: relative;
}
.sp-bottom-cta a .icon {
  display: inline-block;
  background-color: white;
  mask-position: center;
  mask-repeat: no-repeat;
  mask-size: contain;
  width: 2.4em;
  aspect-ratio: 1;
}
.sp-bottom-cta a span {
  line-height: 1;
}
.sp-bottom-cta a.catalog .icon {
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 189 177'%3E%3Cpath fill='%23202020' d='M184.5 24h-19.5V4.5c0-2.49-2.01-4.5-4.5-4.5h-28.2c-22.01 0-35.69 16.55-40.42 30.46-6.37-3.6-18.12-6.46-39.38-6.46H4.5c-2.49 0-4.5 2.01-4.5 4.5v132c0 2.49 2.01 4.5 4.5 4.5h60c16.18 0 24.73 4.97 25.5 7.01 0 .03 0 .06.01.08 0 .13-.01.27-.01.4 0 2.49 2.01 4.5 4.5 4.5s4.5-2.01 4.5-4.5c0-.17.01-.35.02-.52.85-2.06 9.38-6.98 25.48-6.98h60c2.49 0 4.5-2.01 4.5-4.5V28.5c0-2.49-2.01-4.5-4.5-4.5ZM132.3 9h23.7v129h-25.8c-12.58 0-23.82 4.99-31.2 12.78V40.5c0-8.68 10.24-31.5 33.3-31.5ZM64.5 156H9V33h43.5c30.36 0 37.38 6.26 37.5 7.5v120.47c-6.21-3.09-15.19-4.97-25.5-4.97ZM180 156h-55.5c-7.88 0-14.98 1.1-20.66 3 5.91-7.49 16.37-12 26.36-12h30.3c2.49 0 4.5-2.01 4.5-4.5V33h15v123Z'/%3E%3C/svg%3E");
}
.sp-bottom-cta a.store .icon {
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 199 181'%3E%3Cpath fill='%23000000' d='M97 137.7c2.5 0 4.5-2 4.5-4.5V97.3c0-2.5-2-4.5-4.5-4.5H42.9c-2.5 0-4.5 2-4.5 4.5v35.9c0 2.5 2 4.5 4.5 4.5H97Zm-49.6-35.9h45.1v26.9H47.4v-26.9ZM180.4 85.3c-2.5 0-4.5 2-4.5 4.5v82.1h-14.1v-57.9c0-2.5-2-4.5-4.5-4.5h-35.9c-2.5 0-4.5 2-4.5 4.5v57.9H23.2V89.8c0-2.5-2-4.5-4.5-4.5s-4.5 2-4.5 4.5v86.6c0 2.5 2 4.5 4.5 4.5h161.7c2.5 0 4.5-2 4.5-4.5V89.8c0-2.5-2-4.5-4.5-4.5Zm-54.5 86.6v-53.4h26.9v53.4h-26.9ZM199 50.2c0-.2 0-.3-.1-.5 0-.2-.1-.3-.1-.5l-.1-.3L181.7 2.9A4.5 4.5 0 0 0 177.4 0H21.6c-1.9 0-3.6 1.2-4.3 2.9L.3 49c0 .1-.1.2-.1.3v.5c0 .2-.1.3-.1.5v14.2c0 10.4 10.5 18.9 23.5 18.9 7.8 0 14.7-3.1 19-7.8 4.3 4.7 11.2 7.8 19 7.8s14.7-3.1 19-7.8c4.3 4.7 11.2 7.8 19 7.8s14.7-3.1 19-7.8c4.3 4.7 11.2 7.8 19 7.8s14.7-3.1 19-7.8c4.3 4.7 11.2 7.8 19 7.8 13 0 23.5-8.5 23.5-18.9V50.5c0-.1 0-.2-.1-.3ZM23.5 74.6c-7.9 0-14.5-4.5-14.5-9.9V51.3L24.7 9h22.4l-9 40.6v.5c0 .1-.1.3-.1.5v14.2c0 5.3-6.6 9.9-14.5 9.9Zm38 0c-7.9 0-14.5-4.5-14.5-9.9V51L56.4 9h22.7L76 50.2v.3l-.1.2v14.2c0 5.3-6.6 9.9-14.5 9.9Zm38 0c-7.9 0-14.5-4.5-14.5-9.9V50.7L88.1 9h22.8l3.1 41.7v14c0 5.3-6.6 9.9-14.5 9.9Zm38 0c-7.9 0-14.5-4.5-14.5-9.9V50.5v-.3L119.9 9h22.7l9.4 42v13.7c0 5.3-6.6 9.9-14.5 9.9Zm38 0c-7.9 0-14.5-4.5-14.5-9.9V50.5c0-.1 0-.3-.1-.5 0-.1-.1-.3-.1-.4V49.6l-9-40.6h22.4l15.7 42.3v13.4c0 5.3-6.6 9.9-14.5 9.9Z'/%3E%3C/svg%3E");
}
.sp-bottom-cta a.exhibition .icon {
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 189 168.23'%3E%3Cpath d='M172.5 16.95h-20.42v-6.06c0-6.01-4.89-10.89-10.89-10.89s-10.89 4.89-10.89 10.89v6.06H58.71v-6.06c0-6.01-4.89-10.89-10.89-10.89s-10.89 4.89-10.89 10.89v6.06h-20.42C7.4 16.95 0 24.35 0 33.45v118.28c0 9.1 7.4 16.5 16.5 16.5h156c9.1 0 16.5-7.4 16.5-16.5V33.45c0-9.1-7.4-16.5-16.5-16.5ZM139.29 16.95v-6.06c0-1.03.87-1.89 1.89-1.89s1.89.87 1.89 1.89v24.45c0 .26-.05.5-.15.73-.29.67-.97 1.16-1.74 1.16s-1.45-.49-1.74-1.16c-.1-.23-.15-.47-.15-.73v-18.39ZM45.92 16.95v-6.06c0-1.03.87-1.89 1.89-1.89s1.89.87 1.89 1.89v24.45c0 .26-.05.5-.15.73-.29.67-.97 1.16-1.74 1.16s-1.45-.49-1.74-1.16c-.1-.23-.15-.47-.15-.73v-18.39ZM180 151.73c0 4.14-3.36 7.5-7.5 7.5H16.5c-4.14 0-7.5-3.36-7.5-7.5V33.45c0-4.14 3.36-7.5 7.5-7.5h20.42v6.55c-1.4 2.09-2.22 4.6-2.22 7.3 0 7.23 5.88 13.11 13.11 13.11s13.11-5.88 13.11-13.11c0-2.7-.82-5.21-2.22-7.29v-6.55h71.59v6.55c-1.4 2.09-2.22 4.6-2.22 7.29 0 7.23 5.88 13.11 13.11 13.11s13.11-5.88 13.11-13.11c0-2.7-.82-5.21-2.22-7.3v-6.55h20.42c4.14 0 7.5 3.36 7.5 7.5v118.28Z'/%3E%3Cpath d='M47.57 57.32h-10.56c-5.24 0-9.5 4.26-9.5 9.5v10.56c0 5.24 4.26 9.5 9.5 9.5h10.56c5.24 0 9.5-4.26 9.5-9.5v-10.56c0-5.24-4.26-9.5-9.5-9.5ZM48.07 77.39c0 .28-.22.5-.5.5h-10.56c-.28 0-.5-.22-.5-.5v-10.56c0-.28.22-.5.5-.5h10.56c.28 0 .5.22.5.5v10.56Z'/%3E%3Cpath d='M82.67 57.32h-10.56c-5.24 0-9.5 4.26-9.5 9.5v10.56c0 5.24 4.26 9.5 9.5 9.5h10.56c5.24 0 9.5-4.26 9.5-9.5v-10.56c0-5.24-4.26-9.5-9.5-9.5ZM83.17 77.39c0 .28-.22.5-.5.5h-10.56c-.28 0-.5-.22-.5-.5v-10.56c0-.28.22-.5.5-.5h10.56c.28 0 .5.22.5.5v10.56Z'/%3E%3Cpath d='M117.33 57.32h-10.56c-5.24 0-9.5 4.26-9.5 9.5v10.56c0 5.24 4.26 9.5 9.5 9.5h10.56c5.24 0 9.5-4.26 9.5-9.5v-10.56c0-5.24-4.26-9.5-9.5-9.5ZM117.83 77.39c0 .28-.22.5-.5.5h-10.56c-.28 0-.5-.22-.5-.5v-10.56c0-.28.22-.5.5-.5h10.56c.28 0 .5.22.5.5v10.56Z'/%3E%3Cpath d='M152 57.32h-10.56c-5.24 0-9.5 4.26-9.5 9.5v10.56c0 5.24 4.26 9.5 9.5 9.5h10.56c5.24 0 9.5-4.26 9.5-9.5v-10.56c0-5.24-4.26-9.5-9.5-9.5ZM152.5 77.39c0 .28-.22.5-.5.5h-10.56c-.28 0-.5-.22-.5-.5v-10.56c0-.28.22-.5.5-.5h10.56c.28 0 .5.22.5.5v10.56Z'/%3E%3Cpath d='M47.57 89.47h-10.56c-5.24 0-9.5 4.26-9.5 9.5v10.56c0 5.24 4.26 9.5 9.5 9.5h10.56c5.24 0 9.5-4.26 9.5-9.5v-10.56c0-5.24-4.26-9.5-9.5-9.5ZM48.07 109.54c0 .28-.22.5-.5.5h-10.56c-.28 0-.5-.22-.5-.5v-10.56c0-.28.22-.5.5-.5h10.56c.28 0 .5.22.5.5v10.56Z'/%3E%3Cpath d='M82.67 89.47h-10.56c-5.24 0-9.5 4.26-9.5 9.5v10.56c0 5.24 4.26 9.5 9.5 9.5h10.56c5.24 0 9.5-4.26 9.5-9.5v-10.56c0-5.24-4.26-9.5-9.5-9.5ZM83.17 109.54c0 .28-.22.5-.5.5h-10.56c-.28 0-.5-.22-.5-.5v-10.56c0-.28.22-.5.5-.5h10.56c.28 0 .5.22.5.5v10.56Z'/%3E%3Cpath d='M117.33 89.47h-10.56c-5.24 0-9.5 4.26-9.5 9.5v10.56c0 5.24 4.26 9.5 9.5 9.5h10.56c5.24 0 9.5-4.26 9.5-9.5v-10.56c0-5.24-4.26-9.5-9.5-9.5ZM117.83 109.54c0 .28-.22.5-.5.5h-10.56c-.28 0-.5-.22-.5-.5v-10.56c0-.28.22-.5.5-.5h10.56c.28 0 .5.22.5.5v10.56Z'/%3E%3Cpath d='M152 89.47h-10.56c-5.24 0-9.5 4.26-9.5 9.5v10.56c0 5.24 4.26 9.5 9.5 9.5h10.56c5.24 0 9.5-4.26 9.5-9.5v-10.56c0-5.24-4.26-9.5-9.5-9.5ZM152.5 109.54c0 .28-.22.5-.5.5h-10.56c-.28 0-.5-.22-.5-.5v-10.56c0-.28.22-.5.5-.5h10.56c.28 0 .5.22.5.5v10.56Z'/%3E%3Cpath d='M47.57 121.62h-10.56c-5.24 0-9.5 4.26-9.5 9.5v10.56c0 5.24 4.26 9.5 9.5 9.5h10.56c5.24 0 9.5-4.26 9.5-9.5v-10.56c0-5.24-4.26-9.5-9.5-9.5ZM48.07 141.69c0 .28-.22.5-.5.5h-10.56c-.28 0-.5-.22-.5-.5v-10.56c0-.28.22-.5.5-.5h10.56c.28 0 .5.22.5.5v10.56Z'/%3E%3Cpath d='M82.67 121.62h-10.56c-5.24 0-9.5 4.26-9.5 9.5v10.56c0 5.24 4.26 9.5 9.5 9.5h10.56c5.24 0 9.5-4.26 9.5-9.5v-10.56c0-5.24-4.26-9.5-9.5-9.5ZM83.17 141.69c0 .28-.22.5-.5.5h-10.56c-.28 0-.5-.22-.5-.5v-10.56c0-.28.22-.5.5-.5h10.56c.28 0 .5.22.5.5v10.56Z'/%3E%3Cpath d='M117.33 121.62h-10.56c-5.24 0-9.5 4.26-9.5 9.5v10.56c0 5.24 4.26 9.5 9.5 9.5h10.56c5.24 0 9.5-4.26 9.5-9.5v-10.56c0-5.24-4.26-9.5-9.5-9.5ZM117.83 141.69c0 .28-.22.5-.5.5h-10.56c-.28 0-.5-.22-.5-.5v-10.56c0-.28.22-.5.5-.5h10.56c.28 0 .5.22.5.5v10.56Z'/%3E%3Cpath d='M152 121.62h-10.56c-5.24 0-9.5 4.26-9.5 9.5v10.56c0 5.24 4.26 9.5 9.5 9.5h10.56c5.24 0 9.5-4.26 9.5-9.5v-10.56c0-5.24-4.26-9.5-9.5-9.5ZM152.5 141.69c0 .28-.22.5-.5.5h-10.56c-.28 0-.5-.22-.5-.5v-10.56c0-.28.22-.5.5-.5h10.56c.28 0 .5.22.5.5v10.56Z'/%3E%3C/svg%3E");
}
.sp-bottom-cta a.randsel .icon {
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 163.39'%3E%3Cpath d='M26.54 126.66c-5.52 0-10.02 4.5-10.02 10.02s4.49 10.02 10.02 10.02 10.02-4.5 10.02-10.02-4.49-10.02-10.02-10.02ZM26.54 138.9c-1.22 0-2.22-1-2.22-2.22s1-2.22 2.22-2.22 2.22 1 2.22 2.22-1 2.22-2.22 2.22Z'/%3E%3Cpath d='M75.82 126.66c-5.52 0-10.02 4.5-10.02 10.02s4.49 10.02 10.02 10.02 10.02-4.5 10.02-10.02-4.49-10.02-10.02-10.02ZM75.82 138.9c-1.22 0-2.22-1-2.22-2.22s1-2.22 2.22-2.22 2.22 1 2.22 2.22-1 2.22-2.22 2.22Z'/%3E%3Cpath d='M196.14 41.96c-5.77-20.37-16.07-25.6-23.69-26.39-2.69-.28-5.26-.05-7.71.62-1.66-2.6-3.67-4.96-6.03-7.03-6.71-5.9-15.77-9.15-25.51-9.15-.35 0-.7.01-1.04.02-.03 0-.06 0-.09 0H38.33s-.09 0-.13 0C19.22.58 0 14.09 0 38.84v5.52h0v119.03h159.31c3.63 0 7.41-1.91 9.48-6.74 5.6-2.64 11.69-8.2 17.34-18.95 6.47-12.3 11.07-29 12.96-47.04 1.89-18.04.84-35.33-2.95-48.7ZM154.28 17.15c.91.94 1.73 1.95 2.48 3.02.29.42.57.85.84 1.29.85 1.4 1.56 2.91 2.14 4.5 0 0 0 0 0 0 .17.48.33.96.48 1.46.33 1.08.6 2.19.8 3.35 0 0 0 0 0 0 .26 1.43.42 2.91.49 4.45.02.54.04 1.09.04 1.64v2.82h0v8.05h-58.91v-3.35h-.06v-5.52c0-.5.02-.99.04-1.48.28-6.13 2.28-12.35 6.14-17.41 5.71-7.15 14.59-10.75 23.12-11.08.44-.01.87-.03 1.32-.03 7.6 0 14.58 2.47 19.67 6.95.49.43.96.89 1.41 1.36 0 0 0 0 0 0ZM102.63 56.55h5.84v98h-5.84V56.55ZM117.31 153.57V56.55h44.22v73.55h0v8.91h0v6.82h0v1.84c0 .98-.06 1.87-.16 2.66-.02.17-.05.33-.08.49-.39 2.37-1.19 3.73-1.98 3.73h-41.99v-.99ZM170.38 52.13v-9.93h0v-1.96c2.89 4.83 8.4 19.66 5.44 47.98-1.17 11.15-3.19 19.99-5.44 26.85v-62.95ZM8.85 154.53V44.36h0v-5.52c0-19.97 15.3-29.53 29.55-29.98h69.07c-7.59 6.1-12.96 15.3-13.65 27.35-.01.23-.02.47-.03.7-.03.64-.05 1.28-.05 1.93v5.52h0v110.17H8.85ZM191.33 89.85c-1.76 16.83-6.17 32.94-12.1 44.22-2.22 4.23-5.2 8.81-8.85 12.13v-2.7h0v-6.23h0v-3.39c5.66-9.05 11.06-24.42 13.2-44.83 2.1-20.06.04-33.68-2.05-41.57-1.25-4.72-4.81-15.78-10.69-16.39-.27-.03-.54-.03-.82 0-.17-1.33-.41-2.63-.7-3.89 0 0 0 0 0 0-.3-1.29-.68-2.53-1.1-3.75.68-.11 1.37-.18 2.08-.18.45 0 .9.02 1.35.07 9.47.99 14.47 11.84 17 20.76 3.47 12.26 4.45 28.94 2.69 45.77Z'/%3E%3C/svg%3E");
}
.sp-bottom-cta.is-visible {
  opacity: 1;
  pointer-events: auto;
}

.site-footer {
  color: #555555;
  font-size: clamp(11px, 11px + 0.23vw, 13px);
}
.site-footer__menu {
  background-color: #f5f5f5;
}
.site-footer {
  /* 上部ナビ：4カラム共通 */
}
.site-footer__col {
  flex: 0 0 22%;
}
.site-footer {
  /* details + summary ベース（共通） */
}
.site-footer__details {
  margin: 0 0 1.8em;
  border: 0;
  padding: 0;
}
.site-footer__summary {
  list-style: none;
  font-size: 107.69%;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.08em;
  margin: 0 0 0.7em;
  color: #333333;
  text-align: left;
  cursor: default;
}
.site-footer__summary::-webkit-details-marker {
  display: none;
}
.site-footer__panel {
  margin: 0;
}
.site-footer__link {
  display: block;
  text-decoration: none;
  color: #666666;
  line-height: 1.7;
  transition: color 0.15s ease;
}
.site-footer__link:hover {
  color: #b48c6b;
}
.site-footer__panel .site-footer__link + .site-footer__link {
  margin-top: 0.45em;
}
.site-footer {
  /* SNS */
}
.site-footer__sns {
  width: min(1120px, 80%);
  margin: 4em auto 0;
}
.site-footer__sns-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 5%;
  list-style: none;
  margin: 0;
  padding: 0;
}
.site-footer__sns-link {
  display: inline-block;
}
.site-footer__sns-link img {
  display: block;
  max-width: 65px;
  max-height: 30px;
  margin-bottom: 0;
}
.rakuten-furusato-nouzei .site-footer__sns-link img {
  max-width: none;
}
.site-footer {
  /* ブランドロゴ & コピー */
}
.site-footer__brand {
  margin-top: 4em;
  text-align: center;
}
.site-footer__logo {
  height: auto;
  max-width: 80%;
  max-height: 40px;
  margin: 0 auto;
}
.site-footer__brand-caption {
  margin-top: 0.8em;
  font-size: clamp(11.2px, 10.624px + 0.18vw, 12.8px);
  letter-spacing: 0.08em;
  color: #777777;
}
.site-footer__copy {
  background-color: #f5f5f5;
  padding: 1em 5%;
  margin-top: 3em;
  text-align: center;
}
.site-footer__copy a {
  text-decoration: none;
  color: #777777;
  transition: color 0.15s ease;
}
.site-footer__copy a:hover {
  color: #b48c6b;
}

/* ===== PC レイアウト（md以上） ===== */
@media (min-width: 768px) {
  .site-footer {
    border-top: 1px solid white;
  }
  .site-footer__menu {
    padding: 5% 0 calc(5% - 1.8em);
  }
  .site-footer__nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    column-gap: 4%;
    width: min(1120px, 90%);
    margin: 0 auto;
  }
  .site-footer__panel {
    padding-left: 1em;
  }
  .site-footer {
    /* 下部テキストリンク（共通） */
  }
  .site-footer__bottom-nav {
    padding-top: 1.8em;
  }
  .site-footer__bottom-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    column-gap: 2.4em;
    list-style: none;
    margin: 0;
    padding: 0;
  }
  .site-footer__bottom-list > li {
    width: auto;
    margin: 0;
    padding: 0;
  }
  .site-footer__bottom-link {
    text-decoration: none;
    color: #777777;
    letter-spacing: 0.08em;
    line-height: 1.7;
    transition: color 0.15s ease;
  }
  .site-footer__bottom-link:hover {
    color: #b48c6b;
  }
}
/* ===== SP＋タブレット（md未満）共通 ===== */
@media (max-width: 767px) {
  .site-footer__top {
    padding: 0;
  }
  .site-footer__nav {
    border-top: 1px solid #ccc;
  }
  .site-footer__col {
    flex: 0 0 100%;
  }
  .site-footer__bottom-list {
    justify-content: flex-start;
    display: block;
    width: 100%;
  }
  .site-footer__bottom-list li {
    font-size: inherit !important;
    width: 100%;
  }
  .site-footer__bottom-list li .site-footer__bottom-link {
    font-size: inherit !important;
    width: 100% !important;
    border-top: none !important;
    border-right: none !important;
    border-left: none !important;
    border-bottom: 1px solid #ccc !important;
  }
  .site-footer {
    /* details アコーディオン */
  }
  .site-footer__details {
    margin: 0;
    overflow: hidden;
  }
  .site-footer__summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    border-bottom: 1px solid #ccc;
    margin: 0;
    padding: 1em 5%;
  }
  .site-footer__summary::after {
    content: "+";
    font-size: 120%;
    line-height: 1;
    margin-left: 8px;
    display: inline-block;
    transition: transform 0.25s ease;
  }
  .site-footer__details[open] .site-footer__summary::after {
    content: "−";
    transform: rotate(180deg);
  }
  .site-footer__panel {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.25s ease;
  }
  .site-footer__details[open] .site-footer__panel {
    max-height: 500px;
  }
  .site-footer__panel .site-footer__link + .site-footer__link {
    margin-top: 0;
  }
  .site-footer__link {
    background-color: #fff;
    display: block;
    padding: 1em 5% 1em calc(5% + 1em);
    border-bottom: 1px solid #ccc;
  }
  .site-footer__bottom-list {
    padding: 0;
  }
  .site-footer__bottom-link {
    background-color: #fff;
    display: block;
    padding: 1em 5%;
    border-bottom: 1px solid #ccc;
  }
}
.to-top {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-size: min(2.8vw, 16px);
  width: 5em;
  height: 5em;
  padding: 0 0 0.25em;
  border-radius: 999px;
  border: none;
  background-color: white;
  color: #7b5aa8;
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.18);
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  position: fixed;
  right: 1.5rem;
  bottom: 1.5rem;
  z-index: 50;
  transform: translateY(8px);
  transition: opacity 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease, color 0.2s ease, background-color 0.2s ease;
}
.to-top.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
.to-top__icon {
  display: block;
  font-size: 2em;
  background-color: #7b5aa8;
  width: 1em;
  aspect-ratio: 1;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cpath fill='%23202020' d='M48 28L32 12 16 28l4.24 4.24 8.76-8.76V52h6V23.49l8.76 8.76L48 28z'/%3E%3C/svg%3E");
  mask-position: center;
  mask-repeat: no-repeat;
  mask-size: contain;
  transition: background-color 0.2s ease;
}
.to-top__text {
  display: block;
  font-size: 0.5em;
}
@media (any-hover: hover) {
  .to-top:hover {
    background-color: #7b5aa8;
    color: white;
    box-shadow: 0 16px 32px rgba(0, 0, 0, 0.22);
  }
  .to-top:hover .to-top__icon {
    background-color: white;
  }
}

@media (max-width: 576px) {
  .to-top {
    right: 0.5rem;
    bottom: calc(14vw + 0.5rem);
  }
}
/* Slider */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0;
}
.slick-list:focus {
  outline: none;
}
.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.slick-track:before, .slick-track:after {
  content: "";
  display: table;
}
.slick-track:after {
  clear: both;
}
.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
}
[dir=rtl] .slick-slide {
  float: right;
}
.slick-slide img {
  display: block;
}
.slick-slide.slick-loading img {
  display: none;
}
.slick-slide {
  display: none;
}
.slick-slide.dragging img {
  pointer-events: none;
}
.slick-initialized .slick-slide {
  display: block;
}
.slick-loading .slick-slide {
  visibility: hidden;
}
.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
  display: none;
}

/* Slider */
.slick-loading .slick-list {
  background: #fff url("./ajax-loader.gif") center center no-repeat;
}

/* Icons */
@font-face {
  font-family: "slick";
  src: url("./fonts/slick.eot");
  src: url("./fonts/slick.eot?#iefix") format("embedded-opentype"), url("./fonts/slick.woff") format("woff"), url("./fonts/slick.ttf") format("truetype"), url("./fonts/slick.svg#slick") format("svg");
  font-weight: normal;
  font-style: normal;
}
/* Arrows */
.slick-prev,
.slick-next {
  position: absolute;
  display: block;
  height: 20px;
  width: 20px;
  line-height: 0px;
  font-size: 0px;
  cursor: pointer;
  background: transparent;
  color: transparent;
  top: 50%;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  padding: 0;
  border: none;
  outline: none;
}
.slick-prev:hover, .slick-prev:focus,
.slick-next:hover,
.slick-next:focus {
  outline: none;
  background: transparent;
  color: transparent;
}
.slick-prev:hover:before, .slick-prev:focus:before,
.slick-next:hover:before,
.slick-next:focus:before {
  opacity: 1;
}
.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before {
  opacity: 0.25;
}
.slick-prev:before,
.slick-next:before {
  font-family: "slick";
  font-size: 20px;
  line-height: 1;
  color: white;
  opacity: 0.75;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slick-prev {
  left: -25px;
}
[dir=rtl] .slick-prev {
  left: auto;
  right: -25px;
}
.slick-prev:before {
  content: "←";
}
[dir=rtl] .slick-prev:before {
  content: "→";
}

.slick-next {
  right: -25px;
}
[dir=rtl] .slick-next {
  left: -25px;
  right: auto;
}
.slick-next:before {
  content: "→";
}
[dir=rtl] .slick-next:before {
  content: "←";
}

/* Dots */
.slick-dotted.slick-slider {
  margin-bottom: 30px;
}

.slick-dots {
  position: absolute;
  bottom: -25px;
  list-style: none;
  display: block;
  text-align: center;
  padding: 0;
  margin: 0;
  width: 100%;
}
.slick-dots li {
  position: relative;
  display: inline-block;
  height: 20px;
  width: 20px;
  margin: 0 5px;
  padding: 0;
  cursor: pointer;
}
.slick-dots li button {
  border: 0;
  background: transparent;
  display: block;
  height: 20px;
  width: 20px;
  outline: none;
  line-height: 0px;
  font-size: 0px;
  color: transparent;
  padding: 5px;
  cursor: pointer;
}
.slick-dots li button:hover, .slick-dots li button:focus {
  outline: none;
}
.slick-dots li button:hover:before, .slick-dots li button:focus:before {
  opacity: 1;
}
.slick-dots li button:before {
  position: absolute;
  top: 0;
  left: 0;
  content: "•";
  width: 20px;
  height: 20px;
  font-family: "slick";
  font-size: 6px;
  line-height: 20px;
  text-align: center;
  color: black;
  opacity: 0.25;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.slick-dots li.slick-active button:before {
  color: black;
  opacity: 0.75;
}

/*# sourceMappingURL=style.css.map */
