@charset "UTF-8";
/* ===============================================
  * Header - ヘッダーのスタイル *
=============================================== */
.global-header {
  --brand-logo-width: 15.4rem;
  --link-arrow: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI1Ljc1MSIgaGVpZ2h0PSIxMCIgdmlld0JveD0iMCAwIDUuNzUxIDEwIj4gPHBhdGggaWQ9IuODkeOCuV80NTkyIiBkYXRhLW5hbWU9IuODkeOCuSA0NTkyIiBkPSJNLjIyLDUuNTMxYS43NTEuNzUxLDAsMCwxLDAtMS4wNjJMNC40NjkuMjJBLjc1MS43NTEsMCwxLDEsNS41MzEsMS4yODJMMS44MTMsNSw1LjUzMSw4LjcxOEEuNzUxLjc1MSwwLDEsMSw0LjQ2OSw5Ljc4WiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoNS43NTEgMTApIHJvdGF0ZSgtMTgwKSIgZmlsbD0iIzUyOGE5ZiIgZmlsbC1ydWxlPSJldmVub2RkIi8+PC9zdmc+");
  --link-arrow-offset: 0.75px;
}
.global-header summary {
  cursor: pointer;
}
.global-header summary::marker,
.global-header summary::-webkit-details-marker {
  display: none;
}
.global-header__text--link {
  color: var(--color-text-default);
  font-size: 1.2rem;
  letter-spacing: 0.03em;
  line-height: 1.6;
  text-decoration: none;
}
.global-header__search-container {
  --search-button-width: 2rem;
  --padding-horizontal: 2rem;
  position: relative;
  border: 1px solid var(--color-primary);
  border-radius: 100vh;
  color: var(--color-primary);
  overflow: hidden;
}
.global-header__search-form input {
  width: 100%;
  padding-right: calc(
    var(--padding-horizontal) * 1 + var(--search-button-width)
  );
  padding-left: var(--padding-horizontal);
  border: none;
  box-sizing: border-box;
  font-size: 1.6rem;
}
.global-header__search-form input::placeholder {
  font-size: 1.4rem;
  opacity: 0.5;
}
.global-header__search-button {
  position: absolute;
  top: 0;
  right: var(--padding-horizontal);
  bottom: 0;
  display: grid;
  place-content: center;
  width: var(--search-button-width);
  aspect-ratio: 1;
  margin: auto;
  color: var(--color-text-default);
}
.global-header__search-button a {
  color: var(--color-text-default);
}
.global-header .header__content-wrapper--ticker {
  background-color: var(--color-global-nav);
}
.global-header .header__content-wrapper--primary {
  background-color: var(--color-white);
}
.global-header .header__content-wrapper--primary .header__content-inner {
  display: grid;
  align-items: center;
  grid-template-columns: 1fr auto 1fr;
}
.global-header .header__content-wrapper--global-nav {
  position: relative;
  background-color: var(--color-white);
}
.global-header .header__content-wrapper--global-nav::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 2;
  width: 100%;
  border-bottom: var(--border-style);
  pointer-events: none;
}
.global-header .header__content-wrapper--global-nav .header__content-inner {
  display: grid;
  place-content: center;
}
.global-header .ticker__list-item {
  --color-text: var(--color-white);
  --color-bg: var(--color-gray-500);
}
.global-header .ticker__list-item > * {
  display: -webkit-box;
  text-overflow: ellipsis;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  padding: 0 2rem;
  background-color: var(--color-bg);
  color: var(--color-text);
  font-size: 1rem;
  letter-spacing: 0.03em;
  line-height: var(--height-ticker);
  text-align: center;
  text-decoration: none;
}
.global-header .header-primary__brand-logo-wrapper {
  width: var(--brand-logo-width);
}
.global-header
  .header-primary__navigation-container
  .header-primary__navigation-contents-wrapper {
  display: flex;
  justify-content: flex-end;
}
.global-header .header-primary__navigation-item-wrapper--cart {
  --count-num-width: 1.8rem;
  --indicator-width: 0.8rem;
  position: relative;
}
.global-header
  .header-primary__navigation-item-wrapper--cart[data-cart-indicator="count"]
  .cart-state--dot {
  display: none !important;
}
.global-header
  .header-primary__navigation-item-wrapper--cart[data-cart-indicator="dot"]
  .cart-state--count {
  display: none !important;
}
.global-header
  .header-primary__navigation-item-wrapper--cart
  .cart-state--count {
  position: absolute;
  top: calc(var(--count-num-width) / 4 * -1);
  right: calc(var(--count-num-width) / 4 * -1);
  z-index: 2;
  display: grid;
  place-items: center;
  width: var(--count-num-width);
  aspect-ratio: 1;
  background-color: #008cd6;
  border-radius: 100vh;
  overflow: hidden;
  color: var(--color-white);
  font-family: var(--font-en);
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 1;
  pointer-events: none;
}
.global-header
  .header-primary__navigation-item-wrapper--cart
  .cart-state--count
  > span {
  margin: var(--adjust-position-top, 0px) var(--adjust-position-right, 0px)
    var(--adjust-position-bottom, 0px) var(--adjust-position-left, 0px);
}
.global-header .header-primary__navigation-item-wrapper--cart .cart-state--dot {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 2;
  width: var(--indicator-width);
  aspect-ratio: 1;
  background-color: var(--color-emphasis);
  border-radius: 50%;
  overflow: hidden;
  pointer-events: none;
}
/* --- for small viewport --- */
@media screen and (max-width: 767px) {
  .global-header.is-fixed {
    box-shadow: 0px 0.1rem 0.3rem 0px rgba(0, 0, 0, 0.1);
  }
  .global-header .header__content-wrapper--primary .header__content-inner {
    padding-inline: 1.5rem;
  }
  .global-header .header-primary__hamburger-menu-container {
    justify-self: flex-start;
    grid-column: 1;
    grid-row: 1;
  }
  .global-header .header-primary__brand-logo-wrapper {
    grid-column: 2;
    grid-row: 1;
    padding-block: 1rem;
  }
  .header-primary__navigation-container {
    grid-column: 3;
    grid-row: 1;
  }
  .global-header .header-primary__search {
    grid-column: 1 / span 3;
    grid-row: 2;
  }
  .global-header
    .header-primary__navigation-container
    .header-primary__navigation-contents-wrapper {
    gap: 1.2rem;
  }
  .header-primary__search {
    padding-block-start: 1rem;
    padding-block-end: 2rem;
    padding-inline: 1.5rem;
  }
}
/* --- for large viewport --- */
@media screen and (min-width: 768px) {
  .global-header {
    box-shadow: 0px 0.1rem 0.3rem 0px rgba(0, 0, 0, 0.1);
  }
  .global-header .header__content-wrapper--primary .header__content-inner {
    padding-inline: 3rem;
  }
  .global-header
    .header-primary__navigation-container
    .header-primary__navigation-contents-wrapper {
    gap: 2rem;
  }
}

/* ===============================================
  * ヘッダーの固定方式 *
=============================================== */
.global-header {
  position: relative;
  z-index: var(--zindex-header);
}
.global-header[data-stick-header] {
  position: sticky;
  top: calc(var(--height-ticker) * -1);
}
.global-header[data-variable-header] {
  position: sticky;
  top: calc(var(--height-ticker) * -1);
}
.global-header[data-variable-header] [data-header-area="primary"] {
  position: relative;
  z-index: 2;
}
.global-header[data-variable-header] [data-header-area="global-nav"] {
  transition: translate var(--transition-default);
}
.global-header[data-variable-header][data-scroll-direction="down"]
  [data-header-area="global-nav"] {
  z-index: -1;
  translate: 0 -100%;
}

.hamburger-menu__text--section-title {
  padding-block: 1.2rem;
  padding-inline: 1.5rem;
  background-color: var(--color-quinary);
  font-size: 1.5rem;
  color: var(--color-secondary);
  line-height: calc(21 / 15);
  font-weight: 700;
  letter-spacing: 0.05em;
}
.hamburger-menu__text--section-title[data-title-bg="active"] {
  background-color: var(--color-quinary);
}
.hamburger-menu__text--link {
  display: grid;
  align-items: center;
  column-gap: 1ch;
  grid-template-columns: 1fr 0.6rem;
  padding: var(--padding-content);
  color: var(--color-black);
  letter-spacing: 0.05em;
  line-height: calc(20 / 14);
  text-decoration: none;
}
.hamburger-menu__text--link::after {
  content: "";
  width: 100%;
  height: 100%;
  background-image: var(--link-arrow);
  background-position-y: calc(50% + var(--link-arrow-offset));
  background-repeat: no-repeat;
  background-size: contain;
}
.hamburger-menu__button--mail {
  --mail-icon-width: 2.7rem;
  display: grid;
  align-items: center;
  column-gap: 1rem;
  justify-content: center;
  grid-template-columns: var(--mail-icon-width) auto;
  width: calc(100% - 3rem);
  margin: auto;
  padding: 1.6rem 1.8rem;
  background-color: #efefef;
  color: var(--color-gray-500);
  text-align: center;
  text-decoration: none;
}
.hamburger-menu__button--mail::before {
  content: "";
  aspect-ratio: 25/17;
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2225.074%22%20height%3D%2217.63%22%20viewBox%3D%220%200%2025.074%2017.63%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_325%22%20data-name%3D%22%E3%83%91%E3%82%B9%20325%22%20d%3D%22M359.815%2C101.721l-7.6%2C7.555%2C7.6%2C7.556a2.179%2C2.179%2C0%2C0%2C0%2C.221-.944V102.665A2.178%2C2.178%2C0%2C0%2C0%2C359.815%2C101.721Z%22%20transform%3D%22translate(-334.962%20-100.461)%22%20fill%3D%22%23afb0b1%22%2F%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_326%22%20data-name%3D%22%E3%83%91%E3%82%B9%20326%22%20d%3D%22M47.332%2C76H26.665a2.178%2C2.178%2C0%2C0%2C0-.944.221l9.719%2C9.67a2.206%2C2.206%2C0%2C0%2C0%2C3.116%2C0l9.719-9.67A2.178%2C2.178%2C0%2C0%2C0%2C47.332%2C76Z%22%20transform%3D%22translate(-24.461%20-76)%22%20fill%3D%22%23afb0b1%22%2F%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_327%22%20data-name%3D%22%E3%83%91%E3%82%B9%20327%22%20d%3D%22M.221%2C101.721a2.178%2C2.178%2C0%2C0%2C0-.221.944v13.223a2.178%2C2.178%2C0%2C0%2C0%2C.221.944l7.6-7.556Z%22%20transform%3D%22translate(0%20-100.461)%22%20fill%3D%22%23afb0b1%22%2F%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_328%22%20data-name%3D%22%E3%83%91%E3%82%B9%20328%22%20d%3D%22M40.671%2C277.211%2C39.6%2C278.287a3.677%2C3.677%2C0%2C0%2C1-5.194%2C0l-1.076-1.076-7.6%2C7.555a2.178%2C2.178%2C0%2C0%2C0%2C.944.221H47.332a2.178%2C2.178%2C0%2C0%2C0%2C.944-.221Z%22%20transform%3D%22translate(-24.461%20-267.357)%22%20fill%3D%22%23afb0b1%22%2F%3E%3C%2Fsvg%3E");
  background-repeat: no-repeat;
  background-size: contain;
}
.hamburger-menu__button--mail > span {
  display: flex;
  align-items: center;
  column-gap: 1ch;
  font-size: 1.3rem;
  font-weight: bold;
}
.hamburger-menu__button--mail > span > small {
  font-size: 0.6em;
  font-weight: normal;
}
.hamburger-menu__wrapper {
  --hamburger-icon-width: 2.6rem;
  --hamburger-icon-position: 1.6rem;
  --padding-content: 1.5rem 1.5rem;
}
.hamburger-menu__toggle-button {
  --hamburger-transition-duration: 300ms;
  --hamburger-transition-default: var(--hamburger-transition-duration) ease;
  --hamburger-transition-delay: var(--hamburger-transition-duration);
  --icon-width: 2.6rem;
  --icon-height: 1.8rem;
  --icon-border-height: 0.4rem;
  display: grid;
  place-content: center;
  width: var(--hamburger-icon-width);
  aspect-ratio: 1;
  padding: 0;
  background-color: transparent;
  overflow: hidden;
  transition: translate var(--hamburger-menu-transition);
}
.hamburger-menu__toggle-button-inner {
  position: relative;
  display: block;
  width: var(--icon-width);
  height: var(--icon-height);
}
.hamburger-menu__toggle-button-inner > span {
  position: absolute;
  display: block;
  width: 100%;
  height: var(--icon-border-height);
  border-radius: 100vh;
  background-color: var(--color-accent);
  transform-origin: center;
  scale: 1 0.5;
}
.hamburger-menu__toggle-button-inner > span:first-of-type {
  top: 0;
  transition: rotate var(--hamburger-transition-default),
    translate var(--hamburger-transition-default)
      var(--hamburger-transition-delay);
}
[aria-expanded="true"]
  .hamburger-menu__toggle-button-inner
  > span:first-of-type {
  top: calc(var(--icon-border-height) / 2 * -1);
  translate: 0 calc(var(--icon-height) / 2);
  rotate: 45deg;
  transition: translate var(--hamburger-transition-default),
    rotate var(--hamburger-transition-default) var(--hamburger-transition-delay);
}
.hamburger-menu__toggle-button-inner > span:nth-of-type(2) {
  top: 0;
  bottom: 0;
  margin: auto;
  transition: opacity 0ms ease var(--hamburger-transition-delay);
}
[aria-expanded="true"]
  .hamburger-menu__toggle-button-inner
  > span:nth-of-type(2) {
  opacity: 0;
}
.hamburger-menu__toggle-button-inner > span:last-of-type {
  bottom: 0;
  transition: rotate var(--hamburger-transition-default),
    translate var(--hamburger-transition-default)
      var(--hamburger-transition-delay);
}
[aria-expanded="true"]
  .hamburger-menu__toggle-button-inner
  > span:last-of-type {
  bottom: calc(var(--icon-border-height) / 2 * -1);
  translate: 0 calc(var(--icon-height) / 2 * -1);
  rotate: -45deg;
  transition: translate var(--hamburger-transition-default),
    rotate var(--hamburger-transition-default) var(--hamburger-transition-delay);
}
.hamburger-menu__contents-wrapper {
  position: fixed;
  top: 0;
  left: 0;
  z-index: var(--zindex-hamburgermenu-contents);
  width: calc(
    100% - (var(--hamburger-icon-width) + var(--hamburger-icon-position) * 2)
  );
  height: 100dvh;
  background-color: var(--color-white);
  overflow-y: auto;
  box-shadow: 0px 0.3rem 0.6rem 0px rgba(0, 0, 0, 0.16);
}
.hamburger-menu__contents-wrapper .global-header__search-container {
  border: var(--border-style);
  border-radius: 0.5rem;
  overflow: hidden;
}
.hamburger-menu__contents-wrapper .global-header__search-container input {
  border-radius: 0.5rem;
  line-height: 5rem;
}
.hamburger-menu__section[data-section-name="hamburger-mail-magazine"] {
  margin-top: 1.6rem;
}
.hamburger-menu__section[data-section-name="hamburger-sns-area"] {
  margin-top: 3.6rem;
}
.hamburger-menu__section[data-section-name="hamburger-sns-area"]
  .brand-sns__link-list {
  --gap: 2.8rem;
  display: flex;
  flex-wrap: wrap;
  gap: calc(var(--gap) / 2) var(--gap);
  justify-content: center;
  margin-top: 1.8rem;
}
.hamburger-menu__section[data-section-name="hamburger-sns-area"]
  .brand-sns__link-list-item {
  width: 3rem;
  aspect-ratio: 1;
}
.hamburger-menu__section[data-section-name="hamburger-sns-area"]
  .brand-sns__link-list-item
  a {
  color: var(--color-gray-500);
}
.m-hamburger-menu__navigation-buttons {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  padding-block: 2rem;
  padding-inline: 1.5rem;
}
.c-hamburger-menu__navigation-button {
  --button-min-width: 100%;
  --button-font-size: 1.4rem;
  --button-line-height: calc(20 / 14);
  padding-block: 1rem;
  font-weight: 500;
}
.hamburger-menu__content-wrapper {
  padding: var(--padding-content);
}
.hamburger-menu__content-list > li:not(:last-of-type) {
  border-bottom: 1px solid var(--color-gray-200);
}
.hamburger-menu__bg {
  position: fixed;
  top: 0;
  left: 0;
  z-index: var(--zindex-hamburgermenu-bg);
  width: 100%;
  height: 100%;
  background-color: rgba(252, 252, 252, .95);
  opacity: 0;
  transition: opacity 200ms ease-in;
}

/* ===============================================
  * ハンバーガーメニューのアニメーション *
=============================================== */
/* アニメーションの基本設定 */
[data-animation-type] {
  --hamburger-menu-transition: 300ms ease-in-out;
}

/* ハンバーガーメニューが有効になった時の設定 */
#hamburger-menu[data-state="active"] .hamburger-menu__contents-wrapper {
  opacity: 1;
  translate: 0 0;
}
#hamburger-menu[data-state="active"] .hamburger-menu__bg {
  opacity: 1;
}

/* フェードして表示 */
[data-animation-type="fade"] .hamburger-menu__contents-wrapper {
  opacity: 0;
  transition: opacity var(--hamburger-menu-transition);
}

/* 横方向にスライドして表示 */
[data-animation-type="horizontal-slide"] .hamburger-menu__contents-wrapper {
  translate: -100% 0;
  transition: translate var(--hamburger-menu-transition);
  will-change: translate;
}

/* 縦方向にスライドして表示 */
[data-animation-type="vertical-slide"] .hamburger-menu__contents-wrapper {
  translate: 0 -120%;
  transition: translate var(--hamburger-menu-transition);
  will-change: translate;
}
[data-animation-type="vertical-slide"][data-hamburgermenu-type="same-level"]
  .hamburger-menu__contents-wrapper {
  z-index: -1;
}
[data-animation-type="vertical-slide"][data-hamburgermenu-type="same-level"]
  .hamburger-menu__bg {
  z-index: -2;
}

/* ハンバーガーメニューが画面全体にオーバーレイする形式 */
[data-hamburgermenu-type="overlay"]
  .hamburger-menu__toggle-button[aria-expanded="true"] {
  position: fixed;
  top: var(--hamburger-icon-position);
  right: calc(
    (var(--hamburger-icon-width) + var(--hamburger-icon-position)) * -1
  );
  z-index: var(--zindex-hamburgermenu-contents);
  translate: calc(
      (var(--hamburger-icon-width) + var(--hamburger-icon-position) * 2) * -1
    )
    0;
}
[data-hamburgermenu-type="overlay"] .hamburger-menu__contents-wrapper {
  top: 0;
  width: calc(
    100% - (var(--hamburger-icon-width) + var(--hamburger-icon-position) * 2)
  );
  height: 100dvh;
}

/* ハンバーガーメニューがヘッダーの下に表示される形式 */
[data-hamburgermenu-type="same-level"] .hamburger-menu__contents-wrapper {
  top: var(--height-header);
  width: calc(
    100% - (var(--hamburger-icon-width) + var(--hamburger-icon-position) * 2)
  );
  height: calc(100dvh - var(--height-header));
}
[data-hamburgermenu-type="same-level"] .hamburger-menu__bg {
  top: var(--height-header);
  height: calc(100dvh - var(--height-header));
}
[data-state-sticky="active"] [data-hamburgermenu-type="same-level"] {
  --height-header: calc(
    var(--height-header-primary) + var(--height-header-global-nav)
  );
}

/**
 * history
 */
.m-hamburger-menu__history-container {
  display: flex;
  gap: 0.8rem;
  padding-block-start: 1.5rem;
  padding-block-end: 3rem;
  padding-inline: 1.5rem;
  overflow: auto;
}
.c-hamburger-menu__history-item {
  position: relative;
  width: 8rem;
  flex-shrink: 0;
}
.c-hamburger-menu__history-image {
  aspect-ratio: 1 / 1;
}
.c-hamburger-menu__history-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.accordion__details {
  --accordion-icon-width: 1.4rem;
}
.accordion__summary {
  grid-template-columns: 1fr var(--accordion-icon-width);
  background-color: var(--color-white);
  transition: background var(--transition-default);
}
[data-state-accordion="opened"] > .accordion__summary {
  background-color: #fafafa;
}
.accordion__summary::after {
  content: none;
}
.accordion__icon-wrapper {
  position: relative;
  display: block;
  width: var(--accordion-icon-width);
  aspect-ratio: 1;
}
.accordion__icon-wrapper::before,
.accordion__icon-wrapper::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  margin: auto;
  background-color: var(--color-text-default);
}
.accordion__icon-wrapper::before {
  rotate: 90deg;
  transition: rotate var(--transition-default);
}
[data-state-accordion="opened"]
  > .accordion__summary
  .accordion__icon-wrapper::before {
  rotate: 180deg;
}
.accordion__content {
  border-top: var(--border-style);
}
.accordion__content [data-structure="child"] .hamburger-menu__text--link {
  font-size: 0.846em;
}

.global-nav__text--link {
  position: relative;
  display: flex;
  align-items: center;
  column-gap: 1rem;
  place-content: center;
  padding-block: 1.5rem;
  color: var(--color-text-default);
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  line-height: 1;
  text-decoration: none;
  overflow: hidden;
}
.global-nav__text--link::before {
  content: "";
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 3px;
  background-color: var(--color-secondary);
  translate: 0 100%;
  transition: translate var(--transition-default);
  pointer-events: none;
}
:where(.mega-menu__wrapper) .global-nav__text--link::after {
  content: '';
  width: 1.2rem;
  height: .7rem;
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMiIgaGVpZ2h0PSI2LjkwMSIgdmlld0JveD0iMCAwIDEyIDYuOTAxIj4gPHBhdGggaWQ9IuODkeOCuV80NTgyIiBkYXRhLW5hbWU9IuODkeOCuSA0NTgyIiBkPSJNLjI2NCw2LjYzN2EuOS45LDAsMCwxLDAtMS4yNzRsNS4xLTUuMUEuOS45LDAsMSwxLDYuNjM3LDEuNTM5TDIuMTc2LDZsNC40NjEsNC40NjFhLjkuOSwwLDEsMS0xLjI3NSwxLjI3NVoiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDAgNi45MDEpIHJvdGF0ZSgtOTApIiBmaWxsPSIjMzMzIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiLz48L3N2Zz4=");
  background-size: 100%;
  background-repeat: no-repeat;
  transition: background-image var(--transition-default);
}
.global-nav__wrapper .mega-menu__text--link {
  display: grid;
  align-items: center;
  column-gap: var(--megamenu-spacer, 2ch);
  grid-template-columns: 1fr 0.56rem;
  width: fit-content;
  color: var(--color-text-default);
  font-size: 1.4rem;
  line-height: 1.5;
  text-decoration: none;
}
.global-nav__wrapper .mega-menu__text--link::after {
  content: "";
  width: 100%;
  height: 100%;
  background-image: var(--link-arrow);
  background-position-y: calc(50% + var(--link-arrow-offset));
  background-repeat: no-repeat;
  background-size: contain;
  transition: translate var(--animation-hover), scale var(--animation-hover);
  transform-origin: left center;
  transition-timing-function: linear;
  pointer-events: none;
}
.global-nav__wrapper
  .mega-menu__wrapper[data-state="active"]
  .mega-menu__content-inner {
  translate: 0 0;
}
.global-nav__wrapper .mega-menu__wrapper[data-state="active"] .mega-menu__bg {
  opacity: 1;
}
.global-nav__wrapper .mega-menu__content {
  --megamenu-escape-area: 5svh;
  --megamenu-spacer: 1.6rem;
  position: absolute; /* MEMO: global-nav__wrapperにrelativeを設定しているため、親要素にpositionを付与しないように注意してください。 */
  top: 100%;
  left: 0;
  z-index: -1;
  width: 100%;
}
.global-nav__wrapper .mega-menu__content-inner {
  max-height: calc(100svh - var(--megamenu-escape-area) - var(--height-header));
  padding-top: 5svh;
  padding-bottom: 5svh;
  background-color: var(--color-white);
  overflow-y: auto;
  overscroll-behavior: contain;
  translate: 0 -100%;
  transition: translate var(--transition-default);
}
.global-nav__wrapper .mega-menu__content-list[data-structure="parent"] {
  display: grid;
  row-gap: calc(var(--megamenu-spacer) * 3);
}
.global-nav__wrapper .mega-menu__content-list[data-structure="parent"] > li {
  display: grid;
  align-items: flex-start;
  column-gap: 3%;
  grid-template-columns: 30% 1fr;
}
.global-nav__wrapper
  .mega-menu__content-list[data-structure="parent"]
  > li
  > a {
  font-weight: bold;
}
.global-nav__wrapper .mega-menu__content-list[data-structure="child"] {
  display: flex;
  flex-wrap: wrap;
  row-gap: var(--megamenu-spacer);
  padding: 2ch;
  background-color: var(--color-gray-100);
  border-radius: 8px;
}
.global-nav__wrapper .mega-menu__content-list[data-structure="child"] > li > * {
  padding: 0 var(--megamenu-spacer);
}
.global-nav__wrapper
  .mega-menu__content-list[data-structure="child"]
  > li:not(:last-of-type) {
  border-right: var(--border-style);
}
.global-nav__wrapper .mega-menu__bg {
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100dvh;
  background-color: rgba(0, 0, 0, 0.5);
  opacity: 0;
  transition: opacity 200ms ease-in;
  pointer-events: none;
}
.global-nav__content-list {
  display: flex;
  justify-content: center;
  column-gap: 6rem;
}

/* ===============================================
  * Footer - フッターのスタイル *
=============================================== */
.global-footer {
  --spacer-regular: 5rem;
  --spacer-medium: 4rem;
  --border-style: solid 1px var(--color-gray-300);
  --color-default-text: var(--color-black);
  --sns-icon-width: 3rem;
  --brand-logo-width: 15rem;
  background-color: var(--color-quaternary);
}
.global-footer a {
  text-decoration: none;
}
.global-footer__container {
  display: grid;
  row-gap: var(--spacer-regular);
  padding-top: var(--spacer-medium);
}
.global-footer__inner--middle {
  display: grid;
  row-gap: var(--spacer-medium);
  border-top: .5rem solid #D2E4EA;
}
.global-footer__inner--bottom {
  --color-textlink: var(--color-white);
  background-color: var(--color-primary);
  color: var(--color-white);
}
.global-footer__shell {
  width: var(--container-default);
  margin: auto;
  padding-right: var(--padding-horizontal-global) !important;
  padding-left: var(--padding-horizontal-global) !important;
}
.global-footer .static-page__link-list > li {
  border-bottom: var(--border-style);
}
.global-footer .static-page__link-text {
  --padding-vertical: 1.7rem;
  --padding-horizontal: 0.8rem;
  --arrow-width: 1.2rem;
  display: grid;
  align-items: center;
  column-gap: var(--arrow-width);
  grid-template-columns: 1fr var(--arrow-width);
  padding: var(--padding-vertical) var(--padding-horizontal)
    var(--padding-vertical) 0;
  font-size: 1.5rem;
  letter-spacing: 0.05em;
  line-height: 1.5;
}
.global-footer .static-page__link-text::after {
  content: "";
  width: var(--arrow-width);
  aspect-ratio: 1;
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2212.021%22%20height%3D%2212.021%22%20viewBox%3D%220%200%2012.021%2012.021%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_66359%22%20data-name%3D%22%E3%83%91%E3%82%B9%2066359%22%20d%3D%22M4753.778%2C638.215h-8.5v-8.5h1v7.5h7.5Z%22%20transform%3D%22translate(2916.153%203812.715)%20rotate(-135)%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fsvg%3E");
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}
.global-footer .brand-sns__wrapper {
  display: grid;
  align-items: center;
  justify-items: center;
  row-gap: var(--spacer-medium);
}
.global-footer .brand-sns__link-list {
  display: flex;
  flex-wrap: wrap;
  gap: calc(var(--sns-icon-width) / 2) var(--sns-icon-width);
  justify-content: center;
}
.global-footer .brand-sns__link-list-item {
  width: var(--sns-icon-width);
  aspect-ratio: 1;
}
.global-footer .law-page__link-wrapper {
  display: flex;
}
.global-footer .law-page__link-list {
  display: flex;
}
.global-footer .law-page__link-text {
  letter-spacing: .05em;
  font-weight: 500;
}
.global-footer .law-page__copyright-text {
  letter-spacing: .05em;
  font-weight: 500;
}
/* --- for small viewport --- */
@media screen and (max-width: 767px) {
  .global-header__search-container {
    padding-block: 1rem;
  }
  .global-footer__container {
    padding-block-start: 5rem;
  }
  .global-footer__inner--middle {
    padding-block-start: 4rem;
  }
  .global-footer__inner--bottom {
    padding-block-start: 2.5rem;
    padding-block-end: 1.5rem;
  }
  .global-footer .law-page__link-wrapper {
    flex-direction: column;
    row-gap: 2.5rem;
  }
  .global-footer .law-page__link-list {
    flex-wrap: wrap;
    justify-content: center;
    column-gap: 2.5rem;
    row-gap: 1.2rem;
    padding-inline: 4em;
  }
  .global-footer .law-page__link-text {
    font-size: 1.2rem;
  }
  .global-footer .law-page__copyright-text {
    padding-block-start: 1.1rem;
    border-top: 1px solid #94B0B9;
    font-size: 1rem;
    text-align: center;
  }
}
/* --- for large viewport --- */
@media screen and (min-width: 768px) {
  .global-header {
    --brand-logo-width: 24rem;
  }
  .global-header .header__content-wrapper--primary .header__content-inner {
    display: flex;
    justify-content: space-between;
    padding-block-start: 2rem;
    padding-block-end: 1rem;
  }
  .global-header
    .header__content-wrapper--primary
    .header__content-inner
    .global-header__search-container {
    --padding-horizontal: 2rem;
    min-width: 30rem;
    padding-block: 1.2rem;
  }
  .global-header
    .header__content-wrapper--primary
    .header__content-inner
    .global-header__search-container
    input {
    width: calc(100% - (var(--search-button-width) + 1ch));
  }
  .global-header .header-primary__navigation-container {
    display: flex;
    align-items: center;
    column-gap: 3rem;
    flex-shrink: 0;
  }
  .global-header
    .header-primary__navigation-container
    .header-primary__navigation-contents-wrapper
    .global-header__text--link {
    font-weight: bold;
  }
  .global-footer {
    display: grid;
    place-items: center;
  }
  .global-footer__container {
    padding-block-start: 8rem;
  }
  .global-footer__inner--middle {
    padding-block-start: 6rem;
  }
  .global-footer__inner--bottom {
    padding-block: 2rem;
  }
  .global-footer .static-page__link-list {
    display: flex;
    flex-wrap: wrap;
  }
  .global-footer .static-page__link-list > li {
    display: flex;
    align-items: center;
    border-bottom: none;
  }
  .global-footer .static-page__link-list > li:not(:last-of-type)::after {
    content: "|";
    margin: 0 3rem;
    color: var(--color-default-text);
  }
  .global-footer .static-page__link-text {
    display: inline;
    padding: 0;
  }
  .global-footer .static-page__link-text::after {
    content: none;
  }
  .global-footer .brand-sns__wrapper {
    column-gap: 6rem;
    justify-items: flex-start;
    grid-template-columns: var(--brand-logo-width) 1fr;
  }
  .global-footer .law-page__link-wrapper {
    justify-content: space-between;
    width: var(--container-default);
    margin: auto;
    padding-right: var(--padding-horizontal-global) !important;
    padding-left: var(--padding-horizontal-global) !important;
  }
  .global-footer .law-page__link-list {
    column-gap: 2.5rem;
  }
  .global-footer .law-page__link-text {
    font-size: 1.3rem;
    line-height: calc(19 / 13);
  }
  .global-footer .law-page__copyright-text {
    font-size: 1.1rem;
  }
}
@media (hover: none) {
  .global-nav__wrapper .mega-menu__text--link {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  .global-nav__wrapper .mega-menu__text--link:active::after {
    scale: 1.3;
    translate: 50%;
  }
  .global-nav__content-list-item {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  .global-nav__content-list-item:active .global-nav__text--link {
    color: var(--color-secondary);
  }
  .global-nav__content-list-item:active .global-nav__text--link::before {
    translate: 0 0;
  }
  .global-nav__content-list-item:active :where(.mega-menu__wrapper) .global-nav__text--link::after {
    background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMiIgaGVpZ2h0PSI2LjkwMSIgdmlld0JveD0iMCAwIDEyIDYuOTAxIj4gPHBhdGggaWQ9IuODkeOCuV80NTgyIiBkYXRhLW5hbWU9IuODkeOCuSA0NTgyIiBkPSJNLjI2NCw2LjYzN2EuOS45LDAsMCwxLDAtMS4yNzRsNS4xLTUuMUEuOS45LDAsMSwxLDYuNjM3LDEuNTM5TDIuMTc2LDZsNC40NjEsNC40NjFhLjkuOSwwLDEsMS0xLjI3NSwxLjI3NVoiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDEyKSByb3RhdGUoOTApIiBmaWxsPSIjNTI4YTlmIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiLz48L3N2Zz4=");
  }
}
@media (-ms-high-contrast: none),
  (-ms-high-contrast: active),
  (-moz-touch-enabled: 0),
  (hover: hover) {
  .global-nav__wrapper .mega-menu__text--link:hover::after {
    scale: 1.3;
    translate: 50%;
  }
  .global-nav__content-list-item:hover .global-nav__text--link {
    color: var(--color-secondary);
  }
  .global-nav__content-list-item:hover .global-nav__text--link::before {
    translate: 0 0;
  }
  .global-nav__content-list-item:hover :where(.mega-menu__wrapper) .global-nav__text--link::after {
    background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMiIgaGVpZ2h0PSI2LjkwMSIgdmlld0JveD0iMCAwIDEyIDYuOTAxIj4gPHBhdGggaWQ9IuODkeOCuV80NTgyIiBkYXRhLW5hbWU9IuODkeOCuSA0NTgyIiBkPSJNLjI2NCw2LjYzN2EuOS45LDAsMCwxLDAtMS4yNzRsNS4xLTUuMUEuOS45LDAsMSwxLDYuNjM3LDEuNTM5TDIuMTc2LDZsNC40NjEsNC40NjFhLjkuOSwwLDEsMS0xLjI3NSwxLjI3NVoiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDEyKSByb3RhdGUoOTApIiBmaWxsPSIjNTI4YTlmIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiLz48L3N2Zz4=");
  }
}

/**
 * footer shopping guide
 */
.c-footer-shopping-guide__heading {
  color: var(--color-secondary);
  font-weight: 700;
  text-align: center;
}
.c-footer-shopping-guide__list {
  display: grid;
}
.c-footer-shopping-guide__list-item {
  display: flex;
  flex-direction: column;
  height: 100%;
  background-color: var(--color-white);
  border-radius: 1rem;
}
.c-footer-shopping-guide__icon {
  margin-inline: auto;
}
.c-footer-shopping-guide__summary-box {
  display: flex;
  flex-direction: column;
  height: 100%;
  letter-spacing: .05em;
}
.c-footer-shopping-guide__summary-box dt {
  font-weight: 700;
  text-align: center;
}
.c-footer-shopping-guide__summary-box dd {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.c-footer-shopping-guide__link {
  position: relative;
  display: flex;
  align-items: center;
  width: fit-content;
  margin-block-start: auto;
  margin-inline-start: auto;
  border-bottom: 1px solid var(--color-secondary);
  color: var(--color-secondary);
}
.c-footer-shopping-guide__link::after {
  content: '';
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0LjYwMSIgaGVpZ2h0PSI4IiB2aWV3Qm94PSIwIDAgNC42MDEgOCI+IDxwYXRoIGlkPSLjg5HjgrlfNDYxOSIgZGF0YS1uYW1lPSLjg5HjgrkgNDYxOSIgZD0iTTguMTc2LDkuNzY4YS42LjYsMCwwLDEsMC0uODVsMy40LTMuNGEuNi42LDAsMSwxLC44NS44NUw5LjQ1MSw5LjM0M2wyLjk3NCwyLjk3NGEuNi42LDAsMSwxLS44NS44NVoiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDEyLjYwMSAxMy4zNDMpIHJvdGF0ZSgtMTgwKSIgZmlsbD0iIzUyOGE5ZiIgZmlsbC1ydWxlPSJldmVub2RkIi8+PC9zdmc+");
  background-size: 100%;
  background-repeat: no-repeat;
}
/* --- for small viewport --- */
@media screen and (max-width: 767px) {
  .c-footer-shopping-guide__heading {
    padding-block-end: 2.5rem;
    font-size: 2rem;
    line-height: calc(39 / 20);
    letter-spacing: .1em;
  }
  .c-footer-shopping-guide__list {
    grid-template-columns: repeat(2, 1fr);
    column-gap: 1rem;
    row-gap: 1rem;
  }
  .c-footer-shopping-guide__list-item {
    padding-block: 1.5rem;
    padding-inline: 1.5rem;
  }
  .c-footer-shopping-guide__icon {
    width: 7rem;
  }
  .c-footer-shopping-guide__summary-box {
    margin-block-start: 1rem;
  }
  .c-footer-shopping-guide__summary-box dt {
    font-size: 1.4rem;
    line-height: calc(24 / 14);
  }
  .c-footer-shopping-guide__summary-box dd {
    gap: 1rem;
    margin-block-start: .5rem;
  }
  .c-footer-shopping-guide__description {
    font-size: 1.2rem;
    line-height: calc(20 / 12);
  }
  .c-footer-shopping-guide__link {
    gap: .6rem;
    font-size: 1.1rem;
    line-height: calc(21 / 11);
  }
  .c-footer-shopping-guide__link::after {
    width: .45rem;
    height: .9rem;
  }
}
/* --- for large viewport --- */
@media screen and (min-width: 768px) {
  .c-footer-shopping-guide__heading {
    padding-block-end: 3rem;
    font-size: 2.4rem;
    line-height: calc(35 / 24);
    letter-spacing: .15em;
  }
  .c-footer-shopping-guide__list {
    grid-template-columns: repeat(6, 1fr);
    column-gap: 1rem;
  }
  .c-footer-shopping-guide__list-item {
    padding-block: 2rem;
    padding-inline: 1.5rem;
  }
  .c-footer-shopping-guide__icon {
    width: 9rem;
  }
  .c-footer-shopping-guide__summary-box {
    margin-block-start: 1.5rem;
  }
  .c-footer-shopping-guide__summary-box dt {
    font-size: 1.5rem;
    line-height: calc(24 / 15);
  }
  .c-footer-shopping-guide__summary-box dd {
    gap: 1rem;
    margin-block-start: .5rem;
  }
  .c-footer-shopping-guide__description {
    font-size: 1.3rem;
    line-height: calc(21 / 13);
  }
  .c-footer-shopping-guide__link {
    gap: .5rem;
    font-size: 1.2rem;
    line-height: calc(21 / 12);
  }
  .c-footer-shopping-guide__link::after {
    width: .5rem;
    height: 1rem;
  }
}

/**
 * footer static pages
 */
.m-footer-static-pages a {
  color: var(--color-black);
  font-weight: 500;
}
/* --- for small viewport --- */
@media screen and (max-width: 767px) {
  .m-footer-static-pages {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 1.5rem;
  }
  .m-footer-static-pages li a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-block: 1.5rem;
    border-bottom: 1px solid #CCD9DD;
    font-size: 1.4rem;
    line-height: calc(20 / 14);
  }
  .m-footer-static-pages li a::after {
    content: '';
    width: .6rem;
    height: 1.2rem;
    background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSI0LjYwMSIgaGVpZ2h0PSI4IiB2aWV3Qm94PSIwIDAgNC42MDEgOCI+IDxwYXRoIGlkPSLjg5HjgrlfNDYxOSIgZGF0YS1uYW1lPSLjg5HjgrkgNDYxOSIgZD0iTTguMTc2LDkuNzY4YS42LjYsMCwwLDEsMC0uODVsMy40LTMuNGEuNi42LDAsMSwxLC44NS44NUw5LjQ1MSw5LjM0M2wyLjk3NCwyLjk3NGEuNi42LDAsMSwxLS44NS44NVoiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDEyLjYwMSAxMy4zNDMpIHJvdGF0ZSgtMTgwKSIgZmlsbD0iIzUyOGE5ZiIgZmlsbC1ydWxlPSJldmVub2RkIi8+PC9zdmc+");
    background-size: 100%;
    background-repeat: no-repeat;
  }
}
/* --- for large viewport --- */
@media screen and (min-width: 768px) {
  .m-footer-static-pages {
    display: flex;
    justify-content: center;
    column-gap: 4rem;
    font-size: 1.6rem;
    line-height: 1.5;
  }
  .m-footer-static-pages * {
    font-size: inherit;
  }
}

/**
 * ----------
 * modify
 * ----------
 */
/**
 * header
 */
.header-primary__navigation-content-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: 0.5rem;
  text-decoration: none;
}
.header-primary__navigation-icon {
  width: 2.6rem;
}
/* --- for large viewport --- */
@media screen and (min-width: 768px) {
  .header-primary__navigation-caption {
    font-size: 1.1rem;
    line-height: calc(16 / 11);
    letter-spacing: .02em;
    color: var(--color-accent);
  }
}

/**
 * global
 */
/* --- external links --- */
.c-external-links__button {
  --color-textlink: var(--color-white);
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.8rem;
  border-radius: 1rem;
  overflow: hidden;
  text-decoration: none;
}
.c-external-links__line {
  background-color: var(--color-social-line-primary);
}
.c-external-links__socials {
  font-size: 1.3rem;
  line-height: calc(20 / 13);
  text-align: center;
}
.c-external-links__socials dt {
  padding-block-end: var(--external-links-socials-title-spacer, 1rem);
}
.c-external-links__socials-links {
  display: flex;
  justify-content: center;
  align-items: center;
}
.c-external-links__externals {
  display: flex;
  justify-content: center;
}
.c-external-links__externals-link--honelife {
  width: 100%;
  border: 1px solid #27566a;
  background-color: var(--color-white);
}
.c-external-links__externals-link--honelife img {
  width: auto;
  height: 100%;
  margin-inline: auto;
}
.c-external-links__externals-link--official {
  width: 100%;
  background-color: var(--color-official);
}
.c-external-links__externals-link--official::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMiIgaGVpZ2h0PSIxMiIgdmlld0JveD0iMCAwIDEyIDEyIj4gPHBhdGggaWQ9IuODkeOCuV80NjE4IiBkYXRhLW5hbWU9IuODkeOCuSA0NjE4IiBkPSJNOC4zMzMsNWEuNjY3LjY2NywwLDEsMSwwLDEuMzMzaC00djcuMzMzaDcuMzMzdi00YS42NjcuNjY3LDAsMSwxLDEuMzMzLDB2NEExLjMzMywxLjMzMywwLDAsMSwxMS42NjcsMTVINC4zMzNBMS4zMzMsMS4zMzMsMCwwLDEsMywxMy42NjdWNi4zMzNBMS4zMzMsMS4zMzMsMCwwLDEsNC4zMzMsNVptNi0yQS42NjcuNjY3LDAsMCwxLDE1LDMuNjY3VjdhLjY2Ny42NjcsMCwwLDEtMS4zMzMsMFY1LjI3Nkw4LjEzOCwxMC44QS42NjcuNjY3LDAsMSwxLDcuMiw5Ljg2Mmw1LjUyOS01LjUyOUgxMUEuNjY3LjY2NywwLDAsMSwxMSwzWiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTMgLTMpIiBmaWxsPSIjZmZmIi8+PC9zdmc+");
  background-size: 100%;
  background-repeat: no-repeat;
}
.global-footer__inner--middle .c-external-links__line {
  display: none;
}
.global-footer__inner--middle .c-external-links__socials dt {
  --external-links-socials-title-spacer: 0;
  display: none;
}
.global-auto-scroll-top__button {
  position: fixed;
  z-index: var(--zindex-floating-element);
  aspect-ratio: 1 / 1;
}
/* --- for small viewport --- */
@media screen and (max-width: 767px) {
  .c-external-links__button {
    font-size: 1.5rem;
    letter-spacing: .1em;
  }
  .c-external-links__line .c-external-links__icon {
    width: 2.6rem;
  }
  .c-external-links__socials-links {
    gap: 2.5rem;
  }
  .c-external-links__socials-link {
    width: 3rem;
  }
  .hamburger-menu__section[data-section-name=hamburger-external-links-area] {
    padding-block-start: 4rem;
    padding-block-end: 6rem;
    padding-inline: 2rem;
    background-color: var(--color-quaternary);
  }
  .hamburger-menu__section[data-section-name=hamburger-external-links-area] .c-external-links__button {
    height: 5rem;
  }
  .hamburger-menu__section[data-section-name=hamburger-external-links-area] .c-external-links__socials {
    margin-block-start: 1rem;
    padding-block-start: 1.5rem;
    padding-block-end: 2rem;
    border: 1px solid #27566a;
    background-color: var(--color-white);
    border-radius: 1rem;
    overflow: hidden;
  }
  .hamburger-menu__section[data-section-name=hamburger-external-links-area] .c-external-links__socials-link[data-social=line] {
    display: none;
  }
  .hamburger-menu__section[data-section-name=hamburger-external-links-area] .c-external-links__externals {
    flex-direction: column;
    row-gap: 1rem;
    margin-block-start: 3rem;
  }
  .hamburger-menu__section[data-section-name=hamburger-external-links-area] .c-external-links__externals-link--official::after {
    right: 2rem;
    width: 1.2rem;
    height: 1.2rem;
  }
  .global-footer__inner--middle .l-external-links__section {
    margin-block-start: 3.5rem;
  }
  .global-footer__inner--middle .c-external-links__button {
    height: 4.6rem;
    font-size: 1.4rem;
  }
  .global-footer__inner--middle .c-external-links__externals {
    gap: .8rem;
    margin-block-start: 3rem;
  }
  .global-footer__inner--middle .c-external-links__externals-link--official::after {
    right: 1.2rem;
    width: 1rem;
    height: 1rem;
  }
  .global-auto-scroll-top__button {
    bottom: 1rem;
    right: 1rem;
    width: 5rem;
  }
}
/* --- for large viewport --- */
@media screen and (min-width: 768px) {
  .c-external-links__button {
    font-size: 1.6rem;
    letter-spacing: .15em;
  }
  .c-external-links__socials-links {
    gap: 2.6rem;
  }
  .c-external-links__socials-link {
    width: 3.2rem;
  }
  .global-footer__inner--middle .l-external-links__section {
    margin-block-start: 5rem;
  }
  .global-footer__inner--middle .c-external-links__button {
    width: 28rem;
    height: 6rem;
  }
  .global-footer__inner--middle .c-external-links__externals {
    gap: 1rem;
    margin-block-start: 3rem;
  }
  .global-footer__inner--middle .c-external-links__externals-link--official::after {
    right: 2rem;
    width: 1.2rem;
    height: 1.2rem;
  }
  .global-auto-scroll-top__button {
    bottom: 2rem;
    right: 2rem;
    width: 6rem;
  }
}
