@charset "UTF-8";

/* ===============================================
  * Header - ヘッダーのスタイル *
=============================================== */

/* Header - Foundation */

/* Header - Layout */

/* Header - Base */

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

@media (min-width: 768px) {
  .l-header {
    --brand-logo-width: 11.7rem;
  }
}

.l-header summary {
  cursor: pointer;
}

.l-header summary::marker,
.l-header summary::-webkit-details-marker {
  display: none;
}

.l-header__text--link {
  color: var(--color-text-default);
  font-size: 1.2rem;
  letter-spacing: 0.03em;
  line-height: 1.6;
  text-decoration: none;
}

/* Header - ヘッダーの固定方式 */

.l-header {
  position: relative;
  z-index: var(--zindex-header);
}

.l-header[data-stick-header] {
  position: sticky;
  top: calc(var(--height-ticker) * -1);
}

.l-header[data-variable-header] {
  position: sticky;
  top: calc(var(--height-ticker) * -1);
}

.l-header[data-variable-header] [data-header-area=primary] {
  position: relative;
  z-index: 2;
}

.l-header[data-variable-header] [data-header-area=global-nav] {
  transition: translate var(--transition-default);
}

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

.l-header[data-variable-header][data-scroll-direction=down] [data-header-area=global-nav] {
  z-index: -1;
  translate: 0 -100%;
}

/* Header - ティッカー */

.l-header-ticker {
  background-color: var(--color-global-nav);
}

.l-header-ticker__list-item {
  --color-text: var(--color-white);
  --color-bg: var(--color-gray-500);
}

.l-header-ticker__list-item>* {
  display: -webkit-box;
  text-overflow: ellipsis;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  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;
}

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

.l-header-main {
  background-color: var(--color-white);
  border-bottom: var(--border-style);
}

.l-header-main__inner {
  display: grid;
  align-items: center;
  grid-template-columns: 1fr auto 1fr;
  padding: 1rem 1.7rem;
}

@media (min-width: 768px) {
  .l-header-main__inner {
    display: flex;
    justify-content: space-between;
    padding-top: 3.6rem;
    padding-bottom: 3.6rem;
  }
}

.l-header-main__brand-logo-wrapper {
  width: var(--brand-logo-width);
}

@media (min-width: 768px) {
  .l-header-main__navigation-container {
    display: flex;
    align-items: center;
    column-gap: 3rem;
    flex-shrink: 0;
  }
}

.l-header-main__navigation-contents-wrapper {
  display: flex;
  gap: 1rem;
  justify-content: flex-end;
}

@media (min-width: 768px) {
  .l-header-main__navigation-contents-wrapper .l-header__text--link {
    font-weight: bold;
  }
}

.l-header-main__navigation-contents-wrapper [class*=l-header-main__navigation-item-wrapper] {
  width: 3rem;
  aspect-ratio: 1;
}

.l-header-main__navigation-item-wrapper--cart {
  --count-num-width: 1.8rem;
  --indicator-width: .8rem;
  position: relative;
}

.l-header-main__navigation-item-wrapper--cart[data-cart-indicator=count] .cart-state--dot {
  display: none !important;
}

.l-header-main__navigation-item-wrapper--cart[data-cart-indicator=dot] .cart-state--count {
  display: none !important;
}

.l-header-main__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;
}

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

.l-header-main__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;
}

/* Header - グローバルナビ */

.l-header-navigation {
  position: relative;
  background-color: var(--color-white);
}

.l-header-navigation::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 2;
  width: 100%;
  border-bottom: var(--border-style);
  pointer-events: none;
}

.l-header-navigation__inner {
  display: grid;
  place-content: center;
}

.l-header-navigation__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;
}

.l-header-navigation__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;
}

@media (prefers-reduced-motion: reduce) {
  .l-header-navigation__text--link::after {
    transition: none;
  }
}

.l-header-navigation__list {
  display: flex;
  justify-content: center;
  column-gap: 8rem;
}

/* Header - メガメニュー */

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

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

@media (prefers-reduced-motion: reduce) {
  .l-header__mega-menu-text--link::after {
    transition: none;
  }
}

.l-header__mega-menu[data-state=active] .l-header__mega-menu-content-inner {
  translate: 0 0;
}

.l-header__mega-menu[data-state=active] .l-header__mega-menu-bg {
  opacity: 1;
}

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

.l-header__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;
  translate: 0 -100%;
  transition: translate var(--transition-default);
}

@media (prefers-reduced-motion: reduce) {
  .l-header__mega-menu-content-inner {
    transition: none;
  }
}

@supports (overscroll-behavior: contain) {
  .l-header__mega-menu-content-inner {
    overscroll-behavior: contain;
  }
}

.l-header__mega-menu-content-list[data-structure=parent] {
  display: grid;
  row-gap: calc(var(--megamenu-spacer) * 3);
}

.l-header__mega-menu-content-list[data-structure=parent]>li {
  display: grid;
  align-items: flex-start;
  column-gap: 3%;
  grid-template-columns: 30% 1fr;
}

.l-header__mega-menu-content-list[data-structure=parent]>li>a {
  font-weight: bold;
}

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

.l-header__mega-menu-content-list[data-structure=child]>li>* {
  padding: 0 var(--megamenu-spacer);
}

.l-header__mega-menu-content-list[data-structure=child]>li:not(:last-of-type) {
  border-right: var(--border-style);
}

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

@media (prefers-reduced-motion: reduce) {
  .l-header__mega-menu-bg {
    transition: none;
  }
}

/* Header - Object */

/* Header - Component */

/* Header - テキスト */

.c-link__text {
  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;
}

.c-link__text::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;
}

/* Header - 検索 */

.c-header-search {
  --search-button-width: 1.6rem;
  --padding-horizontal: 1.5rem;
  position: relative;
}

@media (min-width: 768px) {
  .c-header-search {
    --padding-horizontal: 0;
    min-width: 22rem;
    padding: 0.4rem 0;
    border-bottom: solid 1px var(--color-gray-600);
  }
}

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

@media (min-width: 768px) {
  .c-header-search__form input {
    width: calc(100% - (var(--search-button-width) + 1ch));
    line-height: 2;
  }
}

.c-header-search__form input::placeholder {
  font-size: 1.2rem;
}

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

.c-header-search__button a {
  color: var(--color-text-default);
}

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

.c-hamburger-menu {
  --hamburger-icon-width: 1.5rem;
  --hamburger-icon-position: 2rem;
  --padding-content: 1.2rem 1.6rem;
  justify-self: flex-start;
}

.c-hamburger-menu button {
  font-size: 3rem;
}

.c-hamburger-menu__button--toggle {
  --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);
}

@media (prefers-reduced-motion: reduce) {
  .c-hamburger-menu__button--toggle {
    transition: none;
  }
}

.c-hamburger-menu__button--toggle__inner {
  position: relative;
  display: block;
  width: var(--icon-width);
  height: var(--icon-height);
}

.c-hamburger-menu__button--toggle__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;
}

.c-hamburger-menu__button--toggle__inner>span:first-of-type {
  top: 0;
  transition: rotate var(--hamburger-transition-default), translate var(--hamburger-transition-default) var(--hamburger-transition-delay);
}

@media (prefers-reduced-motion: reduce) {
  .c-hamburger-menu__button--toggle__inner>span:first-of-type {
    transition: none;
  }
}

.c-hamburger-menu__button--toggle[aria-expanded=true] .c-hamburger-menu__button--toggle__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);
}

@media (prefers-reduced-motion: reduce) {
  .c-hamburger-menu__button--toggle[aria-expanded=true] .c-hamburger-menu__button--toggle__inner>span:first-of-type {
    transition: none;
  }
}

.c-hamburger-menu__button--toggle__inner>span:nth-of-type(2) {
  top: 0;
  bottom: 0;
  margin: auto;
  transition: opacity 0ms ease var(--hamburger-transition-delay);
}

@media (prefers-reduced-motion: reduce) {
  .c-hamburger-menu__button--toggle__inner>span:nth-of-type(2) {
    transition: none;
  }
}

.c-hamburger-menu__button--toggle[aria-expanded=true] .c-hamburger-menu__button--toggle__inner>span:nth-of-type(2) {
  opacity: 0;
}

.c-hamburger-menu__button--toggle__inner>span:last-of-type {
  bottom: 0;
  transition: rotate var(--hamburger-transition-default), translate var(--hamburger-transition-default) var(--hamburger-transition-delay);
}

@media (prefers-reduced-motion: reduce) {
  .c-hamburger-menu__button--toggle__inner>span:last-of-type {
    transition: none;
  }
}

.c-hamburger-menu__button--toggle[aria-expanded=true] .c-hamburger-menu__button--toggle__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);
}

@media (prefers-reduced-motion: reduce) {
  .c-hamburger-menu__button--toggle[aria-expanded=true] .c-hamburger-menu__button--toggle__inner>span:last-of-type {
    transition: none;
  }
}

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

.c-hamburger-menu__section .c-header-search {
  border: var(--border-style);
  border-radius: 0.5rem;
  overflow: hidden;
}

.c-hamburger-menu__section .c-header-search input {
  border-radius: 0.5rem;
  line-height: 5rem;
}

.c-hamburger-menu__section[data-section-name=hamburger-mail-magazine] {
  margin-top: 1.6rem;
}

.c-hamburger-menu__section[data-section-name=hamburger-sns-area] {
  margin-top: 3.6rem;
}

.c-hamburger-menu__section[data-section-name=hamburger-sns-area] .c-sns__list {
  --gap: 2.8rem;
  display: flex;
  flex-wrap: wrap;
  gap: calc(var(--gap) / 2) var(--gap);
  justify-content: center;
  margin-top: 1.8rem;
}

.c-hamburger-menu__section[data-section-name=hamburger-sns-area] .c-sns__list-item {
  width: 3rem;
  aspect-ratio: 1;
}

.c-hamburger-menu__section[data-section-name=hamburger-sns-area] .c-sns__list-item a {
  color: var(--color-gray-500);
}

.c-hamburger-menu__text--section-heading {
  font-size: 1.3rem;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.02em;
  text-align: center;
}

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

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

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

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

.c-hamburger-menu__button--mail>span {
  display: flex;
  align-items: center;
  column-gap: 1ch;
  font-size: 1.3rem;
  font-weight: bold;
}

.c-hamburger-menu__button--mail>span>small {
  font-size: 0.6em;
  font-weight: normal;
}

.c-hamburger-menu__section .c-link__list>li:not(:last-of-type) {
  border-bottom: var(--border-style);
}

.c-hamburger-menu__section .c-link__list[data-structure="parent"] > li:has(
  a[href^="/Form/Product/ProductList.aspx?shop=0&cat=020&"],
  a[href^="/Form/Product/ProductList.aspx?shop=0&cat=021&"],
  a[href^="/Form/Product/ProductList.aspx?shop=0&cat=022&"],
  a[href^="/Form/Product/ProductList.aspx?shop=0&cat=030&"],
  a[href^="/Form/Product/ProductList.aspx?shop=0&cat=031&"],
  a[href^="/Form/Product/ProductList.aspx?shop=0&cat=032&"],
  a[href^="/Form/Product/ProductList.aspx?shop=0&cat=080&"],
  a[href^="/Form/Product/ProductList.aspx?shop=0&cat=080001&"],
  a[href^="/Form/Product/ProductList.aspx?shop=0&cat=080002&"],
  a[href^="/Form/Product/ProductList.aspx?shop=0&cat=080003&"],
  a[href^="/Form/Product/ProductList.aspx?shop=0&cat=080004&"],
  a[href^="/Form/Product/ProductList.aspx?shop=0&cat=093&"]
) {
  display: none;
}

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

@media (prefers-reduced-motion: reduce) {
  .c-hamburger-menu__bg {
    transition: none;
  }
}

/* Header - アコーディオン */

.c-hamburger-menu__details {
  --accordion-icon-width: 1.4rem;
}

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

@media (prefers-reduced-motion: reduce) {
  .c-hamburger-menu__details-summary {
    transition: none;
  }
}

[data-state-accordion=opened]>.c-hamburger-menu__details-summary {
  background-color: #FAFAFA;
}

.c-hamburger-menu__details-summary::after {
  content: none;
}

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

.c-hamburger-menu__details-icon-wrapper::before,
.c-hamburger-menu__details-icon-wrapper::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  margin: auto;
  background-color: var(--color-text-default);
}

.c-hamburger-menu__details-icon-wrapper::before {
  rotate: 90deg;
  transition: rotate var(--transition-default);
}

@media (prefers-reduced-motion: reduce) {
  .c-hamburger-menu__details-icon-wrapper::before {
    transition: none;
  }
}

[data-state-accordion=opened]>.c-hamburger-menu__details-summary .c-hamburger-menu__details-icon-wrapper::before {
  rotate: 180deg;
}

.c-hamburger-menu__details-content {
  border-top: var(--border-style);
}

.c-hamburger-menu__details-content [data-structure=child] .c-link__text {
  font-size: 0.846em;
}

/* Header - アニメーション */

.l-header__inner[data-animation-type] {
  --hamburger-menu-transition: 300ms ease-in-out;
}

.c-hamburger-menu__nav[data-state=active] .c-hamburger-menu__contents-wrapper {
  opacity: 1 !important;
  translate: 0 0 !important;
}

.c-hamburger-menu__nav[data-state=active] .c-hamburger-menu__bg {
  opacity: 1 !important;
}

.l-header__inner[data-animation-type=fade] .c-hamburger-menu__contents-wrapper {
  opacity: 0;
  transition: opacity var(--hamburger-menu-transition);
}

@media (prefers-reduced-motion: reduce) {
  .l-header__inner[data-animation-type=fade] .c-hamburger-menu__contents-wrapper {
    transition: none;
  }
}

.l-header__inner[data-animation-type=horizontal-slide] .c-hamburger-menu__contents-wrapper {
  translate: -100% 0;
  transition: translate var(--hamburger-menu-transition);
  will-change: translate;
}

@media (prefers-reduced-motion: reduce) {
  .l-header__inner[data-animation-type=horizontal-slide] .c-hamburger-menu__contents-wrapper {
    transition: none;
  }
}

.l-header__inner[data-animation-type=vertical-slide] .c-hamburger-menu__contents-wrapper {
  translate: 0 -120%;
  transition: translate var(--hamburger-menu-transition);
  will-change: translate;
}

@media (prefers-reduced-motion: reduce) {
  .l-header__inner[data-animation-type=vertical-slide] .c-hamburger-menu__contents-wrapper {
    transition: none;
  }
}

.l-header__inner[data-animation-type=vertical-slide][data-hamburgermenu-type=same-level] .c-hamburger-menu__contents-wrapper {
  z-index: -1;
}

.l-header__inner[data-animation-type=vertical-slide][data-hamburgermenu-type=same-level] .c-hamburger-menu__bg {
  z-index: -2;
}

.l-header__inner[data-hamburgermenu-type=overlay] .c-hamburger-menu__button--toggle[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;
}

.l-header__inner[data-hamburgermenu-type=overlay] .c-hamburger-menu__button--toggle[aria-expanded=true]>span {
  filter: invert(1);
}

.l-header__inner[data-hamburgermenu-type=overlay] .c-hamburger-menu__contents-wrapper {
  top: 0;
  width: calc(100% - (var(--hamburger-icon-width) + var(--hamburger-icon-position) * 3));
  height: 100dvh;
}

.l-header__inner[data-hamburgermenu-type=same-level] .c-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));
}

.l-header__inner[data-hamburgermenu-type=same-level] .c-hamburger-menu__bg {
  top: var(--height-header);
  height: calc(100dvh - var(--height-header));
}

.l-header[data-state-sticky=active] .l-header__inner[data-hamburgermenu-type=same-level] {
  --height-header: calc(var(--height-header-primary) + var(--height-header-global-nav));
}

/* Header - Project */

/* Header - Utility */

/* Header - Animation */

@media (hover: none) {
  .l-header-navigation__inner .l-header__mega-menu-text--link {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }

  .l-header-navigation__inner .l-header__mega-menu-text--link:active::after,
  .l-header-navigation__inner .l-header__mega-menu-text--link:focus-visible::after {
    scale: 1.3;
    translate: 50%;
  }

  .l-header-navigation__list-item {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }

  .l-header-navigation__list-item:active .l-header-navigation__text--link::after,
  .l-header-navigation__list-item:focus-visible .l-header-navigation__text--link::after {
    translate: 0 0;
  }
}

@media (-ms-high-contrast: none),
(-ms-high-contrast: active),
(-moz-touch-enabled: 0),
(hover: hover) {
  .l-header-navigation__inner .l-header__mega-menu-text--link:hover::after,
  .l-header-navigation__inner .l-header__mega-menu-text--link:focus-visible::after {
    scale: 1.3;
    translate: 50%;
  }

  .l-header-navigation__list-item:hover .l-header-navigation__text--link::after,
  .l-header-navigation__list-item .l-header-navigation__text--link:focus-visible::after,
  .l-header-navigation__list-item .l-header__mega-menu[data-state="active"] .l-header-navigation__text--link::after {
    translate: 0 0;
  }
}




/* ===============================================
  * Footer - フッターのスタイル *
=============================================== */

/* Footer - Foundation */

/* Footer - Layout */

/* Footer - Base */

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

@media (min-width: 768px) {
  .l-footer {
    display: grid;
    place-items: center;
  }
}

.l-footer a {
  color: var(--color-default-text);
  text-decoration: none;
}

.l-footer__inner {
  display: grid;
  row-gap: var(--spacer-regular);
  padding-top: var(--spacer-medium);
  padding-bottom: var(--spacer-medium);
}

@media (min-width: 768px) {
  .l-footer__inner {
    padding-top: var(--spacer-regular);
    padding-bottom: var(--spacer-regular);
  }
}

/* Footer - Top */

@media (min-width: 768px) {
  .l-footer-top .c-link__list {
    display: flex;
    flex-wrap: wrap;
  }
}

.l-footer-top .c-link__list>li {
  border-bottom: var(--border-style);
}

@media (min-width: 768px) {
  .l-footer-top .c-link__list>li {
    display: flex;
    align-items: center;
    border-bottom: none;
  }

  .l-footer-top .c-link__list>li:not(:last-of-type)::after {
    content: "|";
    margin: 0 3rem;
    color: var(--color-default-text);
  }
}

.l-footer-top .c-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;
}

@media (min-width: 768px) {
  .l-footer-top .c-link__text {
    display: inline;
    padding: 0;
  }
}

.l-footer-top .c-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;
}

@media (min-width: 768px) {
  .l-footer-top .c-link__text::after {
    content: none;
  }
}

/* Footer - Bottom */

.l-footer-bottom {
  display: grid;
  row-gap: var(--spacer-medium);
}

@media (min-width: 768px) {
  .l-footer-bottom {
    align-items: flex-start;
    column-gap: 5%;
    grid-template-columns: 1fr auto;
    padding-top: 3.5rem;
    border-top: var(--border-style);
  }
}

.l-footer__brand-sns {
  display: grid;
  align-items: center;
  justify-items: center;
  row-gap: var(--spacer-medium);
}

@media (min-width: 768px) {
  .l-footer__brand-sns {
    column-gap: 6rem;
    justify-items: flex-start;
    grid-template-columns: var(--brand-logo-width) 1fr;
  }
}

.l-footer__brand-sns .c-sns__list {
  display: flex;
  flex-wrap: wrap;
  gap: calc(var(--sns-icon-width) / 2) var(--sns-icon-width);
  justify-content: center;
}

.l-footer__brand-sns .c-sns__list-item {
  width: var(--sns-icon-width);
  aspect-ratio: 1;
}

.l-footer__legal-page-link {
  display: grid;
  row-gap: 2.6rem;
  letter-spacing: 0.03em;
  text-align: center;
}

@media (min-width: 768px) {
  .l-footer__legal-page-link {
    row-gap: 1rem;
    text-align: right;
  }
}

@media (min-width: 768px) {
  .l-footer__legal-page-link-list {
    display: flex;
    gap: 2rem;
  }
}

.l-footer__legal-page-link-text {
  font-size: 1.3rem;
  line-height: 2;
}

.l-footer__copyright-text {
  color: var(--color-white);
  font-size: 1.2rem;
  line-height: 1.5;
}

/* Footer - Object */

/* Footer - Component */

/* Footer - Project */

/* Footer - Utility */




/* ===============================================
  * Override Styles - Header *
=============================================== */

/* Override Styles - Foundation */


/* Override Styles - Layout */

/* 構造 - Base */

.l-header {
  --brand-logo-width: 10.4rem;
  --border-style: solid 1px var(--color-project-border);
  --border-style: none;

  position: relative;
  top: initial;

  height: var(--height-header);

  box-shadow: 0 .2rem .6rem rgba(0, 0, 0, .2);
}

@media (min-width: 768px) {
  .l-header {
    --brand-logo-width: 12.719rem;
  }
}


/* 構造 - Main */

@media (min-width: 768px) {
  .l-header-main {
    border-bottom: none;
  }
}

.l-header-main__inner {
  padding: .8rem 1rem;
}

@media (min-width: 768px) {
  .l-header-main__inner {
    width: 100%;
    height: var(--height-header-primary);
    padding: 0 2rem;
  }
}


/* 構造 - Main - ブランドロゴ */

@media (min-width: 768px) {
  .l-header-main__brand-logo-wrapper {
    display: flex;
    align-items: center;
    column-gap: 1.5rem;

    width: auto;
  }

  .l-header-main__brand-logo-wrapper a {
    display: block;

    width: var(--brand-logo-width);
  }
}

.l-header-main__brand-name-text {
  display: grid;
  place-content: center;

  width: 100%;
  height: 2rem;
  background-color: var(--color-text-default);

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

@media (min-width: 768px) {
  .l-header-main__brand-name-text {
    display: block;

    width: auto;
    height: auto;
    background-color: transparent;

    color: var(--color-text-default);
    font-size: 1.6rem;
    letter-spacing: normal;
    word-break: keep-all;
  }
}


/* 構造 - Main - ナビゲーション */

.l-header-main__navigation-container {
  height: 100%;
}

.l-header-main__navigation-contents-wrapper {
  column-gap: 1.5rem;

  margin-right: .6rem;
}

@media (min-width: 768px) {
  .l-header-main__navigation-contents-wrapper {
    align-items: center;
    column-gap: 1rem;

    height: 100%;
    margin-right: 0;
  }
}

.l-header-main__navigation-details {
  height: 100%;
}

.l-header-main__navigation-details-content {
  --zindex-bg: 1;
  --zindex-contents: 2;

  position: relative;
  z-index: var(--zindex-hamburgermenu-contents);
}

.l-header-main__navigation-details-content::after {
  content: "";

  position: fixed;
  top: var(--height-header-primary);
  left: 0;
  z-index: var(--zindex-bg);

  width: 100%;
  height: calc(100dvh - var(--height-header-primary));
  background-color: rgba(0, 0, 0, .8);

  opacity: 0;
  pointer-events: none;

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

@media (prefers-reduced-motion: reduce) {
  .l-header-main__navigation-details-content::after {
    transition: none;
  }
}

.l-header-main__navigation-details[data-state="active"] .l-header-main__navigation-details-content::after {
  opacity: 1;
}

.l-header-main__navigation-details-content-inner {
  position: absolute;
  top: 0;
  left: -5.5rem;
  z-index: var(--zindex-contents);

  width: 15rem;
  background-color: var(--color-white);
  padding: 1.8rem 2rem;

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

@media (prefers-reduced-motion: reduce) {
  .l-header-main__navigation-details-content-inner {
    transition: none;
  }
}

.l-header-main__navigation-details[data-state="active"] .l-header-main__navigation-details-content-inner {
  opacity: 1;
}

.l-header-main__navigation-details-content-inner .c-link__list {
  display: grid;
  row-gap: 1.5rem;
}

.l-header-main__navigation-details-content-inner .c-link__text {
  --accordion-icon-width: 1rem;

  word-break: keep-all;
}

.l-header-main__navigation-details-content[data-details-name="user"] .l-header-main__navigation-details-content-inner {
  left: -15rem;

  width: 33rem;
}

.l-header-main__navigation-details-content[data-details-name="user"] .c-hamburger-menu__content-wrapper:has([data-link-name="mypage"]) {
  display: grid;
  grid-template-areas: "user-name ." "user-point user-link";
  grid-template-columns: repeat(2, 1fr);
  align-items: center;
  gap: 1.5rem;
}

.l-header-main__navigation-details-content[data-details-name="user"] .c-hamburger-menu__content-wrapper:has([data-link-name="mypage"]) .c-hamburger-menu__user-content-text--name {
  grid-area: user-name;
}
.l-header-main__navigation-details-content[data-details-name="user"] .c-hamburger-menu__content-wrapper:has([data-link-name="mypage"]) .c-hamburger-menu__user-content-text--point {
  grid-area: user-point;

  margin: 0;
}
.l-header-main__navigation-details-content[data-details-name="user"] .c-hamburger-menu__content-wrapper:has([data-link-name="mypage"]) .c-hamburger-menu__user-link-list {
  grid-area: user-link;

  grid-template-columns: auto;

  margin: 0;
}


/* 構造 - Navigation */

.l-header-navigation {
  height: var(--height-header-global-nav);
  background-color: var(--color-text-default);

  color: var(--color-white);
}

.l-header-navigation::after {
  content: none;
}

.l-header-navigation__inner {
  --column-gap: 3rem;

  /* display: flex; */
  grid-template-columns: auto 1fr;
  align-items: center;
  place-content: initial;

  width: 100%;
  height: 100%;
  padding: 0;
}

@media (max-width: 1499px) {
  .l-header-navigation__inner {
    --column-gap: calc(30 / 1700 * 100%);
  }
}

.l-header-navigation__list {
  justify-content: flex-end;
  column-gap: var(--column-gap);

  margin-inline: var(--column-gap);
}

.l-header-navigation__text--link {
  height: var(--height-header-global-nav);
  padding-block: 0;

  color: inherit;
  font-size: 1.2rem;
  font-weight: var(--fw-medium);
  letter-spacing: .05em;
  line-height: calc(16 / 12);
}

@media (min-width: 1500px) {
  .l-header-navigation__text--link {
    font-size: 1.4rem;
    line-height: calc(18 / 14);
  }
}

@media (min-width: 1700px) {
  .l-header-navigation__text--link {
    font-size: 1.5rem;
    line-height: calc(20 / 15);
  }
}

.l-header-navigation__text--link::after {
  background-color: var(--color-primary);
}

summary.l-header-navigation__text--link {
  --arrow-size: 1.2rem;
}

summary.l-header-navigation__text--link > span {
  display: grid;
  grid-template-columns: auto var(--arrow-size);
  align-items: center;
  column-gap: .8rem;
  text-align: center;
}

summary.l-header-navigation__text--link > span::after {
  content: "";

  width: 100%;
  aspect-ratio: 1;
  background-image: var(--asset-link-arrow-bottom-white);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;

  transition: scale var(--transition-default);
}

@media (prefers-reduced-motion: reduce) {
  summary.l-header-navigation__text--link > span::after {
    transition: none;
  }
}

.l-header__mega-menu[data-state="active"] summary.l-header-navigation__text--link > span::after {
  scale: 1 -1;
}

.l-header__mega-menu--brand summary.l-header-navigation__text--link > span {
  display: grid;
  grid-template-columns: var(--arrow-size) auto var(--arrow-size);
  column-gap: 4rem;

  height: var(--height-header-global-nav);
  padding-inline: 2rem;
  background-color: var(--color-project-text-sub);
}

.l-header__mega-menu--brand summary.l-header-navigation__text--link > span::before {
  content: "";
}

@media (max-width: 1499px) {
  .l-header__mega-menu--brand summary.l-header-navigation__text--link {
    place-content: initial;
  }

  .l-header__mega-menu--brand summary.l-header-navigation__text--link > span {
    grid-template-columns: auto var(--arrow-size);
    column-gap: 10%;

    width: calc(180 / 1700 * 100vw);

    word-break: keep-all;
  }

  .l-header__mega-menu--brand summary.l-header-navigation__text--link > span::before {
    content: none;
  }
}

.l-header__mega-menu--brand .l-header__mega-menu-content-inner {
  padding-block: 4rem 8rem;
  background-color: var(--color-project-text-sub);
}

.l-header__mega-menu--brand .l-content__fluid-wrapper,
.l-header__mega-menu--category .l-content__fluid-wrapper {
  width: 100%;
  padding-inline: 12%;
}

.l-header__mega-menu--category .l-content__fluid-wrapper {
  display: grid;
  row-gap: 2rem;
}

.l-header__mega-menu--category .l-header__mega-menu-text--all {
  display: grid;
  grid-template-areas: "img name" "img all";
  grid-template-columns: 10rem;
  align-content: center;
  gap: .8rem 1.5rem;

  width: fit-content;
  padding-left: 0;
}

.l-header__mega-menu--category .l-header__mega-menu-text--all::after {
  content: none;
}

.l-header__mega-menu--category .l-header__mega-menu-text--all > img {
  grid-area: img;
}

.l-header__mega-menu--category .l-header__mega-menu-text--all > b {
  grid-area: name;

  align-self: flex-end;

  font-size: 1.8rem;
  font-weight: var(--fw-bold);
  letter-spacing: .05em;
  line-height: calc(30 / 18);
}

.l-header__mega-menu--category .l-header__mega-menu-text--all > span {
  grid-area: all;

  display: flex;
  align-items: center;
  align-self: flex-start;
  column-gap: 1rem;

  font-size: 1.3rem;
  font-weight: var(--fw-medium);
  letter-spacing: .05em;
  line-height: calc(20 / 13);
}

.l-header__mega-menu--category .l-header__mega-menu-text--all > span::after {
  content: "";

  width: .982rem;
  aspect-ratio: 1;
  background-image: var(--asset-link-arrow-right-red);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}

.l-header__mega-menu--category .c-link__list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1rem;
}

.l-header__mega-menu--category .c-link__list-item > .c-link__text {
  --accordion-icon-width: 1.2rem;

  height: 100%;
  padding: 2rem 1.6rem;
  background-color: var(--color-project-bg-sub);
  border-radius: .4rem;

  font-size: 1.4rem;
  font-weight: var(--fw-regular);
  letter-spacing: .05em;
  line-height: calc(20 / 14);

  transition: box-shadow var(--transition-default);
}

@media (prefers-reduced-motion: reduce) {
  .l-header__mega-menu--category .c-link__list-item > .c-link__text {
    transition: none;
  }
}

.l-header__mega-menu--category .l-header__mega-menu-text--all > span::after,
.l-header__mega-menu--category .c-link__list-item > .c-link__text::after {
  transition: translate var(--transition-default);
}

@media (prefers-reduced-motion: reduce) {
  .l-header__mega-menu--category .l-header__mega-menu-text--all > span::after,
  .l-header__mega-menu--category .c-link__list-item > .c-link__text,
  .l-header__mega-menu--category .c-link__list-item > .c-link__text::after {
    transition: none;
  }
}

.l-header__mega-menu--category .c-link__list-item > .c-link__text:hover,
.l-header__mega-menu--category .c-link__list-item > .c-link__text:focus-visible {
  box-shadow: 0 0 .4rem rgba(0, 0, 0, .16);
}

.l-header__mega-menu--category .l-header__mega-menu-text--all:hover > span::after,
.l-header__mega-menu--category .l-header__mega-menu-text--all:focus-visible > span::after {
  translate: .5rem;
}


/* Override Styles - Object */



/* Override Styles - Object - Component */

/* ナビゲーションリンク */

.c-header__navigation-link {
  display: grid;
  row-gap: .1rem;
  justify-items: center;

  color: var(--color-text-default);
  text-decoration: none;
}

@media (min-width: 768px) {
  .c-header__navigation-link {
    align-content: center;
    row-gap: .5rem;

    width: 6rem;
    height: 100%;
  }
}

.c-header__navigation-link-icon {
  position: relative;

  width: 2.8rem;
  aspect-ratio: 1;
}

@media (min-width: 768px) {
  .c-header__navigation-link-icon {
    width: 3rem;
  }
}

.c-header__navigation-link-icon .cart-state--count {
  position: absolute;
  top: -.3rem;
  right: -.8rem;

  display: grid;
  place-content: center;

  width: 1.6rem;
  aspect-ratio: 1;
  background-color: var(--color-emphasis);
  border-radius: 50%;

  color: var(--color-white);
  font-size: 1rem;
  font-weight: var(--fw-regular);
  letter-spacing: .03em;
  line-height: 1;
}

@media (min-width: 768px) {
  .c-header__navigation-link-icon .cart-state--count {
    top: -.4rem;
    right: -1rem;

    width: 2rem;
  }
}

.c-header__navigation-link-text {
  font-size: 1rem;
  font-weight: var(--fw-medium);
  letter-spacing: normal;
  line-height: 1.5;
}

@media (min-width: 768px) {
  .c-header__navigation-link-text {
    font-size: 1.1rem;
  }
}


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

/* ハンバーガーメニュー - ボタン */

.c-hamburger-menu__button-wrapper {
  transition: translate var(--transition-default);

  color: var(--color-active, var(--color-text-default));
}

@media (prefers-reduced-motion: reduce) {
  .c-hamburger-menu__button-wrapper {
    transition: none;
  }
}

.c-hamburger-menu__button-wrapper:has(.c-hamburger-menu__button--toggle[aria-expanded="false"]) .c-hamburger-menu__button-text--close,
.c-hamburger-menu__button-wrapper:has(.c-hamburger-menu__button--toggle[aria-expanded="true"]) .c-hamburger-menu__button-text--open {
  display: none;
}

.c-hamburger-menu__button--toggle {
  --icon-width: 2.6rem;
  --icon-height: 1.8rem;
  --icon-border-height: 4px;

  border-radius: .4rem;
}

.c-hamburger-menu__button--toggle__inner > span {
  background-color: var(--color-active, var(--color-text-default));
  color: var(--color-active, var(--color-text-default));
}

.l-header__inner[data-hamburgermenu-type=overlay] .c-hamburger-menu__button--toggle[aria-expanded=true] {
  position: initial;
  z-index: initial;

  translate: none;

  filter: invert(1);
}

.l-header__inner[data-hamburgermenu-type=overlay] .c-hamburger-menu__button-wrapper:has(.c-hamburger-menu__button--toggle[aria-expanded=true]) {
  --color-active: var(--color-white);

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

/* ハンバーガーメニュー - コンテンツ */

.c-hamburger-menu__nav {
  --padding-content: 1.6rem var(--padding-horizontal-global);
  --accordion-icon-width: 1rem;
}

.c-hamburger-menu__contents-wrapper {
  padding-bottom: 0;
  box-shadow: 5px 0px 5px rgba(0, 0, 0, 0.16);
}

.c-hamburger-menu__text--section-heading {
  font-size: 1.5rem;
  font-weight: var(--fw-bold);
  letter-spacing: .015em;
}

.c-hamburger-menu__text--section-heading[data-title-bg=active] {
  background-color: var(--color-text-default);

  color: var(--color-white);
}

.c-link__text {
  grid-template-columns: 1fr var(--accordion-icon-width);
  column-gap: 1rem;

  font-size: 1.4rem;
  font-weight: var(--fw-medium);
  letter-spacing: .03em;
  line-height: 1.5;
}

.c-link__text:has(img) {
  grid-template-columns: 4rem 1fr var(--accordion-icon-width);
  column-gap: .5rem;

  padding-left: 1rem;
}

.c-link__text::after {
  height: auto;
  aspect-ratio: 1;
  background-image: var(--asset-link-arrow-right-red);
  background-position: center;

  transition: translate var(--transition-default);
}

.c-link__text[target="_blank"]::after {
  background-image: var(--asset-link-blank-red);
}

@media (prefers-reduced-motion: reduce) {
  .c-link__text::after {
    transition: none;
  }
}

.c-link__text:hover::after,
.c-link__text:focus-visible::after {
  translate: .5rem;
}

.c-hamburger-menu__details {
  --accordion-icon-width: 1rem;
}

[data-state-accordion=opened] > .c-hamburger-menu__details-summary {
  background-color: var(--color-white);
}

.c-hamburger-menu__details-content {
  border-top: none;
}

[data-state-accordion=opened] .c-hamburger-menu__details-content {
  background-color: var(--color-project-bg-sub);
}

.c-hamburger-menu__details-content > .c-link__text {
  border-bottom: var(--border-style);
}

.c-hamburger-menu__details-content .c-link__text {
  font-size: 1.3rem;
  font-weight: var(--fw-regular);
  letter-spacing: .03em;
  line-height: calc(18 / 13);
}

.c-hamburger-menu__details-icon-wrapper::before,
.c-hamburger-menu__details-icon-wrapper::after {
  height: 2px;
  background-color: var(--color-primary);
}

.c-hamburger-menu__section[aria-labelledby="hamburger-menu-user"] .c-hamburger-menu__content-wrapper {
  display: grid;

  padding: 2rem var(--padding-horizontal-global);
  background-color: var(--color-project-bg-sub);
}

.c-hamburger-menu__user-content-text--name {
  font-size: 1.4rem;
  font-weight: var(--fw-medium);
  letter-spacing: .05em;
  line-height: calc(20 / 14);
}

.c-hamburger-menu__user-content-text--point {
  margin-top: .6rem;

  font-size: 1.2rem;
  font-weight: var(--fw-medium);
  letter-spacing: .05em;
  line-height: calc(17 / 12);
}

.c-hamburger-menu__user-content-text--point > b {
  color: var(--color-emphasis);
  font-size: 1.33em;
  font-weight: var(--fw-bold);
}

.c-hamburger-menu__user-link-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: .5rem;

  margin-top: 1rem;
}

.c-hamburger-menu__user-link {
  display: flex;
  align-items: center;
  justify-content: center;
  column-gap: .8rem;

  width: 100%;
  padding-block: 1rem;
  background-color: var(--color-white);
  border: solid 1px var(--color-text-default);
  border-radius: .4rem;

  color: var(--color-text-default);
  font-size: 1.3rem;
  font-weight: var(--fw-medium);
  letter-spacing: .05em;
  line-height: 1;
  text-decoration: none;
}

.c-hamburger-menu__user-link[data-link-name]::before {
  content: "";

  width: 2rem;
  aspect-ratio: 1;
  background-image: var(--icon-url);
  background-repeat: no-repeat;
  background-size: contain;
}

.c-hamburger-menu__user-link[data-link-name="login"] {
  --icon-url: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2220%22%20height%3D%2220%22%20viewBox%3D%220%200%2020%2020%22%3E%20%3Cdefs%3E%20%3CclipPath%20id%3D%22clip-path%22%3E%20%3Crect%20id%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2_24073%22%20data-name%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2%2024073%22%20width%3D%2220%22%20height%3D%2220%22%20transform%3D%22translate(1551%20138)%22%20fill%3D%22%23fff%22%20stroke%3D%22%23707070%22%20stroke-width%3D%221%22%2F%3E%20%3C%2FclipPath%3E%20%3CclipPath%20id%3D%22clip-path-2%22%3E%20%3Crect%20id%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2_24072%22%20data-name%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2%2024072%22%20width%3D%2214.936%22%20height%3D%2218%22%20fill%3D%22none%22%2F%3E%20%3C%2FclipPath%3E%20%3C%2Fdefs%3E%20%3Cg%20id%3D%22%E3%83%9E%E3%82%B9%E3%82%AF%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_42%22%20data-name%3D%22%E3%83%9E%E3%82%B9%E3%82%AF%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%2042%22%20transform%3D%22translate(-1551%20-138)%22%20clip-path%3D%22url(%23clip-path)%22%3E%20%3Cg%20id%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_11534%22%20data-name%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%2011534%22%20transform%3D%22translate(1553.718%20139)%22%3E%20%3Cg%20id%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_11533%22%20data-name%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%2011533%22%3E%20%3Cg%20id%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_11532%22%20data-name%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%2011532%22%20clip-path%3D%22url(%23clip-path-2)%22%3E%20%3Cline%20id%3D%22%E7%B7%9A_1004%22%20data-name%3D%22%E7%B7%9A%201004%22%20x1%3D%223.83%22%20transform%3D%22translate(0.574%209)%22%20fill%3D%22none%22%20stroke%3D%22%23333%22%20stroke-linecap%3D%22square%22%20stroke-miterlimit%3D%2210%22%20stroke-width%3D%221.8%22%2F%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_4770%22%20data-name%3D%22%E3%83%91%E3%82%B9%204770%22%20d%3D%22M35.625%2C7.53v-1.9H46.349V19.592H35.625v-1.9%22%20transform%3D%22translate(-32.763%20-3.499)%22%20fill%3D%22none%22%20stroke%3D%22%23333%22%20stroke-miterlimit%3D%2210%22%20stroke-width%3D%221.8%22%2F%3E%20%3C%2Fg%3E%20%3C%2Fg%3E%20%3Cline%20id%3D%22%E7%B7%9A_1005%22%20data-name%3D%22%E7%B7%9A%201005%22%20x1%3D%223.83%22%20transform%3D%22translate(4.404%209)%22%20fill%3D%22none%22%20stroke%3D%22%23333%22%20stroke-miterlimit%3D%2210%22%20stroke-width%3D%221.8%22%2F%3E%20%3Cline%20id%3D%22%E7%B7%9A_1006%22%20data-name%3D%22%E7%B7%9A%201006%22%20x2%3D%222.328%22%20y2%3D%222.328%22%20transform%3D%22translate(5.946%206.712)%22%20fill%3D%22none%22%20stroke%3D%22%23333%22%20stroke-linecap%3D%22square%22%20stroke-miterlimit%3D%2210%22%20stroke-width%3D%221.8%22%2F%3E%20%3Cline%20id%3D%22%E7%B7%9A_1007%22%20data-name%3D%22%E7%B7%9A%201007%22%20y1%3D%222.328%22%20x2%3D%222.328%22%20transform%3D%22translate(5.946%209)%22%20fill%3D%22none%22%20stroke%3D%22%23333%22%20stroke-linecap%3D%22square%22%20stroke-miterlimit%3D%2210%22%20stroke-width%3D%221.8%22%2F%3E%20%3C%2Fg%3E%20%3C%2Fg%3E%3C%2Fsvg%3E');
}

.c-hamburger-menu__user-link[data-link-name="register"] {
  --icon-url: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2220%22%20height%3D%2220%22%20viewBox%3D%220%200%2020%2020%22%3E%20%3Cdefs%3E%20%3CclipPath%20id%3D%22clip-path%22%3E%20%3Crect%20id%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2_24077%22%20data-name%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2%2024077%22%20width%3D%2220%22%20height%3D%2220%22%20transform%3D%22translate(1672%20138)%22%20fill%3D%22%23fff%22%20stroke%3D%22%23707070%22%20stroke-width%3D%221%22%2F%3E%20%3C%2FclipPath%3E%20%3CclipPath%20id%3D%22clip-path-2%22%3E%20%3Crect%20id%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2_24075%22%20data-name%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2%2024075%22%20width%3D%2218%22%20height%3D%2218%22%20fill%3D%22none%22%20stroke%3D%22%23333%22%20stroke-width%3D%221%22%2F%3E%20%3C%2FclipPath%3E%20%3C%2Fdefs%3E%20%3Cg%20id%3D%22%E3%83%9E%E3%82%B9%E3%82%AF%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_43%22%20data-name%3D%22%E3%83%9E%E3%82%B9%E3%82%AF%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%2043%22%20transform%3D%22translate(-1672%20-138)%22%20clip-path%3D%22url(%23clip-path)%22%3E%20%3Cg%20id%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_11537%22%20data-name%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%2011537%22%20transform%3D%22translate(1673.718%20140.156)%22%3E%20%3Cg%20id%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_11536%22%20data-name%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%2011536%22%20transform%3D%22translate(-1%20-1)%22%3E%20%3Cg%20id%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_11535%22%20data-name%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%2011535%22%20clip-path%3D%22url(%23clip-path-2)%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_4771%22%20data-name%3D%22%E3%83%91%E3%82%B9%204771%22%20d%3D%22M8.346%2C22.923H5.625V20.2L17.872%2C7.955l2.721%2C2.721Z%22%20transform%3D%22translate(-4.215%20-6.333)%22%20fill%3D%22none%22%20stroke%3D%22%23333%22%20stroke-linecap%3D%22square%22%20stroke-miterlimit%3D%2210%22%20stroke-width%3D%221.8%22%2F%3E%20%3C%2Fg%3E%20%3C%2Fg%3E%20%3Cline%20id%3D%22%E7%B7%9A_1008%22%20data-name%3D%22%E7%B7%9A%201008%22%20x2%3D%222.764%22%20y2%3D%222.764%22%20transform%3D%22translate(10.582%202.654)%22%20fill%3D%22none%22%20stroke%3D%22%23333%22%20stroke-linecap%3D%22square%22%20stroke-miterlimit%3D%2210%22%20stroke-width%3D%221.8%22%2F%3E%20%3C%2Fg%3E%20%3C%2Fg%3E%3C%2Fsvg%3E');
}

.c-hamburger-menu__user-link[data-link-name="mypage"] {
  --icon-url: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2220%22%20height%3D%2220%22%20viewBox%3D%220%200%2020%2020%22%3E%20%3Cdefs%3E%20%3CclipPath%20id%3D%22clip-path%22%3E%20%3Crect%20id%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2_3946%22%20data-name%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2%203946%22%20width%3D%2220%22%20height%3D%2220%22%20transform%3D%22translate(1468%2018)%22%20fill%3D%22%23fff%22%20stroke%3D%22%23707070%22%20stroke-width%3D%221%22%2F%3E%20%3C%2FclipPath%3E%20%3C%2Fdefs%3E%20%3Cg%20id%3D%22%E3%83%9E%E3%82%B9%E3%82%AF%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_6%22%20data-name%3D%22%E3%83%9E%E3%82%B9%E3%82%AF%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%206%22%20transform%3D%22translate(-1468%20-18)%22%20clip-path%3D%22url(%23clip-path)%22%3E%20%3Cg%20id%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_11397%22%20data-name%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%2011397%22%20transform%3D%22translate(1468.667%2018.747)%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_4619%22%20data-name%3D%22%E3%83%91%E3%82%B9%204619%22%20d%3D%22M11.043%2C20.336A9.293%2C9.293%2C0%2C0%2C1%2C4.472%2C4.472%2C9.293%2C9.293%2C0%2C0%2C1%2C17.614%2C17.614%2C9.232%2C9.232%2C0%2C0%2C1%2C11.043%2C20.336ZM3.417%2C11.043A7.626%2C7.626%2C0%2C1%2C0%2C5.65%2C5.65%2C7.576%2C7.576%2C0%2C0%2C0%2C3.417%2C11.043Z%22%20transform%3D%22translate(-1.75%20-1.75)%22%20fill%3D%22%23333%22%2F%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_4620%22%20data-name%3D%22%E3%83%91%E3%82%B9%204620%22%20d%3D%22M11.4%2C13.056A3.653%2C3.653%2C0%2C1%2C1%2C15.056%2C9.4%2C3.657%2C3.657%2C0%2C0%2C1%2C11.4%2C13.056ZM9.417%2C9.4A1.987%2C1.987%2C0%2C1%2C0%2C11.4%2C7.417%2C1.989%2C1.989%2C0%2C0%2C0%2C9.417%2C9.4Z%22%20transform%3D%22translate(-2.11%20-1.99)%22%20fill%3D%22%23333%22%2F%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_4621%22%20data-name%3D%22%E3%83%91%E3%82%B9%204621%22%20d%3D%22M16.716%2C19.1a.834.834%2C0%2C0%2C1-.8-.6%2C2.926%2C2.926%2C0%2C0%2C0-2.8-2.089H9.353a2.926%2C2.926%2C0%2C0%2C0-2.8%2C2.084.833.833%2C0%2C0%2C1-1.6-.48%2C4.593%2C4.593%2C0%2C0%2C1%2C4.4-3.271h3.76a4.593%2C4.593%2C0%2C0%2C1%2C4.4%2C3.278.834.834%2C0%2C0%2C1-.8%2C1.072Z%22%20transform%3D%22translate(-1.94%20-2.531)%22%20fill%3D%22%23333%22%2F%3E%20%3C%2Fg%3E%20%3C%2Fg%3E%3C%2Fsvg%3E');
}

.c-hamburger-menu__user-link[data-link-name="favorite"] {
  --icon-url: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2220%22%20height%3D%2220%22%20viewBox%3D%220%200%2020%2020%22%3E%20%3Cdefs%3E%20%3CclipPath%20id%3D%22clip-path%22%3E%20%3Crect%20id%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2_3945%22%20data-name%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2%203945%22%20width%3D%2220%22%20height%3D%2220%22%20transform%3D%22translate(1551%2018)%22%20fill%3D%22%23fff%22%20stroke%3D%22%23707070%22%20stroke-width%3D%221%22%2F%3E%20%3C%2FclipPath%3E%20%3C%2Fdefs%3E%20%3Cg%20id%3D%22%E3%83%9E%E3%82%B9%E3%82%AF%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_5%22%20data-name%3D%22%E3%83%9E%E3%82%B9%E3%82%AF%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%205%22%20transform%3D%22translate(-1551%20-18)%22%20clip-path%3D%22url(%23clip-path)%22%3E%20%3Cpath%20id%3D%22_1010_sy_h%22%20data-name%3D%221010_sy_h%22%20d%3D%22M24.815%2C13.6a4.854%2C4.854%2C0%2C0%2C1%2C3.267%2C1.25.872.872%2C0%2C0%2C1%2C.1.083%2C4.412%2C4.412%2C0%2C0%2C1%2C0%2C6.471L26.668%2C22.85l-5.475%2C5.234a.889.889%2C0%2C0%2C1-1.221%2C0L12.941%2C21.4l-.01-.009a4.416%2C4.416%2C0%2C0%2C1%2C0-6.319%2C4.893%2C4.893%2C0%2C0%2C1%2C6.7-.157l.016.015.915.867.909-.866%2C0%2C0A4.853%2C4.853%2C0%2C0%2C1%2C24.815%2C13.6Zm2.226%2C2.633a.871.871%2C0%2C0%2C1-.1-.078%2C3.116%2C3.116%2C0%2C0%2C0-4.259%2C0L21.17%2C17.6a.889.889%2C0%2C0%2C1-1.219%2C0l-1.517-1.438a3.116%2C3.116%2C0%2C0%2C0-4.259.108l0%2C0a2.726%2C2.726%2C0%2C0%2C0%2C0%2C3.9l6.413%2C6.1%2C4.865-4.651%2C0%2C0%2C1.525-1.446%2C0%2C0a2.724%2C2.724%2C0%2C0%2C0%2C.063-3.935Z%22%20transform%3D%22translate(1540.4%207.396)%22%20fill%3D%22%23333%22%2F%3E%20%3C%2Fg%3E%3C%2Fsvg%3E');
}

.c-hamburger-menu__section[aria-labelledby="hamburger-menu-brands"]  .c-hamburger-menu__content-wrapper {
  padding-bottom: 3rem;
}

.c-hamburger-menu__section[aria-labelledby="hamburger-menu-help"] .c-link__list>li:last-of-type {
  border-bottom: var(--border-style);
}

.c-hamburger-menu__section[aria-labelledby="hamburger-menu-sns"] .c-hamburger-menu__content-wrapper {
  padding-block: 3rem 5rem;
  background-color: var(--color-project-bg-sub);
}

.c-hamburger-menu__section[aria-labelledby="hamburger-menu-sns"] .c-sns__container {
  --gap: .8rem 1.6rem;

  row-gap: .4rem;
}
.c-hamburger-menu__section[aria-labelledby="hamburger-menu-sns"] .c-sns__section {
  padding: 1.5rem;
  background-color: var(--color-white);
}

.c-hamburger-menu__section[aria-labelledby="hamburger-menu-sns"] .c-sns__list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
}

.c-hamburger-menu__section[aria-labelledby="hamburger-menu-sns"] .c-sns__list-item {
  width: 100%;
}

.c-hamburger-menu__section[aria-labelledby="hamburger-menu-sns"] .c-button--mail {
  margin-top: 3rem;
}

.c-hamburger-menu__bg {
  background-color: rgba(0, 0, 0, .8);
}


/* ブランドバナーリンク */
.c-image-banner__list {
  --zindex-shadow: 1;
  --zindex-logo: 2;

  display: grid;
  grid-template-columns: repeat(var(--grid-column, 2), 1fr);
  gap: .9rem;
}

@media (min-width: 768px) {
  .c-image-banner__list {
    --grid-column: 4;

    gap: 2.8rem;
  }
}

.c-image-banner__link {
  display: flex;

  color: var(--color-white);
  text-decoration: none;
}

.c-image-banner__image {
  position: relative;

  aspect-ratio: 133 / 88.8;
  overflow: hidden;
}

@media (min-width: 768px) {
  .c-image-banner__image {
    aspect-ratio: 328 / 219;
  }
}

.c-image-banner__image > img {
  transition: scale var(--transition-duration-extra-long) ease-out;
}

@media (prefers-reduced-motion: reduce) {
  .c-image-banner__image > img {
    transition: none;
  }
}

.c-image-banner__link:hover .c-image-banner__image > img,
.c-image-banner__link:focus-visible .c-image-banner__image > img {
  scale: 1.2;
}

.c-image-banner__image::before {
  content: "";

  position: absolute;
  top: 0;
  left: 0;
  z-index: var(--zindex-shadow, 1);

  width: 100%;
  height: 100%;
  background: linear-gradient(rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.2) 100%);
}

.c-image-banner__name-wrapper {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: var(--zindex-logo, 2);

  display: flex;
  align-items: baseline;
  column-gap: .5rem;

  width: 100%;
  padding: .8rem;

  font-size: 1rem;
  font-weight: var(--fw-extrabold);
  letter-spacing: .05em;
  line-height: 1;
}

@media (min-width: 768px) {
  .c-image-banner__name-wrapper {
    --padding-inline: 1.5rem;
    --arrow-size: .8rem;

    align-items: center;

    padding: 1.6rem calc(var(--padding-inline) + var(--arrow-size) + 1em) 1.6rem var(--padding-inline);
    background-color: rgba(0, 0, 0, .5);
    background-image: var(--asset-link-arrow-right-white);
    background-position: right var(--padding-inline) center;
    background-repeat: no-repeat;
    background-size: var(--arrow-size);

    font-size: 1.4rem;
  }
}

.c-image-banner__name-wrapper {
  transition: background-position var(--transition-default);
}

@media (prefers-reduced-motion: reduce) {
  .c-image-banner__name-wrapper {
    transition: none;
  }
}

.c-image-banner__link:hover .c-image-banner__name-wrapper,
.c-image-banner__link:focus-visible .c-image-banner__name-wrapper {
  background-position: right calc(var(--padding-inline) - .5rem) center;
}

.c-image-banner__name-wrapper img {
  width: auto;
  height: 1.2rem;
}

/* Animation */

.c-image-banner__image img {
  transition: scale var(--transition-duration-extra-long) ease-out;
}

@media (prefers-reduced-motion: reduce) {
  .c-image-banner__image img {
    transition: none;
  }
}

.c-image-banner__link:hover .c-image-banner__image picture > img {
  scale: 1.2;
}


/* SNS, メールマガジン */

.c-sns__container {
  display: grid;
  row-gap: .2rem;
  grid-template-columns: auto 1fr;
  gap: var(--gap, 2rem);
}

.c-sns__section {
  display: grid;
  grid-template-columns: subgrid;
  grid-column: span 2;
  align-items: center;
  gap: var(--gap, 2rem);

  padding: 1.5rem 2.5rem;
  background-color: var(--color-project-bg-sub);
}

.c-sns__text--heading {
  font-size: 1.4rem;
  font-weight: var(--fw-bold);
  letter-spacing: .05em;
  text-align: center;
}

.c-sns__list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gap, 2rem);
}

.c-sns__list-item {
  width: 2.8rem;
}

.c-button--mail {
  display: grid;
  grid-template-columns: repeat(2, auto);
  align-items: center;
  gap: 1.25rem;
  justify-content: center;

  width: 21.5rem;
  min-width: 0;
  margin-top: 4.5rem;
  margin-inline: auto;
  padding-block: 1.5rem;
  padding-inline: 0;

  color: var(--mail-button-text, var(--color-white)) !important;
  font-size: 1.4rem;
  font-weight: var(--fw-bold);
  letter-spacing: .05em;
  line-height: 1;
  word-break: keep-all;
}

.c-button--mail::before {
  content: "";

  width: 1.75rem;
  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%2217.5%22%20height%3D%2214%22%20viewBox%3D%220%200%2017.5%2014%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_4229%22%20data-name%3D%22%E3%83%91%E3%82%B9%204229%22%20d%3D%22M17.75%2C4h-14A1.752%2C1.752%2C0%2C0%2C0%2C2%2C5.75v10.5A1.752%2C1.752%2C0%2C0%2C0%2C3.75%2C18h14a1.752%2C1.752%2C0%2C0%2C0%2C1.75-1.75V5.75A1.752%2C1.752%2C0%2C0%2C0%2C17.75%2C4Zm0%2C1.75V6.2l-7%2C5.445L3.75%2C6.2V5.75Zm-14%2C10.5V8.413l6.463%2C5.027a.87.87%2C0%2C0%2C0%2C1.075%2C0L17.75%2C8.413l0%2C7.836Z%22%20transform%3D%22translate(-2%20-4)%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fsvg%3E');
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}


/* 検索 */

.c-header-search {
  --padding-horizontal: 1.5rem;
  --search-button-width: 3rem;

  width: 100%;
  padding: 0;
  border: none;
}

@media (min-width: 768px) {
  .c-header-search {
    width: 30rem;
  }
}

.c-header-search__form input {
  width: 100%;
  height: 4.4rem;
  padding: 1.2rem calc(var(--padding-horizontal) + (var(--search-button-width) - 1rem) + .5em) 1.2rem var(--padding-horizontal);
  background: var(--color-project-bg-sub);
  border: none;
  border-radius: 2.5rem;
  box-shadow: inset 0 0 .5rem rgba(0, 0, 0, .16);

  font-size: 1.4rem;
}

@media (min-width: 768px) {
  .c-header-search__form input {
    border-radius: 2.2rem;
  }
}

.c-header-search__button {
  display: flex;
  align-items: center;
  justify-content: center;

  height: fit-content;
}

.c-header-search__button img,
.c-header-search__button svg {
  width: 1.7rem;
  height: auto;
}



/* Override Styles - Object - Project */



/* Override Styles - Object - Utility */




/* ===============================================
  * Override Styles - Footer *
=============================================== */

/* Override Styles - Foundation */


/* Override Styles - Layout */

/* 構造 - Base */

.l-footer {
  position: relative;

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

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

.l-footer a {
  color: var(--color-text-default);
}

.l-footer .c-link__text::after {
  background-image: var(--asset-link-arrow-right-red);
}

.l-footer .c-link__text[target="_blank"]::after {
  background-image: var(--asset-link-blank-red);
}

.l-footer__inner {
  row-gap: 4.5rem;

  padding-bottom: 4rem;
}

@media (min-width: 768px) {
  .l-footer__inner {
    row-gap: 4rem;

    padding-block: 8rem 4rem;
  }
}


/* 構造 - リコーイメージングストア オリジナルサービス */

.l-footer-service {
  display: grid;
  row-gap: 3rem;

  width: 100%;
  padding-block: 5rem;
  background-color: var(--color-project-bg-sub);
}

@media (min-width: 768px) {
  .l-footer-service {
    row-gap: 4rem;

    padding-block: 10rem;
  }
}

.l-footer-service__text--heading {
  display: grid;

  font-size: 2.4rem;
  font-weight: var(--fw-bold);
  letter-spacing: .05em;
  line-height: calc(34 / 24);

  text-align: center;
}

@media (min-width: 768px) {
  .l-footer-service__text--heading {
    font-size: 3.5rem;
    line-height: calc(50 / 35);
  }
}

.l-footer-service__text--heading > span {
  font-size: .58em;
}

.l-footer-service .c-link__text {
  --accordion-icon-width: .8rem;

  justify-self: flex-end;

  column-gap: .6rem;

  width: fit-content;
  margin-left: auto;
  padding-bottom: .25rem;
  border-bottom: solid 1px var(--color-primary);

  color: var(--color-primary);
  font-size: 1.1rem;
  font-weight: var(--fw-semibold);
  letter-spacing: .05em;
}

@media (min-width: 768px) {
  .l-footer-service__payment-inner .c-link__text {
    column-gap: .8rem;
  }
}

.l-footer-service__list {
  display: grid;
  grid-template-columns: repeat(var(--grid-column, 2), 1fr);
  gap: 1.1rem;
}

@media (min-width: 768px) {
  .l-footer-service__list {
    --grid-column: 6;
  }
}

.l-footer-service__list-item {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 3;
  align-items: flex-start;
  justify-items: center;
  row-gap: 0;

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

@media (min-width: 768px) {
  .l-footer-service__list-item {
    padding-top: 2rem;
  }
}

.l-footer-service__image {
  width: 8rem;
  margin-bottom: .5rem;
}

@media (min-width: 768px) {
  .l-footer-service__image {
    width: 10rem;
    margin-bottom: 1rem;
  }
}

.l-footer-service__hgroup {
  display: grid;
  row-gap: .6rem;
}

@media (min-width: 768px) {
  .l-footer-service__hgroup {
    row-gap: .8rem;
  }
}

.l-footer-service__text--list-heading {
  font-size: 1.4rem;
  font-weight: var(--fw-bold);
  letter-spacing: .05em;
  line-height: calc(20 / 14);
  text-align: center;
}

@media (min-width: 768px) {
  .l-footer-service__text--list-heading {
    font-size: 1.5rem;
    line-height: calc(23 / 15);
  }
}

.l-footer-service__text--list-paragraph {
  font-size: 1.2rem;
  font-weight: var(--fw-regular);
  letter-spacing: .05em;
  line-height: calc(19 / 12);
}

@media (min-width: 768px) {
  .l-footer-service__text--list-paragraph {
    font-size: 1.3rem;
    line-height: calc(21 / 13);
  }
}

.l-footer-service__list-item .c-link__text {
  margin-top: 1rem;
}

@media (min-width: 768px) {
  .l-footer-service__list-item .c-link__text {
    margin-top: 1.2rem;
  }
}

.l-footer-service__payment-inner {
  padding: 1.5rem 1.5rem 2.5rem;
  background-color: var(--color-white);
}

@media (min-width: 768px) {
  .l-footer-service__payment-inner {
    padding: 4rem;
  }
}

.l-footer-service__text--payment-heading {
  display: grid;
  row-gap: .54rem;
  justify-items: center;

  margin-bottom: 1.2rem;

  font-size: 1.6rem;
  font-weight: var(--fw-bold);
  letter-spacing: .05em;
  line-height: calc(26 / 16);
  text-align: center;
}

.l-footer-service__text--payment-heading::before {
  content: "";

  width: 3.2rem;
  aspect-ratio: 32.23 / 40;

  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2232.235%22%20height%3D%2240%22%20viewBox%3D%220%200%2032.235%2040%22%3E%20%3Cdefs%3E%20%3CclipPath%20id%3D%22clip-path%22%3E%20%3Crect%20id%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2_24032%22%20data-name%3D%22%E9%95%B7%E6%96%B9%E5%BD%A2%2024032%22%20width%3D%2232.235%22%20height%3D%2240%22%20fill%3D%22%23cf122e%22%2F%3E%20%3C%2FclipPath%3E%20%3C%2Fdefs%3E%20%3Cg%20id%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_11490%22%20data-name%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%2011490%22%20transform%3D%22translate(2%202)%22%3E%20%3Cg%20id%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97_11489%22%20data-name%3D%22%E3%82%B0%E3%83%AB%E3%83%BC%E3%83%97%2011489%22%20transform%3D%22translate(-2%20-2)%22%20clip-path%3D%22url(%23clip-path)%22%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_4737%22%20data-name%3D%22%E3%83%91%E3%82%B9%204737%22%20d%3D%22M24.893%2C73.275H3.147A3.15%2C3.15%2C0%2C0%2C1%2C0%2C70.128V49.644c0-.01%2C0-.021%2C0-.032a3.15%2C3.15%2C0%2C0%2C1%2C3.145-3.054H8.964a.368.368%2C0%2C0%2C1%2C0%2C.737H3.147a2.41%2C2.41%2C0%2C0%2C0%2C0%2C4.819H24.893a2.422%2C2.422%2C0%2C0%2C1%2C2.419%2C2.419V70.856a2.422%2C2.422%2C0%2C0%2C1-2.419%2C2.419M.737%2C51.726v18.4a2.412%2C2.412%2C0%2C0%2C0%2C2.41%2C2.41H24.893a1.684%2C1.684%2C0%2C0%2C0%2C1.682-1.682V54.533a1.684%2C1.684%2C0%2C0%2C0-1.682-1.682H3.147a3.141%2C3.141%2C0%2C0%2C1-2.41-1.125%22%20transform%3D%22translate(2.353%20-35.628)%22%20fill%3D%22%23cf122e%22%2F%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_4737_-_%E3%82%A2%E3%82%A6%E3%83%88%E3%83%A9%E3%82%A4%E3%83%B3%22%20data-name%3D%22%E3%83%91%E3%82%B9%204737%20-%20%E3%82%A2%E3%82%A6%E3%83%88%E3%83%A9%E3%82%A4%E3%83%B3%22%20d%3D%22M24.981%2C73.951H3.235A3.739%2C3.739%2C0%2C0%2C1-.5%2C70.217V49.732c0-.02%2C0-.04%2C0-.06a3.739%2C3.739%2C0%2C0%2C1%2C3.733-3.615H9.052a.957.957%2C0%2C1%2C1%2C0%2C1.913H3.235a1.821%2C1.821%2C0%2C1%2C0%2C0%2C3.643H24.981a3.01%2C3.01%2C0%2C0%2C1%2C3.007%2C3.007V70.944A3.01%2C3.01%2C0%2C0%2C1%2C24.981%2C73.951ZM1.413%2C53.053V70.217a1.824%2C1.824%2C0%2C0%2C0%2C1.821%2C1.821H24.981a1.1%2C1.1%2C0%2C0%2C0%2C1.094-1.094V54.621a1.1%2C1.1%2C0%2C0%2C0-1.094-1.094H3.235A3.723%2C3.723%2C0%2C0%2C1%2C1.413%2C53.053Z%22%20transform%3D%22translate(2.265%20-35.716)%22%20fill%3D%22%23cf122e%22%2F%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_4738%22%20data-name%3D%22%E3%83%91%E3%82%B9%204738%22%20d%3D%22M44.31%2C14.871A.368.368%2C0%2C0%2C1%2C44%2C14.308l3.208-5.157a1.218%2C1.218%2C0%2C0%2C0-.359-1.663L37.041.94a1.23%2C1.23%2C0%2C0%2C0-1.681.315l-9.437%2C13.46a.368.368%2C0%2C1%2C1-.6-.423L34.757.831a1.972%2C1.972%2C0%2C0%2C1%2C2.693-.5l9.8%2C6.548a1.952%2C1.952%2C0%2C0%2C1%2C.576%2C2.666L44.623%2C14.7a.369.369%2C0%2C0%2C1-.313.174%22%20transform%3D%22translate(-18.248%202.352)%22%20fill%3D%22%23cf122e%22%2F%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_4738_-_%E3%82%A2%E3%82%A6%E3%83%88%E3%83%A9%E3%82%A4%E3%83%B3%22%20data-name%3D%22%E3%83%91%E3%82%B9%204738%20-%20%E3%82%A2%E3%82%A6%E3%83%88%E3%83%A9%E3%82%A4%E3%83%B3%22%20d%3D%22M25.71%2C15.548a.957.957%2C0%2C0%2C1-.783-1.506L34.364.582A2.556%2C2.556%2C0%2C0%2C1%2C36.458-.5a2.526%2C2.526%2C0%2C0%2C1%2C1.408.425l9.8%2C6.548a2.538%2C2.538%2C0%2C0%2C1%2C.749%2C3.465L45.211%2C15.1a.957.957%2C0%2C0%2C1-1.625-1.01l3.208-5.158a.632.632%2C0%2C0%2C0-.186-.864L36.8%2C1.517a.625.625%2C0%2C0%2C0-.348-.1.638.638%2C0%2C0%2C0-.524.268L26.493%2C15.14A.958.958%2C0%2C0%2C1%2C25.71%2C15.548Z%22%20transform%3D%22translate(-18.336%202.264)%22%20fill%3D%22%23cf122e%22%2F%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_4739%22%20data-name%3D%22%E3%83%91%E3%82%B9%204739%22%20d%3D%22M102.718%2C117.365h-5.56a4.271%2C4.271%2C0%2C0%2C1%2C0-8.542h5.56a.368.368%2C0%2C0%2C1%2C0%2C.737h-5.56a3.534%2C3.534%2C0%2C0%2C0%2C0%2C7.069h5.56a.368.368%2C0%2C1%2C1%2C0%2C.737%22%20transform%3D%22translate(-73.423%20-86.422)%22%20fill%3D%22%23cf122e%22%2F%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_4739_-_%E3%82%A2%E3%82%A6%E3%83%88%E3%83%A9%E3%82%A4%E3%83%B3%22%20data-name%3D%22%E3%83%91%E3%82%B9%204739%20-%20%E3%82%A2%E3%82%A6%E3%83%88%E3%83%A9%E3%82%A4%E3%83%B3%22%20d%3D%22M102.806%2C118.042h-5.56a4.859%2C4.859%2C0%2C0%2C1%2C0-9.719h5.56a.957.957%2C0%2C0%2C1%2C0%2C1.913h-5.56a2.946%2C2.946%2C0%2C0%2C0%2C0%2C5.892h5.56a.957.957%2C0%2C0%2C1%2C0%2C1.913Z%22%20transform%3D%22translate(-73.511%20-86.51)%22%20fill%3D%22%23cf122e%22%2F%3E%20%3Cpath%20id%3D%22%E3%83%91%E3%82%B9_5359%22%20data-name%3D%22%E3%83%91%E3%82%B9%205359%22%20d%3D%22M3.781-4.643%2C5.325-8.531H7.483L5.263-3.609h1.5V-2.4H4.781v.793H6.766v1.2H4.781V1.506H2.713V-.411H.6v-1.2H2.713V-2.4H.6V-3.609H2.285L.059-8.531H2.23Z%22%20transform%3D%22translate(8.192%2030.461)%22%20fill%3D%22%23cf122e%22%2F%3E%20%3C%2Fg%3E%20%3C%2Fg%3E%3C%2Fsvg%3E');
  background-repeat: no-repeat;
  background-size: contain;
}

.l-footer-service__payment-list {
  --row-gap-payment: 1.5rem;
  --border-style-payment: solid 1px var(--color-project-border);
  --border-adjust-size: .75rem;

  display: grid;
  grid-template-columns: repeat(var(--grid-column, 6), 1fr);
}

@media (min-width: 768px) {
  .l-footer-service__payment-list {
    --grid-column: 14;
    --row-gap-payment: 2rem;
    --border-adjust-size: 2rem;
  }
}

.l-footer-service__payment-list-item {
  position: relative;

  display: grid;
  align-items: center;
}

.l-footer-service__payment-list-item::before,
.l-footer-service__payment-list-item::after {
  position: absolute;

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

  pointer-events: none;
}

.l-footer-service__payment-list-item::before {
  top: 0;

  width: calc(100% - var(--border-adjust-size));
  height: 1px;
}

.l-footer-service__payment-list-item::after {
  top: 0;
  right: 0;
  bottom: 0;

  width: 1px;
  height: 5.2rem;
  margin-block: auto;
}

@media (max-width: 767px) {
  .l-footer-service__payment-list-item[data-column-size="large"] {
    grid-column: span 6;

    height: 8.9rem;
    border-bottom: var(--border-style-payment);
  }

  .l-footer-service__payment-list-item[data-column-size="medium"],
  .l-footer-service__payment-list-item[data-column-size="small"] {
    height: 8.2rem;
  }

  .l-footer-service__payment-list-item[data-column-size="medium"] {
    grid-column: span 3;
  }

  .l-footer-service__payment-list > li:nth-child(odd of [data-column-size="medium"]):not(:nth-child(1 of [data-column-size="medium"]))::before {
    content: "";

    left: 0;
  }

  .l-footer-service__payment-list > li:nth-child(even of [data-column-size="medium"]):not(:nth-child(2 of [data-column-size="medium"]))::before {
    content: "";

    right: 0;
  }

  .l-footer-service__payment-list > li:nth-child(odd of [data-column-size="medium"])::after {
    content: "";
  }

  .l-footer-service__payment-list-item[data-column-size="small"] {
    grid-column: span 2;
  }

  .l-footer-service__payment-list-item[data-column-size="small"]::before {
    content: "";
  }

  .l-footer-service__payment-list > li:nth-child(3n+2 of [data-column-size="small"])::before {
    right: 0;
    left: 0;

    width: calc(100% - (var(--border-adjust-size) * 2));
    margin-inline: auto;
  }

  .l-footer-service__payment-list > li:nth-child(3n+3 of [data-column-size="small"])::before {
    right: 0;
  }

  .l-footer-service__payment-list > li[data-column-size="small"]:not(:nth-child(3n of [data-column-size="small"]))::after {
    content: "";
  }
}

@media (min-width: 768px) {
  .l-footer-service__payment-list-item[data-column-size="large"] {
    grid-column: span 7;

    height: 12.5rem;
  }

  .l-footer-service__payment-list-item[data-column-size="large"]::before {
    content: "";
    top: auto;
    bottom: 0;
  }

  .l-footer-service__payment-list > li:nth-child(odd of [data-column-size="large"])::before {
    left: 0;
  }

  .l-footer-service__payment-list > li:nth-child(even of [data-column-size="large"])::before {
    right: 0;
  }

  .l-footer-service__payment-list > li:nth-child(1 of [data-column-size="large"])::after {
    content: "";

    height: 10.5rem;
  }

  .l-footer-service__payment-list-item[data-column-size="medium"],
  .l-footer-service__payment-list-item[data-column-size="small"] {
    grid-column: span 2;

    height: 12.5rem;
  }

  .l-footer-service__payment-list > li:is([data-column-size="medium"], [data-column-size="small"]):not(:nth-child(7n of [data-column-size="medium"], [data-column-size="small"]))::after {
    content: "";
    height: 8.5rem;
  }
}

.l-footer-service__payment-list-item[data-column-size="large"] img {
  width: auto;
  height: 3.6rem;
}

@media (min-width: 768px) {
  .l-footer-service__payment-list-item[data-column-size="large"] img {
    height: 6rem;
  }
}

.l-footer-service__payment-list-item[data-column-size="medium"] img,
.l-footer-service__payment-list-item[data-column-size="small"] img {
  width: auto;
  height: 3rem;
}

@media (min-width: 768px) {
  .l-footer-service__payment-list-item[data-column-size="medium"] img,
  .l-footer-service__payment-list-item[data-column-size="small"] img {
    height: 4rem;
  }
}

.l-footer-service__payment-figure {
  display: grid;
  justify-items: center;
  row-gap: .5rem;
}

.l-footer-service__payment-text--caption {
  font-size: 1.2rem;
  font-weight: var(--fw-bold);
  letter-spacing: .05em;
  line-height: calc(20 / 12);
}

@media (min-width: 768px) {
  .l-footer-service__payment-text--caption {
    font-size: 1.4rem;
    line-height: calc(20 / 14);
  }
}

.l-footer-service__payment-inner .c-link__text {
  margin-top: 2rem;

  font-size: 1.2rem;
}

@media (min-width: 768px) {
  .l-footer-service__payment-inner .c-link__text {
    font-size: 1.4rem;
  }
}


/* 構造 - フッター トップ */

.l-footer-top {
  display: grid;
  row-gap: 2rem;
}

@media (min-width: 768px) {
  .l-footer-top {
    grid-template-columns: 1fr 1fr calc(500 / 1200 * 100%);
    column-gap: calc(60 / 1200 * 100%);
  }
}

.l-footer-top__link-section {
  border: solid 1px var(--color-text-default);
  border-radius: .4rem .4rem 0 0;
}

@media (min-width: 768px) {
  .l-footer-top__link-section {
    display: grid;
    row-gap: 2rem;
    align-content: flex-start;

    border: none;
    border-radius: 0;
  }
}

.l-footer-top__link-section-text--heading {
  padding: 1.5rem 1.9rem;
  background-color: var(--color-text-default);

  color: var(--color-white);
  font-size: 1.5rem;
  font-weight: var(--fw-bold);
  letter-spacing: .05em;
  line-height: 1;
}

@media (min-width: 768px) {
  .l-footer-top__link-section-text--heading {
    padding: 0;
    padding-bottom: 1rem;
    background-color: transparent;
    border-bottom: solid 1px var(--color-text-default);

    color: var(--color-text-default);
    font-size: 1.8rem;
  }
}

@media (min-width: 768px) {
  .l-footer-top__link-section .c-link__list {
    display: grid;
    grid-template-columns: repeat(var(--column-num, 1), auto);
    gap: 1.5rem 6rem;
    justify-content: flex-start;
  }

  .l-footer-top__link-section[aria-labelledby="footer-link-user-support"] .c-link__list {
    --column-num: 2;
  }
}

.l-footer-top__link-section .c-link__list > li {
  border: none;
}

.l-footer-top__link-section .c-link__list > li:not(:last-of-type) {
  border-bottom: solid 1px var(--color-text-default);
}

@media (min-width: 768px) {
  .l-footer-top__link-section .c-link__list > li.c-link__list-item {
    display: block;

    border-bottom: none;
  }
}

@media (min-width: 768px) {
  .l-footer-top__link-section .c-link__list-item::after {
    content: none !important;
  }
}

.l-footer-top__link-section .c-link__text {
  padding: 1.6rem 1.5rem;

  font-size: 1.3rem;
  font-weight: var(--fw-regular);
  letter-spacing: .05em;
}

@media (min-width: 768px) {
  .l-footer-top__link-section .c-link__text {
    display: grid;

    padding: 0;

    font-size: 1.4rem;
  }

  .l-footer-top__link-section .c-link__text::after {
    content: "";
  }
}

.l-footer-top__about-us {
  display: grid;
  row-gap: 1.2rem;

  padding: 2rem 2rem 2.4rem 2rem;
  border: solid 3px var(--color-project-border);
}

.l-footer-top__about-us-text--paragraph {
  font-size: 1.3rem;
  font-weight: var(--fw-regular);
  letter-spacing: .05em;
  line-height: calc(23 / 13);
}

@media (min-width: 768px) {
  .l-footer-top__about-us-text--paragraph {
    font-size: 1.4rem;
    line-height: calc(24 / 14);
  }
}

.l-footer-top__about-us .c-link__text {
  display: grid;
  grid-template-columns: auto 1rem;
  align-items: baseline;

  width: fit-content;
  padding: 0 0 .5rem 0;
  border-bottom: solid 1px var(--color-primary);

  color: var(--color-primary);
  font-size: 1.3rem;
  font-weight: var(--fw-semibold);
  letter-spacing: .05em;
}

@media (min-width: 768px) {
  .l-footer-top__about-us .c-link__text {
    font-size: 1.4rem;
  }
}

.l-footer-top__about-us .c-link__text::after {
  content: "";
}


/* 構造 - フッター ボトム */

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

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

.l-footer__brand-sns {
  row-gap: 4rem;
}

@media (min-width: 768px) {
  .l-footer__brand-sns {
    grid-template-columns: 1fr auto;
  }
}

.l-footer__brand-sns .c-sns__list-item a {
  display: flex;

  transition: scale var(--transition-duration-short) ease;
}

@media (prefers-reduced-motion: reduce) {
  .l-footer__brand-sns .c-sns__list-item a {
    transition: none;
  }
}

.l-footer__brand-sns .c-sns__list-item a:hover,
.l-footer__brand-sns .c-sns__list-item a:focus-visible {
  scale: 1.2;
}

@media (max-width: 767px) {
  .l-footer-bottom .c-sns__container {
    row-gap: .2rem;
  }

  .l-footer-bottom .c-sns__list {
    --sns-icon-width: 100%;

    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--gap, 2rem);
  }
}

@media (min-width: 768px) {
  .l-footer-bottom .c-sns__container {
    display: flex;
    align-items: center;
  }

  .l-footer-bottom .c-sns__container > section:not(:last-of-type)::after {
    content: "";

    width: 1px;
    height: 3rem;
    background-color: var(--color-project-border);
  }

  .l-footer-bottom .c-sns__section {
    --sns-icon-width: 2.6rem;

    display: flex;
    align-items: center;

    padding: 0;
    background-color: transparent;
  }
}

.l-footer-bottom .c-button--mail {
  margin-top: 0;
}

@media (min-width: 768px) {
  .l-footer-bottom .c-button--mail {
    width: 25rem;

    font-size: 1.6rem;
  }

  .l-footer-bottom .c-button--mail::before {
    width: 2rem;
  }
}

.l-footer-bottom .c-button--mail {
  transition: scale var(--transition-duration-short) ease;
}

@media (prefers-reduced-motion: reduce) {
  .l-footer-bottom .c-button--mail {
    transition: none;
  }
}

.l-footer-bottom .c-button--mail:hover,
.l-footer-bottom .c-button--mail:focus-visible {
  scale: 1.05;
}


/* 構造 - フッター 規約 */

.l-footer__legal-page-link {
  row-gap: 3rem;

  width: 100%;
  background-color: var(--color-project-text);
}

.l-footer__legal-page-link a {
  color: var(--color-white);
}

@media (max-width: 767px) {
  .l-footer__legal-page-link .l-content__fluid-wrapper {
    padding: 3rem  3.8rem 2rem;
  }
}

@media (min-width: 768px) {
  .l-footer__legal-page-link .l-content__fluid-wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;

    padding-block: 2.5rem;
  }
}

.l-footer__legal-page-link .c-link__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.5rem 3rem;
}

.l-footer__legal-page-link .c-link__text {
  padding: 0;

  font-size: 1.3rem;
  font-weight: var(--fw-regular);
  letter-spacing: .05em;
  line-height: 1.5;
}

.l-footer__legal-page-link .c-link__text::after {
  content: none;
}

.l-footer__copyright-text {
  font-size: 1rem;
  font-weight: var(--fw-regular);
  letter-spacing: .05em;
  line-height: 3;
}

@media (min-width: 768px) {
  .l-footer__copyright-text {
    font-size: 1.1rem;
  }
}


/* Override Styles - Object */



/* Override Styles - Object - Component */



/* Override Styles - Object - Project */



/* Override Styles - Object - Utility */
