.l-container {
  width: 100%;
}

.pc-header-main.is-fixed {
  display: none;
}

.l-footer,
.pc-footer {
  margin: 0;
  padding: 0;
}

.feature {
  width: 100%;
  background-color: #f5f6f6;
  font-family: "noto-sans-cjk-jp", sans-serif;
  color: #282828;
  margin: 0 auto;
  display: flex;
}
.feature * {
  box-sizing: border-box;
}
.feature img {
  width: 100%;
  height: auto;
  vertical-align: top;
}
.feature a {
  color: inherit;
}

.fadeimg {
  transition: 0.3s;
}

/* =========================================================
ヘッダー
========================================================= */
.hdr {
  width: calc(782 * (100vw / 1400));
  height: 100vh;
  background: url(../img/bg_sky.png) no-repeat center;
  background-size: cover;
  position: sticky;
  top: 0;
  display: grid;
  place-items: center;
}
.hdr-inr {
  max-width: 695px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.hdr-image {
  width: 100%;
}

.hdr-heading {
  font-size: 76px;
  font-weight: normal;
  letter-spacing: 0.05em;
  line-height: 1.2;
  display: flex;
  flex-direction: column;
  margin-top: 10px;
}
.hdr-heading span {
  font-size: 49px;
  letter-spacing: 0.18em !important;
  position: relative;
  left: 9px;
}
.hdr-description {
  font-size: 18px;
  line-height: 1.4;
  letter-spacing: 0.04em;
  margin-top: 23px;
}

.hdr-link {
  font-size: 18px;
  margin-top: 27px;
  color: #138fcf !important;
  text-decoration: underline;
  text-decoration-skip-ink: none;
  text-underline-offset: 10px;
  display: inline-block;
  transition: 0.3s;
  letter-spacing: 0.06em;
}
.hdr-link:hover {
  opacity: 0.6;
}

/* =========================================================
右サイド
========================================================= */
.wrap {
  width: calc(618 * (100vw / 1400));
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-bottom: calc(85 * (100vw / 1400));
}
.inr {
  width: calc(540 * (100vw / 1400));
}

.heading {
  font-size: calc(35 * (100vw / 1400));
  font-weight: 400;
  margin: 0 calc(20 * (100vw / 1400));
}
.description {
  font-size: calc(16 * (100vw / 1400));
  margin: 0 calc(20 * (100vw / 1400));
  margin-top: calc(13 * (100vw / 1400));
  line-height: 1.7;
  margin-bottom: 0;
  letter-spacing: 0.03em;
}

/* =========================================================
スライド
========================================================= */
.category {
  margin-bottom: calc(66 * (100vw / 1400));
  margin-top: calc(90 * (100vw / 1400));
}

.category-slide {
  width: 100%;
  margin-top: calc(20 * (100vw / 1400));
  padding-bottom: calc(26 * (100vw / 1400));
}
.category-slide .swiper-slide {
  width: calc(160 * (100vw / 1400));
  margin: 0 calc(10 * (100vw / 1400));
}
.category-slide a {
  display: flex !important;
  flex-direction: column;
  align-items: center;
  font-size: calc(22 * (100vw / 1400));
  text-decoration: none;
}
.category-slide a span {
  font-size: calc(16 * (100vw / 1400));
  margin-top: calc(12 * (100vw / 1400));
}

.category-scrollbar {
  width: 56% !important;
  left: 50% !important;
  translate: -50%;
}

/* =========================================================
UVカット機能
========================================================= */
.uv {
  margin-bottom: calc(49 * (100vw / 1400));
}
.uv .description {
  margin-top: calc(12 * (100vw / 1400));
  letter-spacing: 0.01em;
  white-space: nowrap;
  /* line-height: 1.7; */
}
.uv-image {
  width: 100%;
  margin-inline: auto;
}

/* =========================================================
各セクション
========================================================= */
.contents {
  display: flex;
  flex-direction: column;
  gap: calc(91 * (100vw / 1400)) 0;
}

.section-inr {
  margin: 0 calc(20 * (100vw / 1400));
}
.section-heading {
  font-size: calc(42 * (100vw / 1400));
  font-weight: 700;
  color: #ff741c;
}
.section-heading span {
  font-family: "apparat", sans-serif;
}
.section-copy {
  font-size: calc(21 * (100vw / 1400));
  font-weight: 400;
  margin-top: calc(10 * (100vw / 1400));
  letter-spacing: 0.1em;
  white-space: nowrap;
}
.section-copy.sp {
  display: none;
}

.section-links {
  display: flex;
  margin-top: calc(21 * (100vw / 1400));
  gap: 0 calc(10 * (100vw / 1400));
}

.section-link {
  font-size: calc(14 * (100vw / 1400));
  color: #138fcf !important;
  display: flex;
}
.section-link a {
  color: inherit;
  text-decoration: none;
  transition: 0.3s;
  background-color: #fff;
  border-radius: calc(50 * (100vw / 1400));
  border: calc(1 * (100vw / 1400)) solid #138fcf;
  padding: calc(7 * (100vw / 1400)) calc(11 * (100vw / 1400));
  display: flex;
  align-items: center;
  gap: 0 calc(4 * (100vw / 1400));
}
.section-link a::after {
  content: "";
  width: calc(8 * (100vw / 1400));
  height: calc(10 * (100vw / 1400));
  display: block;
  background: url(../img/arrow_right_blue.png) no-repeat;
  background-size: contain;
}

.section-link a:hover {
  opacity: 0.6;
}

.section-description {
  font-size: calc(16 * (100vw / 1400));
  margin-top: calc(23 * (100vw / 1400));
  margin-bottom: 0;
}

.section-main-image {
  margin-top: calc(31 * (100vw / 1400));
}
.section-main-image a {
  display: block;
}

.section-items {
  margin-top: calc(43 * (100vw / 1400)) !important;
  padding-bottom: calc(15 * (100vw / 1400));
}
.section-items .swiper-slide {
  box-sizing: content-box;
  width: calc(194 * (100vw / 1400));
  padding-right: calc(15 * (100vw / 1400));
}
.section-items .swiper-slide:first-child {
  padding-left: calc(20 * (100vw / 1400));
}
.section-items .swiper-slide:last-child {
  padding-right: calc(20 * (100vw / 1400));
}

.section-items .m-item {
  width: calc(194 * (100vw / 1400));
}
.section-items .m-item a:hover {
  opacity: 0.6;
}

.section-items .m-item p {
  font-family: "lato", "noto-sans-cjk-jp", sans-serif;
  margin-top: calc(3 * (100vw / 1400));
  font-size: calc(15 * (100vw / 1400));
}
.section-items .m-item-icon,
.section-items .m-item-category,
.section-items .m-item-magazine,
.section-items .m-item-soldout {
  display: none;
}
.section-items .m-item a {
  display: block;
  text-decoration: none;
}

.section-button {
  width: calc(324 * (100vw / 1400));
  height: calc(65 * (100vw / 1400));
  display: flex;
  justify-content: center;
  align-items: center;
  color: white !important;
  font-size: calc(21 * (100vw / 1400));
  background-color: #ff741c;
  border-radius: calc(12 * (100vw / 1400));
  margin: 0 auto;
  margin-top: calc(34 * (100vw / 1400));
  text-decoration: none !important;
  transition: 0.3s;
}
.section-button:hover {
  opacity: 0.6;
}

/* =========================================================
下のボタン
========================================================= */
.bottom-button {
  width: calc(324 * (100vw / 1400));
  margin: 0 auto;
  margin-top: calc(36 * (100vw / 1400));
}
.bottom-button a {
  width: calc(324 * (100vw / 1400));
  height: calc(65 * (100vw / 1400));
  display: flex;
  justify-content: center;
  align-items: center;
  color: white;
  font-size: calc(17 * (100vw / 1400));
  background-color: #3d93bf;
  border-radius: calc(12 * (100vw / 1400));
  text-decoration: none;
  transition: 0.3s;
}
.bottom-button a:hover {
  opacity: 0.6;
}
