@charset "UTF-8";
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-style: normal;
  font-weight: normal;
  font-size: 100%;
  vertical-align: baseline;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block;
}

html {
  overflow-y: scroll;
  -webkit-text-size-adjust: 100%; /* iphoneで文字サイズが変わる対策 */
  -ms-text-size-adjust: 100%;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
  content: "";
  content: none;
}

input, textarea {
  margin: 0;
  padding: 0;
}

ol, ul {
  list-style: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

caption, th {
  text-align: left;
}

a:focus {
  outline: none;
}

img {
  vertical-align: bottom;
  max-width: 100%;
  height: auto;
}

.clearfix:after {
  content: " ";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}

.clearfix {
  min-height: 1px;
}

* html .clearfix {
  height: 1px; /*¥*/ /*/
height: auto;
overflow: hidden;
/**/
}

.both {
  clear: both;
}

.pc {
  display: block;
}

.sp {
  display: none;
}

/* ここからWordpress用初期設定 */
/* 本文中の画像 */
article img {
  border: none;
  max-width: 100%;
  height: auto;
}

/*-----------------------

         COMMON

-----------------------*/
/* リセット */
html {
  font-size: 62.5%;
  scroll-behavior: smooth;
  overflow-x: hidden;
  overflow-y: scroll;
  box-sizing: border-box;
}

html,
body {
  height: 100%;
}

p {
  margin: 0;
}

a {
  text-decoration: none;
  color: inherit;
  transition: 0.3s;
}

a:hover,
a:focus {
  opacity: 0.8;
  text-decoration: none;
  color: inherit;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

input,
textarea,
select,
button {
  font-family: inherit;
}

.pc {
  display: block;
}

.sp {
  display: none;
}

.text-c {
  text-align: center;
}

.text-l {
  text-align: left;
}

.text-r {
  text-align: right;
}

.text-j {
  text-align: justify;
}

/* iOSでのデフォルトスタイルをリセット */
input[type=submit],
input[type=button] {
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}

input[type=submit]::-webkit-search-decoration,
input[type=button]::-webkit-search-decoration {
  display: none;
}

input[type=submit]::focus,
input[type=button]::focus {
  outline-offset: -2px;
}

input,
button,
textarea,
select,
.entry input[type=url],
input[type=email],
.entry input[type=text] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 0;
}

:root {
  --mainColor01: #d2f0f3;
  --mainColor02: #e2f4e5;
  --mainColor03: #ffe7ef;
  --mainColor04: #fefdd6;
  --baseColor: #242424;
  --colorW: #fff;
  --subColor: #edca92;
  --accentColor: #99c5ff;
  --time: "Times New Roman", serif;
  --corm: "Cormorant Garamond", serif;
}

html {
  scroll-padding-top: 6rem;
  font-size: 0.5208333333vw;
}
@media only screen and (max-width: 768px) {
  html {
    font-size: 2.6666666667vw;
  }
}

body {
  width: 100%;
  color: var(--baseColor);
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-feature-settings: "palt";
}

main {
  overflow-x: hidden;
}

.wrapper {
  width: 132.6rem;
  margin-left: auto;
}
@media only screen and (max-width: 768px) {
  .wrapper {
    width: 100%;
  }
}

.pc {
  display: block;
}
@media only screen and (max-width: 768px) {
  .pc {
    display: none;
  }
}

.sp {
  display: none;
}
@media only screen and (max-width: 768px) {
  .sp {
    display: block;
  }
}

figure img {
  width: 100%;
  height: auto;
}

.flex {
  display: flex;
}

.look-box {
  width: 72rem;
}
@media only screen and (max-width: 768px) {
  .look-box {
    width: 100%;
    padding-inline: 1.8rem;
  }
}
.look-box__number {
  color: var(--baseColor);
  text-align: center;
  font-family: "Cormorant Garamond";
  font-size: 2.4rem;
  font-style: normal;
  font-weight: 700;
  letter-spacing: 0.096rem;
  width: 20rem;
  height: 4.8rem;
  border: 2px solid var(--323232, #323232);
  border-radius: calc(infinity * 1px);
  display: flex;
  margin-inline: auto;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media only screen and (max-width: 768px) {
  .look-box__number {
    color: var(--baseColor);
    text-align: center;
    font-family: "Cormorant Garamond";
    font-size: 1.44rem;
    font-style: normal;
    font-weight: 700;
    line-height: 7.68rem;
    letter-spacing: 0.0576rem;
    width: 12rem;
    height: 2.88rem;
    margin-bottom: -0.2rem;
  }
}
.look-box__number--wh {
  color: var(--colorW);
  border-color: var(--colorW);
}
.look-box__number span {
  text-align: center;
  font-family: "Cormorant Infant";
  font-size: 3.2rem;
  font-style: normal;
  font-weight: 700;
  letter-spacing: 0.128rem;
  position: relative;
  left: 1rem;
}
@media only screen and (max-width: 768px) {
  .look-box__number span {
    color: var(--baseColor);
    text-align: center;
    font-family: "Cormorant Infant";
    font-size: 1.92rem;
    font-style: normal;
    font-weight: 700;
    line-height: 7.68rem;
    letter-spacing: 0.0768rem;
    left: 0.6rem;
  }
}
.look-box__ttl-en {
  color: var(--baseColor);
  text-align: center;
  font-family: "Cormorant Garamond";
  font-size: 8rem;
  font-style: normal;
  font-weight: 700;
  line-height: 10.3rem;
  letter-spacing: 0.32rem;
}
@media only screen and (max-width: 768px) {
  .look-box__ttl-en {
    color: var(--baseColor);
    text-align: center;
    font-family: "Cormorant Garamond";
    font-size: 4.8rem;
    font-style: normal;
    font-weight: 700;
    line-height: 7.68rem;
    letter-spacing: 0.192rem;
    margin-bottom: -0.8rem;
  }
}
.look-box__ttl-en--wh {
  color: var(--colorW);
  border-color: var(--colorW);
}
.look-box__ttl-ja {
  color: var(--baseColor);
  text-align: center;
  font-size: 2.4rem;
  font-style: normal;
  font-weight: 500;
  line-height: 6.4rem;
  letter-spacing: 0.096rem;
  margin-bottom: 2.4rem;
}
@media only screen and (max-width: 768px) {
  .look-box__ttl-ja {
    color: var(--baseColor);
    text-align: center;
    font-size: 1.44rem;
    font-style: normal;
    font-weight: 500;
    line-height: 3.84rem;
    letter-spacing: 0.0576rem;
    margin-bottom: 1.1rem;
  }
}
.look-box__ttl-ja--wh {
  color: var(--colorW);
  border-color: var(--colorW);
}
.look-box__text {
  color: #000;
  text-align: center;
  font-size: 2rem;
  font-style: normal;
  font-weight: 400;
  line-height: 4rem;
  letter-spacing: 0.08rem;
}
@media only screen and (max-width: 768px) {
  .look-box__text {
    color: #000;
    text-align: center;
    font-size: 1.4rem;
    font-style: normal;
    font-weight: 500;
    line-height: 2.8rem;
    letter-spacing: 0.056rem;
  }
}
.look-box__text--wh {
  color: var(--colorW);
  border-color: var(--colorW);
}

.look-unit {
  display: flex;
  width: 118.2896rem;
  flex-direction: column;
  align-items: center;
  gap: 2.4rem;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .look-unit {
    width: 100%;
  }
}
.look-unit__ttl--en {
  color: var(--baseColor);
  text-align: center;
  font-family: "Cormorant Garamond";
  font-size: 6.4rem;
  font-style: normal;
  font-weight: 700;
  letter-spacing: 0.512rem;
  margin-bottom: 3.4rem;
  position: relative;
  z-index: 0;
  opacity: 0;
  transform: translateY(2.5rem);
  transition: opacity 1.2s ease-out, transform 1.2s ease-out;
}
@media only screen and (max-width: 768px) {
  .look-unit__ttl--en {
    color: var(--baseColor);
    text-align: center;
    font-family: "Cormorant Garamond";
    font-size: 3.8rem;
    font-style: normal;
    font-weight: 700;
    line-height: 1.92rem;
    letter-spacing: 0.304rem;
    margin-bottom: 2.4rem;
  }
}
.look-unit__ttl--en::after {
  content: "";
  width: 55.9rem;
  height: 4rem;
  opacity: 0.5;
  background: #c2eaed;
  position: absolute;
  left: -3rem;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.5s ease-out;
  transition-delay: 0.8s;
  bottom: -1.1rem;
  z-index: -1;
}
@media only screen and (max-width: 768px) {
  .look-unit__ttl--en::after {
    height: 1.6rem;
    width: 32rem;
    left: -1.3rem;
  }
}
.look-unit__ttl--en.on {
  opacity: 1;
  transform: translateY(0);
  width: fit-content;
  margin-inline: auto;
}
.look-unit__ttl--en.on::after {
  transform: scaleX(1);
}
.look-unit__ttl--ja {
  color: var(--baseColor);
  text-align: center;
  font-size: 2.4rem;
  font-style: normal;
  font-weight: 500;
  letter-spacing: 0.096rem;
}
@media only screen and (max-width: 768px) {
  .look-unit__ttl--ja {
    color: var(--baseColor);
    text-align: center;
    font-size: 1.4rem;
    font-style: normal;
    font-weight: 500;
    line-height: 1.92rem;
    letter-spacing: 0.056rem;
  }
}
.look-unit__flex {
  display: flex;
  align-items: flex-end;
  gap: 12rem;
  align-self: stretch;
  margin-top: -1.6rem;
}
@media only screen and (max-width: 768px) {
  .look-unit__flex {
    flex-direction: column;
    gap: 8rem;
  }
}
.look-unit__color {
  text-align: center;
  -webkit-text-stroke-width: 1px;
  font-family: "Cormorant Garamond";
  font-size: 8rem;
  font-style: normal;
  font-weight: 700;
  line-height: 6.4rem;
  letter-spacing: 0.32rem;
  color: transparent;
}
@media only screen and (max-width: 768px) {
  .look-unit__color {
    text-align: center;
    -webkit-text-stroke-width: 0.6px;
    font-family: "Cormorant Garamond";
    font-size: 5rem;
    font-style: normal;
    font-weight: 700;
    line-height: 5rem;
    letter-spacing: 0.2rem;
  }
}
.look-unit__item {
  margin-inline: auto;
  position: relative;
}
.look-unit__subttl {
  color: var(--baseColor);
  writing-mode: vertical-rl;
  text-orientation: upright;
  height: fit-content;
  font-size: 2rem;
  font-style: normal;
  font-weight: 500;
  line-height: 2.4rem;
  letter-spacing: 0.38rem;
}
@media only screen and (max-width: 768px) {
  .look-unit__subttl {
    color: var(--baseColor);
    text-align: center;
    font-feature-settings: "vert" on;
    font-size: 1.4rem;
    font-style: normal;
    font-weight: 500;
    line-height: 1.6rem;
    letter-spacing: 0.056rem;
  }
}
.look-unit__subttl span {
  display: block;
  padding-left: 0.6rem;
  border-left: 1px solid;
  height: fit-content;
}
@media only screen and (max-width: 768px) {
  .look-unit__subttl span {
    padding-left: 0.36rem;
  }
}
.look-unit__subttl span:not(:last-child) {
  margin-left: 2.2rem;
}
@media only screen and (max-width: 768px) {
  .look-unit__subttl span:not(:last-child) {
    margin-left: 1.36rem;
  }
}
.look-unit__type {
  z-index: -1;
}
.look-unit__type img {
  width: 17.736rem;
  height: 18.336rem;
}
@media only screen and (max-width: 768px) {
  .look-unit__type img {
    width: 10.6416rem;
    height: 11.0016rem;
  }
}
.look-unit .flex {
  position: relative;
}

.look-tate {
  writing-mode: vertical-rl;
  text-orientation: upright;
  color: #fff;
  text-align: center;
  font-feature-settings: "vert" on;
  font-size: 2.8rem;
  font-style: normal;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.35em;
}
@media only screen and (max-width: 768px) {
  .look-tate {
    color: #fff;
    text-align: center;
    font-feature-settings: "vert" on;
    font-size: 1.4rem;
    font-style: normal;
    font-weight: 700;
    line-height: 1.8rem;
    letter-spacing: 0.056rem;
  }
}
.look-tate span {
  display: block;
  padding: 2.4rem 1.3rem;
  background: #f36;
  height: fit-content;
}
@media only screen and (max-width: 768px) {
  .look-tate span {
    padding: 1.15rem 0.62rem;
    letter-spacing: 0.3em;
  }
}
.look-tate span:not(:last-child) {
  margin-left: 2rem;
}
@media only screen and (max-width: 768px) {
  .look-tate span:not(:last-child) {
    margin-left: 0.37rem;
  }
}

.o-card {
  display: grid;
}
.o-card--2wrap {
  grid-template-columns: repeat(2, 1fr);
  gap: 6rem;
}
.o-card--3wrap {
  grid-template-columns: repeat(3, 1fr);
  gap: 4rem;
}
@media only screen and (max-width: 768px) {
  .o-card--3wrap {
    grid-template-columns: repeat(1, 1fr);
    gap: 2rem;
  }
}
.o-card--4wrap {
  grid-template-columns: repeat(4, 1fr);
  gap: 3rem;
}
@media only screen and (max-width: 768px) {
  .o-card--4wrap {
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
  }
}
.o-card--5wrap {
  grid-template-columns: repeat(5, 1fr);
  gap: 1rem;
}
@media only screen and (max-width: 768px) {
  .o-card--5wrap {
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
  }
}

.o-flex {
  display: flex;
  gap: 6rem;
}
@media only screen and (max-width: 768px) {
  .o-flex {
    flex-direction: column;
    gap: 3rem;
  }
}
.o-flex--c {
  justify-content: center;
}
.o-flex--b {
  justify-content: space-between;
}
.o-flex--e {
  justify-content: flex-end;
}
@media only screen and (max-width: 768px) {
  .o-flex--rev {
    flex-direction: column-reverse;
  }
}
.o-flex__item {
  width: calc((100% - 6rem) / 2);
}
@media only screen and (max-width: 768px) {
  .o-flex__item {
    width: 100%;
  }
}
.o-flex__item--1 {
  width: calc((100% - 6rem) / 3);
}
.o-flex__item--2 {
  width: calc((100% - 6rem) / 3 * 2);
}

.l-hdr {
  position: absolute;
  top: 0.6rem;
  left: 0rem;
  z-index: 100;
}
@media only screen and (max-width: 768px) {
  .l-hdr {
    top: 0.8rem;
    left: 0.8rem;
  }
}
.l-hdr__logoimg {
  width: 24rem;
  height: 9.2rem;
}
@media only screen and (max-width: 768px) {
  .l-hdr__logoimg {
    width: 11rem;
    height: auto;
    display: none;
  }
}

.l-ftr {
  padding: 14rem 0 2.87rem;
}
@media only screen and (max-width: 768px) {
  .l-ftr {
    padding: 0 0 1.6rem;
  }
}
.l-ftr__wrap {
  width: 80rem;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .l-ftr__wrap {
    width: 32rem;
  }
}
.l-ftr__list {
  display: flex;
  flex-direction: column;
  gap: 4rem;
  justify-content: center;
  align-items: center;
  margin-bottom: 5.6rem;
  padding-bottom: 5.6rem;
  border-bottom: 1px solid;
}
@media only screen and (max-width: 768px) {
  .l-ftr__list {
    gap: 4rem;
    margin-bottom: 6.5rem;
    padding-bottom: 5.5rem;
  }
}
.l-ftr__link {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 60rem;
  height: 8rem;
  font-size: 2rem;
  border: 1px solid;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .l-ftr__link {
    width: 28rem;
    font-size: 1.4rem;
    height: 6.4rem;
  }
}
.l-ftr__link::after {
  content: "";
  background: url(../images/next.webp) no-repeat center center/contain;
  width: 1.2rem;
  height: 2.4rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 2.5rem;
}
@media only screen and (max-width: 768px) {
  .l-ftr__link::after {
    width: 0.7rem;
    height: 1.4rem;
    right: 1.5rem;
  }
}
.l-ftr__link.time {
  font-size: 2.1rem;
  letter-spacing: 0.08em;
}
@media only screen and (max-width: 768px) {
  .l-ftr__link.time {
    font-size: 1.4rem;
    display: flex;
    flex-direction: column;
    line-height: 2;
  }
}
@media only screen and (max-width: 768px) {
  .l-ftr__link--large {
    height: 7.6rem;
  }
}
.l-ftr__link span {
  color: #58c2e0;
  font-size: 1.6rem;
  letter-spacing: 0.08em;
}
@media only screen and (max-width: 768px) {
  .l-ftr__link span {
    font-size: 1.4rem;
  }
}
.l-ftr__flex {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.4rem;
  margin-bottom: 8rem;
  flex-direction: column;
  align-items: center;
  width: 154.8rem;
  margin-inline: auto;
  position: relative;
  z-index: 200;
}
@media only screen and (max-width: 768px) {
  .l-ftr__flex {
    grid-template-columns: repeat(1, 1fr);
    gap: 1.6rem;
    width: 100%;
    justify-items: center;
    margin-bottom: 5.6rem;
  }
}
.l-ftr__banner {
  width: 96rem;
  height: auto;
}
@media only screen and (max-width: 768px) {
  .l-ftr__banner {
    width: 34rem;
  }
}
.l-ftr__banner--01 {
  width: 108rem;
}
@media only screen and (max-width: 768px) {
  .l-ftr__banner--01 {
    width: 34rem;
  }
}
@media only screen and (max-width: 768px) {
  .l-ftr__banner img {
    width: 28rem;
    height: auto;
  }
}
.l-ftr__sns {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4rem;
  margin-bottom: 4.8rem;
}
@media only screen and (max-width: 768px) {
  .l-ftr__sns {
    gap: 4.3rem;
    margin-bottom: 6.3rem;
  }
}
.l-ftr__snsitem {
  width: 8rem;
  height: 8rem;
  border-radius: 50%;
  border: 1px solid #b9b9b9;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media only screen and (max-width: 768px) {
  .l-ftr__snsitem {
    width: 6.4rem;
    height: 6.4rem;
  }
}
.l-ftr__snsimg--01 {
  width: 3.2rem;
  height: 3.2rem;
}
@media only screen and (max-width: 768px) {
  .l-ftr__snsimg--01 {
    width: 2.5rem;
    height: 2.5rem;
  }
}
.l-ftr__snsimg--02 {
  width: 3.3rem;
  height: 3.2rem;
}
@media only screen and (max-width: 768px) {
  .l-ftr__snsimg--02 {
    width: 2.6rem;
    height: 2.5rem;
  }
}
.l-ftr__logo {
  margin-bottom: 1.6rem;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .l-ftr__logo {
    margin-bottom: 2.1rem;
  }
}
.l-ftr__logoimg {
  width: 18.7rem;
  height: 4rem;
}
@media only screen and (max-width: 768px) {
  .l-ftr__logoimg {
    width: 13.1rem;
    height: 2.8rem;
  }
}
.l-ftr__copy small {
  font-size: 1rem;
  font-family: var(--time);
  display: block;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .l-ftr__copy small {
    font-size: 0.8rem;
  }
}

.floating {
  position: fixed;
  top: 70%;
  right: 3.2rem;
  box-sizing: border-box;
  height: auto;
  padding-block: 3rem;
  opacity: 0;
  transition: opacity 0.5s;
  transform: translateY(-50%);
  height: 100vh;
  z-index: 100;
}
@media only screen and (max-width: 768px) {
  .floating {
    display: none;
  }
}
.floating.is-visible {
  opacity: 1;
}
.floating__list {
  margin: 0;
  padding: 0;
  gap: 1.6rem;
  list-style: none;
  display: grid;
  grid-template-rows: repeat(4, auto);
  grid-auto-flow: column;
  height: auto;
  gap: 0.4rem;
}
.floating__item {
  display: grid;
  place-items: center;
  width: auto;
  max-height: none;
  line-height: 0;
}
.floating__item img {
  width: 8rem;
  height: auto;
}
.floating__item:nth-child(n+5) {
  transform: translateY(2rem);
}

.hero {
  position: relative;
}
.hero__wrap img {
  width: 100%;
}
.hero__list {
  position: absolute;
  top: 4rem;
  right: 4rem;
  width: 66.4rem;
  height: 12rem;
}
@media only screen and (max-width: 768px) {
  .hero__list {
    display: none;
  }
}
.hero__ttlarea {
  position: absolute;
  top: 51%;
  transform: translateY(-50%);
  right: 2%;
  display: flex;
  flex-direction: column;
}
@media only screen and (max-width: 768px) {
  .hero__ttlarea {
    top: 19%;
    right: 14%;
  }
}
.hero__ttl-img01 {
  width: 51.9077rem;
  height: auto;
  top: 0.5rem;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .hero__ttl-img01 {
    width: 17.8532rem;
    top: -1rem;
    left: 1.6rem;
  }
}
.hero__ttl-img02 {
  width: 48.0552rem;
  height: 9.5462rem;
  position: absolute;
  z-index: -1;
  top: 4.4rem;
  left: 2rem;
}
@media only screen and (max-width: 768px) {
  .hero__ttl-img02 {
    width: 15.5699rem;
    height: 3.093rem;
    top: 0.3rem;
    left: 2.3rem;
  }
}
.hero__ttl-img03 {
  width: 6.9244rem;
  height: 6.5638rem;
  position: absolute;
  top: -5rem;
  right: 37rem;
}
@media only screen and (max-width: 768px) {
  .hero__ttl-img03 {
    width: 2.2435rem;
    height: 2.1267rem;
  }
}
.hero__ttl-img04 {
  width: 62.1425rem;
  height: 13.6371rem;
  position: relative;
  left: 12.8rem;
  top: 1.3rem;
}
@media only screen and (max-width: 768px) {
  .hero__ttl-img04 {
    width: 20.1341rem;
    height: 4.4184rem;
    left: 5.8rem;
    top: -0.7rem;
  }
}
.hero__ttl-img05 {
  width: 92.5994rem;
  height: 24.8037rem;
  margin-top: -2rem;
}
@media only screen and (max-width: 768px) {
  .hero__ttl-img05 {
    width: 30.0022rem;
    height: 8.0364rem;
    position: relative;
    top: 0rem;
    left: 1.5rem;
  }
}
.hero__logo {
  position: absolute;
  bottom: 10rem;
  right: 4.6rem;
}
@media only screen and (max-width: 768px) {
  .hero__logo {
    bottom: inherit;
    top: 30%;
    right: 4rem;
  }
}
.hero__logo-img {
  width: 56.7525rem;
  height: 18.8747rem;
}
@media only screen and (max-width: 768px) {
  .hero__logo-img {
    width: 18.3879rem;
    height: 6.1154rem;
  }
}
.hero__catch {
  position: absolute;
  top: 10rem;
  left: 4rem;
  z-index: 10;
  color: var(--colorW);
  text-align: center;
  font-feature-settings: "vert" on;
  font-size: 4.4rem;
  font-style: normal;
  font-weight: 500;
  line-height: 4.4rem; /* 100% */
  display: flex;
  writing-mode: vertical-rl;
  text-orientation: upright;
  flex-direction: column;
}
@media only screen and (max-width: 768px) {
  .hero__catch {
    font-size: 1.76rem;
    line-height: 1.76rem; /* 100% */
    top: 35%;
    left: inherit;
    right: 2.4rem;
  }
}
.hero__catch--01 {
  transform: rotate(-2.535deg);
  position: relative;
  top: 1.7rem;
  right: -9.5rem;
}
@media only screen and (max-width: 768px) {
  .hero__catch--01 {
    right: 2rem;
    transform: rotate(10deg);
  }
}
.hero__catch--02 {
  transform: rotate(-6.633deg);
  position: relative;
  top: 17.2rem;
  right: -6.3rem;
}
@media only screen and (max-width: 768px) {
  .hero__catch--02 {
    right: 4.6rem;
    transform: rotate(5deg);
    top: 7.2rem;
  }
}

.series {
  padding: 14rem 0;
}
@media only screen and (max-width: 768px) {
  .series {
    padding: 5rem 0 6rem;
  }
}
.series__wrap {
  width: 104.16rem;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .series__wrap {
    width: 100%;
    padding-inline: 3rem;
  }
}
.series__ttlarea {
  margin-bottom: 4rem;
}
@media only screen and (max-width: 768px) {
  .series__ttlarea {
    margin-bottom: 2.4rem;
  }
}
.series__ttl {
  text-align: center;
  font-size: 5.6rem;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  letter-spacing: 0.448rem;
  display: flex;
  flex-direction: column;
  width: fit-content;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .series__ttl {
    font-size: 2.24rem;
  }
}
.series__ttl .small {
  font-size: 4rem;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  letter-spacing: 0.32rem;
}
@media only screen and (max-width: 768px) {
  .series__ttl .small {
    font-size: 1.6rem;
  }
}
.series__ttl .bg {
  position: relative;
  z-index: 0;
  --before-mask: 100%;
  --after-scale: 1;
}
.series__ttl .bg::before {
  content: "";
  background: url(../images/series__ttl03.webp) no-repeat center center/contain;
  width: 4.78rem;
  height: 4.5311rem;
  position: absolute;
  top: -1rem;
  right: 16rem;
  clip-path: polygon(0 0, var(--before-mask) 0, var(--before-mask) 100%, 0% 100%);
  will-change: clip-path;
}
@media only screen and (max-width: 768px) {
  .series__ttl .bg::before {
    width: 1.912rem;
    height: 1.8124rem;
    top: -1rem;
    right: 6rem;
  }
}
.series__ttl .bg::after {
  content: "";
  background: url(../images/series__ttl01.webp) no-repeat center center/contain;
  width: 32.7rem;
  height: 2.4rem;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0rem;
  z-index: -1;
  transform: translateX(-50%) scaleX(var(--after-scale));
  transform-origin: left center;
  will-change: transform;
}
@media only screen and (max-width: 768px) {
  .series__ttl .bg::after {
    width: 13.08rem;
    height: 0.96rem;
  }
}
.series__ttl-img01 {
  width: 73.5rem;
  height: 11.173rem;
  display: block;
  margin-inline: auto;
  margin-bottom: 0.4rem;
  margin-top: 2rem;
}
@media only screen and (max-width: 768px) {
  .series__ttl-img01 {
    width: 29.46rem;
    height: 4.5092rem;
    margin-top: 0.5rem;
  }
}
.series__text {
  text-align: center;
  font-size: 2.4rem;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  letter-spacing: 0.192rem;
}
@media only screen and (max-width: 768px) {
  .series__text {
    font-size: 1.2rem;
  }
}
.series__card {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2.5rem 5.6rem;
}
@media only screen and (max-width: 768px) {
  .series__card {
    display: flex;
    flex-wrap: wrap;
    gap: 0.1rem 1.2rem;
    justify-content: center;
  }
}
.series__card-item {
  position: relative;
}
@media only screen and (max-width: 768px) {
  .series__card-item {
    width: calc((100% - 2.4rem) / 3);
  }
}
.series__card-number {
  position: absolute;
  top: 1rem;
  left: 1rem;
  width: 4rem;
  z-index: 10;
}
@media only screen and (max-width: 768px) {
  .series__card-number {
    width: 2.5rem;
    top: 0.5rem;
    left: 0.5rem;
  }
}
@media only screen and (max-width: 768px) {
  .series__card-number img {
    transform: scale(0.6);
    top: -1.5rem;
    left: -1.5rem;
    position: relative;
  }
}
.series__card-img {
  margin-bottom: 1.2rem;
}
@media only screen and (max-width: 768px) {
  .series__card-img {
    margin-bottom: 0.7rem;
  }
}
.series__card-ttl {
  text-align: center;
  font-size: 1.7rem;
  font-weight: 400;
  line-height: 100%;
  letter-spacing: 0.136rem;
  margin-bottom: 0.8rem;
}
@media only screen and (max-width: 768px) {
  .series__card-ttl {
    font-size: 1.2rem;
    font-style: normal;
    font-weight: 400;
    line-height: 100%;
    word-break: keep-all;
  }
}
.series__card-arrow {
  display: block;
  margin-inline: auto;
  padding-bottom: 1.2rem;
}
.series__card-item:nth-child(1) .series__card-link::before {
  background: #ffff8e;
}
.series__card-item:nth-child(2) .series__card-link::before {
  background: #d4f9b8;
}
.series__card-item:nth-child(3) .series__card-link::before {
  background: #f8ddee;
}
.series__card-item:nth-child(4) .series__card-link::before {
  background: #cff0f3;
}
.series__card-item:nth-child(5) .series__card-link::before {
  background: #eae3f8;
}
.series__card-item:nth-child(6) .series__card-link::before {
  background: #ffeded;
}
.series__card-item:nth-child(7) .series__card-link::before {
  background: #e7f7ef;
}
.series__card-item:nth-child(8) .series__card-link::before {
  background: #ffedda;
}

.wardrobe {
  margin-bottom: 12rem;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .wardrobe {
    margin-bottom: 7.5rem;
  }
}
.wardrobe__catch {
  text-align: center;
  font-feature-settings: "liga" off;
  font-size: 1.4rem;
  font-style: normal;
  font-weight: 400;
  line-height: 120%; /* 1.68rem */
  letter-spacing: 0.112rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 200;
}
@media only screen and (max-width: 768px) {
  .wardrobe__catch {
    display: none;
  }
}
.wardrobe__catch--left {
  transform: translateY(-50%) rotate(-90deg);
  left: 4rem;
}
.wardrobe__catch--right {
  transform: translateY(-50%) rotate(90deg);
  right: 4rem;
}
.wardrobe__wrap {
  margin-inline: auto;
  width: 140rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__wrap {
    width: 100%;
    padding-inline: 1.4rem;
  }
}
.wardrobe__box {
  background: #e4f6fb;
  position: relative;
  height: 113.1rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__box {
    height: 68.4rem;
  }
}
.wardrobe__box::before, .wardrobe__box::after {
  content: "";
  width: 0.1rem;
  height: 100%;
  background: #000;
  position: absolute;
  top: 0;
}
.wardrobe__box::before {
  left: 3.2rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__box::before {
    left: 0.7rem;
  }
}
.wardrobe__box::after {
  right: 3.2rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__box::after {
    right: 0.7rem;
  }
}
.wardrobe__list {
  position: relative;
}
.wardrobe__ttl {
  position: relative;
  top: -2.4rem;
  left: 8rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__ttl {
    left: -0.5rem;
    top: -4.2rem;
  }
}
.wardrobe__ttl img {
  width: 36.1rem;
  height: 34.8rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__ttl img {
    height: 8rem;
    width: 29.2rem;
  }
}
.wardrobe__item {
  display: flex;
  position: absolute;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item {
    position: inherit;
  }
}
.wardrobe__item--02, .wardrobe__item--04 {
  flex-direction: row-reverse;
}
.wardrobe__item--01 {
  top: -30rem;
  left: 38%;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item--01 {
    top: -2rem;
    left: 4rem;
  }
}
.wardrobe__item--01 svg {
  top: -4rem;
  left: -4rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item--01 svg {
    top: -2.5rem;
    left: -1.5rem;
    width: 1.7rem;
    height: 0.4rem;
  }
}
.wardrobe__item--02 {
  top: -1.8rem;
  left: 9.5rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item--02 {
    top: 0;
    left: 0;
  }
}
.wardrobe__item--02 .wardrobe__item-cont {
  top: 8.8rem;
  left: 2rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item--02 .wardrobe__item-cont {
    top: -2.1rem;
    left: -3.4rem;
  }
}
@media only screen and (max-width: 768px) {
  .wardrobe__item--02 .wardrobe__item-text .bg:last-child {
    position: relative;
    top: -2.3rem;
  }
}
.wardrobe__item--02 svg {
  right: -25rem;
  top: -1rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item--02 svg {
    top: -3.9rem;
    right: -8.4rem;
    width: 1.7rem;
    height: 1.6rem;
    transform: rotate(346deg);
  }
}
.wardrobe__item--03 {
  top: 30%;
  right: 8%;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item--03 {
    top: -4.6rem;
    right: inherit;
    left: 3.1rem;
  }
}
.wardrobe__item--03 .wardrobe__item-figure {
  position: relative;
  top: -5.8rem;
  left: 0rem;
}
.wardrobe__item--03 .wardrobe__item-cont {
  top: 1.8rem;
  left: -1rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item--03 .wardrobe__item-cont {
    top: -1rem;
    left: 0.6rem;
  }
}
.wardrobe__item--03 svg {
  top: -1rem;
  left: -2rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item--03 svg {
    top: 0;
    left: 0;
    width: 1.6rem;
    height: 1.6rem;
    top: -1.5rem;
    left: -1.3rem;
  }
}
.wardrobe__item--04 {
  bottom: -72.5rem;
  left: 13.9rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item--04 {
    bottom: 13rem;
    left: -1rem;
  }
}
.wardrobe__item--04 .wardrobe__item-cont {
  top: 1.1rem;
  left: -4.2rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item--04 .wardrobe__item-cont {
    top: 2.9rem;
    left: 0.3rem;
  }
}
.wardrobe__item--04 svg {
  left: 24rem;
  top: -4rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item--04 svg {
    top: -2.6rem;
    left: 12rem;
    transform: rotate(320deg);
    height: 1.6rem;
    width: 2rem;
  }
}
.wardrobe__item--05 {
  right: 14rem;
  top: 32.8rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item--05 {
    top: -17rem;
    right: -2.5rem;
  }
}
.wardrobe__item--05 .wardrobe__item-cont {
  top: 14.1rem;
  left: 3.8rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item--05 .wardrobe__item-cont {
    top: 6rem;
    left: 0.4rem;
  }
}
.wardrobe__item--05 svg {
  left: -4.5rem;
  top: -4rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item--05 svg {
    top: -1.4rem;
    left: -1.7rem;
    width: 2.8rem;
    height: 1.6rem;
    transform: rotate(351deg);
  }
}
.wardrobe__item-cont {
  position: relative;
  top: 3rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item-cont {
    top: -0.3rem;
    left: -1rem;
  }
}
.wardrobe__item-number {
  margin-bottom: 1rem;
  text-align: center;
  font-size: 2rem;
  font-style: normal;
  font-weight: 600;
  line-height: 3.639rem; /* 181.949% */
  border: 1px solid;
  border-radius: calc(infinity * 1px);
  width: 8.5rem;
  height: 4rem;
  display: flex;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  z-index: 0;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item-number {
    font-size: 0.732rem;
    font-style: normal;
    font-weight: 600;
    line-height: 1.3319rem; /* 181.949% */
    width: 3.111rem;
    height: 1.464rem;
    margin-bottom: 0.5rem;
  }
}
.wardrobe__item-number::before {
  content: "";
  width: 8.5rem;
  height: 4rem;
  border-radius: calc(infinity * 1px);
  opacity: 0.6;
  background: var(--58C2E0, #58c2e0);
  position: absolute;
  top: 0.37rem;
  left: 0.37rem;
  z-index: -1;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item-number::before {
    width: 3.111rem;
    height: 1.464rem;
    top: 0.13rem;
    left: 0.13rem;
  }
}
.wardrobe__item-text {
  font-size: 2rem;
  font-style: normal;
  font-weight: 500;
  line-height: 3.639rem; /* 181.949% */
  letter-spacing: 0.16rem;
  position: relative;
  z-index: 0;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item-text {
    font-size: 1rem;
    font-style: normal;
    font-weight: 500;
    line-height: 2.1834rem; /* 218.339% */
    letter-spacing: 0.08rem;
  }
}
.wardrobe__item-text svg {
  position: relative;
  z-index: -1;
}
.wardrobe__item-text .bg {
  display: block;
  background-color: var(--colorW);
  width: fit-content;
  padding: 0.4rem 1.6rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item-text .bg {
    padding: 0rem 0.7rem;
  }
}
.wardrobe__item-text .bg:not(:last-child) {
  margin-bottom: 0.8rem;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item-text .bg:not(:last-child) {
    margin-bottom: 0.4rem;
  }
}
.wardrobe__item-text .og {
  color: #e87800;
}
.wardrobe__item-img--01 {
  width: 30rem;
  height: auto;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item-img--01 {
    width: 13.5rem;
    transform: rotate(350deg);
    top: -0.6rem;
    position: relative;
    left: -1rem;
  }
}
.wardrobe__item-img--02 {
  width: 32rem;
  height: auto;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item-img--02 {
    top: -7rem;
    left: -1.6rem;
    transform: rotate(10deg);
    position: relative;
    width: 12rem;
  }
}
.wardrobe__item-img--03 {
  width: 23.5rem;
  height: auto;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item-img--03 {
    width: 10.5rem;
    transform: rotate(346deg);
  }
}
.wardrobe__item-img--04 {
  width: 30rem;
  height: auto;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item-img--04 {
    width: 12rem;
  }
}
.wardrobe__item-img--05 {
  width: 29rem;
  height: auto;
}
@media only screen and (max-width: 768px) {
  .wardrobe__item-img--05 {
    width: 11.7rem;
    transform: rotate(360deg);
  }
}

.type {
  background: #f0f4f5;
  padding: 10rem 8rem;
  margin-bottom: 12.8rem;
}
@media only screen and (max-width: 768px) {
  .type {
    padding: 4rem 1rem 4.5rem;
    margin-bottom: 10.5rem;
  }
}
.type__wrap {
  position: relative;
  z-index: 0;
}
.type__wrap::before, .type__wrap::after {
  content: "";
  width: 0.2rem;
  height: 20rem;
  position: absolute;
  background: var(--baseColor);
}
@media only screen and (max-width: 768px) {
  .type__wrap::before, .type__wrap::after {
    width: 0.1rem;
    height: 7rem;
  }
}
.type__wrap::before {
  bottom: -5rem;
  left: 4rem;
  transform: rotate(-45deg);
  z-index: 10;
}
@media only screen and (max-width: 768px) {
  .type__wrap::before {
    bottom: -2rem;
    left: 2rem;
  }
}
.type__wrap::after {
  top: -5rem;
  right: 4rem;
  transform: rotate(-45deg);
  z-index: 10;
}
@media only screen and (max-width: 768px) {
  .type__wrap::after {
    top: -2rem;
    right: 2rem;
  }
}
.type__box {
  background-color: var(--colorW);
  width: 176rem;
  height: auto;
  clip-path: polygon(16rem 0, 100% 0, 100% calc(100% - 16rem), calc(100% - 16rem) 100%, 0 100%, 0 16rem);
}
@media only screen and (max-width: 768px) {
  .type__box {
    width: 100%;
    clip-path: polygon(5rem 0, 100% 0, 100% calc(100% - 5rem), calc(100% - 5rem) 100%, 0 100%, 0 5rem);
  }
}
.type__flex {
  display: flex;
  justify-content: center;
  gap: 16rem;
  padding: 7rem 12rem 4rem;
}
@media only screen and (max-width: 768px) {
  .type__flex {
    flex-direction: column;
    gap: 2.4rem;
    padding: 5.6rem 4.3rem 0rem;
  }
}
.type__ttlarea {
  position: relative;
  top: 18.5%;
  left: -3.6rem;
}
@media only screen and (max-width: 768px) {
  .type__ttlarea {
    left: 0;
    margin-bottom: 0.5rem;
  }
}
.type__ttl {
  display: flex;
  flex-direction: column;
  position: relative;
  z-index: 0;
}
.type__ttl-img01 {
  width: 46.5308rem;
  height: 10.1855rem;
}
@media only screen and (max-width: 768px) {
  .type__ttl-img01 {
    width: 18.8449rem;
    height: auto;
    position: relative;
    left: 4rem;
  }
}
.type__ttl-img02 {
  width: 38.7171rem;
  height: 22.2303rem;
  position: relative;
  top: 0.4rem;
  left: 3.7rem;
}
@media only screen and (max-width: 768px) {
  .type__ttl-img02 {
    width: 22.7125rem;
    height: auto;
    top: -0.2rem;
    left: 2.1rem;
  }
}
.type__ttl-img03 {
  width: 28.184rem;
  height: auto;
  position: relative;
  top: 2rem;
  left: 8.4rem;
  padding-bottom: 2rem;
}
@media only screen and (max-width: 768px) {
  .type__ttl-img03 {
    width: 11.1rem;
    top: 1rem;
    left: 6rem;
  }
}
.type__ttl-img04 {
  width: 35.0447rem;
  height: 11.7411rem;
  position: absolute;
  bottom: -3rem;
  left: 2rem;
  z-index: -1;
  bottom: -5rem;
  left: 5rem;
}
@media only screen and (max-width: 768px) {
  .type__ttl-img04 {
    width: 14.1931rem;
    height: 4.7551rem;
    bottom: -0.3rem;
    left: 4.5rem;
  }
}
.type__head {
  width: 46.5rem;
}
@media only screen and (max-width: 768px) {
  .type__head {
    width: auto;
  }
}
.type__main {
  position: relative;
  left: 1.2rem;
  top: -0.4rem;
  width: 81.2rem;
}
@media only screen and (max-width: 768px) {
  .type__main {
    width: 100%;
  }
}
.type__img01 {
  width: 39.4388rem;
  height: 35.6523rem;
}
@media only screen and (max-width: 768px) {
  .type__img01 {
    width: 22rem;
    height: auto;
  }
}
.type__img02 {
  width: 29.8078rem;
  height: 36.3655rem;
}
@media only screen and (max-width: 768px) {
  .type__img02 {
    width: 16.3943rem;
    height: 20.001rem;
    position: relative;
    left: -3rem;
    top: 0.4rem;
  }
}
.type__visu {
  position: relative;
}
@media only screen and (max-width: 768px) {
  .type__figure02 {
    text-align: center;
  }
}
.type__temp {
  width: 12rem;
  height: 12rem;
  position: absolute;
}
@media only screen and (max-width: 768px) {
  .type__temp {
    width: 6.4rem;
    height: 6.4rem;
  }
}
.type__temp--01 {
  bottom: 3rem;
  left: 0;
}
@media only screen and (max-width: 768px) {
  .type__temp--01 {
    bottom: inherit;
    top: 1rem;
    left: inherit;
    right: 2.2rem;
  }
}
.type__temp--02 {
  right: -7.5rem;
  bottom: 2.3rem;
}
@media only screen and (max-width: 768px) {
  .type__temp--02 {
    right: 4rem;
    bottom: 0.5rem;
  }
}
.type__item {
  display: flex;
}
@media only screen and (max-width: 768px) {
  .type__item {
    flex-direction: column;
  }
}
.type__item--01 {
  margin-bottom: 3rem;
}
.type__item--01 .type__visu {
  width: 39.4rem;
  height: 38.5rem;
}
@media only screen and (max-width: 768px) {
  .type__item--01 .type__visu {
    width: auto;
    height: auto;
  }
}
.type__item--01 .type__summary {
  width: 41.8rem;
  height: 38.5rem;
}
@media only screen and (max-width: 768px) {
  .type__item--01 .type__summary {
    width: auto;
    height: auto;
  }
}
.type__item--02 {
  gap: 4.2rem;
  position: relative;
  left: -5rem;
}
.type__item--02 .type__summary {
  width: 40.1rem;
  height: 38.5rem;
}
@media only screen and (max-width: 768px) {
  .type__item--02 .type__summary {
    width: auto;
    height: auto;
  }
}
.type__item--02 .type__visu {
  width: 29.8rem;
  height: 38.5rem;
}
@media only screen and (max-width: 768px) {
  .type__item--02 .type__visu {
    width: auto;
    height: auto;
  }
}
@media only screen and (max-width: 768px) {
  .type__item--02 {
    flex-direction: column-reverse;
    left: 0;
  }
}
.type__number01 {
  width: 12.0143rem;
  height: 4.8rem;
  position: relative;
  left: 4.7rem;
  top: -1.2rem;
}
@media only screen and (max-width: 768px) {
  .type__number01 {
    width: 6rem;
    height: auto;
    left: 0.7rem;
    top: 0.2rem;
  }
}
.type__number02 {
  width: 12.9768rem;
  height: 4.8003rem;
  position: relative;
  top: -1.7rem;
  left: 0.5rem;
}
@media only screen and (max-width: 768px) {
  .type__number02 {
    width: 7rem;
    height: auto;
    top: -2.7rem;
    left: 1.5rem;
  }
}
.type__subttl {
  text-align: center;
  margin-bottom: 1.5rem;
  margin-top: -2rem;
}
.type__subttl01 {
  width: 23.9815rem;
  height: 8.2256rem;
  position: relative;
  top: -0.6rem;
  left: 1rem;
}
@media only screen and (max-width: 768px) {
  .type__subttl01 {
    width: 15.2148rem;
    height: 5.1795rem;
    top: 0.9rem;
    left: -1.1rem;
  }
}
.type__svg01 {
  position: relative;
  top: -1.1rem;
  left: 1.8rem;
  width: 41.8rem;
}
@media only screen and (max-width: 768px) {
  .type__svg01 {
    display: none;
  }
}
.type__svg02 {
  position: relative;
  top: -2.4rem;
  left: -1rem;
  width: 40.1rem;
}
@media only screen and (max-width: 768px) {
  .type__svg02 {
    display: none;
  }
}
.type__subttl02 {
  width: 12.2815rem;
  height: 8.2256rem;
  position: relative;
  top: -1.7rem;
  left: -1rem;
}
@media only screen and (max-width: 768px) {
  .type__subttl02 {
    width: 7.8rem;
    height: auto;
    top: -2.5rem;
  }
}
.type__textarea {
  margin-bottom: 4rem;
  width: fit-content;
  margin-inline: auto;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .type__textarea {
    margin-bottom: 2.4rem;
  }
}
.type__textarea--01 {
  top: -2.3rem;
  left: 2rem;
}
@media only screen and (max-width: 768px) {
  .type__textarea--01 {
    top: 0.4rem;
    left: -1rem;
  }
}
.type__textarea--02 {
  top: -4rem;
  left: -0.6rem;
}
@media only screen and (max-width: 768px) {
  .type__textarea--02 {
    top: -3.3rem;
    left: -1.6rem;
  }
}
.type__text {
  font-size: 1.8rem;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  letter-spacing: 0.144rem;
}
@media only screen and (max-width: 768px) {
  .type__text {
    font-size: 1.4rem;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 0.112rem;
    text-align: center;
  }
}
.type .item__head-icon {
  justify-content: center;
}
.type .item__head-icon--01 {
  position: relative;
  top: -2.3rem;
  left: 3rem;
}
@media only screen and (max-width: 768px) {
  .type .item__head-icon--01 {
    top: 0.3rem;
    left: -1.4rem;
  }
}
.type .item__head-icon--02 {
  position: relative;
  top: -4rem;
  left: -1rem;
}
@media only screen and (max-width: 768px) {
  .type .item__head-icon--02 {
    top: -3rem;
    left: -1.3rem;
  }
}
.type .item__head-icon .item__icon--small {
  width: 7.2rem;
  height: 7.2rem;
}
@media only screen and (max-width: 768px) {
  .type .item__head-icon .item__icon--small {
    width: 4.8rem;
    height: 4.8rem;
  }
}

.item {
  margin-bottom: 20rem;
}
.item__head {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 0;
  margin-bottom: 8rem;
}
@media only screen and (max-width: 768px) {
  .item__head {
    margin-bottom: 12rem;
  }
}
.item__head::after {
  content: "";
  width: 100%;
  height: 44.4rem;
  background-color: #f36;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: -1rem;
  z-index: -1;
}
@media only screen and (max-width: 768px) {
  .item__head::after {
    height: 23rem;
  }
}
.item__ttlarea {
  text-align: center;
  margin-bottom: 3.2rem;
}
@media only screen and (max-width: 768px) {
  .item__ttlarea {
    margin-bottom: 1rem;
  }
}
.item__number {
  margin-bottom: 2.4rem;
}
.item__ttl-en {
  margin-bottom: 1.6rem;
}
@media only screen and (max-width: 768px) {
  .item__ttl-en {
    margin-bottom: 1rem;
  }
}
.item__ttl {
  font-size: 2.8rem;
  font-weight: 700;
}
@media only screen and (max-width: 768px) {
  .item__ttl {
    font-size: 1.2rem;
  }
}
.item__cont--visu {
  display: flex;
  position: relative;
}
.item__textarea {
  display: flex;
  flex-direction: row-reverse;
  position: absolute;
  bottom: 0;
  right: -4rem;
}
.item__cm-text {
  font-size: 2rem;
  font-weight: 400;
  line-height: 220%;
  letter-spacing: 0.16rem;
}
@media only screen and (max-width: 768px) {
  .item__cm-text {
    font-size: 1.4rem;
    font-style: normal;
    font-weight: 400;
    line-height: 220%; /* 3.08rem */
    letter-spacing: 0.112rem;
  }
}
.item__head-icon {
  display: flex;
  gap: 0.8rem;
  align-items: center;
}
@media only screen and (max-width: 768px) {
  .item__head-icon {
    gap: 0.6rem;
  }
}
.item__icon {
  width: 8rem;
  height: 8rem;
}
@media only screen and (max-width: 768px) {
  .item__icon {
    width: 4rem;
    height: 4rem;
  }
}
.item__icon--large {
  padding-right: 0.4rem;
  width: 8rem;
  height: 8rem;
}
@media only screen and (max-width: 768px) {
  .item__icon--large {
    padding-right: 0;
    width: 4rem;
    aspect-ratio: 1/1;
    height: 4rem;
  }
}

.item01 {
  margin-bottom: 28rem;
}
@media only screen and (max-width: 768px) {
  .item01 {
    margin-bottom: 14rem;
  }
}
.item01 .item__number {
  position: relative;
}
@media only screen and (max-width: 768px) {
  .item01 .item__number {
    left: -2.5rem;
    top: 0.9rem;
  }
}
.item01 .item__number img {
  width: 10.9181rem;
  height: 12.1263rem;
}
@media only screen and (max-width: 768px) {
  .item01 .item__number img {
    width: 4.5rem;
    height: 5.0111rem;
  }
}
.item01 .item__ttl-en {
  position: relative;
}
@media only screen and (max-width: 768px) {
  .item01 .item__ttl-en {
    left: 2.4rem;
    top: -1rem;
  }
}
.item01 .item__ttl-en img {
  width: 59.1rem;
  height: 16.8rem;
}
@media only screen and (max-width: 768px) {
  .item01 .item__ttl-en img {
    width: 12.1rem;
    height: 10.4rem;
  }
}
.item01 .item__ttl {
  position: relative;
}
@media only screen and (max-width: 768px) {
  .item01 .item__ttl {
    left: -3rem;
    top: -1.2rem;
  }
}
.item01 .item__head {
  margin-bottom: 8.6rem;
}
@media only screen and (max-width: 768px) {
  .item01 .item__head {
    margin-bottom: 10rem;
  }
}
.item01 .item__head::after {
  background: #fbfbef;
}
.item01 .item__head-icon {
  position: relative;
}
@media only screen and (max-width: 768px) {
  .item01 .item__head-icon {
    left: 5.2rem;
    top: -0.8rem;
  }
}
.item01 .item__img {
  width: 55.3411rem;
  height: 57.4rem;
  position: relative;
  left: -3rem;
}
@media only screen and (max-width: 768px) {
  .item01 .item__img {
    width: 21rem;
    height: auto;
    top: -3rem;
    left: -6rem;
  }
}
.item01 .item__text img {
  width: 8.95rem;
  height: 29.3rem;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .item01 .item__text img {
    width: 3.5rem;
    height: auto;
  }
}
.item01 .item__text:nth-child(1) img {
  right: -0.4rem;
  top: 0rem;
}
@media only screen and (max-width: 768px) {
  .item01 .item__text:nth-child(1) img {
    right: 9.3rem;
    top: -1rem;
  }
}
.item01 .item__text:nth-child(2) img {
  right: -1.3rem;
  top: 6rem;
}
@media only screen and (max-width: 768px) {
  .item01 .item__text:nth-child(2) img {
    right: 8.4rem;
    top: 0.3rem;
  }
}
.item01 .item__textarea {
  right: -7rem;
  height: 40rem;
}
@media only screen and (max-width: 768px) {
  .item01 .item__textarea {
    bottom: 4rem;
    right: -7.6rem;
    height: auto;
  }
}
.item01 .detail__item--border .detail__link {
  background: #ffff8e;
}
.item01__wrap {
  width: 151.9rem;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .item01__wrap {
    width: 100%;
  }
}
.item01__flex {
  display: flex;
  gap: 14.9rem;
}
@media only screen and (max-width: 768px) {
  .item01__flex {
    flex-direction: column;
    gap: 3.3rem;
  }
}
.item01__img01 {
  width: 78rem;
  height: 96rem;
  position: relative;
  left: -5rem;
}
@media only screen and (max-width: 768px) {
  .item01__img01 {
    width: 31.2rem;
    height: 38.4rem;
    left: 0;
    margin-left: auto;
  }
}
.item01__img02 {
  width: 54rem;
  height: 70rem;
}
@media only screen and (max-width: 768px) {
  .item01__img02 {
    width: 27rem;
    height: 35rem;
  }
}
.item01__box--left {
  margin-top: 34rem;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .item01__box--left {
    margin-top: 0;
  }
}
.item01__box-wrap {
  position: relative;
}
.item01__box-wrap::before {
  content: "";
  width: 87.9rem;
  height: 93.2rem;
  background: rgba(255, 255, 142, 0.6);
  position: absolute;
  top: -18rem;
  left: -21rem;
  z-index: -1;
}
@media only screen and (max-width: 768px) {
  .item01__box-wrap::before {
    width: 31.2rem;
    height: 38.4rem;
    left: 0;
    top: -5rem;
  }
}
.item01__figure01 {
  position: relative;
  z-index: 0;
}
@media only screen and (max-width: 768px) {
  .item01__figure01 {
    text-align: right;
    margin-right: 1.4rem;
  }
}
.item01__text01 {
  position: absolute;
  top: -21rem;
  right: -7rem;
  width: 47.6rem;
  height: 20.1rem;
  z-index: 10;
}
@media only screen and (max-width: 768px) {
  .item01__text01 {
    width: 24.7rem;
    height: auto;
    top: -6rem;
    right: 0.5rem;
  }
}
.item01__textarea {
  width: 45rem;
  margin-bottom: 6.4rem;
}
@media only screen and (max-width: 768px) {
  .item01__textarea {
    width: 30rem;
    margin-bottom: 4rem;
    margin-inline: auto;
  }
}
.item01__figure02 {
  margin-bottom: 4rem;
}
@media only screen and (max-width: 768px) {
  .item01__figure02 {
    margin-bottom: 2.5rem;
  }
}

@media only screen and (max-width: 768px) {
  .item02 {
    margin-bottom: 7.5rem;
  }
}
.item02 .item__number img {
  width: 11.5661rem;
  height: 10.1623rem;
}
@media only screen and (max-width: 768px) {
  .item02 .item__number img {
    width: 4.5rem;
    height: 5.0111rem;
    position: relative;
    left: 2.3rem;
    top: -0.6rem;
  }
}
.item02 .item__ttlarea {
  position: relative;
  top: -8rem;
  left: 8rem;
}
@media only screen and (max-width: 768px) {
  .item02 .item__ttlarea {
    top: 0;
    left: 0;
  }
}
.item02 .item__ttl-en img {
  width: 41.4rem;
  height: 17.2rem;
}
@media only screen and (max-width: 768px) {
  .item02 .item__ttl-en img {
    width: 14.65rem;
    height: 7.0189rem;
    position: relative;
    top: -2.4rem;
    left: 2.6rem;
  }
}
@media only screen and (max-width: 768px) {
  .item02 .item__ttl {
    position: relative;
    top: -2.5rem;
    left: 2rem;
  }
}
.item02 .item__head {
  margin-bottom: 4rem;
}
@media only screen and (max-width: 768px) {
  .item02 .item__head {
    margin-bottom: 2.4rem;
  }
}
.item02 .item__head-icon {
  position: relative;
  top: -7rem;
  left: 10rem;
}
@media only screen and (max-width: 768px) {
  .item02 .item__head-icon {
    top: 0.3rem;
    left: -7.8rem;
  }
}
.item02 .item__head::after {
  background: #f3fbef;
  bottom: 4rem;
}
@media only screen and (max-width: 768px) {
  .item02 .item__head::after {
    bottom: 0;
  }
}
.item02 .item__img {
  width: 50rem;
  height: auto;
  position: relative;
  top: -7rem;
  left: 6rem;
}
@media only screen and (max-width: 768px) {
  .item02 .item__img {
    width: 14.5rem;
    top: -2.7rem;
    left: 4.5rem;
  }
}
.item02 .item__textarea {
  right: inherit;
  left: -16rem;
  top: -4.1rem;
}
@media only screen and (max-width: 768px) {
  .item02 .item__textarea {
    left: -2rem;
    top: -6.7rem;
  }
}
.item02 .item__text:nth-child(1) img {
  width: 9.65rem;
  height: 34.75rem;
}
@media only screen and (max-width: 768px) {
  .item02 .item__text:nth-child(1) img {
    width: 3.5rem;
    height: auto;
  }
}
.item02 .item__text:nth-child(2) img {
  width: 10.5rem;
  height: 40.1rem;
  position: relative;
  top: 8rem;
  left: 4.5rem;
}
@media only screen and (max-width: 768px) {
  .item02 .item__text:nth-child(2) img {
    width: 3.5rem;
    height: auto;
    left: 1.3rem;
    top: 3.4rem;
  }
}
@media only screen and (max-width: 768px) {
  .item02 .item__cont {
    position: relative;
    top: -2rem;
  }
}
.item02 .detail__item--border .detail__link {
  background: #d4f9b8;
}
.item02__wrap {
  width: 141.8rem;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .item02__wrap {
    width: 100%;
  }
}
.item02__flex {
  display: flex;
  gap: 6.84rem;
  justify-content: space-between;
}
@media only screen and (max-width: 768px) {
  .item02__flex {
    flex-direction: column;
    gap: 4.2rem;
  }
}
.item02__box--left {
  margin-top: 4.85rem;
}
@media only screen and (max-width: 768px) {
  .item02__box--left {
    margin-top: 0;
    order: 2;
  }
}
@media only screen and (max-width: 768px) {
  .item02__box--right {
    display: contents;
  }
}
.item02__figure01 {
  position: relative;
  z-index: 10;
  margin-left: 13rem;
}
@media only screen and (max-width: 768px) {
  .item02__figure01 {
    margin-left: 11rem;
  }
}
.item02__img01 {
  width: 44.1556rem;
  height: 58.1rem;
}
@media only screen and (max-width: 768px) {
  .item02__img01 {
    width: 26rem;
    height: 33.4rem;
  }
}
.item02__figure02 {
  margin-top: -5rem;
  position: relative;
  left: 0;
  margin-bottom: 8.4rem;
  z-index: 20;
}
@media only screen and (max-width: 768px) {
  .item02__figure02 {
    margin-bottom: 2.5rem;
    margin-top: -7rem;
  }
}
.item02__img02 {
  width: 32rem;
  height: auto;
}
@media only screen and (max-width: 768px) {
  .item02__img02 {
    width: 19rem;
    height: auto;
    position: relative;
    left: 1rem;
  }
}
.item02__figure03 {
  margin-bottom: 10.43rem;
  position: relative;
  z-index: 0;
}
@media only screen and (max-width: 768px) {
  .item02__figure03 {
    text-align: center;
    margin-bottom: 0rem;
  }
}
.item02__img03 {
  width: 78rem;
  height: 96rem;
}
@media only screen and (max-width: 768px) {
  .item02__img03 {
    width: 34rem;
    height: 41.8462rem;
  }
}
.item02__textarea {
  width: 40.3rem;
  position: relative;
  left: 2rem;
}
@media only screen and (max-width: 768px) {
  .item02__textarea {
    width: 32rem;
    margin-inline: auto;
    left: 0;
    margin-bottom: -0.4rem;
  }
}
.item02__box--left {
  position: relative;
}
.item02__text {
  position: absolute;
  width: 15.4rem;
  height: 78rem;
  top: 7rem;
  left: -11rem;
}
@media only screen and (max-width: 768px) {
  .item02__text {
    width: 7.4rem;
    height: 37.4rem;
    left: 1.6rem;
    top: 1.1rem;
  }
}
@media only screen and (max-width: 768px) {
  .item02 .detail {
    order: 3;
  }
}
.item02__box-wrap {
  position: relative;
}
@media only screen and (max-width: 768px) {
  .item02__box-wrap {
    order: 1;
    width: fit-content;
    margin-inline: auto;
  }
}
.item02__box-wrap::before {
  content: "";
  width: 115.7rem;
  height: 60rem;
  background: #f3fbef;
  position: absolute;
  top: 42.5rem;
  right: -25rem;
  z-index: -1;
}
@media only screen and (max-width: 768px) {
  .item02__box-wrap::before {
    width: 100vw;
    height: 24rem;
    top: 21rem;
    left: -2rem;
  }
}

.item03 {
  margin-bottom: 25rem;
}
@media only screen and (max-width: 768px) {
  .item03 {
    margin-bottom: 4.7rem;
  }
}
.item03 .item__number img {
  width: 11.1661rem;
  height: 10.1623rem;
}
@media only screen and (max-width: 768px) {
  .item03 .item__number img {
    width: 4.5rem;
    height: 5.0111rem;
    position: relative;
    top: 1.3rem;
    left: -4rem;
  }
}
.item03 .item__ttl-en img {
  width: 50.4rem;
  height: 17.2rem;
}
@media only screen and (max-width: 768px) {
  .item03 .item__ttl-en img {
    width: 9.6rem;
    height: 10.4rem;
    position: relative;
    left: 1rem;
    top: -0.6rem;
  }
}
@media only screen and (max-width: 768px) {
  .item03 .item__ttl {
    font-size: 1.2rem;
    position: relative;
    left: -3.7rem;
    top: -1rem;
    line-height: 1.1;
  }
}
.item03 .item__head {
  position: relative;
}
@media only screen and (max-width: 768px) {
  .item03 .item__head {
    left: 0;
    margin-bottom: 2.9rem;
  }
}
.item03 .item__head-icon {
  position: relative;
  left: 5rem;
}
@media only screen and (max-width: 768px) {
  .item03 .item__head-icon {
    left: 6.7rem;
  }
}
.item03 .item__head::after {
  background: #fff6fb;
}
@media only screen and (max-width: 768px) {
  .item03 .item__head::after {
    bottom: -1.5rem;
    height: 24.8rem;
  }
}
.item03 .item__img {
  width: 40.5939rem;
  height: 51.86rem;
  position: relative;
  left: 4rem;
}
@media only screen and (max-width: 768px) {
  .item03 .item__img {
    width: 14.3rem;
    height: auto;
    left: -6rem;
    transform: rotate(355deg);
    top: -1.3rem;
  }
}
@media only screen and (max-width: 768px) {
  .item03 .item__textarea {
    display: flex;
    flex-direction: row-reverse;
    position: absolute;
    bottom: 0;
    right: 0rem;
    top: -4.3rem;
  }
}
.item03 .item__text:nth-child(1) img {
  width: 9.95rem;
  height: 37.4rem;
  position: relative;
  top: -12.8rem;
  right: -12.5rem;
}
@media only screen and (max-width: 768px) {
  .item03 .item__text:nth-child(1) img {
    width: 3.5rem;
    height: auto;
    top: 1rem;
    right: 1rem;
  }
}
.item03 .item__text:nth-child(2) img {
  width: 9.65rem;
  height: 34.75rem;
  position: relative;
  top: -5rem;
  left: 14.4rem;
}
@media only screen and (max-width: 768px) {
  .item03 .item__text:nth-child(2) img {
    width: 3.5rem;
    height: auto;
    top: 4.8rem;
    right: 0.4rem;
    left: inherit;
  }
}
.item03 .detail__item--border .detail__link {
  background: #f6cbe5;
}
.item03__wrap {
  width: 144.6rem;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .item03__wrap {
    width: 100%;
  }
}
.item03__flex {
  display: flex;
  gap: 9.7rem;
}
@media only screen and (max-width: 768px) {
  .item03__flex {
    flex-direction: column;
    gap: 6rem;
  }
}
.item03__figure01 {
  position: relative;
  z-index: 0;
}
@media only screen and (max-width: 768px) {
  .item03__figure02 {
    order: 1;
    text-align: center;
  }
}
.item03__img01 {
  width: 78rem;
  height: 94rem;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .item03__img01 {
    width: 37.5rem;
    height: 45.1923rem;
    aspect-ratio: 39/47;
    left: 0;
  }
}
.item03__img02 {
  width: 56.9886rem;
  height: 49.8432rem;
  position: relative;
  right: 6rem;
}
@media only screen and (max-width: 768px) {
  .item03__img02 {
    width: 32.8255rem;
    height: 28.7097rem;
    right: 0;
    top: 0;
  }
}
.item03__textarea {
  width: 49.4rem;
  margin-bottom: 6.4rem;
  margin-top: 1.2rem;
  margin-left: 2rem;
}
@media only screen and (max-width: 768px) {
  .item03__textarea {
    order: 2;
    margin-top: 2.5rem;
    width: 32rem;
    margin-bottom: 3.9rem;
    margin-left: 3rem;
  }
}
@media only screen and (max-width: 768px) {
  .item03__box--right {
    display: flex;
    flex-direction: column;
  }
}
.item03__text {
  position: absolute;
  bottom: -3rem;
  left: -7rem;
  width: 31.3rem;
  height: 25.6rem;
  z-index: 10;
}
@media only screen and (max-width: 768px) {
  .item03__text {
    width: 13.6rem;
    height: auto;
    bottom: -6.4rem;
    left: 1.8rem;
  }
}
.item03 .detail {
  margin-bottom: 6.4rem;
}
@media only screen and (max-width: 768px) {
  .item03 .detail {
    order: 3;
  }
}
.item03__box-wrap {
  position: relative;
}
.item03__box-wrap::before {
  content: "";
  width: 53.9rem;
  height: 88.6rem;
  background: #fff6fb;
  position: absolute;
  bottom: -4.5rem;
  left: -24rem;
  z-index: -1;
}
@media only screen and (max-width: 768px) {
  .item03__box-wrap::before {
    width: 21.56rem;
    height: 35.44rem;
    left: 0;
    bottom: -3.5rem;
  }
}

.item04 {
  margin-bottom: 26.5rem;
}
@media only screen and (max-width: 768px) {
  .item04 {
    margin-bottom: 11.8rem;
  }
}
.item04 .item__number img {
  width: 11.0661rem;
  height: 10.1623rem;
}
@media only screen and (max-width: 768px) {
  .item04 .item__number img {
    width: 4.5rem;
    height: 5.0111rem;
    position: relative;
    top: -1rem;
    left: 2rem;
  }
}
.item04 .item__ttl-en img {
  width: 66.2rem;
  height: 17.4rem;
}
@media only screen and (max-width: 768px) {
  .item04 .item__ttl-en img {
    width: 17.7rem;
    height: 9.5rem;
    top: -3rem;
    left: 2.7rem;
    position: relative;
  }
}
@media only screen and (max-width: 768px) {
  .item04 .item__ttl {
    position: relative;
    top: -3.2rem;
    left: 1.5rem;
  }
}
.item04 .item__ttlarea {
  position: relative;
  left: 11rem;
  top: 2rem;
}
@media only screen and (max-width: 768px) {
  .item04 .item__ttlarea {
    left: 0;
    top: 0;
  }
}
.item04 .item__head {
  margin-bottom: 19rem;
}
@media only screen and (max-width: 768px) {
  .item04 .item__head {
    margin-bottom: 4.8rem;
  }
}
.item04 .item__head-icon {
  position: relative;
  left: 25rem;
  top: 2rem;
}
@media only screen and (max-width: 768px) {
  .item04 .item__head-icon {
    left: -7.7rem;
    top: -1.6rem;
  }
}
.item04 .item__head::after {
  background: #effafb;
  bottom: -6rem;
}
@media only screen and (max-width: 768px) {
  .item04 .item__head::after {
    bottom: 0;
  }
}
.item04 .item__img {
  width: 45rem;
  height: auto;
  position: relative;
  left: 5rem;
}
@media only screen and (max-width: 768px) {
  .item04 .item__img {
    width: 14.2rem;
    left: 2.9rem;
    top: -3rem;
    transform: rotate(12deg);
  }
}
@media only screen and (max-width: 768px) {
  .item04 .item__textarea {
    right: inherit;
    left: -4.3rem;
    bottom: inherit;
    top: -8rem;
    height: 17rem;
  }
}
.item04 .item__text:nth-child(1) img {
  width: 9.95rem;
  height: 37.5rem;
  position: relative;
  top: -2.6rem;
  left: -43.7rem;
}
@media only screen and (max-width: 768px) {
  .item04 .item__text:nth-child(1) img {
    width: 3.5rem;
    height: auto;
    top: 0rem;
    left: 1rem;
  }
}
.item04 .item__text:nth-child(2) img {
  width: 10.3rem;
  height: 40.2rem;
  position: relative;
  top: 5.3rem;
  left: -39.5rem;
}
@media only screen and (max-width: 768px) {
  .item04 .item__text:nth-child(2) img {
    width: 3.5rem;
    height: auto;
    top: 3rem;
    left: 2.4rem;
  }
}
.item04 .detail__item--border .detail__link {
  background: #d6f4f7;
}
.item04__wrap {
  width: 157.1rem;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .item04__wrap {
    width: 100%;
  }
}
.item04__flex {
  display: flex;
  gap: 11rem;
  justify-content: center;
}
@media only screen and (max-width: 768px) {
  .item04__flex {
    flex-direction: column;
    position: relative;
    z-index: 0;
    gap: 0;
  }
}
.item04__textarea {
  width: 51.54rem;
  margin-bottom: 12.3rem;
  margin-top: 4rem;
  position: relative;
  z-index: 10;
}
@media only screen and (max-width: 768px) {
  .item04__textarea {
    order: 3;
  }
}
@media only screen and (max-width: 768px) and (max-width: 768px) {
  .item04__textarea {
    width: 32rem;
    margin-top: 2.4rem;
    margin-bottom: 4.1rem;
    margin-inline: auto;
    left: 1rem;
  }
}
.item04__img01 {
  width: 52rem;
  height: 66.6rem;
}
@media only screen and (max-width: 768px) {
  .item04__img01 {
    width: 36rem;
    height: 45.5926rem;
    position: relative;
    left: 1rem;
  }
}
.item04__figure01 {
  position: relative;
  z-index: 10;
}
@media only screen and (max-width: 768px) {
  .item04__figure01 {
    order: 2;
  }
}
.item04__figure02 {
  position: relative;
  z-index: 0;
  margin-bottom: 4rem;
  text-align: right;
  z-index: 200 !important;
}
@media only screen and (max-width: 768px) {
  .item04__figure02 {
    order: 1;
    margin-bottom: 2.6rem;
  }
}
.item04__img02 {
  width: 92rem;
  height: 80rem;
}
@media only screen and (max-width: 768px) {
  .item04__img02 {
    width: 34rem;
    height: 29.5652rem;
    aspect-ratio: 23/20;
    margin-left: auto;
  }
}
.item04__box--right {
  position: relative;
}
@media only screen and (max-width: 768px) {
  .item04__box--right {
    display: contents;
  }
}
@media only screen and (max-width: 768px) {
  .item04__box--left {
    display: flex;
    flex-direction: column;
    order: 2;
  }
}
.item04__text {
  position: absolute;
  top: -4rem;
  right: 2rem;
  height: 62.8rem;
  width: 15.4rem;
  z-index: 200;
}
@media only screen and (max-width: 768px) {
  .item04__text {
    width: 6.2rem;
    height: 25.2rem;
    top: -2rem;
    right: 0.5rem;
    order: 3;
  }
}
@media only screen and (max-width: 768px) {
  .item04 .detail {
    order: 4;
  }
}
.item04__box-wrap {
  position: relative;
}
.item04__box-wrap::before {
  content: "";
  width: 109.0909rem;
  height: 80rem;
  opacity: 0.8;
  background: rgba(107, 207, 217, 0.4);
  z-index: -1;
  position: absolute;
  top: -5rem;
  right: 17rem;
}
@media only screen and (max-width: 768px) {
  .item04__box-wrap::before {
    width: 34rem;
    height: 29.6rem;
    top: -2.3rem;
    right: inherit;
    left: 0;
  }
}

.item05 {
  margin-bottom: 24rem;
}
@media only screen and (max-width: 768px) {
  .item05 {
    margin-bottom: 12rem;
  }
}
.item05 .item__cont {
  position: relative;
  left: -15rem;
  top: -2rem;
}
@media only screen and (max-width: 768px) {
  .item05 .item__cont {
    top: 0;
    left: 0;
  }
}
.item05 .item__number img {
  width: 11.4661rem;
  height: 10.1623rem;
}
@media only screen and (max-width: 768px) {
  .item05 .item__number img {
    width: 4.5rem;
    height: 5.0111rem;
    position: relative;
    top: -3rem;
    left: -4rem;
  }
}
.item05 .item__ttl-en img {
  width: 39.4rem;
  height: 17.6rem;
}
@media only screen and (max-width: 768px) {
  .item05 .item__ttl-en img {
    width: 12.375rem;
    height: 6.9891rem;
    position: relative;
    top: -4.6rem;
    left: -4.6rem;
  }
}
@media only screen and (max-width: 768px) {
  .item05 .item__ttl {
    position: relative;
    left: -4rem;
    top: -5rem;
  }
}
.item05 .item__head {
  margin-bottom: 14rem;
}
@media only screen and (max-width: 768px) {
  .item05 .item__head {
    margin-bottom: 2.4rem;
  }
}
.item05 .item__head::after {
  background: #f9f6ff;
}
@media only screen and (max-width: 768px) {
  .item05 .item__head::after {
    height: 20rem;
    bottom: 2.4rem;
  }
}
@media only screen and (max-width: 768px) {
  .item05 .item__head-icon {
    top: -4rem;
    left: 5rem;
    position: relative;
  }
}
.item05 .item__img {
  width: 49.1019rem;
  height: 44.1619rem;
  position: relative;
  left: 5rem;
}
@media only screen and (max-width: 768px) {
  .item05 .item__img {
    width: 17.2rem;
    height: auto;
    left: -9rem;
    top: -5rem;
  }
}
@media only screen and (max-width: 768px) {
  .item05 .item__textarea {
    bottom: 5.7rem;
    right: 1.3rem;
  }
}
.item05 .item__text:nth-child(1) img {
  width: 8.65rem;
  height: 26.6rem;
  position: relative;
  top: -8rem;
  right: -25.8rem;
}
@media only screen and (max-width: 768px) {
  .item05 .item__text:nth-child(1) img {
    width: 3.5rem;
    height: auto;
    top: -2rem;
    right: -0.6rem;
  }
}
.item05 .item__text:nth-child(2) img {
  width: 8.3rem;
  height: 23.8rem;
  position: relative;
  right: -26.5rem;
  top: -3rem;
}
@media only screen and (max-width: 768px) {
  .item05 .item__text:nth-child(2) img {
    width: 3.5rem;
    height: auto;
    top: 0.3rem;
    right: -1.1rem;
  }
}
.item05 .item__text:nth-child(3) img {
  width: 9.95rem;
  height: 37.4rem;
  position: relative;
  top: -8rem;
  right: -28rem;
}
@media only screen and (max-width: 768px) {
  .item05 .item__text:nth-child(3) img {
    width: 3.5rem;
    height: auto;
    top: -2rem;
    right: -2.1rem;
  }
}
.item05 .detail__item--border .detail__link {
  background: #e6dceb;
}
.item05__wrap {
  width: 149.2rem;
  margin-inline: auto;
  position: relative;
  left: 7rem;
  top: 1rem;
}
@media only screen and (max-width: 768px) {
  .item05__wrap {
    width: 100%;
    left: 0;
    top: 0;
  }
}
.item05__flex {
  display: flex;
  gap: 5rem;
  justify-content: center;
}
@media only screen and (max-width: 768px) {
  .item05__flex {
    flex-direction: column;
    gap: 0;
  }
}
.item05__box--left {
  position: relative;
  margin-top: 7.5rem;
}
@media only screen and (max-width: 768px) {
  .item05__box--left {
    order: 2;
    margin-top: 0rem;
  }
}
@media only screen and (max-width: 768px) {
  .item05__box--right {
    display: contents;
  }
}
.item05__text {
  position: absolute;
  top: 0;
  left: -9rem;
  width: 7.7rem;
  height: 74.1rem;
}
@media only screen and (max-width: 768px) {
  .item05__text {
    width: 3.1rem;
    height: 29.6513rem;
    left: 3rem;
  }
}
.item05__figure01 {
  margin-bottom: 15.5rem;
}
@media only screen and (max-width: 768px) {
  .item05__figure01 {
    margin-bottom: 7.1rem;
  }
}
.item05__figure01 {
  position: relative;
  z-index: 0;
}
@media only screen and (max-width: 768px) {
  .item05__figure01 {
    text-align: right;
  }
}
.item05__img01 {
  width: 72.5rem;
  height: 76.7rem;
}
@media only screen and (max-width: 768px) {
  .item05__img01 {
    width: 29rem;
    height: 30.68rem;
    margin-left: auto;
  }
}
.item05__figure02 {
  margin-bottom: 4rem;
  position: relative;
  z-index: 200;
}
@media only screen and (max-width: 768px) {
  .item05__figure02 {
    margin-left: 1.5rem;
    margin-bottom: 2.4rem;
    order: 1;
  }
}
.item05__img02 {
  width: 71.6rem;
  height: 95.5rem;
}
@media only screen and (max-width: 768px) {
  .item05__img02 {
    width: 28.64rem;
    height: 38.2rem;
  }
}
@media only screen and (max-width: 768px) {
  .item05 .detail {
    order: 3;
  }
}
@media only screen and (max-width: 768px) {
  .item05__textarea {
    width: 32.6rem;
    margin-left: 3.2rem;
    margin-bottom: 4rem;
  }
}
.item05__box-wrap {
  position: relative;
}
.item05__box-wrap::before {
  content: "";
  width: 71.6rem;
  height: 95.5rem;
  background: rgba(203, 186, 237, 0.4);
  z-index: -1;
  position: absolute;
  top: -6rem;
  right: -14rem;
}
@media only screen and (max-width: 768px) {
  .item05__box-wrap::before {
    width: 28.64rem;
    height: 38.2rem;
    top: -2.3rem;
    right: 1.5rem;
  }
}
.item05__box-wrap02 {
  position: relative;
}
.item05__box-wrap02::before {
  content: "";
  width: 87.9rem;
  height: 78.4rem;
  background: #f9f6ff;
  position: absolute;
  bottom: -11rem;
  left: -29rem;
  z-index: -1;
}
@media only screen and (max-width: 768px) {
  .item05__box-wrap02::before {
    width: 32.5rem;
    height: 31.3rem;
    bottom: -4.5rem;
    left: 0;
  }
}

.item06 {
  margin-bottom: 31.5rem;
}
@media only screen and (max-width: 768px) {
  .item06 {
    margin-bottom: 12rem;
  }
}
.item06 .item__number img {
  width: 11.1661rem;
  height: 10.1623rem;
}
@media only screen and (max-width: 768px) {
  .item06 .item__number img {
    width: 4.5rem;
    height: 5.0111rem;
    position: relative;
    top: -2rem;
    left: 4rem;
  }
}
.item06 .item__ttl-en img {
  width: 41.4rem;
  height: 16.4rem;
}
@media only screen and (max-width: 768px) {
  .item06 .item__ttl-en img {
    width: 14.5963rem;
    height: 6.9688rem;
    position: relative;
    top: -4rem;
    left: 4rem;
  }
}
@media only screen and (max-width: 768px) {
  .item06 .item__ttl {
    position: relative;
    top: -4.7rem;
    left: 4rem;
  }
}
.item06 .item__head {
  margin-bottom: 12rem;
}
@media only screen and (max-width: 768px) {
  .item06 .item__head {
    margin-bottom: 4.8rem;
  }
}
.item06 .item__head-icon {
  position: relative;
  left: 16rem;
}
@media only screen and (max-width: 768px) {
  .item06 .item__head-icon {
    left: -6rem;
    top: -3rem;
  }
}
.item06 .item__head::after {
  background: #faf5f5;
}
@media only screen and (max-width: 768px) {
  .item06 .item__head::after {
    height: 20.5rem;
    bottom: 1.6rem;
  }
}
.item06 .item__img {
  position: relative;
  left: 9rem;
  top: -1rem;
  width: 36rem;
  height: 50rem;
}
@media only screen and (max-width: 768px) {
  .item06 .item__img {
    width: 12rem;
    height: auto;
    left: 9.5rem;
    top: -6rem;
  }
}
.item06 .item__ttlarea {
  position: relative;
  left: 15rem;
}
@media only screen and (max-width: 768px) {
  .item06 .item__ttlarea {
    left: 0;
  }
}
.item06 .item__main {
  position: relative;
  left: 5rem;
  top: 1rem;
}
@media only screen and (max-width: 768px) {
  .item06 .item__main {
    left: 0;
    top: 0;
  }
}
@media only screen and (max-width: 768px) {
  .item06 .item__textarea {
    bottom: 10rem;
    right: 1rem;
    height: 14rem;
  }
}
.item06 .item__text:nth-child(1) img {
  width: 9.65rem;
  height: 34.7rem;
  position: relative;
  top: -12.5rem;
  left: -33rem;
}
@media only screen and (max-width: 768px) {
  .item06 .item__text:nth-child(1) img {
    width: 3.5rem;
    height: auto;
    top: 0rem;
    left: -0.7rem;
  }
}
.item06 .item__text:nth-child(2) img {
  width: 7.95rem;
  height: 21.1rem;
  position: relative;
  top: -4.5rem;
  left: -31rem;
}
@media only screen and (max-width: 768px) {
  .item06 .item__text:nth-child(2) img {
    width: 3rem;
    height: auto;
    top: 2.3rem;
    left: 0rem;
  }
}
.item06 .item__text:nth-child(3) img {
  width: 9.65rem;
  height: 34.75rem;
  position: relative;
  top: -8rem;
  left: -28.5rem;
}
@media only screen and (max-width: 768px) {
  .item06 .item__text:nth-child(3) img {
    width: 3.5rem;
    height: auto;
    top: 1rem;
    left: 0.8rem;
  }
}
.item06 .detail__item--border .detail__link {
  background: #f7dbdb;
}
.item06__wrap {
  width: 156.2rem;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .item06__wrap {
    width: 100%;
  }
}
.item06__flex {
  display: flex;
  gap: 18.2rem;
  justify-content: center;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .item06__flex {
    flex-direction: column-reverse;
    gap: 7.2rem;
  }
}
.item06__flex::before {
  content: "";
  width: 192rem;
  height: 67.9rem;
  background: #faf5f5;
  position: absolute;
  bottom: -6.4rem;
  left: 50%;
  z-index: -1;
  transform: translateX(-50%);
}
@media only screen and (max-width: 768px) {
  .item06__flex::before {
    bottom: -4.4rem;
  }
}
.item06__figure01 {
  margin-bottom: 4rem;
}
@media only screen and (max-width: 768px) {
  .item06__figure01 {
    padding-inline: 0.5rem;
    margin-bottom: 2.4rem;
  }
}
.item06__img01 {
  width: 50rem;
  height: 70.5714rem;
}
@media only screen and (max-width: 768px) {
  .item06__img01 {
    width: 36rem;
    height: 50.8115rem;
    aspect-ratio: 175/247;
  }
}
.item06__textarea {
  margin-bottom: 6.4rem;
  position: relative;
  left: 2rem;
}
@media only screen and (max-width: 768px) {
  .item06__textarea {
    margin-bottom: 4rem;
    left: 3rem;
  }
}
.item06__figure02 {
  position: relative;
  z-index: 200 !important;
  margin-top: 9rem;
}
@media only screen and (max-width: 768px) {
  .item06__figure02 {
    margin-top: 0rem;
  }
}
.item06__img02 {
  width: 88rem;
  height: 100.6rem;
}
@media only screen and (max-width: 768px) {
  .item06__img02 {
    width: 35.2rem;
    height: 40.24rem;
  }
}
.item06__box--right {
  position: relative;
}
.item06__text {
  position: absolute;
  bottom: 2rem;
  right: -2rem;
  width: 41.2rem;
  height: 15.1rem;
  z-index: 200;
}
@media only screen and (max-width: 768px) {
  .item06__text {
    width: 16.3rem;
    height: 6.2rem;
    bottom: -6rem;
    right: 2rem;
  }
}
.item06 .detail {
  position: relative;
  left: 2rem;
}
@media only screen and (max-width: 768px) {
  .item06 .detail {
    left: 0;
  }
}
.item06__box-wrap::before {
  content: "";
  width: 88rem;
  height: 100.6rem;
  background: rgba(255, 210, 210, 0.4);
  position: absolute;
  top: -9rem;
  right: -13rem;
  z-index: -1;
}
@media only screen and (max-width: 768px) {
  .item06__box-wrap::before {
    width: 32.3rem;
    height: 40.2rem;
    top: -3.8rem;
    right: 0;
  }
}

.item07 {
  margin-bottom: 21rem;
}
@media only screen and (max-width: 768px) {
  .item07 {
    margin-bottom: 9rem;
  }
}
.item07 .item__number img {
  width: 11.1661rem;
  height: 10.2623rem;
}
@media only screen and (max-width: 768px) {
  .item07 .item__number img {
    width: 4.5rem;
    height: 5.011rem;
    position: relative;
    top: 1rem;
    left: -2.6rem;
  }
}
.item07 .item__ttl-en img {
  width: 60rem;
  height: 17.7rem;
}
@media only screen and (max-width: 768px) {
  .item07 .item__ttl-en img {
    width: 17.7rem;
    height: 10.4rem;
    position: relative;
    top: -1.3rem;
    left: -2.3rem;
  }
}
@media only screen and (max-width: 768px) {
  .item07 .item__ttl {
    position: relative;
    top: -1.5rem;
    left: -3rem;
  }
}
.item07 .item__head-icon {
  position: relative;
  left: -6rem;
  top: -1rem;
}
@media only screen and (max-width: 768px) {
  .item07 .item__head-icon {
    left: 5.3rem;
    top: -1rem;
  }
}
.item07 .item__head::after {
  background: #e7f7ef;
}
.item07 .item__img {
  width: 50.6961rem;
  height: 48.3rem;
  position: relative;
  left: -5rem;
  top: -2rem;
}
@media only screen and (max-width: 768px) {
  .item07 .item__img {
    width: 16rem;
    height: auto;
    top: -2rem;
    left: -5.5rem;
  }
}
@media only screen and (max-width: 768px) {
  .item07 .item__textarea {
    right: 2.7rem;
    bottom: 9rem;
  }
}
@media only screen and (max-width: 768px) {
  .item07 .item__head {
    margin-bottom: 3rem;
  }
}
@media only screen and (max-width: 768px) {
  .item07 .item__head::after {
    bottom: 0;
  }
}
.item07 .item__text img {
  width: 8.65rem;
  height: 26.6rem;
  position: relative;
  top: -24rem;
  left: 5rem;
}
@media only screen and (max-width: 768px) {
  .item07 .item__text img {
    width: 3.5rem;
    height: auto;
    top: 2rem;
    left: 2.4rem;
  }
}
.item07 .item__text:nth-child(2) img {
  position: relative;
  top: -20rem;
  left: 6.5rem;
}
@media only screen and (max-width: 768px) {
  .item07 .item__text:nth-child(2) img {
    top: 4rem;
    left: 3rem;
  }
}
.item07 .item__ttlarea {
  position: relative;
  top: -1.5rem;
  left: -8rem;
}
@media only screen and (max-width: 768px) {
  .item07 .item__ttlarea {
    top: 0;
    left: 0;
  }
}
.item07 .detail__item--border .detail__link {
  background: #cef0de;
}
.item07__wrap {
  width: 140.7rem;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .item07__wrap {
    width: 100%;
  }
}
.item07__flex {
  display: flex;
  gap: 6rem;
}
@media only screen and (max-width: 768px) {
  .item07__flex {
    flex-direction: column;
    gap: 0;
    position: relative;
    z-index: 0;
  }
}
.item07__figure01 {
  margin-bottom: 4rem;
  position: relative;
  z-index: 0;
  margin-top: 12rem;
}
@media only screen and (max-width: 768px) {
  .item07__figure01 {
    text-align: right;
    order: 1;
    margin-top: 0;
    left: 2rem;
  }
}
.item07__img01 {
  width: 66rem;
  height: 92rem;
  position: relative;
  left: -2rem;
}
@media only screen and (max-width: 768px) {
  .item07__img01 {
    width: 36rem;
    height: auto;
  }
}
@media only screen and (max-width: 768px) {
  .item07__figure02 {
    order: 2;
  }
}
.item07__img02 {
  width: 44rem;
  height: 56rem;
  height: auto;
  left: -3rem;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .item07__img02 {
    width: 20.7rem;
    height: auto;
    left: 0.6rem;
    top: 1rem;
  }
}
.item07__figure03 {
  margin-bottom: 4rem;
  margin-top: -12rem;
  position: relative;
  right: -3rem;
}
@media only screen and (max-width: 768px) {
  .item07__figure03 {
    order: 3;
    right: -10rem;
    margin-bottom: 1.5rem;
    margin-top: -3.6rem;
  }
}
.item07__img03 {
  width: 41.9524rem;
  height: 58.1rem;
  margin-left: 22rem;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .item07__img03 {
    width: 20.137rem;
    height: auto;
    margin-left: 0;
  }
}
@media only screen and (max-width: 768px) {
  .item07__box {
    display: contents;
  }
}
.item07__box--right {
  position: relative;
}
@media only screen and (max-width: 768px) {
  .item07__textarea {
    order: 4;
    margin-left: 3.2rem;
    margin-bottom: 4rem;
  }
}
.item07__text {
  position: absolute;
  width: 15.4rem;
  height: 86.8rem;
  top: 9rem;
  right: -21.5rem;
  z-index: 200;
}
@media only screen and (max-width: 768px) {
  .item07__text {
    width: 6.2rem;
    height: 34.72rem;
    right: 1rem;
    z-index: 10;
    top: 56rem;
  }
}
.item07 .detail {
  margin-left: 18rem;
}
@media only screen and (max-width: 768px) {
  .item07 .detail {
    order: 5;
    margin-left: 3.2rem;
  }
}
.item07__box-wrap {
  position: relative;
}
.item07__box-wrap::before {
  content: "";
  width: 77rem;
  height: 96rem;
  opacity: 0.6;
  background: #e7f7ef;
  position: absolute;
  top: -11rem;
  left: -25rem;
  z-index: -1;
}
@media only screen and (max-width: 768px) {
  .item07__box-wrap::before {
    width: 32.2987rem;
    height: 40.2685rem;
    left: -2rem;
    top: inherit;
    bottom: -3rem;
  }
}

.item08 {
  margin-bottom: 31rem;
}
@media only screen and (max-width: 768px) {
  .item08 {
    margin-bottom: 12.7rem;
  }
}
.item08 .item__number img {
  width: 11.0661rem;
  height: 10.2623rem;
}
@media only screen and (max-width: 768px) {
  .item08 .item__number img {
    width: 4.5rem;
    height: 5.0111rem;
    position: relative;
    top: 0rem;
    left: 2rem;
  }
}
.item08 .item__ttl-en img {
  width: 54.4rem;
  height: 16.4rem;
}
@media only screen and (max-width: 768px) {
  .item08 .item__ttl-en img {
    width: 10.5rem;
    height: 10.4rem;
    position: relative;
    left: 2.5rem;
    top: -2rem;
  }
}
@media only screen and (max-width: 768px) {
  .item08 .item__ttl {
    position: relative;
    top: -2.3rem;
    left: 2rem;
  }
}
@media only screen and (max-width: 768px) {
  .item08 .item__head {
    margin-bottom: 3.2rem;
  }
}
.item08 .item__head::after {
  background: #fff8f1;
  bottom: 0;
}
.item08 .item__head-icon {
  position: relative;
  left: 17rem;
  top: 1rem;
}
@media only screen and (max-width: 768px) {
  .item08 .item__head-icon {
    left: -8.3rem;
    top: -1.8rem;
  }
}
.item08 .item__img {
  width: 53.6591rem;
  height: 52.1999rem;
  position: relative;
  left: 2rem;
}
@media only screen and (max-width: 768px) {
  .item08 .item__img {
    width: 16.5rem;
    height: auto;
    left: 5.4rem;
    top: -2.8rem;
  }
}
.item08 .item__text img {
  width: 9.65rem;
  height: 34.75rem;
  position: relative;
  left: -53.9rem;
  top: -12.5rem;
}
@media only screen and (max-width: 768px) {
  .item08 .item__text img {
    width: 3.5rem;
    height: auto;
    left: -2rem;
    top: 0rem;
  }
}
.item08 .item__text:nth-child(2) img {
  position: relative;
  left: -50.5rem;
  top: -4.5rem;
}
@media only screen and (max-width: 768px) {
  .item08 .item__text:nth-child(2) img {
    width: 3rem;
    height: auto;
    left: -0.8rem;
    top: 4rem;
  }
}
@media only screen and (max-width: 768px) {
  .item08 .item__textarea {
    bottom: 9rem;
    right: 9rem;
  }
}
.item08 .item__ttlarea {
  position: relative;
  left: 9rem;
}
@media only screen and (max-width: 768px) {
  .item08 .item__ttlarea {
    left: 0;
  }
}
.item08 .detail__item--border .detail__link {
  background: #ffe4c8;
}
.item08__wrap {
  width: 117.1rem;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .item08__wrap {
    width: 100%;
  }
}
.item08__flex {
  display: flex;
  gap: 5rem;
}
@media only screen and (max-width: 768px) {
  .item08__flex {
    flex-direction: column;
    position: relative;
    z-index: 0;
    gap: 0;
  }
}
.item08__textarea {
  position: relative;
  z-index: 10;
}
.item08__figure01 {
  margin-bottom: 17rem;
  position: relative;
  z-index: 0;
  top: 11rem;
}
@media only screen and (max-width: 768px) {
  .item08__figure01 {
    text-align: right;
    top: 0;
    margin-top: 4rem;
    margin-bottom: 4rem;
    width: fit-content;
    margin-left: auto;
  }
}
.item08__img01 {
  width: 48rem;
  height: 68rem;
}
@media only screen and (max-width: 768px) {
  .item08__img01 {
    width: 20.4rem;
    height: 28.9rem;
    aspect-ratio: 12/17;
  }
}
.item08__figure02 {
  margin-bottom: 7.2rem;
  position: relative;
  z-index: 0;
}
@media only screen and (max-width: 768px) {
  .item08__figure02 {
    order: 1;
    margin-bottom: 2.5rem;
  }
}
.item08__img02 {
  width: 64rem;
  height: 88rem;
}
@media only screen and (max-width: 768px) {
  .item08__img02 {
    width: 36rem;
    height: 49.5rem;
    aspect-ratio: 8/11;
  }
}
@media only screen and (max-width: 768px) {
  .item08__box {
    display: contents;
  }
}
.item08__box--left {
  position: relative;
}
@media only screen and (max-width: 768px) {
  .item08__textarea {
    order: 3;
    left: 3.2rem;
    margin-bottom: 4rem;
  }
}
.item08__text {
  position: absolute;
  left: -26rem;
  width: 30.7rem;
  height: 21rem;
  z-index: 10;
  top: 15rem;
  left: -27rem;
}
@media only screen and (max-width: 768px) {
  .item08__text {
    width: 11.9rem;
    height: 9.3rem;
    top: 1rem;
    letter-spacing: 2rem;
    left: 8rem;
    top: 57rem;
  }
}
.item08 .detail {
  position: relative;
  left: 2rem;
}
@media only screen and (max-width: 768px) {
  .item08 .detail {
    order: 4;
    left: 0;
  }
}
.item08__box-wrap {
  position: relative;
}
@media only screen and (max-width: 768px) {
  .item08__box-wrap {
    order: 2;
  }
}
.item08__box-wrap::before {
  content: "";
  position: absolute;
  bottom: -8rem;
  left: -37rem;
  z-index: -1;
  width: 73.4rem;
  height: 64rem;
  background: #fff8f1;
}
@media only screen and (max-width: 768px) {
  .item08__box-wrap::before {
    width: 29.4rem;
    height: 25.6rem;
    bottom: 2.5rem;
    left: 2.4rem;
  }
}
.item08__box-wrap02 {
  position: relative;
}
.item08__box-wrap02::before {
  content: "";
  width: 64rem;
  height: 88rem;
  background: rgba(255, 209, 164, 0.4);
  position: absolute;
  z-index: -1;
  top: 5rem;
  right: -20rem;
}
@media only screen and (max-width: 768px) {
  .item08__box-wrap02::before {
    width: 28.8rem;
    height: 39.6rem;
    right: 0;
    top: inherit;
    bottom: 0;
  }
}

.detail {
  margin-inline: auto;
}
.detail__wrap {
  width: 45.8rem;
}
@media only screen and (max-width: 768px) {
  .detail__wrap {
    width: 32rem;
    margin-inline: auto;
  }
}
.detail__ttl {
  font-size: 1.4rem;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  letter-spacing: 0.112rem;
}
.detail__ttl span {
  font-size: 1.2rem;
}
.detail__item {
  margin-bottom: 0.8rem;
}
.detail__item:last-child {
  margin-bottom: 0;
}
.detail__item--border {
  margin-bottom: 2.5rem;
  padding-bottom: 2.5rem;
  display: block;
  position: relative;
  border: none !important;
  --border-scale: 0;
}
@media only screen and (max-width: 768px) {
  .detail__item--border {
    margin-bottom: 2rem;
    padding-bottom: 1.7rem;
  }
}
.detail__item--border::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #242424;
  transform: scaleX(var(--border-scale));
  transform-origin: left;
  will-change: transform;
}
.detail__flex {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
.detail__price {
  font-size: 1.6rem;
}
@media only screen and (max-width: 768px) {
  .detail__price {
    font-size: 1.4rem;
    white-space: nowrap;
  }
}
.detail__price span {
  font-size: 1rem;
  padding-left: 0.4rem;
}
@media only screen and (max-width: 768px) {
  .detail__price span {
    font-size: 0.9rem;
    padding-left: 0.28rem;
  }
}
.detail__cont {
  display: flex;
  gap: 1.6rem;
  justify-content: flex-end;
  align-items: center;
}
@media only screen and (max-width: 768px) {
  .detail__cont {
    gap: 0.6rem;
  }
}
.detail__cont--first {
  margin-bottom: 1.1rem;
}
@media only screen and (max-width: 768px) {
  .detail__cont--first {
    margin-bottom: 1.2rem;
  }
}
.detail__sizelist {
  display: flex;
  align-items: center;
  gap: 0.8rem;
}
@media only screen and (max-width: 768px) {
  .detail__sizelist {
    gap: 0.4rem;
  }
}
.detail__size {
  font-size: 1rem;
  height: 2rem;
  padding-inline: 0.5rem;
  border: 0.1rem solid;
  line-height: 2rem;
  border-radius: 0.3rem;
  width: 2rem;
  height: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media only screen and (max-width: 768px) {
  .detail__size {
    padding-inline: 0.2rem;
    height: 1.6rem;
    line-height: 1.6rem;
    width: 1.6rem;
  }
}
.detail__size--middle {
  width: 2.4rem;
}
@media only screen and (max-width: 768px) {
  .detail__size--middle {
    width: 2rem;
  }
}
.detail__size--large {
  width: 2.6rem;
}
@media only screen and (max-width: 768px) {
  .detail__size--large {
    width: 2.4rem;
  }
}
.detail__link {
  background-color: var(--baseColor);
  color: var(--baseColor);
  border: 1px solid;
  font-size: 1.1rem;
  width: 7.2rem;
  height: 2.4rem;
  line-height: 1;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media only screen and (max-width: 768px) {
  .detail__link {
    width: 5rem;
    height: 2.4rem;
    font-size: 1rem;
  }
}
.detail__link--border {
  background-color: transparent;
  color: var(--baseColor);
  border: 1px solid;
  transition: 0.5s;
}
.detail__link--cs {
  pointer-events: none;
  color: var(--baseColor);
  background-color: transparent;
  border: none;
}
@media only screen and (max-width: 768px) {
  .detail__link--cs {
    text-align: center;
    line-height: 1.4;
  }
}
.detail__toggle {
  font-size: 1.3rem;
  text-align: center;
  position: relative;
  display: flex;
  justify-content: center;
  gap: 1rem;
  align-items: center;
}
@media only screen and (max-width: 768px) {
  .detail__toggle {
    padding-bottom: 1rem;
    border: none;
    background: none;
    width: 100%;
    color: var(--baseColor);
  }
}
.detail__toggle::after {
  content: "";
  background: url(../images/arrow.webp) no-repeat center center/contain;
  width: 2rem;
  height: 1rem;
  position: relative;
  display: inline-block;
}
.detail__toggle.open {
  margin-bottom: 2rem;
}
.detail__toggle.open::after {
  transform: rotate(180deg);
}

.detail.wh .detail__toggle::after {
  background: url(../images/arrow-w.webp) no-repeat center center/contain;
}

@media only screen and (max-width: 768px) {
  .detail__list .detail__item--border ~ .detail__item {
    display: none;
  }
  .detail__list.open .detail__item--border ~ .detail__item {
    display: block;
  }
}

.other {
  padding-bottom: 16rem;
}
@media only screen and (max-width: 768px) {
  .other {
    padding-bottom: 9.6rem;
  }
}
.other__subttl {
  margin-inline: auto;
  font-family: var(--corm);
  font-size: 2.4rem;
  font-style: italic;
  font-weight: 600;
  line-height: 100%;
  border-radius: calc(infinity * 1px);
  border: 1px solid;
  width: 14.4rem;
  height: 4rem;
  display: flex;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 3.2rem;
}
@media only screen and (max-width: 768px) {
  .other__subttl {
    font-size: 1.2rem;
    margin-bottom: 0.4rem;
    width: 7.2rem;
    height: 2rem;
  }
}
.other__ttlarea {
  margin-bottom: 6.5rem;
  position: relative;
  z-index: 0;
}
@media only screen and (max-width: 768px) {
  .other__ttlarea {
    margin-bottom: 3rem;
  }
}
.other__ttlarea svg {
  z-index: -1;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: -2rem;
}
@media only screen and (max-width: 768px) {
  .other__ttlarea svg {
    width: 21.4112rem;
    height: auto;
    bottom: -1rem;
  }
}
.other__catch {
  position: absolute;
  width: 18.1rem;
  height: 12.35rem;
  top: 1rem;
  right: 23rem;
}
@media only screen and (max-width: 768px) {
  .other__catch {
    width: 9rem;
    height: auto;
    right: 1rem;
    top: 0;
  }
}
.other__ttl {
  text-align: center;
  font-size: 3.4rem;
  font-style: normal;
  font-weight: 700;
  line-height: 3.639rem; /* 107.029% */
  letter-spacing: 0.272rem;
}
@media only screen and (max-width: 768px) {
  .other__ttl {
    font-size: 1.7rem;
    width: 100%;
  }
}
.other__ttl img {
  width: 40.4rem;
  height: 6.5rem;
  display: block;
  margin-inline: auto;
  margin-top: 3.2rem;
}
@media only screen and (max-width: 768px) {
  .other__ttl img {
    width: 20.2rem;
    height: auto;
    margin-top: 0rem;
  }
}
.other__wrap {
  width: 149rem;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .other__wrap {
    width: 100%;
    padding-inline: 0.8rem;
  }
}
.other__box {
  border: 1px solid #000;
  padding: 6.4rem 14rem;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .other__box {
    padding: 3.2rem 0.8rem 4rem;
  }
}
.other__box::before {
  content: "";
  background: url(../images/other__deco01.webp) no-repeat center center/contain;
  width: 20.4881rem;
  height: 4.56rem;
  position: absolute;
  top: -2rem;
  left: 5.6rem;
}
@media only screen and (max-width: 768px) {
  .other__box::before {
    width: 10.2441rem;
    height: 2.28rem;
    transform: rotate(1.252deg);
    top: -1rem;
    left: 1rem;
  }
}
.other__box::after {
  content: "";
  background: url(../images/other__deco02.webp) no-repeat center center/contain;
  width: 20.4881rem;
  height: 4.56rem;
  position: absolute;
  bottom: -2rem;
  right: 5.6rem;
}
@media only screen and (max-width: 768px) {
  .other__box::after {
    width: 10.2441rem;
    height: 2.28rem;
    transform: rotate(1.252deg);
    bottom: -1rem;
    right: 1rem;
  }
}
.other__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4.4rem 8rem;
}
@media only screen and (max-width: 768px) {
  .other__list {
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem 0.8rem;
  }
}
.other__item {
  position: relative;
  display: flex;
  flex-direction: column;
}
.other__item-ttl {
  font-size: 2rem;
  font-style: normal;
  font-weight: 500;
  line-height: 120%; /* 2.4rem */
  letter-spacing: 0.16rem;
  margin-bottom: 1.6rem;
}
@media only screen and (max-width: 768px) {
  .other__item-ttl {
    font-size: 1.1rem;
    margin-bottom: 1rem;
  }
}
.other__temp {
  width: 9.6rem;
  height: 9.6rem;
  position: absolute;
  top: 0;
  left: 0;
}
@media only screen and (max-width: 768px) {
  .other__temp {
    width: 4.4rem;
    height: 4.4rem;
    aspect-ratio: 1/1;
    top: 1rem;
    left: 1rem;
  }
}
.other__cont {
  width: fit-content;
  margin-inline: auto;
  margin-top: 3.2rem;
}
.other__figure {
  width: 35rem;
  height: 32.8rem;
  display: flex;
  justify-content: center;
  align-items: flex-end;
}
@media only screen and (max-width: 768px) {
  .other__figure {
    width: 16.625rem;
    height: 15.58rem;
    margin-bottom: -2rem;
  }
}
.other__img--01 {
  width: 28rem;
  height: 23rem;
}
@media only screen and (max-width: 768px) {
  .other__img--01 {
    width: 13.3rem;
    height: 10.925rem;
    aspect-ratio: 28/23;
  }
}
.other__img--02 {
  width: 24.6429rem;
  height: 26.6991rem;
  transform: rotate(2deg);
}
@media only screen and (max-width: 768px) {
  .other__img--02 {
    width: 11.7054rem;
    height: 12.6821rem;
    aspect-ratio: 12/13;
  }
}
.other__img--03 {
  width: 28rem;
  height: 24.9rem;
}
@media only screen and (max-width: 768px) {
  .other__img--03 {
    width: 13.3rem;
    height: 11.8275rem;
    aspect-ratio: 133/118.28;
  }
}
.other__img--04 {
  width: 20.7599rem;
  height: 27.0361rem;
  transform: rotate(-2deg);
}
@media only screen and (max-width: 768px) {
  .other__img--04 {
    width: 9.8609rem;
    height: 12.8421rem;
    aspect-ratio: 43/56;
  }
}
.other__img--05 {
  width: 17.6rem;
  height: 32rem;
}
@media only screen and (max-width: 768px) {
  .other__img--05 {
    width: 8.36rem;
    height: 15.2rem;
    aspect-ratio: 11/20;
  }
}
.other__img--06 {
  width: 16.9rem;
  height: 32rem;
}
@media only screen and (max-width: 768px) {
  .other__img--06 {
    width: 8.0275rem;
    height: 15.2rem;
    aspect-ratio: 47/89;
  }
}
.other__detail-list {
  display: flex;
  align-items: center;
}
.other__detail-list:not(:last-child) {
  margin-bottom: 0.6rem;
}
.other__size {
  display: flex;
  gap: 0.4rem;
  width: 5.6rem;
  margin-right: 1rem;
}
@media only screen and (max-width: 768px) {
  .other__size {
    width: 3.192rem;
  }
}
.other__size span {
  font-size: 1rem;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  border: 1px solid;
  width: 2rem;
  height: 2rem;
  display: flex;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 0.2rem;
}
@media only screen and (max-width: 768px) {
  .other__size span {
    width: 1.14rem;
    font-size: 0.57rem;
    height: 1.14rem;
    flex-shrink: 0;
    border-radius: 0.15rem;
  }
}
.other__size--large span {
  width: 2.4rem;
  height: 2rem;
}
@media only screen and (max-width: 768px) {
  .other__size--large span {
    width: 1.482rem;
    height: 1.14rem;
  }
}
.other__price {
  font-size: 1.6rem;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  margin-right: 0.5rem;
}
@media only screen and (max-width: 768px) {
  .other__price {
    font-size: 0.912rem;
  }
}
.other__price span {
  font-size: 1rem;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
}
@media only screen and (max-width: 768px) {
  .other__price span {
    font-size: 0.57rem;
  }
}
.other__link {
  font-size: 1.2rem;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  display: flex;
  width: 7.2rem;
  height: 2.6rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  border: 1px solid;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .other__link {
    font-size: 0.684rem;
    width: 4.104rem;
    height: 1.368rem;
  }
}

.fadeup {
  opacity: 0;
  position: relative;
  transform: translateY(2.5rem);
  transition: all 0.8s ease-out;
}

.fadeup.on {
  opacity: 1;
  transform: translateY(0);
}

.faderight {
  opacity: 0;
  position: relative;
  transform: translateX(-3.5rem);
  transition: all 0.8s ease-out;
}

.faderight.on {
  opacity: 1;
  transform: translateX(0);
}

.fadeleft {
  opacity: 0;
  position: relative;
  transform: translateX(3.5rem);
  transition: all 0.8s ease-out;
}

.fadeleft.on {
  opacity: 1;
  transform: translateX(0);
}

.fadedown {
  overflow: hidden;
}

.mask {
  overflow: hidden;
}

.imgSwitch {
  position: relative;
  overflow: hidden;
  z-index: 5;
}

.imgSwitch__img {
  display: block;
}

.imgSwitch__img--over {
  position: absolute;
  inset: 0;
  z-index: 2;
  will-change: transform;
  opacity: 0;
}

/* 共通アニメーションクラス */
.js-reveal-left {
  /* 左右に大きな余白を作り、その分 margin で位置を戻す */
  padding: 100px 200px !important;
  margin: -100px -200px !important;
  /* 初期状態 */
  clip-path: inset(0 100% 0 0);
  visibility: hidden;
  will-change: clip-path; /* 描画を別レイヤーに分離して計算を正確にさせる */
  isolation: isolate;
  z-index: 1;
}

/* アニメーションを適用したい要素に付与 */
.js-reveal-mask {
  clip-path: inset(0 0 100% 0);
  transition: clip-path 1.2s cubic-bezier(0.25, 1, 0.5, 1);
}

.item__box {
  overflow: visible !important;
}

/* アニメーションの初期状態 */
.js-reveal-item {
  clip-path: inset(-500px -500px 100% -500px);
  transition: none;
  visibility: hidden; /* 最初は完全に消しておく */
}

/* アニメーション完了後 */
.js-reveal-item.is-active {
  clip-path: inset(0 -100px 0% 0);
}

/* --- 表示切り替え --- */
.svg-sp {
  display: none;
}

@media screen and (max-width: 768px) {
  .svg-pc {
    display: none;
  }
  .svg-sp {
    display: block;
  }
}
.js-sunrise-item {
  /* 下（100%）に隠しつつ、左右の装飾が欠けないようにマイナス余白を持たせる */
  clip-path: inset(0 -500px 100% -500px);
  /* 最初は完全に透明 & 非表示 */
  auto-alpha: 0;
  visibility: hidden;
}

/* --- 共通アニメーション設定 --- */
.point-svg .draw-line {
  stroke-dasharray: 300;
  stroke-dashoffset: 300;
}

/* 逆方向（下から上ではなく上から下へ）にしたいパス用 */
.point-svg .draw-line.rev {
  stroke-dashoffset: -300;
}

.point-svg .draw-dot {
  opacity: 0;
  transform: scale(0);
}

/* 発火時 */
.point-svg.is-active .draw-line {
  animation: lineAnim 1.2s ease-in-out forwards;
}

.point-svg.is-active .draw-dot {
  animation: dotAnim 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275) 1s forwards;
}

@keyframes lineAnim {
  to {
    stroke-dashoffset: 0;
  }
}
@keyframes dotAnim {
  to {
    opacity: 1;
    transform: scale(1);
  }
}
/* --- PC版：丸の起点 --- */
.svg-01 .draw-dot {
  transform-origin: 4px 103px;
}

.svg-02 .draw-dot {
  transform-origin: 212px 94px;
}

.svg-03 .draw-dot {
  transform-origin: 4px 4px;
}

/* --- スマホ版：丸の起点 --- */
.svg-01-sp .draw-dot {
  transform-origin: 6.5px 67.2px;
} /* ①下側 */
.svg-02-sp .draw-dot {
  transform-origin: 2.2px 29.5px;
} /* ②左側 */
.svg-03-sp .draw-dot {
  transform-origin: 78.2px 2.2px;
} /* ③右側 */
.blur-in {
  filter: blur(20px);
  opacity: 0;
  transition: filter 1.5s ease-out, opacity 1.5s ease-out;
}

.blur-in.active {
  filter: blur(0);
  opacity: 1;
}

/* 基本の状態：透明で、少し下にある */
.fade-list-slow {
  opacity: 0;
  transform: translateY(2.5rem);
  /* 1.5秒かけてじわっと動かす */
  transition: opacity 1.5s ease-out, transform 1.5s ease-out;
}

/* クラス "on" がついた時の状態：不透明になり、元の位置へ */
.fade-list-slow.on {
  opacity: 1;
  transform: translateY(0);
}

/* 左から順番に出現させるための遅延（delay）設定 */
.fade-list-slow:nth-child(1).on {
  transition-delay: 0s;
}

.fade-list-slow:nth-child(2).on {
  transition-delay: 0.3s;
}

.fade-list-slow:nth-child(3).on {
  transition-delay: 0.6s;
}

.fade-list-slow:nth-child(4).on {
  transition-delay: 0.9s;
}

.blur-in-img {
  /* 配置用の transform はそのまま維持される */
  /* 例: transform: translate(-50%, -50%); などが他にあってもOK */
  /* 初期状態：ぼかしと透明度だけ */
  filter: blur(20px);
  opacity: 0;
  /* 2.0秒かけてじんわり */
  transition: filter 1s ease-out, opacity 1s ease-out;
}

.blur-in-img.on {
  filter: blur(0);
  opacity: 1;
}

.reveal-box {
  position: relative;
  display: inline-block; /* または width: 100% */
  overflow: visible !important; /* ここを visible にするのがコツ */
}

.reveal-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #fff; /* 背景と同じ色にする */
  z-index: 10;
  /* 起点を右にする（右に向かって縮むように見せるため） */
  transform-origin: right;
}

/* 共通クラス：初期状態を左端に縮めておく */
.js-wipe-left {
  /* マスクの初期状態（右側を100%削る） */
  clip-path: inset(0 100% 0 0);
  /* 中身の初期状態：少し左に寄せて透明にする */
  opacity: 0;
  will-change: clip-path, transform, opacity;
}

.series__text {
  overflow: hidden;
}

.series__text span {
  display: block;
}

.ttl-img-mask {
  overflow: hidden;
  display: inline-block; /* または block。デザインに合わせて */
  vertical-align: bottom;
}

.series__ttl-img01 {
  transform: translateY(105%); /* 100%より少し多めに下げておく */
  will-change: transform;
}

.series__text span {
  display: block;
  display: block;
  /* ★追加：最初から下に隠しておく */
  transform: translateY(105%);
  will-change: transform;
}

/* 1. 画像を隠す枠 */
.ttl-img-mask {
  display: inline-block; /* 横並びにする場合 */
  overflow: hidden !important; /* はみ出たものは絶対隠す */
  vertical-align: bottom;
  line-height: 1;
}

/* 2. テキストを隠す枠 */
.series__text-mask {
  display: block;
  overflow: hidden !important; /* ここが水平線になります */
}

/* 3. アニメーションする「中身」の初期状態 */
.series__ttl-img01,
.series__text {
  /* 重要：最初から「枠の下」に配置しておく。
     これで JS が読み込まれる前も丸出しになりません。
  */
  transform: translateY(105%);
  will-change: transform;
}

.series__card-link {
  position: relative;
  display: block;
}

/* 商品画像の土台になる色面 */
.series__card-link::before {
  content: "";
  position: absolute;
  top: 0; /* 商品画像が先頭にある前提。違うなら調整 */
  left: 0;
  width: 22rem;
  height: 28rem;
  background: #d9d1c5; /* 好きな色に変更 */
  z-index: 1;
}
@media only screen and (max-width: 768px) {
  .series__card-link::before {
    width: 9.6rem;
    height: 12.2182rem;
  }
}

/* 商品画像 */
.series__card-img {
  position: relative;
  z-index: 2;
  display: block;
  clip-path: inset(0 100% 0 0);
  will-change: clip-path;
  width: 22rem;
  height: 28rem;
}
@media only screen and (max-width: 768px) {
  .series__card-img {
    width: 9.6rem;
    height: 12.2182rem;
  }
}

.series__card-number {
  position: absolute;
  top: 1rem;
  left: 1rem;
  width: 4rem;
  z-index: 10;
  opacity: 0;
  will-change: transform, opacity;
}

.series__card-number-img {
  display: block;
  width: 100%;
}

.series__card-number,
.series__card-ttl,
.series__card-arrow {
  will-change: transform, opacity;
}

.series__card-img {
  will-change: clip-path;
}

.type-mask {
  overflow: hidden !important;
}
.type-mask img {
  transform: translateY(105%);
  will-change: transform;
}

.type-line-mask {
  --mask-pos: 20%;
  overflow: hidden !important;
}
.type-line-mask img {
  clip-path: polygon(0 0, var(--mask-pos) 0, var(--mask-pos) 100%, 0% 100%);
  visibility: hidden;
  /* ❷念のため opacity も 0 に */
  opacity: 0;
  will-change: clip-path, opacity;
}

/* Type01, Type02 共通の初期状態 */
.type__summary {
  opacity: 0;
  transform: translateY(20px);
  will-change: transform, opacity;
}

/* 中のアイコン（子）の設定 */
.type__summary .item__head-icon {
  opacity: 0;
  visibility: hidden;
  /* はみ出し対策でセーフティゾーン(-50px)を作っておく */
  clip-path: inset(-50px 100% -50px -50px);
  will-change: clip-path, opacity;
}

.type__summary svg path {
  /* JSが動くまでのチラつき防止 */
  opacity: 0;
}

/* 最初は少し下げて透明に */
.wardrobe__item-cont {
  opacity: 0;
  transform: translateY(15px);
  will-change: transform, opacity;
}

/* SVGのパスのチラつき防止 */
.wardrobe__item-cont svg path {
  opacity: 0;
}

.item01__box--left,
.item03__box--left,
.item02__box--right,
.item04__box--right {
  position: relative;
}

.item01__box--left::before,
.item03__box--left::after,
.item02__box--right::before,
.item04__box--right::before {
  transform: scaleX(0);
  transform-origin: left top;
  transition: transform 1.5s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: 0.3s;
}

.item01__box--left.is-active::before,
.item03__box--left.is-active::after,
.item02__box--right.is-active::before,
.item04__box--right.is-active::before {
  transform: scaleX(1);
}

.item01__box-wrap {
  position: relative;
}
.item01__box-wrap::before {
  transform: scaleX(0);
  transform-origin: left top;
  transition: transform 1.5s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: 0.3s;
}
.item01__box-wrap.is-active::before {
  transform: scaleX(1);
}

.item02__box-wrap {
  position: relative;
}
.item02__box-wrap::before {
  transform: scaleX(0);
  transform-origin: left top;
  transition: transform 1.5s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: 0.3s;
}
.item02__box-wrap.is-active::before {
  transform: scaleX(1);
}

.item03__box-wrap {
  position: relative;
}
.item03__box-wrap::before {
  transform: scaleX(0);
  transform-origin: left top;
  transition: transform 1.5s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: 0.3s;
}
.item03__box-wrap.is-active::before {
  transform: scaleX(1);
}

.item04__box-wrap {
  position: relative;
}
.item04__box-wrap::before {
  transform: scaleX(0);
  transform-origin: left top;
  transition: transform 1.5s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: 0.3s;
}
.item04__box-wrap.is-active::before {
  transform: scaleX(1);
}

.item05__box-wrap, .item05__box-wrap02 {
  position: relative;
}
.item05__box-wrap::before, .item05__box-wrap02::before {
  transform: scaleX(0);
  transform-origin: left top;
  transition: transform 1.5s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: 0.3s;
}
.item05__box-wrap.is-active::before, .item05__box-wrap02.is-active::before {
  transform: scaleX(1);
}

.item06__box-wrap {
  position: relative;
}
.item06__box-wrap::before {
  transform: scaleX(0);
  transform-origin: left top;
  transition: transform 1.5s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: 0.3s;
}
.item06__box-wrap.is-active::before {
  transform: scaleX(1);
}

.item07__box-wrap {
  position: relative;
}
.item07__box-wrap::before {
  transform: scaleX(0);
  transform-origin: left top;
  transition: transform 1.5s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: 0.3s;
}
.item07__box-wrap.is-active::before {
  transform: scaleX(1);
}

.item08__box-wrap, .item08__box-wrap02 {
  position: relative;
}
.item08__box-wrap::before, .item08__box-wrap02::before {
  transform: scaleX(0);
  transform-origin: left top;
  transition: transform 1.5s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: 0.3s;
}
.item08__box-wrap.is-active::before, .item08__box-wrap02.is-active::before {
  transform: scaleX(1);
}

/* ① 画像ズーム用 */
.hero__wrap img {
  opacity: 0;
  transform: scale(1.1); /* 最初は少しズーム */
  will-change: transform;
}

/* ② タイトル・ロゴ（太陽パターン ＆ ワイプパターン） */
.hero__ttl-img01,
.hero__ttl-img03,
.hero__ttl-img04,
.hero__logo {
  opacity: 0;
  clip-path: inset(100% 0 0 0); /* 下から上へ隠す（太陽） */
  transform: translateY(20px);
}

.hero__ttl-img02,
.hero__ttl-img05,
.hero__list {
  opacity: 0;
  clip-path: inset(0 100% 0 0); /* 右側を100%削る（左からワイプ） */
  transform: translateX(-20px);
}

/* ④ キャッチコピー（上からマスク） */
/* 共通設定 */
.hero__catch span {
  opacity: 0;
  /* 縦書きなので「上からマスク」は clip-path の inset(0 0 100% 0) でOK */
  clip-path: inset(0 0 100% 0);
  will-change: clip-path, opacity, transform;
}

/* ①・② 太陽パターン用（下から） */
.other__subttl, .other__ttl {
  opacity: 0;
  clip-path: inset(100% 0 0 0);
  transform: translateY(20px);
}

/* ③ SVG（最初は隠しておく） */
.other__ttlarea svg {
  /* opacity ではなく visibility を使うのがコツです */
  visibility: hidden;
}

.other__ttlarea svg path {
  /* 念のため、パス自体も透明にしておきます */
  opacity: 0;
}

/* ④ キャッチ（左からワイプ） */
.other__catch {
  opacity: 0;
  clip-path: inset(0 100% 0 0);
  transform: translateX(-20px);
}

/* タイトルエリアとアイコン、両方に同じ初期設定を適用 */
.item__ttlarea,
.item__head-icon {
  position: relative;
  /* 初期状態：隠しておく */
  clip-path: inset(-100px 100% -50px -100px);
  opacity: 0;
  visibility: hidden;
  will-change: clip-path, opacity, transform;
}
/*# sourceMappingURL=style.css.map */
