:root {
  --bg-main: #faf8f8;
  --bg-page: #faf8f8;
  --text-main: #23262e;
  --line: #4f5560;
  --wrap-max: 1280px;
}

body {
  background: var(--bg-page);
  color: var(--text-main);
}

html,
body {
  overflow-x: hidden;
  overflow-x: clip;
}

.universe-fitit__Lp {
  overflow: visible;
}

.footer::after {
  background-image: url("../../images/fitit/fitit3type-footer__Background.webp");
}

.footer::before {
  content: none;
}

.top-nav {
  --wave-scale: 1;
  --wave-width: calc(1280px * var(--wave-scale));
  --wave-front-height: calc(144.8px * var(--wave-scale));
  --wave-back-height: calc(223.4px * var(--wave-scale));
  --wave-overlap-y: 0px;
  --wave-layer-offset: calc(var(--wave-back-height) - var(--wave-front-height));
  position: relative;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  background: #434853;
  color: #fff;
  z-index: 5;
  transition: box-shadow 0.24s ease;
}

body.is-nav-fixed .top-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  margin-left: 0;
  margin-right: 0;
  max-width: none;
  z-index: 1200;
  box-shadow: 0 8px 22px rgba(32, 36, 44, 0.2);
  opacity: 0;
  transform: translateY(-10px);
  animation: lowerNavFadeIn 0.34s ease forwards;
}

body.is-nav-fixed .universe-fitit__Lp {
  padding-top: var(--lower-nav-height, 0px);
}

body.is-nav-fixed .top-nav::before,
body.is-nav-fixed .top-nav::after,
body.is-nav-fixed .top-nav__wave-flow {
  display: none;
}

.top-nav::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 100%;
  width: var(--wave-width);
  height: var(--wave-front-height);
  background: url("../../images/fitit/fitit-top__wave.svg") center bottom / var(--wave-width) var(--wave-front-height) no-repeat;
  pointer-events: none;
  z-index: 2;
  transform: translateX(-50%) translateY(var(--wave-overlap-y));
}

.top-nav::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 100%;
  width: var(--wave-width);
  height: var(--wave-back-height);
  background: url("../../images/fitit/fitit-top__waveBack.svg") center bottom / var(--wave-width) var(--wave-back-height) no-repeat;
  pointer-events: none;
  z-index: 1;
  transform: translateX(-50%) translateY(calc(var(--wave-overlap-y) + var(--wave-layer-offset)));
}

.top-nav__wave-flow {
  position: absolute;
  left: 50%;
  bottom: 100%;
  width: var(--wave-width);
  height: var(--wave-front-height);
  transform: translateX(-50%) translateY(var(--wave-overlap-y));
  pointer-events: none;
  z-index: 3;
  overflow: hidden;
}

.top-nav__wave-svg {
  display: block;
  width: 100%;
  height: 100%;
}

.top-nav__parallax > use {
  animation: topWaveFlow 1.2s cubic-bezier(0.55, 0.5, 0.45, 0.5) infinite;
}

.top-nav__parallax > use:nth-child(1) {
  animation-delay: -0.18s;
  animation-duration: 0.9s;
}

.top-nav__parallax > use:nth-child(2) {
  animation-delay: -0.24s;
  animation-duration: 1.15s;
}

.top-nav__parallax > use:nth-child(3) {
  animation-delay: -0.31s;
  animation-duration: 1.45s;
}

.top-nav__parallax > use:nth-child(4) {
  animation-delay: -0.39s;
  animation-duration: 1.9s;
}

@keyframes topWaveFlow {
  0% {
    transform: translate3d(-90px, 0, 0);
  }

  100% {
    transform: translate3d(85px, 0, 0);
  }
}

@keyframes lowerNavFadeIn {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.top-nav ul {
  position: relative;
  z-index: 4;
  margin: 0;
  padding: 50px 20px;
  list-style: none;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 16px;
  font-size: 13px;
  letter-spacing: 0.18em;
  font-weight: 700;
}

.top-nav li + li::before {
  content: "|";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translate(-50%, -50%);
  opacity: 0.9;
}

.top-nav li {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding-inline: 20px;
}

.shoplist-main {
  background: var(--bg-main);
}

.shoplist-hero {
  --shoplist-hero-width: 1280px;
  --shoplist-hero-height: 752px;
  position: relative;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  height: var(--shoplist-hero-height);
  overflow: hidden;
}

.shoplist-hero img {
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 100%;
  min-width: var(--shoplist-hero-width);
  height: auto;
  max-width: none;
  transform: translateX(-50%);
}

.shoplist-content {
  width: min(100% - 176px, 980px);
  margin-inline: auto;
  padding: 56px 0 120px;
}

.section-title {
  margin: 0;
  font-family: var(--font-en), sans-serif;
  font-size: 29.5px;
  font-weight: 600;
  letter-spacing: 0.2em;
  line-height: 1.22;
  color: #2a303a;
}

.stockist-copy {
  margin: 20px 0 0;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.85;
  letter-spacing: 0.2em;
  color: #363b45;
}

.lineup {
  margin-top: 58px;
}

.lineup--selected {
  margin-top: 100px;
}

.lineup-group {
  margin-top: 22px;
}

.group-title {
  margin: 0;
  padding: 0 0 4px;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0.2em;
  color: #2f3540;
}

.lineup-group--chubu {
  margin-top: 80px;
}

.shop-list {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid var(--line);
}

.shop-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  padding: 40px 0;
  border-bottom: 1px solid var(--line);
}

.shop-list--online .shop-item:last-child {
  border-bottom: 0;
}

.shop-item__meta {
  min-width: 0;
  flex: 1;
  padding-left: 16px;
}

.shop-item__name-row {
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 8px;
}

.shop-item__name {
  margin: 0;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 21px;
  font-weight: 500;
  line-height: 1.42;
  letter-spacing: 0.2em;
  color: #262c35;
}

.shop-item__name--tomys {
  font-family: "Zen Kaku Gothic New", sans-serif !important;
}

.shop-item__divider,
.shop-item__address {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: #333a44;
}

.shop-item__url {
  margin: 6px 0 0;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.4;
  color: #2f3641;
  word-break: break-all;
}

.shop-item__url a {
  border-bottom: 1px solid transparent;
}

.shop-item__url a:hover,
.shop-item__url a:focus-visible {
  border-bottom-color: currentColor;
}

.shop-item__icon-link {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  padding-right: 60px;
  transition: transform 0.2s ease;
}

.shop-item__icon-link:hover,
.shop-item__icon-link:focus-visible {
  transform: translateY(-1px);
}

.shop-item__icon-link--cart img {
  width: 39px;
}

.shop-item__icon-link--map img {
  width: 40px;
}

@media (max-width: 1100px) {
  .shoplist-content {
    width: min(100% - 80px, 980px);
  }
}

@media (max-width: 900px) {
  .top-nav ul {
    padding: 36px 16px;
    gap: 8px;
    font-size: 12px;
    letter-spacing: 0.16em;
  }

  .top-nav li {
    padding-inline: 12px;
  }
}

@media (max-width: 834px) {
  .section-title {
    font-size: 27.5px;
  }

  .stockist-copy {
    font-size: 16px;
  }

  .group-title {
    font-size: 16px;
  }

  .shop-item__name {
    font-size: 19px;
  }

  .shop-item__divider,
  .shop-item__address,
  .shop-item__url {
    font-size: 14px;
  }

  .shop-item__icon-link {
    padding-right: 30px;
  }
}

@media (max-width: 768px) {
  .shoplist-content {
    width: min(100% - 32px, 980px);
    padding: 0 0 88px;
  }

  .section-title {
    font-size: 27.5px;
  }

  .stockist-copy {
    font-size: 16px;
    line-height: 1.75;
    letter-spacing: 0.14em;
  }

  .lineup {
    margin-top: 44px;
  }

  .group-title {
    font-size: 16px;
    letter-spacing: 0.16em;
  }

  .shop-item {
    align-items: flex-start;
    gap: 10px;
  }

  .shop-item__name {
    font-size: 19px;
    letter-spacing: 0.14em;
  }

  .shop-item__icon-link--cart img {
    width: 35px;
  }

  .shop-item__icon-link--map img {
    width: 36px;
  }
}

@media (max-width: 480px) {
  .shop-item__name-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
  }

  .shop-item__divider {
    display: none;
  }
}
