@charset "utf-8";

html,
body {
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-optical-sizing: auto;
  line-height: 1.5;
  letter-spacing: 0.15em;
  overflow-x: clip;
  background-color: #fff;
  color: #292929;
  word-break: auto-phrase;
}

html.is-nav-open,
body.is-nav-open {
  overflow: hidden;
  height: 100%;
}

.bg-fix {
  background-image: url("../images/washi-bg.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  font-style: normal;
}

a {
  color: #000;
  text-decoration: none !important;
}

a:hover {
  color: #c3ab13;
  cursor: pointer;
}

/* フォント */

.ave {
  font-family: "Averia Serif Libre", serif;
  font-weight: 700;
  font-style: italic;
}

.sou-han {
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.sou-han-m {
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  font-style: normal;
}

.zen {
  font-family: "zen-kaku-gothic-antique", sans-serif;
  font-weight: 500;
  font-style: normal;
}

.zen-b {
  font-family: "zen-kaku-gothic-antique", sans-serif;
  font-weight: 700;
  font-style: normal;
}

.heisei {
  font-family: "heisei-mincho-std", serif;
  font-weight: 700;
  font-style: normal;
}

.fc-white {
  color: #fff !important;
}

.fc-beige {
  color: #fff9ec !important;
}

.fc-brown {
  color: #5e3505 !important;
}

.fc-red {
  color: #e43905 !important;
}

.fc-pink {
    color: #E38C7B !important;
}

.fc-gray {
  color: #4d4d4d !important;
}

.v-text {
  writing-mode: vertical-rl;
  text-orientation: upright;
  white-space: nowrap;
}

.text-shadow {
  text-shadow: 2px 2px 5px black;
}

.text-shadow-white {
  text-shadow: 2px 2px 5px white;
}

.has-shadow {
  box-shadow: 4px 4px 12px rgba(0, 0, 0, 0.15);
}

/* 背景 */
.bg-white {
  background-color: #fff;
}

.bg-black {
  background-color: #000;
}

.bg-gray {
  background-color: #eeeeee;
}

/*罫線*/
.b-black {
  border: 1px solid #000000;
}

.bl-black {
  border-left: 1px solid #000000;
}

.br-black {
  border-right: 1px solid #000000;
}

.bb-black {
  border-bottom: 1px solid #000000;
}

.bt-black {
  border-bottom: 1px solid #000000;
}

/* ボタン */

.button {
  position: relative;
  display: inline-flex !important;
  background-color: #7e7266;
  width: 270px;
  height: 62px;
  justify-content: space-between;
  align-items: center;
  transition: all 0.3s;
  padding: 1.4rem;
}

.button-2 {
  position: relative;
  display: inline-flex !important;
  background-color: #7e7266;
  width: 100%;
  height: 125px;
  justify-content: space-between;
  align-items: center;
  transition: all 0.3s;
  padding: 1.6rem;
}

.button-3 {
  position: relative;
  display: inline-flex !important;
  background-color: #41382f;
  width: 100%;
  height: 125px;
  justify-content: space-between;
  align-items: center;
  transition: all 0.3s;
  padding: 1.4rem;
}

.button.lani,
.button-2.lani {
  background-color: #c1958d;
  border-radius: 0 20px 0 0;
}

@media (min-width: 768px) {
  .button {
    width: 340px;
  }

  .button-2,
  .button-3 {
    width: 420px;
  }
}

.button::after,
.button-2::after,
.button-3::after {
  content: "";
  width: 22px;
  height: 25px;
  background-image: url(../images/button-deco1.svg);
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  position: absolute;
  top: 50%;
  right: 5%;
  transform: translateY(-50%) rotate(0deg);
  transition: all 0.3s ease-in;
}

.button.lani::after,
.button-2.lani::after {
  background-image: url(../images/button-deco2.svg);
}

.button:hover {
  background-color: #ada25d;
}

.button-2:hover {
  background-color: #41382f;
}

.button-3:hover {
  background-color: #7e7266;
}

.button.lani:hover,
.button-2.lani:hover {
  background-color: #f39d91;
}

.button:hover::after,
.button-2:hover::after,
.button-3:hover::after {
  transform: translateY(-50%) rotate(180deg);
}

.button p {
  color: #fff;
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  font-size: clamp(0.75rem, 0.71rem + 0.18vw, 0.875rem);
  margin: 0 !important;
  padding: 0 !important;
}

.button-box {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 0.4rem;
}

.button-2 .t1,
.button-3 .t1 {
  color: #fff;
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  font-size: clamp(1.5rem, 1.338rem + 0.7vw, 2rem);
  margin: 0 !important;
  padding: 0 !important;
}

.button-2 .t2,
.button-3 .t2 {
  color: #fff;
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  margin: 0 !important;
  padding: 0 !important;
}

.button-n {
  display: inline-flex !important;
  background-color: #7e7266;
  width: 80%;
  height: auto;
  justify-content: space-between;
  align-items: center;
  transition: all 0.3s;
  padding: 2rem 1.4rem;
}

.button-n.line {
  background-color: #4cc764;
  border-radius: 14px;
}

@media (min-width: 768px) {
  .button-n {
    width: 372px;
  }
}

.button-n p {
  font-family: "zen-kaku-gothic-antique", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: clamp(1rem, 0.919rem + 0.35vw, 1.25rem);
  color: #fff;
}

.button-n img {
  width: 38px;
  height: auto;
}

.button-n:hover {
  background-color: #41382f;
}

.inst-btn {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 2.4rem;
  padding: 1.2rem;
  background-color: #FFF;
  border-radius: 20px;
  transition: all 0.3s;
  box-shadow: 2px 2px 12px 0 rgba(0, 0, 0, 0.15);
}

.inst-btn p {
  font-size: clamp(0.875rem, 0.754rem + 0.53vw, 1.25rem);
  color: #4d4d4d;
  font-family: "zen-kaku-gothic-antique", sans-serif;
  font-weight: 500;
}

.inst-btn img {
  width: 40px;
}

.inst-btn:hover {
  background-color: #c1958d;
}

/* ナビ */

.a-nav-menu {
  visibility: hidden;
  opacity: 0;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 900;
  justify-content: center;
  align-items: center;
  transition: all 0.3s;
  background-color: #fff;
  overflow-y: auto;
  padding-block: 85px;
}

@media (min-width: 768px) {
  .a-nav-menu {
    display: flex;
    flex-direction: column;
  }
}

.a-nav-menu.is-active {
  visibility: visible;
  opacity: 1;
}

.a-nav-menu.edit {
  visibility: visible;
  opacity: 1;
}

.nav-menu-box {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
}

@media (min-width: 768px) {
  .nav-menu-box {
    flex-direction: row;
    align-items: stretch;
    justify-content: center;
  }
}

.nav-menu-box .l {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: start;
  background-color: #7e7266;
  gap: 1rem;
  padding: 3rem 3rem;
}

.nav-menu-box .r {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: start;
  background-color: #c1958d;
  gap: 1rem;
  padding: 3rem 3rem;
}

@media (min-width: 768px) {
  .nav-menu-box .l {
    padding: 3.4rem 5rem;
    gap: 1.2;
  }

  .nav-menu-box .r {
    padding: 3.4rem 5rem;
    gap: 1.2;
  }
}

.nav-menu-box .l img {
  width: 100%;
  max-width: 236px;
}

.nav-menu-box .r img {
  width: 100%;
  max-width: 200px;
}

.nav-menu-box .l a,
.nav-menu-box .r a {
  max-height: auto;
  position: relative;
}

.nav-menu-box .l a::before,
.nav-menu-box .r a::before {
  content: "";
  width: 15px;
  height: 1px;
  position: absolute;
  background-color: #fff;
  top: 50%;
  left: 0%;
  transform: translateY(-50%);
}

.nav-menu-box .l a p,
.nav-menu-box .r a p {
  color: #fff;
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  transition: all 0.3s ease;
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  margin-left: 25px;
}

.nav-menu-box .l a:hover p {
  color: #c3ab13;
}

.nav-menu-box .r a:hover p {
  color: #5D432E;
}

.nav-button-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
}

@media (min-width: 768px) {
  .nav-button-box {
    flex-direction: row;
    gap: 2rem;
  }
}

.nav-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 220px;
  padding: 1rem 2rem;
  border: 1px solid #fff;
  background-color: #000;
  transition: all 0.3s ease;
}

.nav-button.w {
  border: 1px solid #000;
  background-color: #fff;
  transition: all 0.3s ease;
}

.nav-button p {
  color: #fff;
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
}

.nav-button.w p {
  color: #000;
}

.nav-button:hover {
  background-color: #716255;
}

.nav-button:hover p {
  color: #fff;
}

.floating-btn {
  position: fixed;
  right: -120px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1000;
}

.floating-btn.edit {
  right: 0px;
}

.floating-btn a {
  display: block;
  margin: 0;
  padding: 0;
}

.floating-btn a img {
  width: 40px;
  height: 160px;
}

@media (min-width: 768px) {
  .floating-btn a img {
    width: 70px;
    height: 284px;
  }
}

.header-wrap {
  position: fixed;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.8rem 0 0 0.8rem;
  z-index: 1000;
}

@media (min-width: 768px) {
  .header-wrap {
    padding: 2rem 0 0 2rem;
  }
}

.a-burger {
  position: relative;
  z-index: 1100;
  border: 1px solid #fff;
  background: rgba(31, 31, 31, 0.3);
  cursor: pointer;
  width: 54px;
  height: 54px;
  margin: 0;
  padding: 0;
}

.a-burger div {
  width: 32px;
  height: 1px;
  background-color: #fff;
  position: absolute;
  left: 11px;
  transform-origin: center;
  transition: all 0.3s;
  padding: 0;
  margin: 0;
  min-height: 1px !important;
}

.a-burger div:nth-child(1) {
  top: 21px;
}

.a-burger div:nth-child(2) {
  bottom: 21px;
}

.a-burger.is-active div:nth-child(1) {
  transform: rotate(-45deg);
  top: 25px;
}

.a-burger.is-active div:nth-child(2) {
  transform: rotate(45deg);
  bottom: 25px;
}

/* フッター */

.foot-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
}

/* ページ共通設定 */

.fv-wrap {
  width: 100%;
  height: 100vh;
  display: flex;
  flex-direction: column-reverse;
  align-items: center;
  justify-content: center;
  margin: auto;
}

@media (min-width: 768px) {
  .fv-wrap {
    height: 100vh;
    flex-direction: row;
  }
}

.fv-wrap .r {
  flex: 1;
  width: 100%;
  height: auto;
  overflow: hidden;
}

.fv-wrap .r img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: left;
}

.fv-wrap .l {
  flex: 0 0 auto;
  width: 100%;
  height: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: linear-gradient(0deg, #fff 0%, #e7ded6 100%);
  gap: 3rem;
  padding: 3rem 0;
}

@media (min-width: 768px) {
  .fv-wrap .r {
    flex: 1.8;
    width: 100%;
    height: 100%;
    overflow: hidden;
  }

  .fv-wrap .l {
    flex: 1;
    width: 100%;
    height: 100%;
    padding: 0 2rem;
    gap: 5rem;
  }
}

@media (min-width: 1200px) {
  .fv-wrap .r {
    flex: 2.5;
  }
}

.fv-wrap .l .text {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.6rem;
}

.fv-wrap .l .text .jp {
  writing-mode: vertical-rl;
  text-orientation: upright;
  white-space: nowrap;
  font-size: clamp(1rem, 0.757rem + 1.05vw, 1.75rem);
  line-height: 1.8;
  letter-spacing: 0.4em;
}

@media (min-width: 768px) {
  .fv-wrap .l .text {
    align-items: center;
    gap: 1.6rem;
  }
}

.fv-wrap .l .text .en {
  font-size: clamp(0.375rem, 0.213rem + 0.7vw, 0.875rem);
}

.fv-wrap .l .logo {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2rem;
}

.fv-wrap .l .logo .ava {
  width: 100%;
  max-width: 264px;
}

.fv-wrap .l .logo .lash {
  width: 100%;
  max-width: 178px;
}

@media (min-width: 768px) {
  .fv-wrap .l .logo {
    gap: 3rem;
  }
}

.fv-sub-wrap {
  width: 100%;
  height: 60vh;
  display: flex;
  align-items: center;
  justify-content: start;
}

.fv-sub-wrap.lash {
  height: 100%;
  justify-content: center;
}

.fv-sub-wrap.lash2 {
  height: 100%;
  justify-content: center;
  flex-direction: column;
}

@media (min-width: 768px) {
  .fv-sub-wrap {
    height: 70vh;
  }
}

.fv-sub-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.4rem;
}

.fv-sub-title img {
  width: 80%;
  max-width: 452px;
}

@media (min-width: 768px) {
  .fv-sub-title {
    gap: 2.4rem;
  }
  .fv-sub-title img {
    width: 100%;
  }
}

.fv-sub-title h1 {
  color: #fff;
  font-size: clamp(1.25rem, 0.805rem + 1.93vw, 2.625rem);
}

.fv-sub-wrap2 {
  width: 100%;
  height: 70vh;
  display: flex;
  flex-direction: column-reverse;
  align-items: center;
  justify-content: center;
}

@media (min-width: 992px) {
  .fv-sub-wrap2 {
    height: 80vh;
    flex-direction: row;
  }
}

.fv-sub-wrap2 .l {
  flex: 0.6;
  height: 100%;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  padding: 1.5rem 0 1.5rem 2rem;
  gap: 0.8rem;
  background-color: #7e7266;
}

.fv-sub-wrap2 .l img {
  width: 40%;
  height: auto;
  max-width: 260px;
}

@media (min-width: 992px) {
  .fv-sub-wrap2 .l {
    flex: 1;
    padding: 1.5rem 0 1.5rem 5rem;
    gap: 1.6rem;
  }

  .fv-sub-wrap2 .l img {
    width: 100%;
  }
}

@media (min-width: 1200px) {
  .fv-sub-wrap2 .l {
    padding: 1.5rem 0 1.5rem 10rem;
  }
}

.fv-sub-wrap2 .l p {
  font-family: "heisei-mincho-std", serif;
  font-weight: 700;
  font-size: clamp(2.25rem, 1.359rem + 3.85vw, 5rem);
  color: #fff;
}

.fv-sub-wrap2 .l h1 {
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  font-size: clamp(0.875rem, 0.754rem + 0.53vw, 1.25rem);
  color: #fff;
}

.fv-sub-wrap2 .r {
  flex: 1;
  overflow: hidden;
  height: 100%;
  width: 100%;
}

.fv-sub-wrap2 .r img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/* プラシバシーポリシー */
.policy-box {
  overflow-y: scroll;
  height: 400px;
  border-radius: 30px;
}

.btn a::after {
  content: "→";
}

/* TOP */

.top-sec2-wrap {
  background-color: #7e7266;
  width: 100%;
  display: flex;
  flex-direction: column;
}

.top-sec2-box1 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

@media (min-width: 768px) {
  .top-sec2-box1 {
    flex-direction: row;
    align-items: stretch;
  }
}

.top-sec2-box1 .l {
  flex: 1;
  overflow: hidden;
}

.top-sec2-box1 .l img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.top-sec2-box1 .r {
  flex: 1.2;
  display: flex;
  align-items: center;
  justify-content: start;
  padding: 2rem 3.4rem;
}

.top-sec2-box1 .r .text {
  font-size: clamp(1rem, 0.757rem + 1.05vw, 1.75rem);
  color: #fff;
}

.top-sec2-box1 .r img {
  width: 100%;
  max-width: 420px;
}

.top-sec2-box2 {
  width: 100%;
  position: relative;
}

.top-sec2-box2 .bg-box {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  background-color: #fff;
}

.top-sec2-con {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 1;
}

@media (min-width: 768px) {
  .top-sec2-box2 .bg-box {
    width: 70%;
  }

  .top-sec2-con {
    flex-direction: row;
    align-items: stretch;
    justify-content: center;
  }
}

.top-sec2-con .l {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 2rem;
  padding: 3rem;
}

.top-sec2-con .l .title {
  font-size: clamp(1.25rem, 1.007rem + 1.05vw, 2rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
}

.top-sec2-con .l .text {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  line-height: 2.8;
}

.top-sec2-con .r {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.2rem;
  padding-bottom: 3rem;
}

.top-sec2-con .r img {
  width: 100%;
  object-fit: contain;
  object-position: center;
  max-width: 486px;
}

@media (min-width: 768px) {
  .top-sec2-con .r {
    padding: 2rem 0;
  }
}

.top-sec3-con {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3rem;
}

@media (min-width: 768px) {
  .top-sec3-con {
    flex-direction: row;
    align-items: stretch;
    justify-content: center;
    gap: 1.2rem;
  }
}

.top-sec3-con .l {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.top-sec3-con .l img {
  width: 100%;
  max-width: 262px;
}

.top-sec3-con .l .title {
  font-size: clamp(1.25rem, 1.088rem + 0.7vw, 1.75rem);
  font-family: "zen-kaku-gothic-antique", sans-serif;
  font-weight: 700;
  text-align: center;
}

.top-sec3-con .l .text {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  line-height: 2.8;
  text-align: center;
}

.top-sec3-con .r {
  flex: 1;
  width: 100%;
  height: auto;
  overflow: hidden;
  border-radius: 0 40px 0 0;
}

.top-sec3-con .r img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/* AVANTE-TOP */

.a-top-sec2-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  background-color: #000;
  overflow: hidden;
  padding-top: 110px;
  padding-bottom: 180px;
}

@media (min-width: 768px) {
  .a-top-sec2-wrap {
    padding-top: 200px;
    padding-bottom: 300px;
  }
}

.a-top-sec2-bg1 {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  z-index: 0;
}

.a-top-sec2-bg2 {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 0;
}

@media (min-width: 768px) {
  .a-top-sec2-bg1 {
    width: 80%;
  }

  .a-top-sec2-bg2 {
    width: 80%;
  }
}

.a-top-sec2-title {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  position: relative;
  z-index: 1;
  gap: 3.4rem;
}

@media (min-width: 768px) {
  .a-top-sec2-title {
    flex-direction: row;
    gap: 1.4rem;
  }
}

.a-top-sec2-title .l {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: start;
  gap: 1rem;
  color: #fff;
}

.a-top-sec2-title .l .en {
  font-size: clamp(1rem, 0.838rem + 0.7vw, 1.5rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
}

.a-top-sec2-title .l .jp {
  font-size: clamp(1.5rem, 1.257rem + 1.05vw, 2.25rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
}

.a-top-sec2-title .r {
  flex: 0.8;
  display: flex;
  align-items: start;
  justify-content: start;
}

.a-top-sec2-title .r p {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 400;
  color: #fff;
}

.a-top-sec3-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, #070707 0%, #7c7c7c 100%);
  gap: 3.6rem;
}

.a-top-sec3-title {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  color: #fff;
  gap: 1rem;
}

@media (min-width: 768px) {
  .a-top-sec3-title {
    display: flex;
    flex-direction: row;
    align-items: end;
    justify-content: start;
    gap: 2rem;
  }
}

.a-top-sec3-title .en {
  font-size: clamp(2.25rem, 1.886rem + 1.58vw, 3.375rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
}

.a-top-sec3-title .jp {
  font-size: clamp(0.75rem, 0.588rem + 0.7vw, 1.25rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
}

.a-top-sec3-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.5rem;
}

@media (min-width: 768px) {
  .a-top-sec3-box {
    flex-direction: row;
  }
}

.a-top-sec3-box .box {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
  overflow: hidden;
  border: 1px #fff solid;
  text-align: center;
  position: relative;
  z-index: 0;
  width: 100%;
}

.a-top-sec3-box .box .bg {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}

.a-top-sec3-box .box .en {
  font-size: clamp(1.5rem, 1.338rem + 0.7vw, 2rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  position: relative;
  z-index: 2;
  color: #fff;
}

.a-top-sec3-box .box .jp {
  font-size: clamp(0.625rem, 0.544rem + 0.35vw, 0.875rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  position: relative;
  z-index: 2;
  color: #fff;
}

.a-top-sec3-box .box .deco {
  width: 22px;
  height: 25px;
  position: relative;
  z-index: 2;
  transition: transform 0.6s ease;
}

/* グラデーション（疑似要素で重ねる） */

.a-top-sec3-box .box::before,
.a-top-sec3-box .box::after {
  content: "";
  position: absolute;
  inset: 0;
  transition: opacity 0.5s ease;
}

/* 初期（濃い） */
.a-top-sec3-box .box::before {
  background: linear-gradient(
    0deg,
    rgba(69, 69, 69, 0.7),
    rgba(69, 69, 69, 0.7)
  );
  opacity: 1;
}

/* ホバー用（薄い） */
.a-top-sec3-box .box::after {
  background: linear-gradient(
    0deg,
    rgba(69, 69, 69, 0.4),
    rgba(69, 69, 69, 0.4)
  );
  opacity: 0;
}

.a-top-sec3-box .box:hover::before {
  opacity: 0;
}

.a-top-sec3-box .box:hover::after {
  opacity: 1;
}

.a-top-sec3-box .box:hover img {
  transform: scale(1.05); /* 20%アップ */
}

.a-top-sec3-box .box:hover .deco {
  transform: rotate(180deg) scale(1.1);
}

.a-top-sec4-box1 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2rem;
}

@media (min-width: 768px) {
  .a-top-sec4-box1 {
    display: flex;
    flex-direction: row;
    align-items: stretch;
  }
}

.a-top-sec4-box1 .l {
  flex: 1;
  overflow: hidden;
}

.a-top-sec4-box1 .r {
  flex: 2;
  overflow: hidden;
}

.a-top-sec4-box1 .l img,
.a-top-sec4-box1 .r img {
  object-fit: cover;
  object-position: center;
  width: 100%;
  height: 100%;
}

.a-top-sec4-box2 {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  gap: 1.4rem;
}

@media (min-width: 768px) {
  .a-top-sec4-box2 {
    display: flex;
    flex-direction: row;
  }
}

.a-top-sec4-box2 .l {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 1.5rem;
}

.a-top-sec4-box2 .l .en {
  font-size: clamp(2.25rem, 1.886rem + 1.58vw, 3.375rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
}

.a-top-sec4-box2 .l .jp {
  font-size: clamp(0.75rem, 0.588rem + 0.7vw, 1.25rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
}

.a-top-sec4-box2 .l .p {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 400;
  line-height: 2.4;
}

.a-top-sec4-box2 .r {
  flex: 1;
  display: flex;
  flex-direction: row;
  align-items: stretch;
  justify-content: center;
  gap: 2rem;
}

@media (min-width: 768px) {
  .a-top-sec4-box2 .r {
    flex-direction: column;
    align-items: stretch;
    justify-content: center;
  }
}

.a-top-sec4-box2 .r .box {
  width: 100%;
  height: auto;
  overflow: hidden;
}

.a-top-sec4-box2 .r .box {
  width: 100%;
  height: auto;
  overflow: hidden;
}

.a-top-sec4-box2 .r .box img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.a-top-sec5-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.9);
  padding: 5rem 0;
  gap: 1.2rem;
  text-align: center;
}

.a-top-sec5-box .en {
  font-size: clamp(2.25rem, 1.886rem + 1.58vw, 3.375rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
}

.a-top-sec5-box .jp {
  font-size: clamp(0.75rem, 0.588rem + 0.7vw, 1.25rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
}

.a-top-sec5-box .p {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 400;
  line-height: 2.4;
}

/* AVANTEコンセプト */

.a-con-sec2-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #000;
}

.a-con-sec2-box1 {
  position: relative;
  z-index: 0;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 2rem;
  padding: 5rem 1rem 0 1rem;
}

.a-con-sec2-box1::before {
  content: "";
  width: 105px;
  height: 105px;
  position: absolute;
  right: 5%;
  top: 0;
  z-index: -1;
  background-image: url(../images/a-con-sec2-no1.svg);
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
}

.a-con-sec2-box1.no2::before {
  left: 5%;
  background-image: url(../images/a-con-sec2-no2.svg);
}

.a-con-sec2-box1.no3::before {
  background-image: url(../images/a-con-sec2-no3.svg);
}

@media (min-width: 768px) {
  .a-con-sec2-box1 {
    flex-direction: row;
    align-items: end;
    padding: 3rem 2rem;
    gap: 3rem;
  }

  .a-con-sec2-box1.no2 {
    flex-direction: row-reverse;
  }

  .a-con-sec2-box1::before {
    content: "";
    width: 165px;
    height: 165px;
    right: 0;
    top: 0;
  }
  .a-con-sec2-box1.no2::before {
    left: 0;
  }
}

@media (min-width: 1200px) {
  .a-con-sec2-box1::before {
    width: 265px;
    height: 265px;
    right: 5%;
  }

  .a-con-sec2-box1.no2::before {
    left: 5%;
  }
}

.a-con-sec2-box1 .l {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 3rem;
}

.a-con-sec2-box1.no2 .l {
  align-items: end;
}

.a-con-sec2-box1 .l h2 {
  position: relative;
  font-size: clamp(1.375rem, 1.092rem + 1.23vw, 2.25rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  color: #fff;
}

.a-con-sec2-box1 .l h2::before {
  content: "";
  width: 200px;
  height: 1px;
  background-color: #fff;
  position: absolute;
  top: 192%;
  right: -26%;
}

.a-con-sec2-box1.no2 .l h2::before {
  left: -26%;
}

@media (min-width: 768px) {
  .a-con-sec2-box1 .l h2::before {
    width: 300px;
    top: 50%;
    transform: translateY(-50%);
    right: -75%;
  }

  .a-con-sec2-box1.no2 .l h2::before {
    left: -75%;
  }
}

@media (min-width: 992px) {
  .a-con-sec2-box1 .l h2::before {
    right: -85%;
  }
  .a-con-sec2-box1.no2 .l h2::before {
    left: -85%;
  }
}

.a-con-sec2-box1 .l img {
  width: 100%;
  height: auto;
}

.a-con-sec2-box1 .r {
  flex: 0.8;
  display: flex;
  align-items: end;
  justify-content: start;
}

.a-con-sec2-box1 .r p {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 400;
  color: #fff;
  line-height: 2.6;
}

.a-con-sec3-wrap {
  background: linear-gradient(180deg, #070707 0%, #7c7c7c 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4.5rem;
}

.a-con-sec3-title {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 0;
}

.a-con-sec3-title::before {
  content: "";
  width: 90%;
  height: 128px;
  max-width: 640px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: -50%;
  z-index: -1;
  background-image: url(../images/a-con-sec3-titledeco.svg);
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
}

@media (min-width: 768px) {
  .a-con-sec3-title::before {
    top: -8%;
  }
}

.a-con-sec3-title h2 {
  color: #fff;
  text-align: center;
  font-size: clamp(1.125rem, 0.761rem + 1.58vw, 2.25rem);
  line-height: 1.8;
}

.a-con-sec3-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.2rem;
  position: relative;
  z-index: 2;
}

@media (min-width: 768px) {
  .a-con-sec3-box {
    flex-direction: row;
    gap: 1rem;
  }
}

.a-con-sec3-box .box {
  flex: 1;
  width: 100%;
  height: 200px;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 0;
  overflow: hidden;
  position: relative;
  padding: 2.4rem 0;
}

.a-con-sec3-box .box img {
  object-fit: cover;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
  width: 100%;
  height: 100%;
}

.a-con-sec3-box .box p {
  font-size: clamp(0.875rem, 0.835rem + 0.18vw, 1rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  color: #fff;
  text-align: center;
}

.a-con-sec3-box2 {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2rem;
}

@media (min-width: 768px) {
  .a-con-sec3-box2 {
    flex-direction: row;
    gap: 3rem;
  }
}

.a-menu-sec2-title {
  color: #7e7266;
  text-align: center;
  font-size: clamp(1.25rem, 0.926rem + 1.4vw, 2.25rem);
  line-height: 1.8;
}

.a-menu-sec2-wrap {
  background-color: #7e7266;
}

.a-menu-sec2-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.a-menu-sec2-box .en {
  color: #fff;
  font-size: clamp(1.25rem, 0.926rem + 1.4vw, 2.25rem);
}

.a-menu-sec2-box .jp {
  color: #fff;
  font-size: clamp(0.625rem, 0.504rem + 0.53vw, 1rem);
}

.a-menu-sec2-flex {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  gap: 1rem;
}

@media (min-width: 992px) {
  .a-menu-sec2-flex {
    flex-direction: row;
    gap: 1.2rem;
  }
}

.a-menu-sec2-flex .box {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  height: 100%;
}

.a-menu-sec2-flex .box .title {
  width: 100%;
  padding: 2rem;
  background-color: #464646;
  color: #fff;
  font-size: clamp(1rem, 0.96rem + 0.18vw, 1.125rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
}

.a-menu-sec2-flex .box .text {
  width: 100%;
  padding: 2rem;
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  background-color: #fff;
  line-height: 1.8;
}

.a-menu-sec3-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.a-menu-sec3-box .en {
  color: #7e7266;
  font-size: clamp(1.25rem, 0.926rem + 1.4vw, 2.25rem);
}

.a-menu-sec3-box .jp {
  color: #7e7266;
  font-size: clamp(0.625rem, 0.504rem + 0.53vw, 1rem);
}

.a-menu-sec3-flex {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  gap: 1rem;
}

.a-menu-sec3-flex .box {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  background: #fff;
  box-shadow: 2px 2px 12px 0 rgba(0, 0, 0, 0.15);
  overflow: hidden;
}

@media (min-width: 768px) {
  .a-menu-sec3-flex .box {
    flex-direction: row;
  }
}

.a-menu-sec3-flex .box .l {
  flex: none;
  width: 100%;
  height: 20vh;
  overflow: hidden;
}

@media (min-width: 768px) {
  .a-menu-sec3-flex .box .l {
    flex: 1;
    height: auto;
  }
}

.a-menu-sec3-flex .box .l img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.a-menu-sec3-flex .box .r {
  flex: 4;
  width: 100%;
  padding: 2rem;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 0.8rem;
}

@media (min-width: 768px) {
  .a-menu-sec3-flex .box .r {
    padding: 2rem 3rem;
  }
}

.a-menu-sec3-flex .box .r .title {
  color: #7e7266;
  font-size: clamp(1rem, 0.757rem + 1.05vw, 1.75rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
}

.a-menu-sec3-flex .box .r .text {
  font-size: clamp(0.625rem, 0.504rem + 0.53vw, 1rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  line-height: 1.8;
}

.a-menu-sec4-wrap {
  background: linear-gradient(180deg, #070707 0%, #7c7c7c 100%);
}

.a-menu-sec4-wrap .title {
  font-size: clamp(1.25rem, 0.926rem + 1.4vw, 2.25rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  color: #fff;
  text-align: center;
}

.a-menu-sec4-wrap .text {
  font-size: clamp(0.875rem, 0.754rem + 0.53vw, 1.25rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  color: #fff;
  text-align: center;
  line-height: 2;
}

.a-menu-sec4-box {
  position: relative;
  border: 1px #fff solid;
  padding: 2.4rem 1.4rem;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 1.5rem;
  max-width: 878px;
}

@media (min-width: 768px) {
  .a-menu-sec4-box {
    padding: 3rem;
    gap: 3rem;
  }
}

.a-menu-sec4-box::after {
  content: "";
  position: absolute;
  width: 270px;
  height: 35px;
  top: 7%;
  right: 5%;
  background-image: url(../images/a-menu-sec3-deco1.svg);
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
}

.a-menu-sec4-box.no2::after {
  background-image: url(../images/a-menu-sec3-deco2.svg);
}

@media (min-width: 768px) {
  .a-menu-sec4-box::after {
    width: 422px;
    height: 64px;
    top: 12%;
    right: 5%;
  }
}

.a-menu-sec4-box .t1 {
  font-size: clamp(1.75rem, 1.588rem + 0.7vw, 2.25rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  color: #fff;
  position: relative;
  z-index: 2;
}

.a-menu-sec4-box .t2 {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 400;
  color: #fff;
  line-height: 2;
  position: relative;
  z-index: 2;
}

/* 整備・修理 */

.a-cust-box {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  gap: 2.4rem;
}

@media (min-width: 768px) {
  .a-cust-box {
    flex-direction: row;
    align-items: center;
    justify-content: stretch;
  }
}

.a-cust-box .l {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 2rem;
}

.a-cust-box .l .title {
  font-size: clamp(1.75rem, 1.588rem + 0.7vw, 2.25rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  color: #fff;
  line-height: 1.8;
}

.a-cust-box .l .text {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 400;
  color: #fff;
  line-height: 2;
}

.a-cust-box .r {
  flex: 1;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  gap: 1rem;
}

.a-cust-box .r .box {
  width: 100%;
  background-color: #fff;
  padding: 1.2rem;
}

.a-cust-box .r .box p {
  font-size: clamp(0.75rem, 0.588rem + 0.7vw, 1.25rem);
  text-align: center;
}

.a-cust-sec3-box1 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2rem;
}

@media (min-width: 992px) {
  .a-cust-sec3-box1 {
    flex-direction: row;
    align-items: stretch;
    justify-content: center;
  }
}

.a-cust-sec3-box1 .l {
  flex: 1.2;
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: start;
  justify-content: center;
}

.a-cust-sec3-box1 .l .en {
  font-size: clamp(0.75rem, 0.588rem + 0.7vw, 1.25rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  color: #7e7266;
}

.a-cust-sec3-box1 .l .jp {
  font-size: clamp(1.75rem, 1.588rem + 0.7vw, 2.25rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  color: #7e7266;
}

.a-cust-sec3-box1 .l .p {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 400;
  line-height: 2;
}

.a-cust-sec3-box1 .box {
  display: flex;
  align-items: center;
  justify-content: start;
  border: #7e7266 solid 0.5px;
  background-color: #fff;
  padding: 1.5rem;
  width: 100%;
}

.a-cust-sec3-box1 .box .t1 {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 400;
  text-align: center;
  white-space: nowrap;
}

.a-cust-sec3-box1 .box .t2 {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 400;
  padding-left: 1.2rem;
  margin-left: 1.2rem;
  border-left: #292929 1px solid;
}

@media (min-width: 992px) {
  .a-cust-sec3-box1 .box {
    padding: 1.5rem 2.5rem;
  }

  .a-cust-sec3-box1 .box .t2 {
    padding-left: 2.5rem;
    margin-left: 2.5rem;
  }
}

.a-cust-sec3-box1 .r {
  flex: none;
  width: 100%;
  height: 30vh;
  overflow: hidden;
}

.a-cust-sec3-box1 .r2 {
  flex: none;
  display: flex;
  flex-direction: row;
  width: 100%;
  height: 30vh;
  overflow: hidden;
}

@media (min-width: 992px) {
  .a-cust-sec3-box1 .r {
    flex: 1;
    height: auto;
  }

  .a-cust-sec3-box1 .r2 {
    flex: 1;
    flex-direction: column;
    height: auto;
  }
}

.a-cust-sec3-box1 .r img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  aspect-ratio: 4 / 3;
  flex: 1;
}

.a-cust-sec3-box1 .r2 img {
  width: auto;
  height: 100%;
  object-fit: cover;
  object-position: center;
  aspect-ratio: 4 / 3;
  flex: 1;
}

@media (min-width: 992px) {
  .a-cust-sec3-box1 .r2 img {
    width: 100%;
    height: auto;
  }
}

.a-cust-sec4-menu {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.a-cust-sec4-menu .title {
  font-size: clamp(1rem, 0.838rem + 0.7vw, 1.5rem);
  text-align: center;
  color: #7e7266;
}

.coat-menu {
  display: flex;
  align-items: center;
  justify-content: start;
  padding: 0.8rem 1.2rem;
  width: 100%;
  background-color: #fbf7f3;
  border: #000 solid 0.5px;
}

.coat-menu.t1 {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 400;
  text-align: center;
  white-space: nowrap;
}

.coat-menu .t2 {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 400;
  padding-left: 1.2rem;
  margin-left: 1.2rem;
  border-left: #292929 1px solid;
}

@media (min-width: 992px) {
  .coat-menu {
    padding: 1.5rem 2.5rem;
  }

  .coat-menu .t2 {
    padding-left: 2.5rem;
    margin-left: 2.5rem;
  }
}

.coat-price {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  width: 100%;
  gap: 0.3rem;
}

@media (min-width: 768px) {
  .coat-price {
    display: flex;
    align-items: center;
    flex-direction: row;
    gap: 0.6rem;
  }
}

.coat-price .box {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.5rem 1.5rem;
  border: #000 0.5px solid;
}

@media (min-width: 768px) {
  .coat-price .box {
    padding: 0.8rem;
  }
}

.coat-price .box .en1 {
  background-color: #ff1313;
  padding: 0.3rem 0.5rem;
  color: #fff;
  font-size: clamp(0.875rem, 0.794rem + 0.35vw, 1.125rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 700;
}

.coat-price .box .en2 {
  background-color: #149c2f;
}

.coat-price .box .en3 {
  background-color: #0095ff;
}

.coat-price .box .t2 {
  font-size: clamp(0.875rem, 0.673rem + 0.88vw, 1.5rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
}

/* 店舗情報 */

.a-store-box {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  gap: 2.4rem;
}

@media (min-width: 768px) {
  .a-store-box {
    flex-direction: row;
    align-items: center;
    justify-content: stretch;
  }
}

.a-store-box .l {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
}

.a-store-box .l .text {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 400;
  line-height: 2.8;
}

.a-store-box .r {
  flex: 1.2;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: stretch;
}

.a-store-box .r img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  object-position: center;
}

.a-store-sec3-wrap {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2.4rem;
  z-index: 0;
}

.a-store-sec3-bg {
  width: 100%;

  background-image: url(../images/a-store-sec3-bg.jpg);
  background-size: cover !important;
  background-repeat: no-repeat !important;
  background-position: center !important;

  background-attachment: fixed;
}

.a-store-sec3-logo {
  width: 60%;
  max-width: 386px;
}

.a-store-sec3-box1 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  max-width: 800px;
}

.a-store-sec3-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.5rem;
  width: 100%;
  background-color: #7e7266;
  padding: 2.4rem 1rem;
}

.a-store-sec3-title.no2 {
  background-color: #41382f;
}

.a-store-sec3-title .t1 {
  font-size: clamp(1rem, 0.676rem + 1.4vw, 2rem);
  color: #fff;
  text-align: center;
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
}

.a-store-sec3-title .t2 {
  font-size: clamp(0.875rem, 0.673rem + 0.88vw, 1.5rem);
  color: #fff;
  text-align: center;
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
}

.a-store-sec3-text {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  width: 100%;
  background-color: #fff;
  padding: 3.5rem 1rem;
}

.a-store-sec3-text .t1 {
  font-size: clamp(0.875rem, 0.754rem + 0.53vw, 1.25rem);
  color: #292929;
  text-align: center;
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  line-height: 2.2;
}

.a-store-sec3-text .t2 {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  color: #292929;
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 400;
}

.a-store-sec3-text .t2.row {
  gap: 0.4rem;
  line-height: 1.8;
  text-align: center;
}

@media (min-width: 768px) {
  .a-store-sec3-text .t2.row {
    text-align: start;
    gap: 0;
  }
}

.map-width {
  width: 100%;
  max-width: 800px;
  max-height: 240px;
}

iframe {
  border: none;
  display: block;
}

/* 求人情報 */

.recru-wrap {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 1.2rem;
  width: 100%;
  max-width: 800px;
}

.recru-title {
  background-color: #7e7266;
  color: #fff;
  padding: 1.2rem;
  font-size: clamp(1.25rem, 0.926rem + 1.4vw, 2.25rem);
  width: 100%;
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
}

.recru-text {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  width: 100%;
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 400;
  line-height: 2;
}

.recru-title2 {
  padding-bottom: 1rem;
  border-bottom: 1px #000 solid;
  width: 100%;
  font-size: clamp(1rem, 0.838rem + 0.7vw, 1.5rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
}

.recru-message {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.recru-message .en {
  color: #7e7266;
  font-size: clamp(0.875rem, 0.754rem + 0.53vw, 1.25rem);
}

.recru-message .jp {
  color: #7e7266;
  font-size: clamp(1.5rem, 1.257rem + 1.05vw, 2.25rem);
}

.recru-message .text {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  line-height: 2.4;
}

/* Lash-Lani TOP */

.l-top-fv-box {
  display: flex;
  flex-direction: column-reverse;
  align-items: stretch;
  justify-content: center;
}

@media (min-width: 768px) {
  .l-top-fv-box {
    flex-direction: row;
  }
}

.l-top-fv-box .l {
  flex: 0.6;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  padding: 1.5rem 0 1.5rem 0;
  gap: 0.8rem;
}

.l-top-fv-box .l img {
  width: 80%;
  height: auto;
  max-width: 260px;
}

@media (min-width: 768px) {
  .l-top-fv-box .l {
    flex: 1;
    padding: 1.5rem 0 1.5rem 3rem;
    gap: 1.6rem;
  }

  .l-top-fv-box .l img {
    width: 100%;
  }
}

@media (min-width: 1200px) {
  .l-top-fv-box .l {
    padding: 1.5rem 0 1.5rem 10rem;
  }
}

.l-top-fv-box .l h1 {
  font-family: "heisei-mincho-std", serif;
  font-weight: 700;
  font-size: clamp(1.875rem, 1.632rem + 1.05vw, 2.625rem);
  color: #4d4d4d;
  line-height: 2.2;
  letter-spacing: 0.15em;
}

.l-top-fv-box .l p {
  font-family: "zen-kaku-gothic-antique", sans-serif;
  font-weight: 500;
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  color: #4d4d4d;
}

.l-top-fv-box .r {
  flex: none;
  overflow: hidden;
  height: 35vh;
  width: 100%;
  border-radius: 0 60px 0 0;
}

.l-top-fv-box .r img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

@media (min-width: 768px) {
  .l-top-fv-box .r {
    flex: 1;
    height: auto;
    width: 100%;
  }
}

.l-top-sec2-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2.4rem;
}

@media (min-width: 768px) {
  .l-top-sec2-box {
    flex-direction: row;
    align-items: stretch;
  }
    .l-top-sec2-box.re {
    flex-direction: row-reverse;
  }
}

.l-top-sec2-box .l {
  flex: none;
  border-radius: 0 40px 0 0;
  box-shadow: 4px 4px 12px 0 rgba(0, 0, 0, 0.15);
  overflow: hidden;
  width: 100%;
  height: 30vh;
}

@media (min-width: 768px) {
  .l-top-sec2-box .l {
  flex: 0.8;
  height: auto;
}
}

.l-top-sec2-box .l img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.l-top-sec2-box .r {
  flex: 1;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 2.4rem;
}

.l-top-sec2-box .r .title {
  font-size: clamp(2.25rem, 1.683rem + 2.45vw, 4rem);
  font-family: "Averia Serif Libre", serif;
  font-weight: 700;
  font-style: italic;
  color: #E38C7B;
}

.l-top-sec2-box .r .t1 {
  font-size: clamp(1.5rem, 1.257rem + 1.05vw, 2.25rem);
  color: #4d4d4d;
}

.l-top-sec2-box .r .t2 {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  color: #4d4d4d;
  font-family: "zen-kaku-gothic-antique", sans-serif;
  font-weight: 500;
  line-height: 2.4;
}

.l-top-sec2-button {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  gap: 3rem;
}

@media (min-width: 768px) {
.l-top-sec2-button {
  flex-direction: row;
}
}

.l-top-sec2-button .box {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.6s ease;
  width: 85%;
}

@media (min-width: 768px) {
  .l-top-sec2-button .box {
    width: 100%;
}
}

.l-top-sec2-button .box img {
  width: 100%;
  height: auto;
  object-fit: contain;
  object-position: center;
}

.l-top-sec2-button .box:hover {
  transform: scale(1.02);
}

.l-top-sec3-img {
  width: 100%;
  height: 30vh;
  overflow: hidden;
  border-radius: 0 0 40px 40px;
  padding: 0%;
  max-height: 394px;
}

@media (min-width: 768px) {
  .l-top-sec3-img {
  height: 40vh;
  border-radius: 0 0 60px 60px;
}
}

.l-top-sec3-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.l-top-sec3-box {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 2rem;
}

@media (min-width: 768px) {
  .l-top-sec3-box {
  flex-direction: row;
  align-items: start;
  gap: 4rem;
}
}

.l-top-sec3-box .box1 {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 1.4rem;
}

.l-top-sec3-box .box2 {
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 1.4rem;
}

.l-top-sec3-box .box1 .title {
  font-size: clamp(2.25rem, 1.683rem + 2.45vw, 4rem);
  font-family: "Averia Serif Libre", serif;
  font-weight: 700;
  font-style: italic;
  color: #E38C7B;
}

.l-top-sec3-box .box2 .t1 {
  font-size: clamp(1rem, 0.919rem + 0.35vw, 1.25rem);
  font-family: "zen-kaku-gothic-antique", sans-serif;
  font-weight: 500;
  color: #4d4d4d;
}

.l-top-sec3-box .box2 .t2 {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  color: #4d4d4d;
  font-family: "zen-kaku-gothic-antique", sans-serif;
  font-weight: 500;
  line-height: 2.4;
}

.l-top-sec4-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 4rem 0;
  gap: 1.5rem;
  text-align: center;
}

.l-top-sec4-box  .en {
  font-size: clamp(2.25rem, 1.886rem + 1.58vw, 3.375rem);
  font-family: "Averia Serif Libre", serif;
  font-weight: 700;
  font-style: italic;
  color: #E38C7B;
}

.l-top-sec4-box  .jp {
  font-size: clamp(0.75rem, 0.588rem + 0.7vw, 1.25rem);
  font-family: "zen-kaku-gothic-antique", sans-serif;
  font-weight: 500;
  color: #4d4d4d;
  line-height: 2.4;
}

.l-top-sec4-box  .p {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  font-family: "zen-kaku-gothic-antique", sans-serif;
  font-weight: 500;
  color: #4d4d4d;
}

.l-top-sec4-box  .title {
  font-size: clamp(1.125rem, 0.761rem + 1.58vw, 2.25rem);
  font-family: "zen-kaku-gothic-antique", sans-serif;
  font-weight: 500;
  color: #4d4d4d;
  line-height: 2.0;
}

/* Lash店舗情報 */

.l-store-sec2 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.8rem;
}

@media (min-width: 768px) {
  .l-store-sec2 {
    flex-direction: row;
    align-items: stretch;
    gap: 0.5rem;
  }
}

.l-store-sec2 .r {
  flex: none;
  border-radius: 0 40px 0 0;
  box-shadow: 4px 4px 12px 0 rgba(0, 0, 0, 0.15);
  overflow: hidden;
  width: 100%;
  height: 30vh;
}

@media (min-width: 768px) {
  .l-store-sec2 .r {
  flex: 0.8;
  height: auto;
}
}

.l-store-sec2 .r img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.l-store-sec2 .l {
  flex: 1;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: center;
  gap: 1.2rem;
}

.l-store-sec2 .l img{
  width: 60%;
  max-width: 320px;
}

.l-store-sec2 .l .t2 {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  color: #4d4d4d;
  font-family: "zen-kaku-gothic-antique", sans-serif;
  font-weight: 500;
  line-height: 2.0;
}

/* LashLaniメニュー */

.l-menu-title {
  font-size: clamp(1.5rem, 1.014rem + 2.1vw, 3rem);
    font-family: "zen-kaku-gothic-antique", sans-serif;
  font-weight: 700;
  color: #E38C7B;
}

.l-menu-box {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  gap: 2.4rem;
}

@media (min-width: 768px) {
  .l-menu-box {
  flex-direction: row;
}
}

.l-menu-box .l {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: start;
  gap: 0.5rem;
}

.l-menu-box .l .title {
  font-size: clamp(1.125rem, 0.761rem + 1.58vw, 2.25rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 700;
}

.l-menu-box .l .title2 {
  font-size: clamp(1rem, 0.838rem + 0.7vw, 1.5rem);
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 500;
  line-height: 2.0;
}

.l-menu-box .l .t1 {
  font-size: clamp(0.75rem, 0.669rem + 0.35vw, 1rem);
  font-family: "zen-kaku-gothic-antique", sans-serif;
  font-weight: 500;
  color: #4d4d4d;
  line-height: 2.0;
}

.l-menu-box .l .t2 {
  font-size: clamp(0.813rem, 0.671rem + 0.61vw, 1.25rem);
  font-family: "zen-kaku-gothic-antique", sans-serif;
  font-weight: 500;
  color: #4d4d4d;
}

.l-menu-box .l .t2 .row {
  gap: 0.4rem;
}

.l-menu-box .r {
  flex: none;
  width: 100%;
  height: 30vh;
  overflow: hidden;
}

@media (min-width: 768px) {
  .l-menu-box .r {
  flex: 1.2;
  height: auto;
}
}

.l-menu-box .r img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}