@charset "UTF-8";
img {
  -webkit-touch-callout: none !important;
  -webkit-user-select: none !important;
  -moz-user-select: none !important;
  -ms-user-select: none !important;
  user-select: none !important;
  -webkit-user-drag: none !important;
  user-drag: none !important;
}

/* ===============================================
  * Header - ヘッダーのスタイル *
=============================================== */
.global-header {
  --header-color-border: #efefef;
  --header-color-section-title-bg: #efefef;
  --border-style: solid 1px var(--header-color-border);
  --brand-logo-width: 11.6rem;
  --link-arrow: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2218%22%20height%3D%2218%22%20viewBox%3D%220%200%2018%2018%22%3E%0A%20%20%3Cg%20id%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_13960%22%20data-name%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%2013960%22%20transform%3D%22translate(-652%20-590)%22%3E%0A%20%20%20%20%3Crect%20id%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2_5873%22%20data-name%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2%205873%22%20width%3D%2218%22%20height%3D%2218%22%20rx%3D%222%22%20transform%3D%22translate(652%20590)%22%20fill%3D%22%238d8d8d%22%2F%3E%0A%20%20%20%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_50492%22%20data-name%3D%22%E3%83%91%E3%82%B9%2050492%22%20d%3D%22M661%2C604.477a.5.5%2C0%2C0%2C1-.354-.854L665%2C599.272l-4.352-4.352a.5.5%2C0%2C0%2C1%2C.707-.707l4.706%2C4.706a.5.5%2C0%2C0%2C1%2C0%2C.707l-4.706%2C4.706A.5.5%2C0%2C0%2C1%2C661%2C604.477Z%22%20transform%3D%22translate(-2.501%20-0.067)%22%20fill%3D%22%23fff%22%2F%3E%0A%20%20%3C%2Fg%3E%0A%3C%2Fsvg%3E%0A");
  --link-arrow-offset: .75px;
}
@media screen and (min-width: 768px) {
  .global-header {
    --link-arrow: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2211.5%22%20height%3D%226.5%22%20viewBox%3D%220%200%2011.5%206.5%22%3E%0A%20%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_50248%22%20data-name%3D%22%E3%83%91%E3%82%B9%2050248%22%20d%3D%22M477.707%2C64.75a.748.748%2C0%2C0%2C1-.53-.22l-4.47-4.47-4.47%2C4.47a.75.75%2C0%2C0%2C1-1.061-1.061l5-5a.75.75%2C0%2C0%2C1%2C1.061%2C0l5%2C5a.75.75%2C0%2C0%2C1-.53%2C1.28Z%22%20transform%3D%22translate(-466.957%20-58.25)%22%20fill%3D%22%23113258%22%2F%3E%0A%3C%2Fsvg%3E%0A");
    --link-arrow-wh: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2211.5%22%20height%3D%226.5%22%20viewBox%3D%220%200%2011.5%206.5%22%3E%0A%20%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_50248%22%20data-name%3D%22%E3%83%91%E3%82%B9%2050248%22%20d%3D%22M472.707%2C64.75a.748.748%2C0%2C0%2C1-.53-.22l-5-5a.75.75%2C0%2C0%2C1%2C1.061-1.061l4.47%2C4.47%2C4.47-4.47a.75.75%2C0%2C1%2C1%2C1.061%2C1.061l-5%2C5A.748.748%2C0%2C0%2C1%2C472.707%2C64.75Z%22%20transform%3D%22translate(-466.957%20-58.25)%22%20fill%3D%22%23fff%22%2F%3E%0A%3C%2Fsvg%3E%0A");
  }
}

.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: 1.6rem;
  --padding-horizontal: 1.5rem;
  position: relative;
}

.global-header__search-form input {
  width: 100%;
  padding-right: calc(var(--padding-horizontal) * 2 + var(--search-button-width));
  padding-left: var(--padding-horizontal);
  border: none;
  box-sizing: border-box;
  font-size: 1.6rem;
  font-family: var(--font-ja);
}

.global-header__search-form input::placeholder {
  font-size: 1.2rem;
}

.global-header__search-button {
  position: absolute;
  top: 0;
  right: var(--search-button-width);
  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);
  border-bottom: var(--border-style);
}

.global-header .header__content-wrapper--primary .header__content-inner {
  display: grid;
  align-items: center;
  grid-template-columns: 6rem auto 1fr;
  padding: 1rem !important;
  gap: 1rem;
}

.global-header .header__content-wrapper--global-nav {
  position: relative;
  background-color: var(--color-secondary);
}

.global-header .header__content-wrapper--global-nav .header__content-inner {
  display: grid;
  place-content: center;
}

.global-header .ticker__list-item {
  --color-text: var(--color-project-text);
  --color-bg: var(--color-project-bg);
}

.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: 1.2rem;
  letter-spacing: 0.05em;
  line-height: var(--height-ticker);
  text-align: center;
  text-decoration: none;
}

.global-header .header-primary__hamburger-menu-container {
  justify-self: flex-start;
}

.global-header .header-primary__hamburger-menu-container button {
  font-size: 3rem;
}

.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;
  gap: 0.2rem;
  justify-content: flex-end;
}
@media screen and (min-width: 768px) {
  .global-header .header-primary__navigation-container .header-primary__navigation-contents-wrapper {
    gap: 1.6rem;
  }
}

.global-header .header-primary__navigation-container .header-primary__navigation-contents-wrapper [class*=header-primary__navigation-item-wrapper] {
  width: 5rem;
  aspect-ratio: 1;
  display: grid;
  align-content: center;
  grid-gap: 0.1rem;
  text-decoration-line: none;
}
.global-header .header-primary__navigation-container .header-primary__navigation-contents-wrapper [class*=header-primary__navigation-item-wrapper] svg {
  width: 3rem;
  aspect-ratio: 1;
  margin-inline: auto;
}

.global-header .header-primary__navigation-item-wrapper--cart {
  --count-num-width: 1.6rem;
  --indicator-width: .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) * 0);
  right: calc(var(--count-num-width) * 0.2);
  z-index: 2;
  display: grid;
  place-items: center;
  width: var(--count-num-width);
  aspect-ratio: 1;
  background-color: #EA5504;
  border-radius: 50%;
  overflow: hidden;
  color: var(--color-white);
  font-family: var(--font-en);
  font-size: 1rem;
  letter-spacing: 0em;
  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;
}

/* ===============================================
  * ヘッダーの固定方式 *
=============================================== */
.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 {
  font-size: 1.3rem;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.02em;
  text-align: center;
}

.hamburger-menu__text--section-title[data-title-bg=active] {
  background-color: var(--header-color-section-title-bg);
  padding: var(--padding-content);
  text-align: left;
}

.hamburger-menu__text--link {
  display: grid;
  align-items: center;
  column-gap: 1ch;
  grid-template-columns: 1fr 1.8rem;
  padding: var(--padding-content);
  color: var(--color-black);
  font-size: 1.3rem;
  letter-spacing: 0.02em;
  line-height: 1.5;
  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: 1.5rem;
  --hamburger-icon-position: 2rem;
  --padding-content: 1.8rem 1rem;
}

.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: 3rem;
  --icon-height: 3rem;
  --icon-border-height: 2px;
  display: grid;
  place-content: center;
  width: 5rem;
  aspect-ratio: 1;
  padding: 0;
  background-color: transparent;
  overflow: hidden;
  transition: translate var(--hamburger-menu-transition);
  aspect-ratio: 1;
}
.hamburger-menu__toggle-button::after {
  content: "メニュー";
  font-size: 1rem;
  letter-spacing: 0.02em;
  font-family: var(--font-ja);
}

.hamburger-menu__toggle-button-inner {
  position: relative;
  display: block;
  width: var(--icon-width);
  height: var(--icon-height);
  padding: 0.6rem 0.5rem;
  margin-inline: auto;
}

.hamburger-menu__toggle-button-inner > span {
  position: absolute;
  display: block;
  width: 2rem;
  height: var(--icon-border-height);
  transform-origin: center;
  scale: 1;
}

.hamburger-menu__toggle-button-inner > span:first-of-type {
  top: 0.6rem;
  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.6rem;
  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) * 3));
  height: 100dvh;
  padding-bottom: 4rem;
  background-color: var(--color-white);
  overflow-y: auto;
}

.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);
}

.hamburger-menu__content-wrapper {
  padding: var(--padding-content);
}

.hamburger-menu__content-list > li:not(:last-of-type) {
  border-bottom: var(--border-style);
}

.hamburger-menu__bg {
  position: fixed;
  top: 0;
  left: 0;
  z-index: var(--zindex-hamburgermenu-bg);
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  opacity: 0;
  transition: opacity 200ms ease-in;
}

.hamburger-menu__accordion-list {
  padding-bottom: 1.8rem;
}

/* ===============================================
  * ハンバーガーメニューのアニメーション *
=============================================== */
/* アニメーションの基本設定 */
[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) * 3));
  height: 100dvh;
}

/* ハンバーガーメニューがヘッダーの下に表示される形式 */
[data-hamburgermenu-type=same-level] .hamburger-menu__contents-wrapper {
  top: var(--height-header);
  width: 100vw;
  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));
}

[data-hamburgermenu-type=same-level] .hamburger-menu__toggle-button[aria-expanded=true]::after {
  content: "閉じる";
  font-size: 1rem;
  letter-spacing: 0.02em;
}

.accordion__details {
  --accordion-icon-width: 1.8rem;
}

.accordion__summary {
  grid-template-columns: 1fr var(--accordion-icon-width);
  background-color: var(--color-white);
  transition: background var(--transition-default);
}

.accordion__summary::after {
  content: none;
}

.accordion__icon-wrapper {
  position: relative;
  display: block;
  width: var(--accordion-icon-width);
  aspect-ratio: 1;
}

.accordion__icon-wrapper::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  margin: auto;
  background: var(--link-arrow);
  transition: rotate var(--transition-default);
}

.accordion__icon-wrapper::before {
  rotate: 90deg;
}

[data-state-accordion=opened] > .accordion__summary .accordion__icon-wrapper::before {
  rotate: -90deg;
}

.accordion__content [data-structure=child] .hamburger-menu__text--link {
  font-size: 0.846em;
}

.global-nav__text--link {
  position: relative;
  display: grid;
  place-content: center;
  padding: 2rem;
  color: var(--color-white);
  font-size: 1.2rem;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.03em;
  line-height: 1;
  text-decoration: none;
  overflow: hidden;
}

.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%;
  height: 0;
}

.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: 8rem;
}

.global-nav__wrapper .mega-menu__wrapper .global-nav__text--wrapper {
  display: grid;
  align-items: center;
  grid-template-columns: 1fr 1.15rem;
  grid-gap: 1rem;
}
.global-nav__wrapper .mega-menu__wrapper .global-nav__text--wrapper::after {
  content: "";
  position: static;
  display: block;
  width: 1.15rem;
  height: 0.65rem;
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2211.5%22%20height%3D%226.5%22%20viewBox%3D%220%200%2011.5%206.5%22%3E%0A%20%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_50248%22%20data-name%3D%22%E3%83%91%E3%82%B9%2050248%22%20d%3D%22M472.707%2C64.75a.748.748%2C0%2C0%2C1-.53-.22l-5-5a.75.75%2C0%2C0%2C1%2C1.061-1.061l4.47%2C4.47%2C4.47-4.47a.75.75%2C0%2C1%2C1%2C1.061%2C1.061l-5%2C5A.748.748%2C0%2C0%2C1%2C472.707%2C64.75Z%22%20transform%3D%22translate(-466.957%20-58.25)%22%20fill%3D%22%23fff%22%2F%3E%0A%3C%2Fsvg%3E%0A");
  background-size: contain;
  background-repeat: no-repeat;
  background-color: transparent;
}
.global-nav__wrapper .mega-menu__wrapper[data-state=active] .global-nav__text--link {
  background-color: var(--color-white);
  color: var(--color-secondary);
}
.global-nav__wrapper .mega-menu__wrapper[data-state=active] .global-nav__text--wrapper::after {
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2211.5%22%20height%3D%226.5%22%20viewBox%3D%220%200%2011.5%206.5%22%3E%0A%20%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_50248%22%20data-name%3D%22%E3%83%91%E3%82%B9%2050248%22%20d%3D%22M477.707%2C64.75a.748.748%2C0%2C0%2C1-.53-.22l-4.47-4.47-4.47%2C4.47a.75.75%2C0%2C0%2C1-1.061-1.061l5-5a.75.75%2C0%2C0%2C1%2C1.061%2C0l5%2C5a.75.75%2C0%2C0%2C1-.53%2C1.28Z%22%20transform%3D%22translate(-466.957%20-58.25)%22%20fill%3D%22%23113258%22%2F%3E%0A%3C%2Fsvg%3E%0A");
}

.header-primary__navigation-item-wrapper {
  text-align: center;
  color: var(--color-project-text);
  text-decoration-line: none;
}

.header-primary__navigation-item--text {
  text-align: center;
  color: var(--color-project-text);
  font-size: 1rem;
}

.hamburger-menu__user .hamburger-menu__user-name {
  padding: 2.5rem 1rem 1rem;
  font-size: 1.8rem;
  letter-spacing: 0.02em;
  font-weight: var(--fw-bold);
}
.hamburger-menu__user .hamburger-menu__user-name small {
  font-size: 1.4rem;
  padding-left: 0.6rem;
}
.hamburger-menu__user .hamburger-menu__icon-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-gap: 1rem;
  padding: 1rem;
  background-color: var(--color-project-bg);
  margin-bottom: 2rem;
}
.hamburger-menu__user .hamburger-menu__icon-list .hamburger-menu__icon-link {
  display: grid;
  justify-items: center;
  justify-content: center;
  align-content: center;
  height: 18.666vw;
  border: 1px solid var(--color-project-text);
  border-radius: 0.4rem;
  background-color: var(--color-white);
  color: var(--color-project-text);
  text-decoration-line: none;
}
.hamburger-menu__user .hamburger-menu__icon-list .hamburger-menu__icon-img {
  width: 3.6rem;
  aspect-ratio: 1;
}
.hamburger-menu__user .hamburger-menu__icon-list .hamburger-menu__icon-txt {
  font-size: 1.4rem;
  letter-spacing: 0.02em;
  font-weight: var(--fw-medium);
}
.hamburger-menu__user .hamburger-menu__user-list {
  display: grid;
  grid-template-columns: 64vw;
  grid-gap: 1rem;
  justify-content: center;
  padding: 3rem 0;
}
.hamburger-menu__user .hamburger-menu__user-list .hamburger-menu__user-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 5rem;
  border: 1px solid var(--color-secondary);
  border-radius: 0.6rem;
  text-decoration-line: none;
  font-weight: var(--fw-bold);
  font-size: 1.6rem;
  letter-spacing: 0.02em;
}
.hamburger-menu__user .hamburger-menu__user-list .hamburger-menu__user-link.primary {
  color: var(--color-white);
  background-color: var(--color-secondary);
}
.hamburger-menu__user .hamburger-menu__user-list .hamburger-menu__user-link.secondary {
  color: var(--color-secondary);
}

.hamburger-menu__section {
  margin-inline: 1rem;
  border-top: 1px solid #D3D3D3;
}
.hamburger-menu__section:last-of-type {
  border-bottom: 1px solid #D3D3D3;
}

.hamburger-menu__section-title {
  font-size: 1.6rem;
  letter-spacing: 0.02em;
  line-height: 1.5;
  text-decoration: none;
  font-weight: var(--fw-bold);
}

@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::after {
    translate: 0 0;
  }
}
@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::after {
    translate: 0 0;
  }
}
@media screen and (min-width: 768px) {
  .global-header {
    --brand-logo-width: 21.5rem;
  }
  .global-header .header__content-wrapper--primary .header__content-inner {
    display: flex;
    justify-content: space-between;
    padding-top: 3.6rem;
    padding-bottom: 3.6rem;
  }
  .global-header .header__content-wrapper--primary .header__content-inner .global-header__search-container {
    min-width: 30rem;
  }
  .global-header .header__content-wrapper--primary .header__content-inner .global-header__search-container input {
    width: 100%;
    line-height: 2.6rem;
    padding: 0.4rem 1rem;
    border: solid 2px #EDEDED;
    border-radius: 0.6rem;
    font-family: var(--font-ja);
    font-size: 1.3rem;
  }
  .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;
  }
}
.header-primary__brand-wrapper {
  display: flex;
  align-items: center;
  gap: 2rem;
}
.header-primary__brand-wrapper .header-primary__brand-catch {
  font-size: 1.1rem;
  letter-spacing: 0.02em;
}

@media screen and (max-width: 767px) {
  .hamburger-menu__accordion-list:has(.tag-title-list) {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

.tag-title-list {
  display: flex;
  justify-content: center;
  gap: 2rem;
  flex-wrap: wrap;
}
@media screen and (min-width: 768px) {
  .tag-title-list {
    display: flex;
    gap: 4rem;
  }
}
.tag-title-list .tag-title-content-list__item {
  width: calc((100% - 4rem) / 3);
}
@media screen and (min-width: 768px) {
  .tag-title-list .tag-title-content-list__item {
    width: 12rem;
  }
}
.tag-title-list .tag-title-content-list__link {
  display: grid;
  align-items: center;
  gap: 1rem;
  text-decoration-line: none;
  font-size: 1.2rem;
  letter-spacing: 0.02em;
  font-weight: var(--fw-bold);
  line-height: 1.4285714286;
  color: var(--color-project-text);
  text-align: center;
}
@media screen and (min-width: 768px) {
  .tag-title-list .tag-title-content-list__link {
    font-size: 1.4rem;
  }
}
.tag-title-list .tag-title-content-list__link .tag-title-image-wrapper {
  border-radius: 50%;
  overflow: hidden;
  box-shadow: 0 3px 10px 0px rgba(0, 0, 0, 0.1);
}
.tag-title-list .tag-title-content-list__link .tag-title-image-wrapper .tag-title-image {
  transition: scale 0.3s ease;
}
.tag-title-list .tag-title-content-list__link .tag-title-image-wrapper .tag-title-image:hover {
  scale: 1.1;
}

.category-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-gap: 0.8rem 0.7rem;
}
@media screen and (min-width: 768px) {
  .category-list {
    grid-template-columns: repeat(5, 1fr);
    grid-gap: 1.9rem;
  }
}
.category-list .category-content-list__link {
  background-color: var(--color-project-bg);
  border-radius: 0.8rem;
  display: grid;
  grid-template-columns: 6rem 1fr;
  align-items: center;
  gap: 1rem;
  padding-right: 1rem;
  text-decoration-line: none;
  font-size: 1.4rem;
  letter-spacing: 0.02em;
  font-weight: var(--fw-bold);
  line-height: 1.4285714286;
  color: var(--color-project-text);
  position: relative;
  border-radius: 0.8rem;
  transition: border var(--transition-default);
}
@media screen and (min-width: 768px) {
  .category-list .category-content-list__link {
    grid-template-columns: 8rem 1fr;
    gap: 2rem;
  }
}
.category-list .category-content-list__link::after {
  content: "";
  width: 100%;
  height: 100%;
  display: block;
  background-color: var(--color-project-bg);
  scale: 1;
  position: absolute;
  margin: auto;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  z-index: -1;
  border-radius: 0.8rem;
}
.category-list .category-content-list__link:hover::after {
  border: 3px solid var(--color-primary);
  width: calc(100% + 6px);
  left: -3px;
  height: calc(100% + 6px);
}
.category-list .category-content-list__link .category-image {
  border-radius: 0.8rem 0 0 0.8rem;
}

/* ===============================================
  * Footer - フッターのスタイル *
=============================================== */
.global-footer {
  --spacer-regular: 5rem;
  --spacer-medium: 6.4rem;
  --border-style: solid 1px var(--color-gray-300);
  --sns-icon-width: 2.4rem;
  --brand-logo-width: 11.6rem;
  background-color: var(--color-white);
  border-top: 0.4rem solid var(--color-project-bg);
  position: relative;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .global-footer {
    --brand-logo-width: 21.5rem;
    display: grid;
    place-items: center;
    justify-items: stretch;
  }
}
.global-footer a {
  color: var(--color-default-text);
  text-decoration: none;
}
@media screen and (min-width: 768px) {
  .global-footer a {
    right: var(--swiper-button-position-desktop, 20%);
  }
}
.global-footer .global-footer__inner {
  display: grid;
  row-gap: var(--spacer-regular);
  padding-top: var(--spacer-medium);
  padding-bottom: var(--spacer-regular);
}
@media screen and (min-width: 768px) {
  .global-footer .global-footer__inner {
    padding-top: var(--spacer-medium);
    padding-bottom: var(--spacer-regular);
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
}
.global-footer .brand-sns__wrapper {
  display: grid;
  align-items: center;
  justify-items: center;
  row-gap: 3rem;
}
@media screen and (min-width: 768px) {
  .global-footer .brand-sns__wrapper {
    justify-items: flex-start;
    grid-template-columns: var(--brand-logo-width);
  }
}
.global-footer .brand-sns__link-list {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  justify-content: center;
}
.global-footer .brand-sns__link-list-item {
  width: var(--sns-icon-width);
  aspect-ratio: 1;
}
.global-footer .global-footer__inner--bottom {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-gap: 2rem 1.1rem;
}
@media screen and (min-width: 768px) {
  .global-footer .global-footer__inner--bottom {
    grid-template-columns: repeat(3, 20rem);
    grid-gap: 8rem;
  }
}
.global-footer .static-page__link-list {
  display: grid;
  grid-gap: 0.8rem;
}
@media screen and (min-width: 768px) {
  .global-footer .static-page__link-list {
    grid-gap: 0.4rem;
  }
}
.global-footer .static-page__link-list > li {
  display: flex;
  align-items: center;
  border-bottom: none;
}
.global-footer .static-page__link-heading {
  padding-bottom: 0.9rem;
  margin-bottom: 0.9rem;
  border-bottom: 1px solid #D3D3D3;
  font-size: 1.4rem;
  font-weight: var(--fw-bold);
  font-size: 1.4rem;
  letter-spacing: 0.02em;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .global-footer .static-page__link-heading {
    padding-bottom: 1rem;
    margin-bottom: 0.7rem;
    font-size: 1.2rem;
  }
}
.global-footer .static-page__link-text {
  --padding-vertical: .3rem;
  --padding-horizontal: 0.5rem;
  display: grid;
  align-items: center;
  column-gap: var(--padding-horizontal);
  grid-template-columns: 0.4rem 1fr;
  padding: var(--padding-vertical) 0 var(--padding-vertical);
  font-size: 1.3rem;
  letter-spacing: 0;
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .global-footer .static-page__link-text {
    font-size: 1.1rem;
  }
}
.global-footer .static-page__link-text::before {
  content: "";
  display: block;
  width: 0.4rem;
  height: 0.4rem;
  border-radius: 50%;
  background-color: #EA5504;
}
.global-footer .global-footer-copyright-text {
  color: var(--color-white);
  font-size: 1rem;
  line-height: 3rem;
  letter-spacing: 0.02em;
  background-color: var(--color-secondary);
  text-align: center;
}

.p-page__sticky {
  position: fixed;
  z-index: 10;
  bottom: 4.4rem;
  right: 0;
  opacity: 1;
  transition: all var(--transition-default);
  display: flex;
  align-items: center;
  gap: 1rem;
  opacity: 0;
}
@media screen and (min-width: 768px) {
  .p-page__sticky {
    bottom: 4.4rem;
  }
}
.p-page__sticky.is-active {
  opacity: 1;
}
.p-page__sticky .page-top {
  width: 6.3rem;
  height: 8.3rem;
}
@media screen and (min-width: 768px) {
  .p-page__sticky .page-top {
    width: 8.129rem;
    height: 10.709rem;
  }
}
.p-page__sticky:not(.active) {
  animation: floating-vertical 2s ease-in-out infinite alternate;
}
.p-page__sticky.active {
  animation: pageTopBalloon 0.5s ease 0s 1 forwards;
}

.p-page__fixed {
  position: absolute;
  bottom: 0;
  right: 5rem;
  animation: shaking-horizontal 1s ease-in-out infinite alternate;
}
@media screen and (min-width: 768px) {
  .p-page__fixed {
    right: 6.4rem;
  }
}
.p-page__fixed .page-top__fixed {
  width: 6.2rem;
  height: 6.1rem;
}
@media screen and (min-width: 768px) {
  .p-page__fixed .page-top__fixed {
    width: 8rem;
    height: 7.87rem;
  }
}

@keyframes shaking-horizontal {
  0% {
    transform: rotate(-2deg);
  }
  50% {
    transform: rotate(6deg);
  }
  100% {
    transform: rotate(-2deg);
  }
}
@keyframes floating-vertical {
  0% {
    transform: translate3d(0, 0.2rem, 0);
  }
  50% {
    transform: translate3d(0, -0.2rem, 0);
  }
  100% {
    transform: translate3d(0, 0.2rem, 0);
  }
}
@keyframes pageTopBalloon {
  0% {
    transform: scale(1.2, 1.2) translate(0, 0);
  }
  70% {
    transform: scale(1, 0.8) translate(0, 30%);
  }
  75% {
    transform: scale(1, 0.8) translate(-2%, 30%);
  }
  80% {
    transform: scale(1, 0.8) translate(2%, 30%);
  }
  85% {
    transform: scale(1, 0.8) translate(-2%, 30%);
  }
  90% {
    transform: scale(1, 0.8) translate(2%, 30%);
  }
  95% {
    transform: scale(0.9, 1.5) translate(0%, 0%);
  }
}
