@charset "UTF-8";
/* ===============================================
  * Header - ヘッダーのスタイル *
=============================================== */
.global-header {
  --header-color-border: #efefef;
  --header-color-section-title-bg: #efefef;
  --border-style: solid 1px var(--header-color-border);
  --brand-logo-width: 6.6rem;
  --link-arrow: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%225.604%22%20height%3D%229.061%22%20viewBox%3D%220%200%205.604%209.061%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_3384%22%20data-name%3D%22%E3%83%91%E3%82%B9%203384%22%20d%3D%22M538.692%2C543.294l-1.033-1.088%2C3.455-3.283-3.482-3.656%2C1.086-1.034%2C4.518%2C4.744Z%22%20transform%3D%22translate(-537.632%20-534.233)%22%20fill%3D%22%237c7c7c%22%2F%3E%3C%2Fsvg%3E");
  --link-arrow-offset: .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: 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;
}
.global-header__search-form input::placeholder {
  font-size: 1.2rem;
}
.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);
  border-bottom: var(--border-style);
}
.global-header .header__content-wrapper--primary .header__content-inner {
  display: grid;
  align-items: center;
  grid-template-columns: 1fr auto 1fr;
  padding: 1rem 1.7rem;
}
.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__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);
}

.header-primary__brand-logo-wrapper:has(.header-primary__brand-logo--cosme){
  --brand-logo-width: 114px;
}

.global-header .header-primary__navigation-container .header-primary__navigation-contents-wrapper {
  display: flex;
  gap: 1rem;
  justify-content: flex-end;
}
.global-header .header-primary__navigation-container .header-primary__navigation-contents-wrapper [class*=header-primary__navigation-item-wrapper] {
  width: 3rem;
  aspect-ratio: 1;
}
.global-header .header-primary__navigation-item-wrapper--cart {
  --count-num-width: 1.8rem;
  --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) / 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: var(--color-emphasis);
  border-radius: 50%;
  overflow: hidden;
  color: var(--color-white);
  font-family: var(--font-en);
  font-size: 0.9rem;
  letter-spacing: 0.03em;
  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 0.56rem;
  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.2rem 1.6rem;
}
.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.4rem;
  --icon-height: 15px;
  --icon-border-height: 2px;
  display: grid;
  place-content: center;
  width: 3rem;
  aspect-ratio: 1;
  padding: 0;
  background-color: transparent;
  border-radius: 50%;
  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);
  background-color: var(--color-text-default);
  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) * 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;
}

/* ===============================================
  * ハンバーガーメニューのアニメーション *
=============================================== */
/* アニメーションの基本設定 */
[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__toggle-button[aria-expanded=true] > span {
  filter: invert(1);
}
[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: calc(100% - (var(--hamburger-icon-width) + var(--hamburger-icon-position) * 3));
  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));
}

.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: grid;
  place-content: center;
  padding: 2rem 0;
  color: var(--color-text-default);
  font-size: 1.2rem;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.03em;
  line-height: 1;
  text-decoration: none;
  overflow: hidden;
}
.global-nav__text--link::after {
  content: "";
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 3px;
  background-color: var(--color-text-default);
  translate: 0 100%;
  transition: translate var(--transition-default);
  pointer-events: none;
}
.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: 8rem;
}

/* ===============================================
  * Footer - フッターのスタイル *
=============================================== */
.global-footer {
  --spacer-regular: 5rem;
  --spacer-medium: 4rem;
  --border-style: solid 1px var(--color-gray-300);
  --color-default-text: var(--color-white);
  --sns-icon-width: 3rem;
  --brand-logo-width: 15rem;
  background-color: var(--color-primary);
}
.global-footer a {
  color: var(--color-default-text);
  text-decoration: none;
}
.global-footer__inner {
  display: grid;
  row-gap: var(--spacer-regular);
  padding-top: var(--spacer-medium);
  padding-bottom: var(--spacer-medium);
}
.global-footer__inner--bottom {
  display: grid;
  row-gap: var(--spacer-medium);
}
.global-footer .static-page__link-list > li {
  border-bottom: var(--border-style);
}
.global-footer .static-page__link-text {
  --padding-vertical: 1.7rem;
  --padding-horizontal: .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: grid;
  row-gap: 2.6rem;
  letter-spacing: 0.03em;
  text-align: center;
}
.global-footer .law-page__link-text {
  font-size: 1.3rem;
  line-height: 2;
}
.global-footer .law-page__copyright-text {
  color: var(--color-white);
  font-size: 1.2rem;
  line-height: 1.5;
}
@media screen and (min-width: 768px){
  .global-header {
    --brand-logo-width: 11.7rem;
  }
  .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 {
    --padding-horizontal: 0;
    min-width: 22rem;
    padding: 0.4rem 0;
    border-bottom: solid 1px var(--color-gray-600);
  }
  .global-header .header__content-wrapper--primary .header__content-inner .global-header__search-container input {
    width: calc(100% - (var(--search-button-width) + 1ch));
    line-height: 2;
  }
  .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__inner {
    padding-top: var(--spacer-regular);
    padding-bottom: var(--spacer-regular);
  }
  .global-footer__inner--bottom {
    align-items: flex-start;
    column-gap: 5%;
    grid-template-columns: 1fr auto;
    padding-top: 3.5rem;
    border-top: var(--border-style);
  }
  .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 {
    row-gap: 1rem;
    text-align: right;
  }
  .global-footer .law-page__link-list {
    display: flex;
    gap: 2rem;
  }
}
@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;
  }
}




/* ===============================================
  * Override *
=============================================== */

/*
 * 共通
 */

/* TODO: 作業用スタイル. 完了後に削除する. */
.u-todo {
  display: grid;
  grid-template-columns: repeat(2, auto);
  align-items: center;
  column-gap: .5em;

  width: fit-content;
  margin: 1em auto;
  font-size: 1.4rem;
  letter-spacing: var(--ls-regular);
}

.u-todo::before {
  content: "TODO";

  display: grid;
  place-content: center;

  width: fit-content;
  padding: .25em .75em;
  background-color: var(--color-emphasis);
  border-radius: .4rem;

  color: var(--color-white);
  font-family: var(--font-en);
  font-weight: var(--fw-bold);
  letter-spacing: .1em;
  line-height: 1;
}




/*
 * ヘッダー
 */

/* 共通 */

.global-header {
  --border-style: solid 1px var(--color-project-sub);
  --brand-logo-width: 100px;
  --link-arrow: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2217%22%20height%3D%2217%22%20viewBox%3D%220%200%2017%2017%22%3E%20%3Cg%20id%3D%22%E3%82%B3%E3%83%B3%E3%83%9D%E3%83%BC%E3%83%8D%E3%83%B3%E3%83%88_42_12%22%20data-name%3D%22%E3%82%B3%E3%83%B3%E3%83%9D%E3%83%BC%E3%83%8D%E3%83%B3%E3%83%88%2042%20%E2%80%93%2012%22%20transform%3D%22translate(17%2017)%20rotate(180)%22%3E%20%3Crect%20id%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2_42%22%20data-name%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2%2042%22%20width%3D%2217%22%20height%3D%2217%22%20fill%3D%22none%22%2F%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_6%22%20data-name%3D%22%E3%83%91%E3%82%B9%206%22%20d%3D%22M349.884-1274.3l-6.071%2C5.261%2C6.071%2C5.26%22%20transform%3D%22translate(-338.045%201277.838)%22%20fill%3D%22none%22%20stroke%3D%22%23999%22%20stroke-linecap%3D%22round%22%20stroke-width%3D%221.5%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E');

  height: var(--height-header);
}

@media (min-width: 768px) {
  .global-header {
    --brand-logo-width: 114px;
  }
}


/* キーワード検索 */

.global-header__search-container {
  --search-button-width: 2.4rem;
  --padding-horizontal: 1.6rem;

  height: 100%;
}

@media (min-width: 768px) {
  .global-header .header__content-wrapper--primary .header__content-inner .global-header__search-container {
    --search-button-width: 2rem;
    --padding-horizontal: 1.4rem;

    width: 27rem;
    min-width: 0;
    padding: 0;
    border: none;
  }

  .global-header .header__content-wrapper--primary .header__content-inner .global-header__search-container input {
    width: 100%;
    height: 3.8rem;
    line-height: normal;
  }
}

.global-header__search-button {
  right: auto;
  left: var(--padding-horizontal);

  opacity: .4;
}

.global-header__search-form {
  height: 100%;
}

.global-header__search-form input {
  height: 100%;
  padding-inline: calc(var(--padding-horizontal) + var(--search-button-width) + .6rem) var(--padding-horizontal);
  border: solid 1px var(--color-project-gray-light);
  border-radius: calc(infinity * 1px);
  outline: none !important;

  font-family: var(--font-ja);
  font-size: 1.6rem;
  font-weight: var(--fw-regular);
  letter-spacing: var(--ls-regular);
}

.global-header__search-form input:focus-visible {
  border-color: var(--color-project-cv);
}

.global-header__search-form input:active {
  border-color: var(--color-project-cv);
}

.global-header__search-container:has(.global-header__search-form input:focus-visible) .global-header__search-button,
.global-header__search-container:has(.global-header__search-form input:active) .global-header__search-button {
  opacity: 1;
}

.global-header__search-container:has(.global-header__search-form input:focus-visible) svg,
.global-header__search-container:has(.global-header__search-form input:active) svg {
  color: var(--color-project-cv);
}

.global-header__search-form input::placeholder {
  font-size: 1.4rem;
  font-weight: inherit;
  letter-spacing: inherit;

  opacity: .4;
}

.global-header__suggest-keyword {
  --spacer-l: calc(var(--spacer-m, .8rem) * 2);
  --spacer-m: .8rem;
  --spacer-s: calc(var(--spacer-m, .8rem) / 2);

  position: absolute;
  top: calc(100% + 1rem);
  left: 0;

  row-gap: var(--spacer-m);

  width: 100%;
  max-height: min(40dvh, 50rem);
  padding: var(--spacer-l) var(--spacer-m);
  background-color: var(--color-white);
  border-radius: var(--spacer-m);
  box-shadow: 1px 4px 12px rgba(0, 0, 0, .2);

  overflow-y: auto;
  overscroll-behavior: contain;
}

.global-header__suggest-keyword :where(a, span, div) {
  color: var(--color-text-default);
  font-size: 1.2rem;
  letter-spacing: var(--ls-ja);
  text-decoration: none;
}

.global-header__suggest-keyword :where(a) {
  font-weight: var(--fw-bold);
}

.global-header__suggest-keyword .suggest-item {
  padding: var(--spacer-m);
  border-radius: var(--spacer-s);
  background-color: var(--color-project-pink-tertiary);
}

.global-header__suggest-keyword .suggest-item[onclick] {
  cursor: pointer;
}

.global-header__suggest-keyword .suggest-item:has(.suggest-item__image-wrapper) > div {
  display: grid;
  grid-template-columns: 30% 1fr;
  column-gap: 3%;
  align-items: flex-start;
}

.global-header__suggest-keyword .suggest-item:has(.suggest-item__image-wrapper) img {
  width: 100% !important;
  height: auto;
  aspect-ratio: 1;
}

.global-header__suggest-keyword .suggest-item__text-container {
  display: grid;
}


/* ティッカー */

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

.global-header .ticker__list-item > * {
  display: grid;

  height: var(--height-ticker);
  padding: 0 1.6rem;

  font-size: 1.2rem;
  letter-spacing: var(--ls-regular);
}

.global-header .ticker__list-item > * span {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
}


/* メインコンテンツ */

.global-header [data-header-area="primary"] {
  height: var(--height-header-primary);

  transition: background-color var(--transition-default);
}

@media (prefers-reduced-motion: reduce) {
  .global-header [data-header-area="primary"] {
    transition: none;
  }
}

@media (hover: hover) {
  .global-header [data-header-area="primary"]:hover {
    background-color: var(--color-white) !important;
  }
}

@media (min-width: 768px) {
  .global-header [data-header-area="primary"] {
    border-bottom: solid 1px #ededed;
  }
}

.global-header[data-page-top="false"] [data-header-area="primary"] {
  background-color: rgba(255, 255, 255, .9);
}

.global-header [data-header-area="primary"]:has(#hamburger-menu[hidden]) {
  transform: translateZ(0);
}

.global-header [data-header-area="primary"] .header__content-inner {
  height: 100%;
  margin-inline: auto;
  padding-block: 0;
  padding-inline: var(--padding-horizontal-global);
}

@media (min-width: 768px) {
  .global-header [data-header-area="primary"] .header__content-inner {
    display: grid;
    grid-template-columns: auto 1fr auto;
    column-gap: calc(40 / 1400 * 100%);

    max-width: none;
  }
}

@media (min-width: 768px) {
  .global-header .header-primary__navigation-container {
    column-gap: 1.8rem;
  }
}

.global-header .header-primary__navigation-container .header-primary__navigation-contents-wrapper [class*=header-primary__navigation-item-wrapper] {
  color: var(--color-text-default);
}

@media (min-width: 768px) {
  .global-header .header-primary__navigation-container .header-primary__navigation-contents-wrapper [class*=header-primary__navigation-item-wrapper] {
    width: 3.2rem;
  }
}

.global-header .header-primary__navigation-item-wrapper--cart .cart-state--count {
  --adjust-position-top: .1rem;

  top: -.2rem;
  right: -.3rem;

  background-color: var(--color-project-pink-primary);

  letter-spacing: var(--ls-en);
}

@media (min-width: 768px) {
  .global-header .header-primary__navigation-item-wrapper--cart .cart-state--count {
    top: .1rem;
    right: -.1rem;
  }
}


/* ハンバーガーメニュー */

.header-primary__hamburger-menu-container {
  --hamburger-menu-width: calc(100% - (var(--hamburger-icon-width) + var(--hamburger-icon-position) * 3));
}

.hamburger-menu__toggle-button {
  --icon-width: 1.8rem;
  /* --icon-height: 1.2rem; */
  --icon-height: 1.5rem;
  --icon-border-height: 2px;
  --hamburger-icon-position: 1rem;
  --hamburger-icon-position-x: 2.5rem;

  transition: translate var(--hamburger-menu-transition), opacity var(--hamburger-menu-transition);
}

.hamburger-menu__toggle-button-inner > span {
  border-radius: .4rem;

  scale: 1 1;
}

[data-hamburgermenu-type=overlay] .hamburger-menu__toggle-button[aria-expanded=false] {
  transition: none;
}

[data-hamburgermenu-type=overlay] .hamburger-menu__toggle-button[aria-expanded=true] {
  top: 1rem;
  right: auto;
  left: calc(3rem * -1);
  z-index: calc(var(--zindex-hamburgermenu-contents) + 1);

  opacity: 1;
  translate: calc(var(--hamburger-icon-position-x) + 3rem) 0;
}

[data-hamburgermenu-type=overlay] .hamburger-menu__toggle-button[aria-expanded=true] > span {
  filter: none;
}

[data-animation-type=horizontal-slide] .hamburger-menu__contents-wrapper {
  left: auto;
  right: 0;

  width: var(--hamburger-menu-width);
  padding-bottom: 6.8rem;

  translate: 100% 0;
}

[data-hamburgermenu-type=overlay] .hamburger-menu__toggle-button[aria-expanded=true] .hamburger-menu__toggle-button-inner > span {
  background-color: var(--color-white);
}

.hamburger-menu__wrapper {
  --padding-horizontal-item: 1.5rem;
}

.hamburger-menu__text--section-title[data-title-bg="active"] {
  --padding-content: .8rem var(--padding-horizontal-item);

  background-color: var(--color-project-white);

  font-family: var(--font-en);
  font-size: 1.5rem;
  font-weight: var(--fw-medium);
  letter-spacing: .2em;
}

.hamburger-menu__section .hamburger-menu__content-list {
  --border-style: solid 1px var(--color-project-gray-light);
  --padding-vertical-item: 1.4rem;

  display: grid;
  row-gap: var(--padding-vertical-item);

  padding: var(--padding-vertical-item, 1.4rem) var(--padding-horizontal-item, 1.5rem);
}

.hamburger-menu__section[data-section-name="item"] .hamburger-menu__content-list,
.hamburger-menu__section[data-section-name="contents"] .hamburger-menu__content-list {
  padding-bottom: 0;
}

.hamburger-menu__section .hamburger-menu__content-list:not([data-structure="child"], [data-structure="grand-child"]) > li:last-of-type {
  border-bottom: var(--border-style);
}

.hamburger-menu__section .hamburger-menu__content-list .hamburger-menu__text--link {
  grid-template-columns: 1fr 1.7rem;

  width: 100%;
  padding-top: 0;
  padding-bottom: var(--padding-vertical-item);
  padding-inline: 0;

  font-size: 1.3rem;
  font-family: var(--font-main);
  letter-spacing: var(--ls-ja);
  line-height: calc(19.5 / 13);
  text-align: left;
}

.hamburger-menu__section [data-state-accordion=opened] > .accordion__summary {
  background-color: transparent;
  border-bottom: var(--border-style);
}

.accordion__icon-wrapper::before,
.accordion__icon-wrapper::after {
  height: 1.5px;
  background-color: var(--color-project-gray-dark);
}

.hamburger-menu__section .accordion__content {
  padding: 2rem;
  background-color: var(--color-project-white);
  border-top: none;
}

.hamburger-menu__section .accordion__content .c-page-link__list {
  display: grid;
  row-gap: 1.2rem;
}

.hamburger-menu__section .accordion__content .c-page-link__text {
  color: var(--color-text-default);
  font-size: 1.3rem;
  font-weight: var(--fw-regular);
  letter-spacing: var(--ls-ja);
  text-decoration: none;
}

.hamburger-menu__section[data-section-name="user-info"] .hamburger-menu__text--section-title[data-title-bg="active"] {
  padding: 1.5rem var(--padding-horizontal-item);
  background-color: var(--color-project-pink-secondary);

  font-family: var(--font-main);
  font-size: 1.4rem;
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-ja);
  text-align: left;
}

.hamburger-menu__section[data-section-name="user-info"] .hamburger-menu__text--section-title[data-title-bg="active"] > small {
  display: inline-block;
  margin-left: .5rem;
  font-size: calc(12 / 14 * 1em);
}

.hamburger-menu__section[data-section-name="user-info"] .hamburger-menu__content-list {
  padding: 2rem var(--padding-horizontal-item);
}

.hamburger-menu__section[data-section-name="user-info"][data-state-login="false"] .hamburger-menu__content-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: .5rem;
}

.hamburger-menu__section[data-section-name="user-info"] .hamburger-menu__content-list-item {
  border: none !important;
}

.hamburger-menu__section[data-section-name="user-info"] .c-button {
  display: grid;
  grid-template-columns: 2.1rem auto;
  align-items: center;
  place-content: center;
  column-gap: .4rem;

  min-width: 0;
  padding: .9rem 0;

  font-size: 1.3rem;
  letter-spacing: var(--ls-ja);
}

.hamburger-menu__section[data-section-name="user-info"] .hamburger-menu__content-list {
  row-gap: 1.3rem;
}

.hamburger-menu__section[data-section-name="user-info"] .hamburger-menu__content-list-item {
  border: none;
}

.hamburger-menu__section[data-section-name="user-info"] .hamburger-menu__text--link {
  display: grid;
  grid-template-columns: 2.1rem 1fr;
  align-items: center;
  column-gap: .7rem;

  padding: 0;

  font-size: 1.3rem;
  font-weight: var(--fw-regular);
  letter-spacing: var(--ls-ja);
}

.hamburger-menu-overlay__dialog {
  top: 0;
  right: 0;
  left: auto;

  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  background-color: transparent;
  border: none;

  translate: 100% 0;
  transition: translate var(--hamburger-menu-transition);
  will-change: translate;
}

.hamburger-menu-overlay__dialog[data-state="active"] {
  translate: 0 0;
}

.hamburger-menu-overlay__dialog-inner {
  position: fixed;
  top: 0;
  right: 0;
  left: auto;

  width: var(--hamburger-menu-width);
  height: 100dvh;
  background-color: var(--color-white);

  overflow-y: auto;
}

.header-primary__hamburger-menu-container:has(.hamburger-menu-overlay__dialog[data-state="active"]) .hamburger-menu__toggle-button {
  opacity: 0;
}

.hamburger-menu-overlay__dialog::backdrop {
  background: transparent;
}

.hamburger-menu-overlay__sticky-button {
  position: sticky;
  top: 0;
  left: 0;
  z-index: 2;

  display: grid;
  grid-template-columns: 1.7rem 1fr 1.7rem;
  align-items: center;
  column-gap: 1rem;

  padding-block: 1.2rem;
  padding-inline: var(--padding-horizontal-item);
  background-color: var(--color-project-gray-light);
}

.hamburger-menu-overlay__sticky-button::after {
  content: "";
}

.hamburger-menu-overlay__sticky-button > * {
  font-size: 1.4rem;
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-regular);
  text-align: center;
}

.hamburger-menu-overlay__content-wrapper {
  padding: 1.7rem var(--padding-horizontal-item);
}

.hamburger-menu-overlay__content-wrapper .hamburger-menu__content-list {
  padding: 0;
}

.hamburger-menu-overlay__content-wrapper .accordion__content .hamburger-menu__content-list {
  row-gap: 0;
}

.hamburger-menu__section .hamburger-menu-overlay__content-wrapper .accordion__content {
  padding: 0;
  background-color: transparent;
}

.hamburger-menu-overlay__content-wrapper .accordion__content .hamburger-menu__text--link {
  padding-block: 1.5rem;
  padding-left: 2rem;
}

.hamburger-menu-overlay__content-wrapper .accordion__content .hamburger-menu__text--link:has(+ [data-structure="child"]) {
  border-bottom: var(--border-style);
}

.hamburger-menu-overlay__content-wrapper .accordion__content [data-structure="child"] .accordion__content {
  display: grid;
  row-gap: 1.8rem;

  padding: 2rem 1.5rem 1.3rem 2rem;
  background-color: var(--color-project-white);
  /* border-top: var(--border-style); */
}

.hamburger-menu-overlay__content-wrapper .accordion__content [data-structure="child"] .accordion__content .hamburger-menu__text--link {
  padding: 0;
}

.hamburger-menu-overlay__content-wrapper .accordion__content [data-structure="child"] .accordion__content .hamburger-menu__text--link::after {
  content: none;
}

.hamburger-menu-overlay__content-wrapper .accordion__content [data-structure="grand-child"] {
  display: grid;
  row-gap: 1.8rem;
}

.hamburger-menu-overlay__content-wrapper .accordion__content [data-structure="grand-child"] .hamburger-menu__content-list-item {
  border: none;
}

.hamburger-menu-overlay__content-wrapper .hamburger-menu__content-list-item[data-category-id="700"] .hamburger-menu__content-list-item[data-category-id="700101101"] {
  display: none !important;
}

.hamburger-menu-overlay__content-wrapper .hamburger-menu__content-list-item[data-category-id="700"] .hamburger-menu__content-list-item:has(+ .hamburger-menu__content-list-item[data-category-id="700101101"]) {
  border-bottom: none;
}

.hamburger-menu__section[data-section-name="hamburger-sns-area"] {
  display: grid;
  row-gap: 3rem;

  margin-top: 4rem;
}

.hamburger-menu__instagram-wrapper {
  display: grid;
  row-gap: 1rem;
}

.hamburger-menu__instagram-text--heading {
  display: grid;
  grid-template-columns: 2.5rem auto;
  align-items: center;
  justify-content: center;
  column-gap: .8rem;

  font-family: var(--font-en);
  font-size: 1.8rem;
  font-weight: var(--fw-regular);
  letter-spacing: .15em;
}

.hamburger-menu__instagram-wrapper .c-instagram-links__list {
  display: grid;
  row-gap: .8rem;

  text-align: center;
}

.hamburger-menu__instagram-wrapper .c-instagram-links__text--link {
  color: var(--color-text-default);
  font-family: var(--font-en);
  font-size: 1.3rem;
  font-weight: var(--fw-regular);
  letter-spacing: var(--ls-regular);
  text-decoration: none;
}

.hamburger-menu__sns-wrapper .c-sns-links__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: .5rem;
}

.hamburger-menu__sns-wrapper .c-sns-links__link-wrapper {
  display: grid;

  width: 5.5rem;
}


/* 検索エリア（モバイルのみ） */

.global-header [data-header-area="search"] {
  height: var(--height-header-search-area);
  padding-inline: var(--padding-horizontal-global);
  padding-bottom: 1.8rem;
  background-color: var(--color-white);

  transition: translate var(--transition-default), background-color var(--transition-default);
}

@media (prefers-reduced-motion: reduce) {
  .global-header [data-header-area="search"] {
    transition: none;
  }
}

.global-header[data-scroll-direction="down"] [data-header-area="search"] {
  translate: 0 -200%;
}

.global-header[data-page-top="false"] [data-header-area="search"] {
  background-color: rgba(255, 255, 255, .9);
}


/* メガメニュー（デスクトップのみ） */

.header-primary__mega-menu-wrapper {
  height: 100%;
}

.header-primary__mega-menu-wrapper .global-nav__content-list {
  justify-content: flex-start;
  column-gap: 3.5rem;

  height: 100%;
}

.header-primary__mega-menu-wrapper .mega-menu__wrapper {
  height: 100%;
}

.header-primary__mega-menu-wrapper .global-nav__text--link {
  place-content: center;

  height: 100%;

  font-family: var(--font-en);
  font-size: 1.5rem;
  font-weight: var(--fw-regular);
  letter-spacing: .15em;

  transition: font-weight var(--transition-default);
}

.header-primary__mega-menu-wrapper .mega-menu__wrapper[data-state="active"] .global-nav__text--link {
  font-weight: var(--fw-semibold);
}

.header-primary__mega-menu-wrapper .global-nav__text--link::after {
  content: none !important;
}

.header-primary__mega-menu-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%;
}

.header-primary__mega-menu-wrapper .mega-menu__content-inner {
  /* max-height: calc(100svh - var(--megamenu-escape-area) - var(--height-header)); */
  max-height: 70svh;
  padding-block: 3rem 6rem;
  background-color: var(--color-white);
  overflow-y: auto;
  overscroll-behavior: contain;

  opacity: 0;
  transition: opacity var(--transition-default);
}

.header-primary__mega-menu-wrapper .mega-menu__content-inner:has(.c-tab-panel__tab-list) {
  padding-top: 0;
}

.header-primary__mega-menu-wrapper .mega-menu__wrapper[data-state="active"] .mega-menu__content-inner {
  opacity: 1;
}

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

header:has(.mega-menu__wrapper[data-state="active"]) .header__mega-menu-bg {
  opacity: 1;
}

.mega-menu__contents-list {
  display: grid;
  grid-template-columns: repeat(3, auto);
  align-items: flex-start;
  justify-content: center;
  column-gap: calc(100 / 1200 * 100%);
}

.mage-menu__contents-list-item {
  display: grid;
  row-gap: 1.5rem;
}

.mega-menu__contents-text--title {
  color: var(--color-project-pink-primary);
  font-family: var(--font-en);
  font-size: 1.6rem;
  font-weight: var(--fw-medium);
}

.mage-menu__contents-list-item .c-page-link__list {
  display: grid;
  grid-template-columns: repeat(var(--column-num, 1), auto);
  gap: 1rem 3.5rem;
}

.mage-menu__contents-list-item .c-page-link__list .c-page-link__text {
  color: var(--color-text-default);
  font-size: 1.2rem;
  font-weight: var(--fw-regular);
  letter-spacing: var(--ls-ja);
  text-decoration: none;
}

.mega-menu__tab-panel .c-tab-panel__tab-list {
  /* Layout */
  --row-gap-tab-button-list: 0;
  --column-gap-tab-button-list: 0;
  --column-num: 6;
  ---tab-button-list-margin-bottom: 3rem;

  /* Tab Button Styles */
  --button-width: calc(100% / var(--column-num));
  --button-padding: 0 0 1rem;
  --button-bg: transparent;
  --button-border-radius: 0;
  --button-text-color: var(--color-text-default);
  --button-font-size: 1.5rem;
  --button-font-weight: var(--fw-semibold);
  --button-letter-spacing: .15em;
  --button-opacity-inactive: .3;
  --button-opacity-hover: var(--hover-opacity);
  --button-opacity-active: 1;

  position: sticky;
  top: 0;
  left: 0;

  padding-top: 3rem;
  background-color: var(--color-white);
}

.mega-menu__tab-panel .c-tab-panel__button--tab {
  border-bottom: solid 2px var(--color-text-default);
}

.mega-menu__tab-panel .c-tab-panel__button--tab[aria-selected="true"] {
  border-color: var(--color-primary);
}

.mega-menu__category-list[data-hierarchy="parent"] {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  align-items: flex-start;
  gap: 2rem 4rem;
}

.mega-menu__category-list[data-hierarchy="parent"] > li.mega-menu__category-list-item {
  display: grid;
  row-gap: 1.5rem;
}

.mega-menu__category-list[data-hierarchy="child"] {
  display: grid;
  row-gap: 1rem;

  padding-inline: 1.2rem;
}

.mega-menu__category-text--parent-link {
  display: grid;
  grid-template-columns: 1fr 1.7rem;
  align-items: center;
  column-gap: 1.8rem;

  background-color: var(--color-project-white);
  padding-block: .7rem;
  padding-inline: 1rem .5rem;

  color: var(--color-text-default);
  font-size: 1.3rem;
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-regular);
  line-height: var(--lh-regular);
  text-decoration: none;
}

.mega-menu__category-text--parent-link::after {
  content: "";

  width: 100%;
  aspect-ratio: 1;
  background-image: var(--link-arrow);
  background-repeat: no-repeat;
  background-size: contain;
}

.mega-menu__category-text--child-link {
  color: var(--color-text-default);
  font-size: 1.2rem;
  font-weight: var(--fw-regular);
  letter-spacing: var(--ls-regular);
  line-height: var(--lh-regular);
  text-decoration: none;
}

.mega-menu__category-list + .c-button {
  width: fit-content;
  min-width: 22rem;
  margin-top: 2rem;
  margin-inline: auto;
  padding-inline: 1.6rem;
}




/*
 * フッター
 */

.global-footer {
  --spacer-regular: 3rem;

  background-color: var(--color-text-default);

  line-height: 1.35;
}

.global-footer__inner {
  padding: 4rem 1.5rem 2rem;
}

@media (min-width: 768px) {
  .global-footer__inner {
    padding-block: 7rem 3rem;
    padding-inline: 0;
  }
}


/* Footer - Top */

.global-footer__inner--top {
  display: grid;
  row-gap: var(--spacer-regular);
}

@media (min-width: 768px) {
  .global-footer__inner--top {
    grid-auto-flow: column;
    align-items: flex-start;
    justify-content: flex-start;
    column-gap: 5.6rem;
  }
}

.global-footer__page-links-wrapper {
  display: grid;
  row-gap: 2rem;
}

@media (min-width: 768px) {
  .global-footer__page-links-wrapper {
    row-gap: 2.5rem;
  }
}

.global-footer__page-links-text--title {
  color: var(--color-project-pink-primary);
  font-family: var(--font-en);
  font-size: 1.6rem;
  font-weight: var(--fw-medium);
}

.global-footer__page-links-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.3rem;
}

@media (min-width: 768px) {
  .global-footer__page-links-list {
    column-gap: 3rem;
  }

  .global-footer__page-links-list[data-max-grid-rows] {
    grid-template-columns: initial;
    grid-template-rows: repeat(4, auto);
    grid-auto-flow: column;
  }
}

.global-footer__page-link-text--link {
  display: inline-grid;

  color: var(--color-white);
  font-size: 1.2rem;
  font-weight: var(--fw-regular);
  letter-spacing: var(--ls-ja);
  text-decoration: none;
}

.global-footer__page-link-text--link[target="_blank"] {
  grid-template-columns: auto 1.5rem;
  align-items: center;
  column-gap: .2rem;
}

.global-footer__page-link-text--link[target="_blank"]::after {
  content: "";

  width: 100%;
  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%2215%22%20height%3D%2215%22%20viewBox%3D%220%200%2015%2015%22%3E%20%3Cg%20id%3D%22_Blank_icon%22%20data-name%3D%22_Blank%20icon%22%20opacity%3D%220.6%22%3E%20%3Crect%20id%3D%22base%22%20width%3D%2215%22%20height%3D%2215%22%20fill%3D%22rgba(255%2C255%2C255%2C0)%22%2F%3E%20%3Cg%20id%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2_31%22%20data-name%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2%2031%22%20transform%3D%22translate(4.944%203.621)%22%20fill%3D%22none%22%20stroke%3D%22%23fff%22%20stroke-width%3D%221%22%3E%20%3Crect%20width%3D%228.451%22%20height%3D%226.416%22%20stroke%3D%22none%22%2F%3E%20%3Crect%20x%3D%220.5%22%20y%3D%220.5%22%20width%3D%227.451%22%20height%3D%225.416%22%20fill%3D%22none%22%2F%3E%20%3C%2Fg%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_9%22%20data-name%3D%22%E3%83%91%E3%82%B9%209%22%20d%3D%22M2.817%2C5.221v5h7%22%20transform%3D%22translate(-0.186%201.812)%22%20fill%3D%22none%22%20stroke%3D%22%23fff%22%20stroke-width%3D%221%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E');
  background-repeat: no-repeat;
  background-size: contain;
}

.global-footer__separator {
  border-color: rgba(255, 255, 255, .1);
}

@media (min-width: 768px) {
  .global-footer__separator {
    width: 1.5px;
    height: 100%;
  }
}


/* Footer - Bottom */

@media (min-width: 768px) {
  .global-footer__inner--bottom {
    display: block;

    padding-top: 0;
    border-top: none;
  }
}

.global-footer__image-banner-list {
  display: grid;
  grid-template-columns: repeat(var(--column-num, 2), 1fr);
  gap: .9rem;
}

@media (min-width: 768px) {
  .global-footer__image-banner-list {
    --column-num: 4;
    gap: 1.6rem;
  }
}


/* Footer - Legal */

.global-footer__inner--legal {
  display: grid;
  row-gap: 2.5rem;
  justify-content: center;

  text-align: center;
}

@media (min-width: 768px) {
  .global-footer__inner--legal {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}

.global-footer__legal-link-list {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 1.7rem;
}

.global-footer__legal-link-text {
  color: var(--color-white);
  font-size: 1rem;
  font-weight: var(--fw-regular);
  letter-spacing: var(--ls-ja);
  text-decoration: none;
}

.law-page__copyright-text {
  font-family: var(--font-en);
  font-size: 1.2rem;
  font-weight: var(--fw-regular);
}


/* Footer - Page Top Button */

.c-button--page-top {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  z-index: var(--zindex-floating-element);

  display: grid;
  place-content: center;
  justify-items: center;

  width: 3.5rem;
  aspect-ratio: 1;
  background-color: var(--color-project-pink-primary);
  border-radius: 50%;

  color: var(--color-white);

  cursor: pointer;

  translate: 0 calc(100% + 1rem);
  transition: translate var(--transition-default);
}

.c-button--page-top[data-state-visible="visible"] {
  translate: 0 0;
}

.c-button--page-top svg {
  width: 60%;

  rotate: 90deg;
}
