/* ==========================================
 FV
============================================*/
.fv {
  background-color: #fff7f9;
}

.fv__upper .inner {
  max-width: 1216px;
  padding-inline: 0;
}

.fv__lower {
  background-color: #fff;
  padding-block: var(--sz-60);
}

.fv__desc {
  text-align: center;
  font-size: var(--sz-30);
  font-weight: 700;
  line-height: 1.66;
}
.fv__desc p:last-child {
  margin-bottom: 0;
}

@media screen and (min-width: 992px) {
  .fv__lower {
    padding-block: var(--sz-28) var(--sz-48);
  }
  .fv__desc {
    font-size: var(--sz-25);
    line-height: 1.6;
    letter-spacing: 0.05em;
  }
}
/* ==========================================
 Services
============================================*/
.serivces {
  background-color: #fff7f9;
  background-image: url(../images/bg-services-upper@2x.png), url(../images/bg-services-lower@2x.png);
  background-repeat: no-repeat, no-repeat;
  background-position: top left, bottom right;
  background-size: var(--sz-600);
  padding-block: var(--sz-106) var(--sz-174);
}

.serivces__heading {
  text-align: center;
  font-size: var(--sz-50);
  line-height: 1;
  margin-bottom: var(--sz-50);
}

.services__nav {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sz-28) var(--sz-50);
  margin-bottom: var(--sz-93);
}

.sercices__nav-item {
  filter: drop-shadow(0px var(--sz-4) var(--sz-4) rgba(0, 0, 0, 0.25));
}

.service {
  background-color: #fff;
  padding: var(--sz-48) var(--sz-25) var(--sz-86);
  border: var(--sz-5) solid #ffe0d4;
}

.service + .service {
  margin-top: var(--sz-74);
}

/* service */
.service__heading {
  margin-bottom: var(--sz-39);
}

.service__heading--tailoring {
  width: var(--sz-300);
}

.service__heading--adjustment {
  width: var(--sz-448);
}

.service__heading--washing {
  width: var(--sz-280);
}

.service__heading--redyeing {
  width: var(--sz-280);
}

.service__heading--crest {
  width: var(--sz-253);
}

.service__content {
  font-size: var(--sz-30);
  line-height: 1.66;
  --mb-p: 1.5em;
}

.service__image {
  width: 100%;
  margin-bottom: var(--sz-18);
}

.service__entry {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  width: var(--sz-400);
  margin-top: var(--sz-74);
}

.service__image2 {
  width: 99.53%;
}

.service__image3 {
  width: 46.87%;
}

.service__image4 {
  width: 94.21%;
  margin-inline: auto;
}

.service__media {
  margin-top: var(--sz-70);
}

.service__media-lead {
  text-align: center;
  margin-bottom: var(--sz-18);
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--sz-20);
}

.service__media-lead::before,
.service__media-lead::after {
  content: "";
  width: 1px;
  height: var(--sz-160);
  background-color: #000;
  display: block;
}

.service__media-lead::before {
  rotate: -15deg;
  transform-origin: bottom right;
}

.service__media-lead::after {
  rotate: 15deg;
  transform-origin: bottom left;
}

.service__video {
  margin-bottom: var(--sz-10);
}

.service__media-title {
  font-feature-settings: "palt";
  font-size: var(--sz-20);
  line-height: 1.25;
  padding-left: 2em;
  position: relative;
}

.service__media-title .fa-youtube {
  color: var(--color-red);
  font-size: 150%;
  position: absolute;
  left: 0;
}

/* flow */
:where(#flow).service {
  padding-block: var(--sz-123) var(--sz-109);
  margin-inline: calc(-1 * var(--sz-26));
  border: none;
}

.service__bubble {
  width: var(--sz-258);
}

:where(#flow) .serivce__heading {
  text-align: center;
  font-size: var(--sz-50);
  line-height: 1.2;
  letter-spacing: 0.05em;
  margin-bottom: var(--sz-63);
}

.service__flow {
  display: flex;
  flex-direction: column;
  gap: var(--sz-27);
}

.service__flow-heading {
  font-size: var(--sz-40);
  font-weight: 700;
  line-height: 1.5;
}

.service__flow-desc {
  font-size: var(--sz-25);
  line-height: 1.6;
}

@media screen and (min-width: 992px) {
  .serivces {
    background-color: #fff7f9;
    background-image: url(../images/bg-services-upper.png), url(../images/bg-services-lower.png);
    background-size: var(--sz-999);
    padding-block: var(--sz-134) var(--sz-214);
  }
  .serivces__heading {
    font-size: var(--sz-40);
    line-height: 1.25;
    margin-bottom: var(--sz-50);
  }
  .services__nav {
    display: flex;
    gap: var(--sz-4);
    margin-bottom: var(--sz-47);
  }
  .service {
    padding: var(--sz-30) var(--sz-36) var(--sz-83);
    position: relative;
  }
  .service + .service {
    margin-top: var(--sz-61);
  }
  /* service */
  .service__heading {
    position: absolute;
    top: var(--sz-80);
    left: var(--sz-36);
    margin-bottom: var(--sz-120);
  }
  .service__heading--tailoring {
    width: var(--sz-335);
  }
  .service__heading--adjustment {
    width: var(--sz-426);
  }
  .service__heading--washing {
    width: var(--sz-301);
  }
  .service__heading--redyeing {
    width: var(--sz-267);
  }
  .service__heading--crest {
    width: var(--sz-240);
  }
  .service__content {
    font-size: var(--sz-30);
    line-height: 1.66;
    --mb-p: 1.5em;
  }
  .service__image {
    width: var(--sz-407);
    margin-bottom: var(--sz-27);
    margin-inline: auto 0;
  }
  .service__image2 {
    width: var(--sz-637);
  }
  .service__image3 {
    width: var(--sz-300);
    position: absolute;
    top: var(--sz-1400);
    right: var(--sz-100);
  }
  .service__image4 {
    width: var(--sz-405);
  }
  .service__media {
    margin-top: var(--sz-47);
  }
  .service__media-lead {
    margin-bottom: var(--sz-14);
  }
  .service__video {
    width: var(--sz-632);
    margin-inline: auto;
    margin-bottom: var(--sz-21);
  }
  .service__media-title {
    text-align: center;
    width: -moz-fit-content;
    width: fit-content;
    margin-inline: auto;
  }
  /* flow */
  :where(#flow).service {
    padding-block: var(--sz-44) var(--sz-133);
    margin-inline: unset;
  }
  :where(#flow) .serivce__heading {
    font-size: var(--sz-40);
    line-height: 1.5;
    margin-bottom: var(--sz-37);
  }
  .service__flow-heading {
    font-size: var(--sz-30);
  }
  .service__flow-desc {
    padding-left: 1em;
  }
}
/* ==========================================
 Flow
============================================*/
.flow {
  background-color: #fff;
}

.flow__inner {
  padding-block: var(--sz-30) var(--sz-70);
  padding-inline: var(--sz-20);
  position: relative;
}

.flow__heading {
  color: var(--color-primary);
  font-size: var(--sz-40);
  font-weight: 700;
  line-height: 1.33;
  text-align: center;
}

.flow__list {
  gap: var(--sz-60) var(--sz-25);
  margin-top: var(--sz-60);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}

.flow__item {
  border-radius: var(--sz-10);
  border: 1px solid;
  padding: var(--sz-65) var(--sz-10) var(--sz-40);
  position: relative;
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 3;
  gap: var(--sz-20);
}

.flow__item-idx {
  border-radius: 100vh;
  border: 1px solid;
  background: #fff;
  font-size: var(--sz-30);
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0.75em 1.65em;
  width: -moz-fit-content;
  width: fit-content;
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50% -50%;
}

.flow__item-idx > span {
  font-size: 133%;
}

.flow__item-image {
  width: auto;
  height: var(--sz-166);
}

.flow__item-label {
  color: var(--color-primary);
  font-size: var(--sz-30);
  font-weight: 700;
  line-height: 1.33;
  text-align: center;
}

.flow__item-label > span {
  color: var(--color-accent);
  font-size: 83%;
  font-weight: 700;
  line-height: 1.33;
  display: block;
}

.flow__item-desc {
  margin-bottom: 0;
  text-align: center;
  font-size: var(--sz-25);
  font-weight: bold;
  line-height: 1.4;
}

.flow__annotation {
  font-size: var(--sz-30);
  font-weight: bold;
  line-height: 1.66;
  text-align: center;
  position: absolute;
  bottom: var(--sz-140);
  left: 50%;
  width: -moz-fit-content;
  width: fit-content;
  color: var(--color-accent);
  background: url(../images/bg-bubble.png) no-repeat center/100%;
  aspect-ratio: 541/544;
  display: flex;
  justify-content: center;
  align-items: center;
}

@media screen and (min-width: 992px) {
  .flow__inner {
    padding-block: var(--sz-40) var(--sz-80);
    padding-inline: var(--sz-30);
  }
  .flow__heading {
    font-size: var(--sz-40);
  }
  .flow__list {
    gap: var(--sz-70) var(--sz-30);
    margin-top: var(--sz-130);
    grid-template-columns: repeat(3, 1fr);
  }
  .flow__item {
    padding: var(--sz-75) var(--sz-10) var(--sz-40);
    gap: var(--sz-15);
  }
  .flow__item-idx > span {
    font-size: 133%;
  }
  .flow__item-image {
    height: var(--sz-170);
  }
  .flow__item-label {
    font-size: var(--sz-40);
    line-height: 1.2;
  }
  .flow__item-label > span {
    font-size: 75%;
    line-height: 1.16;
  }
  .flow__item-desc {
    font-size: var(--sz-30);
    line-height: 1.33;
  }
  .flow__annotation {
    font-size: var(--sz-30);
  }
}