@charset "UTF-8";
* {
  box-sizing: border-box;
}

html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
figure,
span,
img,
a,
table,
tr,
th,
td {
  margin: 0;
  padding: 0;
  border: 0;
  font-weight: 400;
  vertical-align: baseline;
}

h1, h2, h3, h4, h5, h6 {
  margin: 0;
  padding: 0;
  font-size: 1em; /* フォントサイズをリセット */
}

header,
footer,
nav,
section,
article,
aside,
picture,
figure,
figcaption {
  display: block;
}

body {
  line-height: 1;
}

ol,
ul {
  list-style: none;
  list-style-type: none;
}

ul {
  list-style: none;
}

li {
  list-style-type: none; /*リストマーカー無しにする*/
}

a {
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}

img {
  width: 100%;
  vertical-align: text-bottom;
  vertical-align: -webkit-baseline-middle;
  max-width: 100%;
  height: auto;
}

@media (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}
html {
  font-size: 18px;
}
@media (max-width: 767px) {
  html {
    font-size: 14px;
  }
}

body {
  font-family: "Marcellus", serif;
  color: #333333;
  background: #F9F8F6;
}

.marcellus-regular {
  font-family: "Marcellus", serif;
  font-weight: 400;
  font-style: normal;
}

.parisienne-regular {
  font-family: "Parisienne", cursive;
  font-weight: 400;
  font-style: normal;
}

/*******************************************************************  
* 共通
*******************************************************************/
html {
  scroll-behavior: smooth;
  overflow-x: hidden;
}

.inner {
  width: 84%;
  margin-inline: auto;
}
@media (min-width: 768px) {
  .inner {
    width: 83.3333333333%;
    max-width: 1200px;
  }
}

.u-sp {
  display: block;
}
@media (min-width: 768px) {
  .u-sp {
    display: none !important;
  }
}

.u-pc {
  display: block;
}
@media (max-width: 767px) {
  .u-pc {
    display: none;
  }
}

.title-area {
  position: relative;
  overflow: visible;
}

.title-text {
  position: relative;
  font-family: "Marcellus", serif;
  color: #CA7F13;
  font-size: clamp(28px, 12.8vw, 106px);
  letter-spacing: 0.04em;
}
@media (min-width: 768px) {
  .title-text {
    font-size: clamp(48px, 5.8333333333vw, 84px);
    line-height: 1.2619047619;
  }
}

.title-back-text::after {
  position: absolute;
  font-size: clamp(56px, 19.2vw, 120px);
  color: rgba(202, 127, 19, 0.0784313725);
  font-family: "annabelle-jf", "Parisienne", sans-serif;
  line-height: 1.4027777778;
  white-space: nowrap;
  letter-spacing: normal;
}
@media (min-width: 768px) {
  .title-back-text::after {
    font-size: clamp(72px, 8.3333333333vw, 120px);
    line-height: 1.4;
  }
}

.title-text-jp {
  color: #CA7F13;
  font-family: "游明朝";
  font-size: clamp(12px, 0.9722222222vw, 14px);
  letter-spacing: 0.04em;
}

.fade-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 1s ease, transform 1s ease;
}

.fade-up.is-show {
  opacity: 1;
  transform: translateY(0);
}

.breadcrumb-line {
  height: 100%;
  margin: 0 16px;
}

.lower-title {
  margin-top: clamp(60px, 21.3333333333vw, 173px);
  text-transform: uppercase;
  padding: clamp(84px, 11.1111111111vw, 141px) 0;
  font-size: clamp(32px, 5.5555555556vw, 80px);
  letter-spacing: 0.1em;
  text-align: center;
  color: #CA7F13;
  background: #D4CEBE;
}
@media (min-width: 768px) {
  .lower-title {
    margin-top: clamp(80px, 12.0138888889vw, 172px);
  }
}

.lower-title-img-wrap.fixed {
  position: sticky;
  top: 0;
  z-index: -1;
}

.lower-title-img {
  width: 100%;
  display: block;
}
.lower-title-img img {
  width: 100%;
  height: auto;
  display: block;
}

.ls-main {
  position: relative;
  z-index: 1;
  background: #fff;
}

.breadcrumb-list {
  padding-top: clamp(12px, 1.4583333333vw, 21px);
  margin-left: clamp(15px, 2.5694444444vw, 37px);
}

.breadcrumb-item {
  display: inline;
  color: #CA7F13;
  letter-spacing: 0.1em;
  font-family: "Yu Gothic";
  opacity: 0.8;
}
@media (any-hover: hover) {
  .breadcrumb-item a:hover {
    color: #54372D;
  }
}

.breadcrumb-line {
  display: inline-block;
  width: 1px;
  height: clamp(14px, 1.4583333333vw, 21px);
  margin: 0 10px;
  background: #CA7F13;
  opacity: 0.8;
}
@media (min-width: 768px) {
  .breadcrumb-line {
    margin: -4px 8px;
  }
}

.breadcrumb-link {
  display: inline;
  line-height: 1.7;
}
@media (min-width: 768px) {
  .breadcrumb-link {
    letter-spacing: 0.1em;
  }
}

/* SP */
.u-sp-hide {
  display: none;
}
@media (min-width: 768px) {
  .u-sp-hide {
    display: revert;
  }
}

/* PC → 非表示 */
.u-sp-only {
  display: revert;
}
@media (min-width: 768px) {
  .u-sp-only {
    display: none;
  }
}

/* デフォルト（SP表示） */
.is-sp-only {
  display: table;
}
@media (min-width: 768px) {
  .is-sp-only {
    display: none;
  }
}

/*******************************************************************  
* ヘッダー  
*******************************************************************/
header {
  position: fixed;
  width: 100%;
  z-index: 1000;
  top: 0;
  left: 0;
  padding-top: clamp(20px, 5.3333333333vw, 48px);
}
@media (min-width: 768px) {
  header {
    padding-top: clamp(22px, 3.3333333333vw, 48px);
  }
}

.header__inner {
  display: flex;
  position: relative;
  width: 89.3333333333%;
  margin-inline: auto;
  align-items: center;
  justify-content: space-between;
}
@media (min-width: 768px) {
  .header__inner {
    justify-content: flex-start;
    width: 93.2638888889%;
    max-width: 1343px;
  }
}

.header__logo-link {
  display: flex;
  align-items: center;
  gap: 8px;
}

.logo {
  display: flex;
  gap: 8px;
  transition: all 0.5s ease;
}
@media (any-hover: hover) {
  .logo:hover {
    opacity: 0.7;
  }
}

.logo-img {
  width: clamp(28px, 8.5333333333vw, 48px);
  aspect-ratio: 32/32;
}
@media (min-width: 768px) {
  .logo-img {
    width: clamp(32px, 4.4444444444vw, 64px);
    aspect-ratio: 64/64;
    padding-top: 2px;
  }
}

.header__logo-text {
  margin: 0;
}

.logo-text {
  font-size: 28px;
  line-height: 1.25;
  letter-spacing: 0.2em;
  color: #54372D;
}

.header__list {
  margin: 0;
  padding: 0;
  list-style: none;
}
@media (min-width: 768px) {
  .header__list {
    display: flex;
    align-items: center;
    gap: clamp(18px, 2.0833333333vw, 30px);
    margin-top: -2px;
    margin-left: auto;
    margin-right: 2px;
  }
}

.header__item {
  color: #54372D;
}
.header__item:nth-child(3) {
  transform: translateX(-1px);
}

.header__link {
  text-decoration: none;
  transition: all 0.5s ease;
}
@media (min-width: 768px) {
  .header__link {
    display: block;
    font-size: 20px;
    letter-spacing: 0.1em;
    line-height: 1;
  }
}
@media (any-hover: hover) {
  .header__link:hover {
    color: #CA7F13;
  }
}

@media (min-width: 768px) {
  .header__item-icon {
    position: relative;
    left: -16px;
  }
}

@media (min-width: 768px) {
  .header__btn-text {
    display: inline-flex;
    align-items: center;
    padding: 15px 37px;
    background: #949E33;
    border-radius: 40px;
    color: #fff;
    font-family: "游明朝";
    font-weight: 600;
    font-size: 20px;
    line-height: 1;
    white-space: nowrap;
    gap: clamp(18px, 2.3611111111vw, 34px);
  }
}
@media (any-hover: hover) {
  .header__btn-text:hover {
    background: #54372D;
    color: #fff;
  }
}

@media (min-width: 768px) {
  .header__btn-label {
    position: relative;
    left: -27px;
    top: -1px;
  }
}

/*******************************************************************  
* ハンバーガーメニュー  
*******************************************************************/
.c-button {
  display: inline-block;
  text-decoration: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  background-color: transparent;
  cursor: pointer;
  z-index: 1000;
  padding: 9px;
}

.p-hamburger {
  display: flex;
  align-items: center;
  gap: 7px;
  position: relative;
  top: -1px;
  left: -1px;
  right: 0;
  margin: 0;
  width: clamp(100px, 26.6666666667vw, 130px);
  height: clamp(30px, 8vw, 40px);
  border-radius: 40px;
  background: #949E33;
  box-shadow: 0 0 2rem transparent;
  outline: none;
  transition: all 0.3s ease-in-out;
  color: #fff;
}
@media (min-width: 768px) {
  .p-hamburger {
    display: none;
  }
}

.p-hamburger[aria-expanded=true] {
  width: clamp(30px, 8vw, 40px);
}

.p-hamburger__text {
  font-size: clamp(12px, 3.4666666667vw, 13px);
  letter-spacing: 2px;
  font-family: "游明朝";
  font-weight: 600;
  margin-left: clamp(1px, 0.2666666667vw, 11px);
}

.p-hamburger__text.is-active {
  display: none;
}

.p-hamburger:hover,
.p-hamburger:focus {
  box-shadow: 0 0 0.5rem rgba(255, 255, 255, 0.5);
}

.p-hamburger:focus-visible {
  box-shadow: 0 0 0.5rem rgba(255, 255, 255, 0.8);
  outline: 2px solid #949E33;
}

.p-hamburger__line {
  position: relative;
  top: -1px;
  left: clamp(0px, 0px + 2 * (100vw - 320px) / 55, 2px);
  margin: auto;
  width: 12px;
  height: 1px;
  background-color: #fff;
  transition: inherit;
}

.p-hamburger__line::before,
.p-hamburger__line::after {
  position: absolute;
  display: block;
  width: 12px;
  height: 1px;
  background-color: #fff;
  content: "";
  transition: inherit;
}

.p-hamburger__line::before {
  top: clamp(11px, 2.9333333333vw, 15px);
  top: 4px;
}

.p-hamburger__line::after {
  top: clamp(19px, 5.0666666667vw, 25px);
  top: -4px;
}

.p-hamburger[aria-expanded=true] .p-hamburger__line {
  background-color: transparent;
}

.p-hamburger[aria-expanded=true] .p-hamburger__line::before,
.p-hamburger[aria-expanded=true] .p-hamburger__line::after {
  background-color: #fff;
  top: 0;
}

.p-hamburger[aria-expanded=true] .p-hamburger__line::before {
  transform: rotate(45deg);
}

.p-hamburger[aria-expanded=true] .p-hamburger__line::after {
  transform: rotate(-45deg);
}

.u-visuallyHidden {
  position: absolute;
  white-space: nowrap;
  width: 1px;
  height: 1px;
  overflow: hidden;
  border: 0;
  padding: 0;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  margin: -1px;
}

.c-navigation {
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  visibility: hidden;
  background: #D4CEBE;
  transition: opacity 0.3s ease-in-out, visibility 0.3s ease-in-out;
}

.c-navigation.is-active {
  opacity: 1;
  z-index: 100;
  visibility: visible;
}

.c-navigation__list {
  list-style: none;
  display: block;
  padding: 144px 60px;
  margin: 0;
}

.c-navigation__item {
  margin-bottom: 19px;
}

.c-navigation__link {
  display: block;
  color: #CA7F13;
  text-decoration: none;
  font-size: 24px;
  letter-spacing: 0.1em;
  font-family: "Marcellus", serif;
  text-transform: uppercase;
}

.c-navigation__link:hover {
  background-color: #949E33;
}

/*******************************************************************  
* フッター  
*******************************************************************/
footer {
  background: #fff;
}

.footer__inner {
  padding-top: clamp(102px, 8.3333333333vw, 120px);
  margin-inline: auto;
  position: relative;
}

.footer__logo {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-left: 29px;
}
@media (min-width: 768px) {
  .footer__logo {
    justify-content: center;
    margin-left: 0;
  }
}

.footer__logo-img {
  width: 50px;
  aspect-ratio: 50/50;
  padding-bottom: 5px;
}
@media (min-width: 768px) {
  .footer__logo-img {
    width: 64px;
    aspect-ratio: 64/64;
  }
}

.footer__logo-text {
  font-size: clamp(20px, 1.9444444444vw, 28px);
  letter-spacing: 0.2em;
  line-height: 1.4;
  color: #54372D;
}
@media (min-width: 768px) {
  .footer__logo-text {
    line-height: 1.25;
    transform: translateX(5px);
  }
}

.footer__nav {
  margin-top: clamp(39px, 3.1944444444vw, 46px);
}

.footer__nav-list,
.footer__sub-list {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  row-gap: clamp(6px, 0.5555555556vw, 8px);
  padding: 0;
  margin: 0;
  list-style: none;
}

@media (min-width: 768px) {
  .footer__nav-list {
    flex-wrap: nowrap;
  }
}

.footer__item--main:first-child {
  text-transform: uppercase;
}
@media (min-width: 768px) {
  .footer__item--main:first-child .footer__link {
    transform: translateX(3px);
  }
}
@media (min-width: 768px) {
  .footer__item--main:nth-child(2) {
    margin-left: 10px;
  }
}
.footer__item--main:nth-child(5) {
  margin-left: 20px;
}
@media (min-width: 768px) {
  .footer__item--main:nth-child(5) {
    margin-left: 0;
  }
}

.footer__sub-list {
  margin-top: 32px;
}
@media (min-width: 768px) {
  .footer__sub-list {
    margin-top: 33px;
  }
}

.footer__break {
  flex-basis: 100%;
  height: 0;
}
@media (min-width: 768px) {
  .footer__break {
    flex-basis: auto;
    display: flex;
    align-items: center;
  }
  .footer__break::before {
    content: "";
    width: 1px;
    height: 24px;
    margin-left: 27px;
    margin-right: 34px;
    background: #54372D;
  }
}

.footer__item {
  display: flex;
  align-items: center;
}
.footer__item:not(.footer__break) + .footer__item:not(.footer__break)::before {
  content: "";
  width: 1px;
  height: clamp(17px, 1.6666666667vw, 24px);
  display: inline-block;
  margin-left: 11px;
  margin-right: 11px;
  background: #54372D;
}
@media (min-width: 768px) {
  .footer__item:not(.footer__break) + .footer__item:not(.footer__break)::before {
    margin-left: 30px;
    margin-right: 31px;
  }
}

.footer__link {
  font-size: clamp(14px, 1.3888888889vw, 20px);
  letter-spacing: 0.1em;
  transition: all 0.5s ease;
  color: #54372D;
}
@media (any-hover: hover) {
  .footer__link:hover {
    color: #CA7F13;
  }
}

.footer__btn {
  position: absolute;
  right: -5px;
  bottom: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: clamp(40px, 5.5555555556vw, 80px);
  height: clamp(40px, 5.5555555556vw, 80px);
  background: #949E33;
  border-radius: 40px;
}
@media (min-width: 768px) {
  .footer__btn {
    right: clamp(-79px, -35px + -44 * (100vw - 768px) / 672, -35px);
    bottom: 25px;
  }
}

.footer__btn-icon {
  color: #fff;
  font-size: clamp(24px, 3.125vw, 45px);
}

.footer__copy {
  margin-top: clamp(40px, 3.8194444444vw, 55px);
  padding-bottom: clamp(8px, 2.2222222222vw, 32px);
  font-size: clamp(8px, 3.2vw, 12px);
  letter-spacing: 0.1em;
  white-space: nowrap;
  text-align: center;
  color: #54372D;
}

.footer__btn {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 100;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.5s ease, visibility 0.5s ease;
}
@media (min-width: 768px) {
  .footer__btn {
    right: 30px;
    bottom: 30px;
  }
}
.footer__btn.is-show {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/*******************************************************************  
* First View
*******************************************************************/
.fv {
  position: relative;
  background-image: url("../img/fv_bg-sp.webp");
  background-size: cover;
  background-position: right center;
  background-repeat: no-repeat;
  height: 809px;
}
@media (min-width: 768px) {
  .fv {
    background-image: url("../img/fv_bg-pc.webp");
    height: 900px;
  }
}

@media (min-width: 768px) {
  .fv__inner {
    width: 100%;
  }
}

.fv__text {
  position: absolute;
  bottom: clamp(250px, 72.5333333333vw, 272px);
  left: clamp(14px, 3.7333333333vw, 70px);
  font-family: "游明朝";
  color: #fff;
  font-size: clamp(32px, 8.5333333333vw, 48px);
  line-height: 1.5;
  letter-spacing: 0.1em;
  font-weight: 300;
  text-shadow: 4px 4px 10px rgba(0, 0, 0, 0.1607843137);
}
@media (min-width: 768px) {
  .fv__text {
    line-height: 1.5;
    text-shadow: none;
    bottom: 351px;
    left: clamp(14px, 2.5vw, 36px);
    font-size: clamp(32px, 4.4444444444vw, 64px);
    opacity: 0;
    animation: fvFadeIn 1.2s ease 0.2s forwards;
  }
}

@keyframes fvFadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
/*******************************************************************
* news
*******************************************************************/
.news__inner {
  padding-top: clamp(62px, 12.4305555556vw, 179px);
  padding-bottom: clamp(120px, 14.0277777778vw, 120px);
}
@media (min-width: 768px) {
  .news__inner {
    width: 75.0347222222%;
    max-width: 1080px;
  }
}

.news__head {
  padding-left: 9px;
}
@media (min-width: 768px) {
  .news__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    padding-left: 0;
  }
}

.news__title-back-text::after {
  content: "News";
  top: -33px;
  left: clamp(60px, 6.5972222222vw, 95px);
  overflow: hidden;
}
@media (min-width: 768px) {
  .news__title-back-text::after {
    top: -40px;
  }
}

.news__title-text-jp {
  margin-top: 8px;
}
@media (min-width: 768px) {
  .news__title-text-jp {
    margin-top: 0;
    position: absolute;
    left: 2px;
    bottom: -12px;
  }
}

.news__button {
  width: clamp(120px, 11.1111111111vw, 160px);
  height: clamp(30px, 2.7777777778vw, 40px);
  display: flex;
  justify-content: center;
  align-items: center;
  background: #949E33;
  border: none;
  border-radius: 40px;
  margin-top: 21.5px;
  margin-inline: auto;
  padding-top: 4px;
  padding-left: 3px;
  color: #fff;
  font-size: clamp(12px, 1.1111111111vw, 16px);
  font-family: "游明朝";
  letter-spacing: 0.1em;
  transition: all 0.5s ease;
}
@media (min-width: 768px) {
  .news__button {
    margin: 0;
    margin-bottom: -16px;
    padding-left: 2px;
    padding-top: 4px;
  }
}
@media (any-hover: hover) {
  .news__button:hover {
    background: #54372D;
  }
}

.news__button--pc {
  display: none;
}
@media (min-width: 768px) {
  .news__button--pc {
    display: flex;
  }
}

@media (min-width: 768px) {
  .news__button--sp {
    display: none;
  }
}

.news__list {
  margin-top: clamp(32px, 3.6805555556vw, 53px);
}
@media (min-width: 1024px) {
  .news__list {
    position: relative;
    display: flex;
    align-items: stretch;
    justify-content: stretch;
  }
}

@media (min-width: 1024px) {
  .news__list::after {
    content: "";
    position: absolute;
    top: 0;
    right: -2px;
    width: 1px;
    height: 100%;
    background: #7b5c46;
  }
}

.news__item {
  box-sizing: border-box;
  padding: 24.5px 0;
  border-top: 1px solid #54372D;
}
@media (min-width: 1024px) {
  .news__item {
    display: flex;
    flex: 0 0 calc((100% - 2px) / 3);
    padding: 15px 20.5px 16.5px 19.5px;
    border-top: none;
    transform: translateY(1px);
    border-left: 1px solid #54372D;
  }
}
.news__item:nth-child(2) {
  transform: translateY(4px);
}
@media (min-width: 768px) {
  .news__item:nth-child(2) {
    transform: translateY(0px);
  }
}
.news__item:last-child {
  transform: translateY(2px);
  border-bottom: 1px solid #54372D;
  padding-bottom: 22.5px;
}
@media (min-width: 1024px) {
  .news__item:last-child {
    border-bottom: none;
    transform: translateY(2px) translateX(2px);
  }
}
.news__item:last-child:not(:last-child) .news__link .news__cat {
  transform: translateY(2px);
}

.news__link {
  font-family: "Yu Gothic";
  color: #54372D;
  transition: all 0.5s ease;
}
@media (any-hover: hover) {
  .news__link:hover {
    color: #CA7F13;
  }
}

.news__date {
  font-weight: bold;
  font-size: 14px;
  letter-spacing: 0.1em;
  font-family: "游ゴシック";
}

.news__title {
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.1em;
  margin-top: 12px;
  line-height: 1.5;
  font-family: "游ゴシック";
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  min-height: 3em;
}
@media (min-width: 1024px) {
  .news__title {
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    min-height: 3em;
  }
}

.news__cat {
  font-size: 14px;
  letter-spacing: 0.1em;
  margin-top: 16px;
  text-transform: uppercase;
  font-family: "Marcellus", serif;
  overflow-wrap: anywhere;
}
@media (min-width: 768px) {
  .news__cat {
    text-transform: capitalize;
  }
}

/*******************************************************************
* concept
*******************************************************************/
.concept__inner {
  margin-bottom: clamp(112px, 13.4722222222vw, 194px);
}
@media (min-width: 768px) {
  .concept__inner {
    position: relative;
    margin-top: 80px;
  }
}

.concept__head {
  position: relative;
  margin-right: auto;
}

.concept__head-img {
  max-width: 100%;
  aspect-ratio: 315/250;
}
@media (min-width: 768px) {
  .concept__head-img {
    width: clamp(450px, 60.0694444444vw, 865px);
    aspect-ratio: 865/680;
    margin-left: auto;
  }
}

.concept__title-area {
  position: absolute;
  margin-top: 74px;
}
@media (min-width: 768px) {
  .concept__title-area {
    margin-top: 0;
    top: clamp(127px, 18.9583333333vw, 273px);
    left: -1px;
  }
}

.concept__title-back-text::after {
  content: "Concept";
  position: absolute;
  top: -35px;
  left: 55px;
  z-index: 0;
  overflow: hidden;
}

.concept__title-text {
  position: relative;
  text-transform: uppercase;
  z-index: 2;
}

.concept__title-text-jp {
  margin-top: 9px;
}
@media (min-width: 768px) {
  .concept__title-text-jp {
    margin-top: -1px;
  }
}

.concept__head-text {
  position: absolute;
  left: 10px;
  top: clamp(400px, 115.7333333333vw, 900px);
  color: #CA7F13;
  font-size: clamp(18px, 4.8vw, 28px);
  font-family: "游明朝";
  letter-spacing: 0.1em;
  line-height: 2;
}
@media (min-width: 768px) {
  .concept__head-text {
    top: clamp(205px, 28.3333333333vw, 408px);
    left: 1px;
    font-size: clamp(18px, 1.9444444444vw, 28px);
    z-index: 2;
  }
}

@media (min-width: 768px) {
  .concept__area {
    display: flex;
    align-items: flex-start;
    margin-top: 80px;
  }
}

.concept__img {
  position: relative;
  width: clamp(108px, 28.8vw, 230px);
  margin-top: 41px;
  aspect-ratio: 108/245;
  margin-left: auto;
  z-index: 1;
}
@media (min-width: 768px) {
  .concept__img {
    margin: 0;
    width: 540px;
    aspect-ratio: 540/210;
  }
}

.concept__text {
  margin-top: 39px;
  color: #54372D;
  font-size: clamp(16px, 4.2666666667vw, 18px);
  line-height: 2;
  letter-spacing: 0.1em;
  font-family: "游ゴシック";
}
@media (min-width: 768px) {
  .concept__text {
    margin-top: -5px;
    margin-left: 61px;
    line-height: 2;
    font-size: clamp(16px, 1.25vw, 18px);
  }
}

.concept__btn {
  position: relative;
  margin-left: auto;
  display: flex;
  width: -moz-fit-content;
  width: fit-content;
  margin-top: 13px;
  margin-right: 18px;
  color: #54372D;
  font-family: "游明朝";
  font-size: 18px;
  letter-spacing: 0.1em;
  line-height: 2;
  transition: all 0.5s ease;
}
@media (min-width: 768px) {
  .concept__btn {
    margin-top: 11px;
    margin-right: 18px;
  }
}
@media (any-hover: hover) {
  .concept__btn:hover {
    color: #CA7F13;
  }
  .concept__btn:hover:hover::before, .concept__btn:hover:hover::after {
    background: #CA7F13;
  }
}

.concept__btn::before {
  content: "";
  position: absolute;
  width: 120px;
  height: 1px;
  background: #54372D;
  right: -17px;
  bottom: 8px;
}

.concept__btn::after {
  content: "";
  position: absolute;
  width: 6px;
  height: 1px;
  background: #54372D;
  right: -17px;
  bottom: 10px;
  transform: rotate(35deg);
}

/*******************************************************************
* feature
*******************************************************************/
.feature {
  padding-top: clamp(88px, 11.1805555556vw, 161px);
  padding-bottom: 49px;
  background: #464646;
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 1s ease, transform 1s ease;
}
@media (min-width: 768px) {
  .feature {
    padding-bottom: 59px;
    display: flex;
    justify-content: center;
  }
}

.feature.is-show {
  opacity: 1;
  transform: translateY(0);
}

.feature__inner {
  position: relative;
  margin-inline: auto;
}
@media (min-width: 768px) {
  .feature__inner {
    width: 100%;
    max-width: 1440px;
    display: flex;
    margin-inline: 0;
    justify-content: center;
  }
}

.feature__title-area {
  position: absolute;
  top: clamp(-50px, -22px + -28 * (100vw - 375px) / 392, -22px);
  left: clamp(80px, 23.2vw, 178px);
}
@media (min-width: 768px) {
  .feature__title-area {
    top: -63px;
    left: 0;
    right: 0;
    margin-inline: auto;
    width: -moz-fit-content;
    width: fit-content;
    transform: translateX(8px);
    z-index: 2;
  }
}

.feature__title-text {
  position: relative;
  text-transform: uppercase;
  z-index: 2;
}
@media (min-width: 768px) {
  .feature__title-text {
    margin-left: -11px;
  }
}

.feature__title-back-text::after {
  content: "Feature";
  position: absolute;
  max-width: 100%;
  z-index: 0;
  white-space: nowrap;
  top: -48px;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 768px) {
  .feature__title-back-text::after {
    top: -60px;
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  .feature__title-back-text::after {
    top: -23px;
  }
}

@media (min-width: 768px) {
  .feature__main {
    display: flex;
    align-items: center;
  }
}

@media (min-width: 768px) {
  .feature__nav-list {
    display: flex;
    flex-direction: column;
    transform: translateY(3px) translateX(34px);
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  .feature__nav-list {
    display: none;
  }
}

@media (min-width: 768px) {
  .feature__nav-item {
    font-family: "Yu Mincho";
    color: #CA7F13;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 15px;
    flex: 1;
    white-space: nowrap;
    opacity: 0.4;
    transition: opacity 0.4s ease;
  }
}
@media (min-width: 768px) {
  .feature__nav-item:not(:first-child) {
    margin-top: 60px;
  }
}
@media (min-width: 768px) {
  .feature__nav-item:nth-child(2) {
    transform: translateY(-4px) translateX(1px);
  }
  .feature__nav-item:nth-child(2) .feature__nav-text {
    transform: translateY(-1px) translateX(-4px);
  }
  .feature__nav-item:nth-child(2) .feature__nav-tag {
    font-size: 16px;
  }
}
@media (min-width: 768px) {
  .feature__nav-item:last-child {
    transform: translateY(-23px) translateX(2px);
  }
  .feature__nav-item:last-child .feature__nav-text {
    transform: translateY(9px) translateX(-2px);
  }
}

.feature__nav-item.is-active {
  opacity: 1;
}

@media (min-width: 768px) {
  .feature__nav-text {
    line-height: 1.5;
    letter-spacing: 0.1em;
  }
}

@media (min-width: 768px) {
  .feature__nav-tag {
    font-size: 24px;
    width: 40px;
    text-align: center;
    flex-shrink: 0;
  }
}

.feature__desc-list {
  position: relative;
}
@media (min-width: 768px) {
  .feature__desc-list {
    overflow: hidden;
    margin-left: -6px;
  }
}

.feature__pc {
  margin-left: clamp(50px, 9.375vw, 135px);
}
@media (min-width: 768px) {
  .feature__pc {
    margin-left: clamp(40px, 3.9024390244vw, 135px);
  }
}
.feature__pc .feature__desc-item {
  width: 100%;
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  opacity: 0;
  pointer-events: none;
  transition: opacity 1.5s ease, transform 1.5s ease;
}
.feature__pc .feature__desc-item.is-active {
  position: relative;
  opacity: 1;
  pointer-events: auto;
}
@media (min-width: 768px) {
  .feature__pc .feature__desc-item.is-active {
    display: flex;
    gap: clamp(15px, 1.4634146341vw, 32px);
  }
}

@media (min-width: 768px) {
  .feature__img {
    position: relative;
    width: clamp(340px, 31.25vw, 450px);
    aspect-ratio: 450/630;
  }
}
@media (min-width: 768px) {
  .feature__img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}

.feature__swiper-img {
  width: 100%;
  overflow: hidden;
}
.feature__swiper-img .swiper-slide {
  display: flex;
  justify-content: center;
}
.feature__swiper-img .feature__img {
  width: clamp(270px, 84vw, 420px);
  aspect-ratio: 315/275;
  margin-inline: auto;
}

.feature__text-area {
  transform: translateX(1px);
}
@media (min-width: 768px) {
  .feature__text-area {
    width: clamp(315px, 29.4444444444vw, 424px);
    max-width: 424px;
    margin-top: 116px;
  }
}

.feature__num {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16.5px;
  margin-top: 28px;
  color: #CA7F13;
  line-height: 1.9285714286;
  letter-spacing: 0.1em;
  font-size: clamp(14px, 3.7333333333vw, 18px);
}
@media (min-width: 768px) {
  .feature__num {
    position: relative;
    flex-direction: column;
    font-size: clamp(14px, 1.25vw, 18px);
    transform: translateY(-24px) translateX(-3px);
  }
}

.feature__num--3 {
  font-size: clamp(12px, 3.2vw, 16px);
}

.feature__num-line {
  width: clamp(80px, 26.6666666667vw, 100px);
  height: 1px;
  background: #CA7F13;
}
@media (min-width: 768px) {
  .feature__num-line {
    position: absolute;
    width: 24px;
    height: 2px;
    top: 51px;
    right: 0;
    left: 0;
    margin-inline: auto;
    transform: translateX(6px);
  }
}

.feature__title {
  display: flex;
  justify-content: center;
  margin-top: 7px;
  font-size: clamp(18px, 1.6666666667vw, 24px);
  color: #CA7F13;
  font-family: "游明朝";
  line-height: 2;
  letter-spacing: 0.1em;
  text-align: center;
  transform: translateX(1px);
}
@media (min-width: 768px) {
  .feature__title {
    transform: translateY(-1px) translateX(-11px);
  }
}

.feature__text {
  color: #CA7F13;
  margin-top: clamp(18px, 2.5694444444vw, 37px);
  font-size: clamp(14px, 1.25vw, 18px);
  font-family: "Yu Gothic";
  line-height: 2;
  letter-spacing: 0.1em;
  opacity: 0.8;
  text-align: center;
}
@media (min-width: 768px) {
  .feature__text {
    transform: translateX(-1px);
  }
}

/*******************************************************************
* price menu
*******************************************************************/
.price__inner {
  width: 84%;
  margin-inline: auto;
  padding-top: 156px;
}
@media (min-width: 768px) {
  .price__inner {
    width: 83.3333333333%;
    margin-top: 121px;
    margin-inline: 0;
    margin-left: auto;
  }
}
@media (min-width: 1440px) {
  .price__inner {
    max-width: 1200px;
    margin-left: 0;
    margin-inline: auto;
  }
}

.price__title-area {
  max-width: 100%;
  padding-top: 30px;
  margin-top: -30px;
  overflow: hidden;
}
@media (min-width: 768px) {
  .price__title-area {
    position: relative;
    overflow: visible;
  }
}

.price__title-text {
  text-transform: uppercase;
  position: relative;
}
@media (min-width: 768px) {
  .price__title-text {
    position: absolute;
    top: 0;
    left: -120px;
  }
}
@media (min-width: 1440px) {
  .price__title-text {
    left: 0;
  }
}

.price__title-back-text::after {
  content: "Price menu";
  white-space: nowrap;
  top: 0;
  left: 60px;
}
@media (min-width: 768px) {
  .price__title-back-text::after {
    letter-spacing: 0px;
    top: -40px;
    left: -25px;
  }
}
@media (min-width: 1440px) {
  .price__title-back-text::after {
    left: 60px;
  }
}

.price__title-text-jp {
  margin-top: 9px;
}
@media (min-width: 768px) {
  .price__title-text-jp {
    display: inline-block;
    position: absolute;
    top: 96px;
    left: -120px;
  }
}
@media (min-width: 1440px) {
  .price__title-text-jp {
    left: 0;
  }
}

.price__list {
  margin-top: clamp(40px, 16.2666666667vw, 61px);
  width: 100%;
  margin-inline: auto;
}
@media (min-width: 768px) {
  .price__list {
    margin-top: 152px;
    margin-right: 120px;
    max-width: 800px;
    display: flex;
    flex-wrap: wrap;
    position: relative;
  }
  .price__list::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 50%;
    transform: translateX(-0.5px);
    width: 1px;
    background: #CA7F13;
  }
}
@media (min-width: 1440px) {
  .price__list {
    margin-inline: 0;
    margin-left: auto;
  }
}

.price__item {
  border-top: 1px solid #CA7F13;
}
.price__item:first-child {
  border-top: none;
  transform: translateY(-1px) translateX(4px);
}
.price__item:first-child .price__link-jp {
  display: inline-block;
  transform: translateY(-5px) translateX(-1px);
}
.price__item:first-child .price__btn {
  transform: translateY(-2px) translateX(-10px);
}
.price__item:not(:first-child) {
  transform: translateY(9px);
  padding-top: 10px;
  padding-left: 4px;
  padding-bottom: 5px;
}
.price__item:not(:first-child) .price__link-jp {
  display: inline-block;
  transform: translateY(1px) translateX(-2px);
}
.price__item:not(:first-child) .price__btn {
  transform: translateY(-6px) translateX(-6px);
}
@media (min-width: 768px) {
  .price__item:not(:first-child) {
    transform: translateY(6px);
    padding-top: 11px;
    padding-left: 4px;
    padding-bottom: 5px;
  }
}
.price__item:nth-child(3) {
  padding-left: 12px;
}
.price__item:nth-child(3) .price__link-jp {
  display: inline-block;
  transform: translateY(1px) translateX(-2px);
}
.price__item:nth-child(4) {
  padding-top: 10px;
  padding-bottom: 4px;
}
.price__item:nth-child(4) .price__link-jp {
  display: inline-block;
  transform: translateX(-1px);
}
.price__item:last-child {
  border-bottom: 1px solid #CA7F13;
  padding-bottom: 7px;
}
.price__item:last-child .price__link-jp {
  display: inline-block;
  transform: translateX(-1px);
}

.price__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: #CA7F13;
  font-size: clamp(36px, 3.3333333333vw, 48px);
  letter-spacing: clamp(1.44px, 0.1333333333vw, 1.92px);
  padding: 14px 0;
  transition: all 0.5s ease;
}
@media (min-width: 768px) {
  .price__link {
    padding-top: 0;
    padding-bottom: 0;
    padding-left: 9px;
    padding-right: 9px;
  }
}
@media (any-hover: hover) {
  .price__link:hover {
    color: #54372D;
  }
  .price__link:hover .price__btn {
    color: #54372D;
    transition: all 0.5s ease;
  }
}

@media (min-width: 768px) {
  .price__item {
    width: 50%;
    border-top: none;
    border-bottom: 1px solid #CA7F13;
  }
  .price__item:first-child .price__link {
    transform: translateY(8px) translateX(-1px);
  }
  .price__item:first-child .price__link-jp {
    display: inline-block;
    transform: translateY(-1px) translateX(-5px);
  }
  .price__item:nth-child(2) .price__link {
    padding-bottom: 10px;
    transform: translateY(-4px) translateX(-1px);
  }
  .price__item:nth-child(5) .price__link {
    padding-top: 7px;
    padding-bottom: 13px;
  }
  .price__item:nth-child(5) .price__link-jp {
    display: inline-block;
    margin-left: -5px;
  }
  .price__item:nth-child(6) .price__link {
    transform: translateY(6px) translateX(-1px);
  }
  .price__item:nth-child(6) .price__link-jp {
    display: inline-block;
    margin-left: -2px;
  }
  .price__item:not(:first-child) {
    transform: translateY(-1px);
  }
  .price__item:not(:first-child) .price__btn {
    transform: translateY(-1px) translateX(-5px);
  }
  .price__item:last-child {
    border-bottom: none;
    padding-bottom: 13px;
  }
  .price__item:last-child .price__link {
    transform: translateY(6px) translateX(-1px);
  }
  .price__item:last-child .price__link-jp {
    display: inline-block;
    transform: translateX(-2px);
  }
}

.price__link-text {
  display: inline-flex;
  align-items: baseline;
  gap: 20px;
}

.price__link-jp {
  font-size: 14px;
  font-family: "游明朝";
  line-height: 1;
  letter-spacing: 0.04em;
  margin-left: 0;
}

.price__btn {
  color: #CA7F13;
  font-size: 27px;
  flex: 0 0 auto;
  margin-left: 16px;
}
@media (min-width: 768px) {
  .price__btn {
    margin-left: 24px;
  }
}

/*******************************************************************
* faq
*******************************************************************/
.faq__inner {
  margin-top: clamp(163px, 11.5972222222vw, 167px);
  padding-bottom: 120px;
}
@media (min-width: 768px) {
  .faq__inner {
    width: 75%;
    margin-inline: auto;
    max-width: 1080px;
  }
}

.faq__title-area {
  position: relative;
}

.faq__title-text {
  text-transform: uppercase;
}
@media (min-width: 768px) {
  .faq__title-text {
    left: -60px;
  }
}

.faq__title-back-text::after {
  content: "FAQ";
  position: absolute;
  left: 55px;
  top: -32px;
}
@media (min-width: 768px) {
  .faq__title-back-text::after {
    left: 35px;
    top: -42px;
  }
}

.faq__title-text-jp {
  margin-top: 8px;
}
@media (min-width: 768px) {
  .faq__title-text-jp {
    margin-top: -1px;
    margin-left: -60px;
  }
}

.faq__list {
  margin-top: clamp(42px, 4.375vw, 63px);
}
@media (min-width: 768px) {
  .faq__list {
    margin-right: -3px;
  }
}

.faq__item {
  padding-left: 16px;
  padding-right: 14px;
  padding-top: 16px;
  padding-bottom: 15px;
  background: #D4CEBE;
  color: #CA7F13;
  font-family: "游明朝";
  letter-spacing: 0.04em;
  line-height: 1.5;
  cursor: pointer;
}
.faq__item:not(:first-child) {
  margin-top: 20px;
}
.faq__item:not(:first-child) {
  padding-top: clamp(14px, 2.1527777778vw, 31px);
  padding-bottom: clamp(14px, 2.2916666667vw, 33px);
}
@media (min-width: 768px) {
  .faq__item:last-child .faq__btn {
    margin-top: 0;
  }
}
@media (min-width: 768px) {
  .faq__item {
    padding-left: 20px;
    padding-right: 36px;
    padding-top: 33px;
    padding-bottom: 31px;
  }
}

.faq__head {
  display: flex;
  justify-content: flex-start;
  gap: 9px;
}

.btn-active {
  transform: rotate(180deg);
}

.faq__head--tag {
  font-size: clamp(18px, 1.6666666667vw, 24px);
  letter-spacing: 0.04em;
}

.faq__head-text {
  margin-top: 3px;
  margin-left: 2px;
  flex: 1;
}
@media (min-width: 768px) {
  .faq__head-text {
    margin-top: 5px;
    margin-left: 9px;
    letter-spacing: 0.04em;
  }
}

.faq__btn {
  display: inline-block;
  background: none;
  border: none;
  padding: 0;
  color: #54372D;
  font-size: 16px;
  margin-top: 1px;
  margin-right: -3px;
}

.faq__answer {
  display: none;
}

.faq__answer-inner {
  display: flex;
  gap: clamp(12px, 1.3888888889vw, 20px);
  margin-top: clamp(13px, 1.0416666667vw, 15px);
}
@media (min-width: 768px) {
  .faq__answer-inner {
    margin-left: 2px;
  }
}

.faq__answer--tag {
  font-size: clamp(18px, 1.6666666667vw, 24px);
  letter-spacing: 0.04em;
}

.faq__answer-text {
  margin-top: clamp(2px, 0.3472222222vw, 5px);
}
@media (min-width: 768px) {
  .faq__answer-text {
    letter-spacing: 0.14em;
  }
}

/*******************************************************************
* reserve
*******************************************************************/
.reserve {
  background: #fff;
}

.reserve__inner {
  position: relative;
}

.reserve__title-area {
  position: absolute;
  height: 100%;
  inset: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding-bottom: 16px;
}
@media (min-width: 768px) {
  .reserve__title-area {
    padding: 0;
  }
}

.reserve__title-text {
  text-transform: uppercase;
  font-size: clamp(28px, 12.8vw, 48px);
  letter-spacing: 0.1em;
  transition: all 0.5s ease;
}
@media (min-width: 768px) {
  .reserve__title-text {
    font-size: clamp(48px, 5.5555555556vw, 80px);
  }
}

.reserve__title-text-jp {
  font-size: clamp(12px, 1.1111111111vw, 16px);
  letter-spacing: 0.1em;
  margin-top: 7px;
  margin-left: 2px;
  transition: all 0.5s ease;
}
@media (min-width: 768px) {
  .reserve__title-text-jp {
    margin-top: 1px;
  }
}

.reserve__img-link {
  display: block;
  position: relative;
  height: clamp(170px, 53.3333333333vw, 400px);
}
@media (min-width: 768px) {
  .reserve__img-link {
    height: clamp(200px, 27.7777777778vw, 533px);
  }
}
@media (any-hover: hover) {
  .reserve__img-link:hover .reserve__title-text,
  .reserve__img-link:hover .reserve__title-text-jp {
    color: #fff;
    transition: all 0.5s ease;
  }
}

.reserve__img {
  position: relative;
  width: 100%;
  aspect-ratio: 375/200;
}
@media (min-width: 768px) {
  .reserve__img {
    aspect-ratio: 1440/400;
  }
}
.reserve__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
.reserve__img::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(70, 70, 70, 0.8);
  pointer-events: none;
}

.reserve__list {
  width: 84%;
  margin-inline: auto;
}
@media (min-width: 768px) {
  .reserve__list {
    width: 83.3333333333%;
    display: flex;
    gap: 38px;
    position: relative;
  }
  .reserve__list::before {
    content: "";
    position: absolute;
    top: 30px;
    bottom: 30px;
    left: 50%;
    transform: translateX(-0.5px);
    width: 1px;
    background: #CA7F13;
  }
  .reserve__list::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 1px;
    background: #CA7F13;
  }
}

.reserve__item {
  text-align: center;
  border-bottom: 1px solid #CA7F13;
}
@media (min-width: 768px) {
  .reserve__item:first-child {
    transform: translateX(-62px);
  }
  .reserve__item:first-child .reserve__text-jp {
    transform: translateX(-5px) translateY(17px);
  }
}
@media (min-width: 768px) {
  .reserve__item:last-child .reserve__text {
    font-size: clamp(48px, 5vw, 72px);
    letter-spacing: 0.1em;
  }
  .reserve__item:last-child .reserve__text-jp {
    transform: translateX(-3px) translateY(16px);
  }
}
@media (min-width: 768px) {
  .reserve__item {
    width: 50%;
    border-bottom: none;
    flex: 0 0 auto;
    min-width: 0;
  }
}

.reserve__link {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-decoration: none;
  padding-top: clamp(60px, 6.25vw, 90px);
  padding-bottom: clamp(71px, 8.75vw, 126px);
  transition: all 0.5s ease;
}
@media (any-hover: hover) {
  .reserve__link:hover .reserve__text {
    color: #54372D;
    transition: all 0.5s ease;
  }
  .reserve__link:hover .reserve__text-jp {
    color: #54372D;
    transition: all 0.5s ease;
  }
}

.reserve__text {
  color: #CA7F13;
  font-size: clamp(28px, 12.8vw, 48px);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-left: 5px;
  transition: all 0.5s ease;
}
@media (min-width: 768px) {
  .reserve__text {
    font-size: clamp(48px, 5.5555555556vw, 80px);
    margin-left: 0;
  }
}

.reserve__text-jp {
  color: #CA7F13;
  font-size: clamp(12px, 1.1111111111vw, 16px);
  letter-spacing: 0.1em;
  font-family: "Yu Mincho";
  font-weight: 600;
  margin-top: 9px;
  transition: all 0.5s ease;
}

.reserve-main .reserve {
  padding-top: clamp(25px, 6.1111111111vw, 88px);
}

/*******************************************************************
* news
*******************************************************************/
/* ===============================
   全体
================================ */
.ln-main {
  background: #fff;
}

.ln-main__inner,
.ln-single__inner {
  width: 90.9333333333%;
  margin-inline: auto;
  padding-top: 65px;
  padding-bottom: clamp(82px, 8.6805555556vw, 125px);
}
@media (min-width: 768px) {
  .ln-main__inner,
  .ln-single__inner {
    width: 75%;
    max-width: 1080px;
    display: flex;
    gap: 38px;
  }
}

.ln__list {
  margin-top: clamp(14px, 2.7083333333vw, 39px);
}
@media (min-width: 768px) {
  .ln__list {
    width: 80%;
  }
}

/* ===============================
   記事リスト
================================ */
.ln__items {
  list-style: none;
  padding: 0;
  margin: 0;
}
@media (min-width: 768px) {
  .ln__items {
    flex: 1;
  }
}

.ln__item:not(:first-child) {
  margin-top: clamp(11px, 1.25vw, 18px);
}

/* ===============================
   記事カード
================================ */
.ln__link {
  display: block;
  position: relative;
  padding: clamp(15px, 2.0138888889vw, 29px) clamp(12px, 1.7361111111vw, 25px);
  background: #D4CEBE;
  text-decoration: none;
}
@media (min-width: 768px) {
  .ln__link {
    display: flex;
    align-items: center;
    gap: 7px;
    padding-right: clamp(110px, 10.7638888889vw, 155px);
  }
}
@media (any-hover: hover) {
  .ln__link:hover .ln__date,
  .ln__link:hover .ln__title {
    color: #54372D;
  }
}

/* 日付 */
.ln__date {
  display: block;
  font-size: clamp(14px, 1.1111111111vw, 16px);
  letter-spacing: 0.1em;
  color: #CA7F13;
  transition: all 0.5s ease;
}
@media (min-width: 768px) {
  .ln__date {
    margin-bottom: 0;
  }
}

/* タイトル */
.ln__title {
  display: block;
  font-size: clamp(14px, 1.1111111111vw, 16px);
  letter-spacing: 0.1em;
  line-height: 1.5;
  font-family: "游明朝";
  color: #CA7F13;
  margin-top: 9px;
  margin-bottom: -5px;
  transition: all 0.5s ease;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
@media (min-width: 768px) {
  .ln__title {
    margin: 0;
    line-height: 0.875;
    -webkit-line-clamp: 1;
    min-height: 0.875em;
  }
}

/* 右下カテゴリ */
.ln__category {
  position: absolute;
  right: 8px;
  bottom: -3px;
  font-size: clamp(20px, 2.2222222222vw, 32px);
  color: rgba(84, 55, 45, 0.2);
  pointer-events: none;
}
@media (min-width: 768px) {
  .ln__category {
    letter-spacing: 0.04em;
    right: 23px;
    bottom: 13px;
  }
}

/* ===============================
   ページネーション
================================ */
.ln__pn .page-numbers {
  margin-top: clamp(9px, 1.3194444444vw, 19px);
  list-style: none;
  gap: clamp(14px, 1.7361111111vw, 25px);
  display: flex;
  justify-content: center;
  color: #CA7F13;
  font-size: clamp(16px, 2.2222222222vw, 32px);
}
.ln__pn .page-numbers a {
  transition: all 0.5s ease;
}
@media (any-hover: hover) {
  .ln__pn .page-numbers a:hover {
    color: #54372D;
  }
}

.ln__pn .next {
  margin-top: 0;
  font-size: clamp(25px, 2.0833333333vw, 30px);
  margin-left: -4px;
  font-family: serif;
}
@media (min-width: 768px) {
  .ln__pn .next {
    margin-top: clamp(1px, 1.1111111111vw, 16px);
  }
}

.page-numbers.current {
  color: #54372D;
  border-bottom: #54372D 1px solid;
}

/* ===============================
   カテゴリ
================================ */
.ln__sidebar {
  margin-top: 41px;
}

@media (min-width: 768px) {
  .ln__cat-nav {
    border-left: 1px solid #CA7F13;
    padding: 10px 0;
    padding-left: 16.5px;
    transform: translateX(4px);
  }
}

.ln__cat-title {
  font-size: clamp(24px, 2.2222222222vw, 32px);
  letter-spacing: 0.1em;
  color: #CA7F13;
}

.ln__cat-list {
  margin-top: clamp(21px, 2.0833333333vw, 30px);
  display: flex;
  flex-wrap: wrap;
  gap: 14px 0px;
}
@media (min-width: 768px) {
  .ln__cat-list {
    display: block;
  }
}

.ln__cat-item {
  width: 44%;
}
@media (min-width: 768px) {
  .ln__cat-item:not(:first-child) {
    width: 100%;
    margin-top: 11px;
  }
}

@media (min-width: 768px) {
  .ln__cat-item--news {
    order: 2;
  }
  .ln__cat-item--column {
    order: 3;
  }
}
.ln__cat-link {
  font-size: clamp(14px, 1.1111111111vw, 16px);
  letter-spacing: 0.1em;
  color: #CA7F13;
  font-family: "游ゴシック";
  transition: all 0.5s ease;
}
@media (any-hover: hover) {
  .ln__cat-link:hover {
    color: #54372D;
  }
}

.ln__cat-item.is-current .ln__cat-link {
  color: #54372D;
}

/*******************************************************************
* single
*******************************************************************/
.ln-single {
  background: #fff;
}

.ln-s-head__list {
  width: 89.6%;
  margin-inline: auto;
  padding-top: clamp(12px, 1.3888888889vw, 20px);
  margin-left: clamp(15px, 2.5694444444vw, 37px);
}

.ln-single__inner {
  width: 91.4666666667%;
  margin-inline: auto;
  padding-top: clamp(75px, 7.2916666667vw, 105px);
  padding-bottom: clamp(81px, 12.6388888889vw, 182px);
}
@media (min-width: 768px) {
  .ln-single__inner {
    max-width: 963px;
    justify-content: center;
    gap: 88px;
  }
}

@media (min-width: 768px) {
  .ln-single__main {
    max-width: 691px;
  }
}
.ln-single__main {
  /* =========================
     タイトルエリア
  ========================= */
}
.ln-single__main .ln-single__title {
  font-size: clamp(18px, 1.6666666667vw, 24px);
  letter-spacing: 0.1em;
  line-height: 1.5;
  font-family: "游明朝";
  color: #CA7F13;
  margin-top: 0;
}
.ln-single__main .ln-single__meta {
  margin-top: 2px;
  font-size: clamp(12px, 0.9722222222vw, 14px);
  letter-spacing: 0.1em;
  color: #CA7F13;
}
@media (min-width: 768px) {
  .ln-single__main .ln-single__meta {
    margin-top: 0;
  }
}
.ln-single__main .ln-single__date {
  margin-left: clamp(2px, 0.3472222222vw, 5px);
  margin-top: 2px;
}
@media (min-width: 768px) {
  .ln-single__main .ln-single__date {
    margin-top: 0;
  }
}
.ln-single__main .news-desc {
  font-size: clamp(14px, 1.1111111111vw, 16px);
  letter-spacing: 0.1em;
  line-height: 2;
  color: #333333;
  font-family: "游ゴシック";
  margin-top: 34px;
}
@media (min-width: 768px) {
  .ln-single__main .news-desc {
    margin-top: 27px;
    line-height: 2;
  }
}
.ln-single__main {
  /* =========================
     画像
  ========================= */
}
.ln-single__main .ln-s__img {
  width: 100%;
  margin-top: clamp(19px, 2.8472222222vw, 41px);
}
.ln-single__main {
  /* =========================
     本文
  ========================= */
}
.ln-single__main p {
  font-size: clamp(14px, 1.1111111111vw, 16px);
  letter-spacing: 0.1em;
  margin-top: 1px;
  line-height: 2;
  color: #333333;
  font-family: "游ゴシック";
}
@media (min-width: 768px) {
  .ln-single__main p {
    line-height: 2;
  }
}
.ln-single__main h2 {
  margin-top: clamp(14px, 1.6666666667vw, 24px);
  font-size: clamp(16px, 1.25vw, 18px);
  letter-spacing: 0.1em;
  line-height: 2;
  font-family: "游明朝";
  color: #CA7F13;
}
@media (min-width: 768px) {
  .ln-single__main h2 {
    line-height: 1.7777777778;
  }
}
.ln-single__main h3 {
  font-size: 16px;
  letter-spacing: 0.1em;
  line-height: 1.75;
  margin-top: clamp(3px, 0.2777777778vw, 4px);
  color: #333333;
  font-family: "游ゴシック";
}
@media (min-width: 768px) {
  .ln-single__main h3 {
    line-height: 1.98;
  }
}
.ln-single__main {
  /* =========================
     一覧ボタン
  ========================= */
}
.ln-single__main .ln-single__footer {
  margin-top: clamp(20px, 2.7777777778vw, 40px);
  text-align: center;
}
@media (min-width: 768px) {
  .ln-single__main .ln-single__footer {
    margin-top: 30px;
  }
}
.ln-single__main .ln-single__back-btn {
  margin-inline: auto;
  display: flex;
  justify-content: center;
  align-items: center;
  width: clamp(160px, 14.0277777778vw, 202px);
  height: 40px;
  border-radius: 50px;
  background: #949E33;
  color: #fff;
  text-decoration: none;
  font-size: 16px;
  letter-spacing: 0.1em;
  font-family: "游明朝";
}

.ln-s__sidebar {
  margin-top: 39px;
}
@media (min-width: 768px) {
  .ln-s__sidebar {
    margin-top: 0;
  }
}
@media (min-width: 768px) {
  .ln-s__sidebar .ln__cat-nav {
    transform: translateX(58px);
    padding: 5px 0;
    padding-left: 8px;
  }
}
@media (min-width: 768px) {
  .ln-s__sidebar .ln__cat-title {
    font-size: 24px;
    letter-spacing: 0.1em;
  }
}
@media (min-width: 768px) {
  .ln-s__sidebar .ln__cat-list {
    margin-top: 20px;
  }
}

/*******************************************************************
* lower-concept
*******************************************************************/
.lower-concept__main {
  position: relative;
  z-index: 1;
  background: #D4CEBE;
}

.lower-concept {
  background: #D4CEBE;
  position: relative;
  z-index: 1;
}

.lower-concept__main {
  position: relative;
  z-index: 1;
  background: #D4CEBE;
}

.lower-concept__inner {
  color: #CA7F13;
  padding-bottom: clamp(55px, 5.2083333333vw, 75px);
}
@media (min-width: 768px) {
  .lower-concept__inner {
    position: relative;
  }
}

.lower-concept__about {
  margin-top: clamp(54px, 5.4861111111vw, 79px);
}

.lower-concept__about-title {
  margin-top: 19px;
  font-size: clamp(18px, 2.7777777778vw, 40px);
  line-height: 2;
  letter-spacing: 0.1em;
  font-weight: 600;
  font-family: "Yu Mincho";
}
@media (min-width: 1170px) {
  .lower-concept__about-title {
    position: absolute;
    margin-top: 0;
    top: 142px;
    line-height: 1.5;
  }
}

.lower-concept__about-img {
  width: 100%;
  aspect-ratio: 315/177;
}
@media (min-width: 1170px) {
  .lower-concept__about-img {
    width: 720px;
    aspect-ratio: 720/405;
    margin-left: auto;
  }
}

.lower-concept__about-text {
  margin-top: 13px;
  font-size: clamp(14px, 1.25vw, 18px);
  line-height: 2;
  letter-spacing: 0.1em;
  font-family: "Yu Gothic";
  opacity: 0.8;
}
@media (min-width: 768px) {
  .lower-concept__about-text {
    line-height: 2;
    margin-top: clamp(24px, 3.6805555556vw, 53px);
  }
}

/*******************************************************************
* lower-concept instagram
*******************************************************************/
.instagram {
  background: #fff;
  padding-top: clamp(116px, 11.5972222222vw, 167px);
}

.instagram__inner {
  padding-top: clamp(60px, 4.4444444444vw, 64px);
}
@media (min-width: 768px) {
  .instagram__inner {
    width: 55.5555555556%;
    max-width: 800px;
    margin-inline: auto;
  }
}

#sb_instagram {
  padding: 0 !important;
}
#sb_instagram #sbi_images {
  padding: 0 !important;
  gap: clamp(19px, 2.7777777778vw, 40px) !important;
}
.instagram__title-area {
  margin-left: 16px;
  overflow: hidden;
}
@media (min-width: 768px) {
  .instagram__title-area {
    width: 83.3333333333%;
    max-width: 1200px;
    margin-inline: auto;
  }
}

.instagram__title-area {
  overflow: visible;
}

.instagram__title-text {
  text-transform: uppercase;
}

.instagram__title-back-text {
  position: relative;
  left: clamp(55px, 6.25vw, 90px);
  top: -85px;
}
@media (min-width: 768px) {
  .instagram__title-back-text {
    top: -154px;
  }
}

.instagram__title-back-text::after {
  content: "Instagram";
}

.instagram__title-text-jp {
  margin-top: 9px;
}
@media (min-width: 768px) {
  .instagram__title-text-jp {
    margin-top: -3px;
  }
}

.instagram__btn {
  width: 200px;
  margin-inline: auto;
  margin-top: clamp(30px, 4.1666666667vw, 60px);
  padding: 15px 0;
  padding-left: 14px;
  display: flex;
  align-items: center;
  font-size: 20px;
  letter-spacing: 0.1em;
  background: #949E33;
  border-radius: 40px;
  color: #fff;
  font-family: "游明朝";
}

.fa-instagram {
  margin-right: 9px;
}

/*******************************************************************
* lower-concept company-profile
*******************************************************************/
.company-profile {
  background: #fff;
  padding-top: clamp(149px, 11.5972222222vw, 167px);
  padding-bottom: 157px;
}
@media (min-width: 768px) {
  .company-profile {
    padding-bottom: 124px;
  }
}

.company-profile__inner {
  width: 91.4666666667%;
  margin-inline: auto;
  padding-top: 2px;
}
@media (min-width: 768px) {
  .company-profile__inner {
    width: 75%;
    max-width: 1080px;
    margin-inline: auto;
  }
}

.company-profile__title-area {
  margin-left: 15px;
}
@media (min-width: 768px) {
  .company-profile__title-area {
    width: 83.3333333333%;
    max-width: 1200px;
    margin-inline: auto;
  }
}

.company-profile__title-text {
  text-transform: uppercase;
  line-height: 1.25;
}

.company-profile__title-back-text {
  position: relative;
  top: -162px;
  left: clamp(55px, 6.25vw, 90px);
}

.company-profile__title-back-text::after {
  content: "Company\aProfile";
  white-space: pre;
}
@media (min-width: 768px) {
  .company-profile__title-back-text::after {
    content: "Company Profile";
    white-space: nowrap;
  }
}

@media (min-width: 768px) {
  .company-profile__space {
    display: inline-flex;
    margin-left: 28px;
  }
}

.company-profile__title-text-jp {
  margin-top: 2px;
}
@media (min-width: 768px) {
  .company-profile__title-text-jp {
    margin-top: -5px;
  }
}

.company-profile__img {
  margin-top: 64px;
  aspect-ratio: 343/200;
}
@media (min-width: 768px) {
  .company-profile__img {
    margin-top: 51px;
    aspect-ratio: 1080/540;
  }
}

.company-profile__list {
  margin-top: clamp(40px, 4.1666666667vw, 60px);
}
@media (min-width: 768px) {
  .company-profile__list:last-child {
    white-space: nowrap;
  }
}
@media (min-width: 768px) {
  .company-profile__list {
    display: grid;
    grid-template-columns: clamp(278px, 28.8888888889vw, 416px) 1fr;
    -moz-column-gap: 0px;
         column-gap: 0px;
  }
}

.company-profile__item {
  display: grid;
  grid-template-columns: 113px 1fr;
  padding: 26px 14px;
  border-top: 1px solid #CA7F13;
}
@media (min-width: 768px) {
  .company-profile__item a[href^="tel:"] {
    pointer-events: none;
  }
}
.company-profile__item .company-profile__text {
  font-style: normal;
}
@media (max-width: 767px) {
  .company-profile__item:first-child .company-profile__label {
    transform: translateY(2px);
  }
  .company-profile__item:first-child .company-profile__text {
    transform: translateY(4px);
  }
  .company-profile__item:nth-child(2) {
    transform: translateY(2px);
  }
  .company-profile__item:nth-child(2) .company-profile__label {
    transform: translateY(5px);
  }
  .company-profile__item:nth-child(2) .company-profile__text {
    transform: translateY(6px);
  }
  .company-profile__item:nth-child(3) {
    transform: translateY(9px);
  }
  .company-profile__item:nth-child(3) .company-profile__label {
    transform: translateY(4px);
  }
  .company-profile__item:nth-child(3) .company-profile__text {
    transform: translateX(0px) translateY(6px);
  }
  .company-profile__item:nth-child(4) {
    transform: translateY(15px);
  }
  .company-profile__item:nth-child(4) .company-profile__label {
    transform: translateY(5px);
  }
  .company-profile__item:nth-child(4) .company-profile__text {
    transform: translateX(-1px) translateY(6px);
    line-height: 1.5;
  }
  .company-profile__item:nth-child(5) {
    transform: translateY(19px);
  }
  .company-profile__item:nth-child(5) .company-profile__label {
    transform: translateY(6px);
  }
  .company-profile__item:nth-child(5) .company-profile__text {
    transform: translateX(-1px) translateY(8px);
  }
  .company-profile__item:nth-child(6) {
    transform: translateY(25px);
  }
  .company-profile__item:nth-child(6) .company-profile__label {
    transform: translateY(4px);
  }
  .company-profile__item:nth-child(6) .company-profile__text {
    transform: translateY(5px);
  }
  .company-profile__item:nth-child(7) {
    transform: translateY(30px);
  }
  .company-profile__item:nth-child(7) .company-profile__label {
    transform: translateY(6px);
  }
  .company-profile__item:nth-child(7) .company-profile__text {
    transform: translateY(7px);
  }
  .company-profile__item:nth-child(9) {
    transform: translateY(36px);
    padding-right: 0;
    padding-bottom: 27px;
    border-bottom: 1px solid #CA7F13;
  }
  .company-profile__item:nth-child(9) .company-profile__label {
    transform: translateY(6px);
  }
  .company-profile__item:nth-child(9) .company-profile__text {
    transform: translateX(0px) translateY(6px);
    line-height: 1.5;
  }
}
@media (min-width: 768px) {
  .company-profile__item {
    border-top: none;
    position: relative;
    padding-top: 27px;
    padding-bottom: 26px;
    padding-left: 11px;
    padding-right: 14px;
    grid-template-columns: clamp(75px, 7.8472222222vw, 113px) 1fr;
  }
  .company-profile__item:nth-child(4) .company-profile__label {
    transform: translateY(-1px);
  }
  .company-profile__item:nth-child(4) .company-profile__text {
    transform: translateX(-2px) translateY(1px);
  }
  .company-profile__item:nth-child(5) .company-profile__label {
    transform: translateY(1px);
  }
  .company-profile__item:nth-child(5) .company-profile__text {
    transform: translateY(2px);
  }
  .company-profile__item:nth-child(6) .company-profile__label {
    transform: translateY(1px);
  }
  .company-profile__item:nth-child(6) .company-profile__text {
    transform: translateY(2px);
  }
  .company-profile__item:nth-child(7) .company-profile__label {
    transform: translateY(2px);
  }
  .company-profile__item:nth-child(7) .company-profile__text {
    transform: translateY(4px);
  }
  .company-profile__item:nth-child(9) .company-profile__label {
    transform: translateY(3px);
  }
  .company-profile__item:nth-child(9) .company-profile__text {
    transform: translateY(5px) translateX(1px);
  }
  .company-profile__item:nth-child(9) .company-profile__text::before {
    content: "-";
    margin-right: -7px;
  }
}

@media (min-width: 768px) {
  .company-profile__item::before {
    content: "";
    position: absolute;
    top: 2px;
    left: 0;
    right: 0;
    height: 1px;
    background: #CA7F13;
  }
}

.company-profile__label {
  color: #CA7F13;
  letter-spacing: 0.1em;
  font-family: "游明朝";
  font-size: clamp(14px, 1.25vw, 18px);
}

.company-profile__text {
  font-size: clamp(12px, 1.1111111111vw, 16px);
  line-height: 1.1666666667;
  letter-spacing: 0.1em;
  font-family: "Yu Gothic";
}

.company-profile__line {
  display: none;
}
@media (min-width: 768px) {
  .company-profile__line {
    display: block;
  }
}

@media (min-width: 768px) {
  .company-profile__line::before {
    content: "";
    position: absolute;
    top: 2px;
    left: 0;
    right: 0;
    height: 1px;
    background: #CA7F13;
  }
}

/*******************************************************************
* menu
*******************************************************************/
.lower-price-menu__menu {
  background: #fff;
}
@media (min-width: 768px) {
  .lower-price-menu__menu {
    padding-bottom: 34px;
  }
}

.lower-price-menu__menu-inner {
  background: #fff;
  padding-bottom: 76px;
}
@media (min-width: 1024px) {
  .lower-price-menu__menu-inner {
    display: flex;
    align-items: flex-start;
    gap: 47px;
    margin-top: 64px;
  }
}

.lower-price-menu__menu-text {
  width: 100%;
  margin-top: 30px;
  font-size: clamp(14px, 1.25vw, 18px);
  line-height: 2;
  letter-spacing: 0.1em;
  font-family: "Yu Gothic";
  color: #CA7F13;
}
@media (min-width: 1024px) {
  .lower-price-menu__menu-text {
    width: 50%;
    margin: 0;
    line-height: 2;
  }
}

.fade-up.is-show.lower-price-menu__opacity {
  opacity: 0.8;
}

.lower-price-menu__menu-text-m {
  display: block;
  margin-top: 28px;
}

.lower-price__list {
  display: flex;
  flex-direction: column;
  list-style: none;
  color: #CA7F13;
  margin-top: 69px;
}
@media (min-width: 1024px) {
  .lower-price__list {
    width: 46.25%;
    margin-left: auto;
    flex-direction: row;
    flex-wrap: wrap;
    margin-top: -4px;
  }
}

.lower-price__item:not(:first-child) {
  border-top: 1px solid #CA7F13;
}
@media (min-width: 1024px) {
  .lower-price__item {
    width: 50%;
  }
  .lower-price__item:nth-child(odd) {
    border-right: 1px solid #CA7F13;
  }
  .lower-price__item:nth-child(2) {
    border-top: none;
  }
}

.lower-price__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  text-decoration: none;
  padding-block: 8px;
  padding-inline: 0;
  padding-left: 16px;
  padding-right: 13px;
}
@media (min-width: 1024px) {
  .lower-price__link {
    padding-block: 13px;
    padding-left: 8px;
  }
}
@media (any-hover: hover) {
  .lower-price__link:hover {
    color: #54372D;
  }
  .lower-price__link:hover .lower-price__link-text {
    color: #54372D;
  }
  .lower-price__link:hover .lower-price__btn {
    color: #54372D;
  }
}

.lower-price__link-text {
  transition: all 0.5s ease;
}

.lower-price__link-text {
  display: flex;
  align-items: baseline;
  gap: clamp(8px, 0.6944444444vw, 10px);
  font-size: clamp(20px, 2.2916666667vw, 33px);
  letter-spacing: 0.04em;
  min-width: 0;
}

.lower-price__link-jp {
  font-size: clamp(12px, 0.9722222222vw, 14px);
  letter-spacing: 0.04em;
  font-family: "游明朝";
  white-space: nowrap;
}
@media (min-width: 1024px) {
  .lower-price__link-jp {
    font-size: 9px;
  }
}

.lower-price__btn {
  flex: 0 0 auto;
  font-size: clamp(11px, 1.1111111111vw, 16px);
  transition: all 0.5s ease;
}

@media (min-width: 1024px) {
  .lower-price__item:nth-child(2) .lower-price__link-text .lower-price__link-jp {
    transform: translateX(2px) translateY(1px);
  }
  .lower-price__item:nth-child(3) .lower-price__link-text {
    transform: translateX(-2px);
  }
  .lower-price__item:nth-child(3) .lower-price__link-text .lower-price__link-jp {
    transform: translateX(2px);
  }
  .lower-price__item:nth-child(4) .lower-price__link-text .lower-price__link-jp {
    transform: translateX(-1px) translateY(1px);
  }
  .lower-price__item:nth-child(5) .lower-price__link-text {
    transform: translateY(-2px);
  }
  .lower-price__item:nth-child(5) .lower-price__link-text .lower-price__link-jp {
    transform: translateX(2px);
  }
}
/*******************************************************************
* lower-price__main
*******************************************************************/
.lower-price__main {
  background: #D4CEBE;
  overflow: hidden;
}
@media (min-width: 768px) and (max-width: 1024px) {
  .lower-price__main .u-sp {
    display: initial;
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  .lower-price__main .u-pc {
    display: none;
  }
}

.lp-inner {
  padding-top: clamp(66px, 4.7916666667vw, 69px);
  padding-bottom: clamp(46px, 4.375vw, 63px);
}

.lp-inner {
  width: 91.6%;
  margin-inline: auto;
  color: #CA7F13;
}
@media (min-width: 1024px) {
  .lp-inner {
    width: 55.7291666667%;
    width: 802.5px;
  }
}
@media (min-width: 768px) and (max-width: 1024px) {
  .lp-inner {
    max-width: 60%;
  }
}

.lp-title {
  font-size: clamp(56px, 22.4vw, 84px);
  letter-spacing: 0.04em;
  text-align: center;
  margin-left: 13px;
}

.lower-price__body-title {
  margin-top: 0;
}
@media (min-width: 1024px) {
  .lower-price__body-title {
    margin-left: 15px;
  }
}

.lp-subtitle {
  margin-top: clamp(61px, 5.6944444444vw, 82px);
  font-size: clamp(18px, 1.6666666667vw, 24px);
  letter-spacing: 0.1em;
  font-family: "Yu Mincho";
  text-align: center;
}

.lower-price__body-subtitle--top {
  margin-top: 72px;
}
@media (min-width: 1024px) {
  .lower-price__body-subtitle--top {
    margin-top: 55px;
  }
}

.lp-desc {
  margin-top: 27px;
  font-size: clamp(14px, 1.25vw, 18px);
  line-height: 2.2857142857;
  letter-spacing: 0.1em;
  font-family: "游明朝";
}
@media (min-width: 1024px) {
  .lp-desc {
    margin-top: 31px;
    line-height: 1.7777777778;
    text-align: center;
    margin-left: 3px;
  }
}

.lp-part-title {
  margin-top: 23px;
  font-size: 18px;
  letter-spacing: 0.04em;
  line-height: 1.6666666667;
  font-family: "Yu Gothic";
  text-align: center;
}

.lp-sp-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 38px;
  padding: 0 0 34px;
  border-bottom: 1px solid #CA7F13;
  font-size: 16px;
  letter-spacing: 0.04em;
  font-family: "Yu Gothic";
}

.lp-sp-head__left {
  padding-left: 49px;
}

.lp-sp-head__right {
  padding-right: 40px;
}

.lp-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
}
@media (min-width: 1024px) {
  .lp-table {
    margin-top: 62px;
  }
}

.lp-thead {
  display: none;
}
@media (min-width: 1024px) {
  .lp-thead {
    display: table-header-group;
  }
}

.lp-head {
  padding-bottom: 22px;
  padding-left: 32px;
  border-bottom: 1px solid #CA7F13;
  font-size: clamp(16px, 1.25vw, 18px);
  letter-spacing: 0.04em;
  font-family: "Yu Gothic";
  text-align: center;
  vertical-align: middle;
  white-space: pre;
}

.lp-head--label {
  width: 140px;
}

@media (max-width: 1023px) {
  .lp-row {
    display: block;
  }
}

.lp-label {
  font-size: 18px;
  letter-spacing: 0.04em;
  font-family: "游ゴシック";
  text-align: center;
  vertical-align: middle;
}
@media (max-width: 1023px) {
  .lp-label {
    display: block;
    margin-top: 44px;
  }
}
@media (min-width: 1024px) {
  .lp-label {
    border-bottom: 1px solid #CA7F13;
    transform: translateX(-5px);
  }
}

.lp-cell {
  font-size: clamp(18px, 1.6666666667vw, 24px);
  letter-spacing: 0.1em;
  font-family: "Yu Mincho";
  font-weight: 600;
  text-align: center;
  vertical-align: middle;
  padding: clamp(18px, 1.5972222222vw, 23px) 0;
  border-bottom: 1px solid #CA7F13;
}
@media (max-width: 1023px) {
  .lp-cell {
    display: flex;
    justify-content: space-between;
    align-items: center;
    min-height: 74px;
  }
}
@media (max-width: 1023px) {
  .lp-cell::before {
    content: attr(data-course);
    padding-left: 0;
    font-size: 16px;
    font-family: "Yu Gothic";
    font-weight: 400;
    letter-spacing: 0.04em;
  }
}
@media (min-width: 1024px) {
  .lp-cell {
    padding-left: 31px;
  }
}

.lp-price {
  display: flex;
  align-items: center;
  gap: 8px;
}
@media (max-width: 1023px) {
  .lp-price {
    margin-left: auto;
    margin-right: 23px;
  }
}
@media (min-width: 1024px) {
  .lp-price {
    justify-content: center;
    font-weight: 600;
  }
}

@media (max-width: 1023px) {
  .lp-cell-group {
    display: block;
  }
}
@media (min-width: 1024px) {
  .lp-cell-group {
    display: none;
  }
}

.lp-yen {
  display: inline-block;
  margin-top: 0;
  margin-left: 0;
  font-size: clamp(14px, 1.25vw, 18px);
  letter-spacing: 0.1em;
}

.lp-note {
  margin-top: 12px;
  font-size: 12px;
  letter-spacing: 0.04em;
  line-height: 1.5;
  font-family: "Yu Gothic";
}
@media (min-width: 1024px) {
  .lp-note {
    text-align: right;
    margin-top: 11px;
    margin-right: 2px;
  }
}

.lower-price__body-section + .lower-price__body-section {
  margin-top: 56px;
}
@media (min-width: 1024px) {
  .lower-price__body-section + .lower-price__body-section {
    margin-top: 0;
  }
}

.lower-price__line,
.lower-price__set {
  margin-top: clamp(80px, 8.8194444444vw, 127px);
}

@media (max-width: 1023px) {
  .lower-price__line .lp-label,
  .lower-price__set .lp-label {
    margin-top: 61px;
  }
}

.sp-hide {
  display: none;
}
@media (min-width: 1024px) {
  .sp-hide {
    display: table-cell;
  }
}

.lp-head,
.lp-label,
.lp-cell,
.lp-sp-head {
  border-color: transparent;
  transition: border-color 1s ease, opacity 1s ease, transform 1s ease;
}

.lp-head.is-show,
.lp-label.is-show,
.lp-cell.is-show,
.lp-sp-head.is-show {
  border-color: #CA7F13;
}

@media (max-width: 1023px) {
  .lower-price__body-section--s .lower-price__body-table .lp-row td:nth-of-type(1) .lp-price {
    transform: translateX(2px);
  }
  .lower-price__body-section--s .lower-price__body-table .lp-row td:nth-of-type(1) .lp-price .lp-yen {
    transform: translateX(-2px) translateY(2px);
  }
  .lower-price__body-section--s .lower-price__body-table .lp-row td:nth-of-type(2) .lp-price {
    transform: translateX(2px);
  }
  .lower-price__body-section--s .lower-price__body-table .lp-row td:nth-of-type(2) .lp-price .lp-yen {
    transform: translateX(1px) translateY(3px);
  }
  .lower-price__body-section--s .lower-price__body-table .lp-row td:nth-of-type(3) .lp-price .lp-yen {
    transform: translateX(1px) translateY(3px);
  }
  .lower-price__body-section--m .lower-price__body-table .lp-row td:nth-of-type(1) .lp-price {
    transform: translateX(8px);
  }
  .lower-price__body-section--m .lower-price__body-table .lp-row td:nth-of-type(1) .lp-price .lp-yen {
    transform: translateX(-2px) translateY(2px);
  }
  .lower-price__body-section--m .lower-price__body-table .lp-row td:nth-of-type(2) .lp-price {
    transform: translateX(8px);
  }
  .lower-price__body-section--m .lower-price__body-table .lp-row td:nth-of-type(2) .lp-price .lp-yen {
    transform: translateX(1px) translateY(3px);
  }
  .lower-price__body-section--m .lower-price__body-table .lp-row td:nth-of-type(3) {
    min-height: 75px;
  }
  .lower-price__body-section--m .lower-price__body-table .lp-row td:nth-of-type(3) .lp-price {
    transform: translateY(1px);
  }
  .lower-price__body-section--m .lower-price__body-table .lp-row td:nth-of-type(3) .lp-price .lp-yen {
    transform: translateX(1px) translateY(3px);
  }
  .lower-price__body-section--l .lp-subtitle {
    margin-top: 62px;
  }
  .lower-price__body-section--l .lower-price__body-table .lp-row td:nth-of-type(1) .lp-price {
    transform: translateX(8px);
  }
  .lower-price__body-section--l .lower-price__body-table .lp-row td:nth-of-type(1) .lp-price .lp-yen {
    transform: translateX(-2px) translateY(2px);
  }
  .lower-price__body-section--l .lower-price__body-table .lp-row td:nth-of-type(2) .lp-price {
    transform: translateX(8px);
  }
  .lower-price__body-section--l .lower-price__body-table .lp-row td:nth-of-type(2) .lp-price .lp-yen {
    transform: translateX(1px) translateY(3px);
  }
  .lower-price__body-section--l .lower-price__body-table .lp-row td:nth-of-type(3) {
    min-height: 75px;
  }
  .lower-price__body-section--l .lower-price__body-table .lp-row td:nth-of-type(3) .lp-price {
    transform: translateX(6px) translateY(1px);
  }
  .lower-price__body-section--l .lower-price__body-table .lp-row td:nth-of-type(3) .lp-price .lp-yen {
    transform: translateX(1px) translateY(2px);
  }
  .lower-price__body-section--l .lp-note {
    margin-top: 11px;
  }
  .lower-price__line .lp-title {
    margin-top: 90px;
    margin-left: 17px;
  }
  .lower-price__line .lp-sp-head {
    margin-top: 46px;
  }
  .lower-price__line .lp-row:first-child .lp-cell[data-course="トライアルコース(3回)"] .lp-price {
    transform: translateX(1px);
  }
  .lower-price__line .lp-row:first-child .lp-cell[data-course="トライアルコース(3回)"] .lp-price .lp-yen {
    transform: translateX(-1px) translateY(1px);
  }
  .lower-price__line .lp-row:first-child .lp-cell[data-course="減毛コース(6回)"] .lp-price {
    transform: translateX(2px);
  }
  .lower-price__line .lp-row:first-child .lp-cell[data-course="減毛コース(6回)"] .lp-price .lp-yen {
    transform: translateY(2px);
  }
  .lower-price__line .lp-row:first-child .lp-cell[data-course="脱毛コース(12回)"] .lp-price {
    transform: translateY(1px);
  }
  .lower-price__line .lp-row:first-child .lp-cell[data-course="脱毛コース(12回)"] .lp-price .lp-yen {
    transform: translateY(3px);
  }
  .lower-price__line .lp-row:nth-child(2) .lp-label {
    margin-top: 63px;
  }
  .lower-price__line .lp-row:nth-child(2) .lp-cell[data-course="トライアルコース(3回)"] .lp-price {
    transform: translateX(7px);
  }
  .lower-price__line .lp-row:nth-child(2) .lp-cell[data-course="トライアルコース(3回)"] .lp-price .lp-yen {
    transform: translateX(-1px) translateY(1px);
  }
  .lower-price__line .lp-row:nth-child(2) .lp-cell[data-course="減毛コース(6回)"] .lp-price {
    transform: translateX(8px);
  }
  .lower-price__line .lp-row:nth-child(2) .lp-cell[data-course="減毛コース(6回)"] .lp-price .lp-yen {
    transform: translateY(2px);
  }
  .lower-price__line .lp-row:nth-child(2) .lp-cell[data-course="脱毛コース(12回)"] .lp-price {
    transform: translateY(1px);
  }
  .lower-price__line .lp-row:nth-child(2) .lp-cell[data-course="脱毛コース(12回)"] .lp-price .lp-yen {
    transform: translateY(3px);
  }
  .lower-price__line .lp-row:nth-child(3) .lp-label {
    margin-top: 63px;
  }
  .lower-price__line .lp-row:nth-child(3) .lp-cell[data-course="トライアルコース(3回)"] {
    transform: translateY(-2px);
  }
  .lower-price__line .lp-row:nth-child(3) .lp-cell[data-course="トライアルコース(3回)"] .lp-price {
    transform: translateX(8px);
  }
  .lower-price__line .lp-row:nth-child(3) .lp-cell[data-course="トライアルコース(3回)"] .lp-price .lp-yen {
    transform: translateX(-3px) translateY(2px);
  }
  .lower-price__line .lp-row:nth-child(3) .lp-cell[data-course="減毛コース(6回)"] .lp-price {
    transform: translateX(8px);
  }
  .lower-price__line .lp-row:nth-child(3) .lp-cell[data-course="減毛コース(6回)"] .lp-price .lp-yen {
    transform: translateY(2px);
  }
  .lower-price__line .lp-row:nth-child(3) .lp-cell[data-course="脱毛コース(12回)"] .lp-price {
    transform: translateX(6px);
  }
  .lower-price__line .lp-note {
    margin-top: 12px;
  }
  .lower-price__set .lp-title {
    margin-top: 91px;
    margin-left: 9px;
  }
  .lower-price__set .lp-sp-head {
    margin-top: 46px;
  }
  .lower-price__set .lp-row:first-child .lp-cell[data-course="トライアルコース(3回)"] .lp-price {
    transform: translateX(1px);
  }
  .lower-price__set .lp-row:first-child .lp-cell[data-course="トライアルコース(3回)"] .lp-price .lp-yen {
    transform: translateX(-1px) translateY(1px);
  }
  .lower-price__set .lp-row:first-child .lp-cell[data-course="減毛コース(6回)"] .lp-price {
    transform: translateX(2px);
  }
  .lower-price__set .lp-row:first-child .lp-cell[data-course="減毛コース(6回)"] .lp-price .lp-yen {
    transform: translateY(2px);
  }
  .lower-price__set .lp-row:first-child .lp-cell[data-course="脱毛コース(12回)"] .lp-price {
    transform: translateY(1px);
  }
  .lower-price__set .lp-row:first-child .lp-cell[data-course="脱毛コース(12回)"] .lp-price .lp-yen {
    transform: translateY(3px);
  }
  .lower-price__set .lp-row:nth-child(2) .lp-label {
    margin-top: 63px;
  }
  .lower-price__set .lp-row:nth-child(2) .lp-cell[data-course="トライアルコース(3回)"] .lp-price {
    transform: translateX(7px);
  }
  .lower-price__set .lp-row:nth-child(2) .lp-cell[data-course="トライアルコース(3回)"] .lp-price .lp-yen {
    transform: translateX(-1px) translateY(1px);
  }
  .lower-price__set .lp-row:nth-child(2) .lp-cell[data-course="減毛コース(6回)"] .lp-price {
    transform: translateX(8px);
  }
  .lower-price__set .lp-row:nth-child(2) .lp-cell[data-course="減毛コース(6回)"] .lp-price .lp-yen {
    transform: translateY(2px);
  }
  .lower-price__set .lp-row:nth-child(2) .lp-cell[data-course="脱毛コース(12回)"] .lp-price {
    transform: translateY(1px);
  }
  .lower-price__set .lp-row:nth-child(2) .lp-cell[data-course="脱毛コース(12回)"] .lp-price .lp-yen {
    transform: translateY(3px);
  }
  .lower-price__set .lp-row:nth-child(3) .lp-label {
    margin-top: 63px;
  }
  .lower-price__set .lp-row:nth-child(3) .lp-cell[data-course="トライアルコース(3回)"] {
    transform: translateY(-2px);
  }
  .lower-price__set .lp-row:nth-child(3) .lp-cell[data-course="トライアルコース(3回)"] .lp-price {
    transform: translateX(8px);
  }
  .lower-price__set .lp-row:nth-child(3) .lp-cell[data-course="トライアルコース(3回)"] .lp-price .lp-yen {
    transform: translateX(-3px) translateY(2px);
  }
  .lower-price__set .lp-row:nth-child(3) .lp-cell[data-course="減毛コース(6回)"] .lp-price {
    transform: translateX(8px);
  }
  .lower-price__set .lp-row:nth-child(3) .lp-cell[data-course="減毛コース(6回)"] .lp-price .lp-yen {
    transform: translateY(2px);
  }
  .lower-price__set .lp-row:nth-child(3) .lp-cell[data-course="脱毛コース(12回)"] .lp-price {
    transform: translateX(6px);
  }
  .lower-price__set .lp-row:nth-child(4) .lp-label {
    margin-top: 63px;
  }
  .lower-price__set .lp-row:nth-child(4) .lp-cell[data-course="トライアルコース(3回)"] {
    transform: translateY(-3px);
  }
  .lower-price__set .lp-row:nth-child(4) .lp-cell[data-course="トライアルコース(3回)"] .lp-price {
    transform: translateX(8px);
  }
  .lower-price__set .lp-row:nth-child(4) .lp-cell[data-course="トライアルコース(3回)"] .lp-price .lp-yen {
    transform: translateX(-3px) translateY(2px);
  }
  .lower-price__set .lp-row:nth-child(4) .lp-cell[data-course="減毛コース(6回)"] {
    transform: translateY(-3px);
  }
  .lower-price__set .lp-row:nth-child(4) .lp-cell[data-course="減毛コース(6回)"] .lp-price {
    transform: translateX(8px);
  }
  .lower-price__set .lp-row:nth-child(4) .lp-cell[data-course="減毛コース(6回)"] .lp-price .lp-yen {
    transform: translateY(2px);
  }
  .lower-price__set .lp-row:nth-child(4) .lp-cell[data-course="脱毛コース(12回)"] .lp-price {
    transform: translateX(6px);
  }
  .lower-price__set .lp-note {
    margin-top: 12px;
  }
}
@media (min-width: 1024px) {
  .lower-price__body-section--s .lp-note {
    letter-spacing: 0.35px;
  }
  .lower-price__body-section--m .lp-subtitle {
    margin-left: 11px;
  }
  .lower-price__body-section--m .lp-desc {
    margin-left: -16px;
  }
  .lower-price__body-section--m .lower-price__body-table .lp-row td:nth-of-type(1) {
    padding-left: 25px;
  }
  .lower-price__body-section--m .lower-price__body-table .lp-row td:nth-of-type(1) .lp-yen {
    padding-top: 5px;
  }
  .lower-price__body-section--m .lower-price__body-table .lp-row td:nth-of-type(2) {
    padding-left: 43px;
  }
  .lower-price__body-section--m .lower-price__body-table .lp-row td:nth-of-type(2) .lp-yen {
    padding-top: 5px;
  }
  .lower-price__body-section--m .lower-price__body-table .lp-row td:nth-of-type(3) {
    padding-left: 43px;
  }
  .lower-price__body-section--m .lower-price__body-table .lp-row td:nth-of-type(3) .lp-yen {
    padding-top: 5px;
  }
  .lower-price__body-section--l .lp-subtitle {
    margin-top: 84px;
    margin-left: 6px;
  }
  .lower-price__body-section--l .lp-desc {
    margin-left: -8px;
  }
  .lower-price__body-section--l .lower-price__body-table .lp-row td:nth-of-type(1) {
    padding-left: 32px;
  }
  .lower-price__body-section--l .lower-price__body-table .lp-row td:nth-of-type(1) .lp-yen {
    padding-top: 5px;
  }
  .lower-price__body-section--l .lower-price__body-table .lp-row td:nth-of-type(2) {
    padding-left: 50px;
  }
  .lower-price__body-section--l .lower-price__body-table .lp-row td:nth-of-type(2) .lp-yen {
    padding-top: 5px;
  }
  .lower-price__body-section--l .lower-price__body-table .lp-row td:nth-of-type(3) {
    padding-left: 72px;
  }
  .lower-price__body-section--l .lower-price__body-table .lp-row td:nth-of-type(3) .lp-yen {
    padding-top: 5px;
  }
  .lower-price__line .lp-title {
    margin-left: 15px;
  }
  .lower-price__line .lp-table {
    margin-top: 71px;
  }
  .lower-price__line .lp-tbody .lp-row:first-of-type .lp-label {
    padding-right: 8px;
  }
  .lower-price__line .lp-tbody .lp-row:first-of-type > td.sp-hide:nth-of-type(2) {
    padding-left: 53px;
  }
  .lower-price__line .lp-tbody .lp-row:first-of-type > td.sp-hide:nth-of-type(3) {
    padding-left: 55px;
  }
  .lower-price__line .lp-tbody .lp-row:first-of-type > td.sp-hide:last-of-type {
    padding-left: 56px;
  }
  .lower-price__line .lp-tbody .lp-row:nth-of-type(2) .lp-label {
    padding-right: 3px;
  }
  .lower-price__line .lp-tbody .lp-row:nth-of-type(2) > td.sp-hide:nth-of-type(2) {
    padding-left: 48px;
  }
  .lower-price__line .lp-tbody .lp-row:nth-of-type(2) > td.sp-hide:nth-of-type(3) {
    padding-left: 50px;
  }
  .lower-price__line .lp-tbody .lp-row:nth-of-type(2) > td.sp-hide:last-of-type {
    padding-left: 51px;
  }
  .lower-price__line .lp-tbody .lp-row:nth-of-type(3) {
    padding-bottom: 0;
  }
  .lower-price__line .lp-tbody .lp-row:nth-of-type(3) .lp-label {
    padding-right: 3px;
  }
  .lower-price__line .lp-tbody .lp-row:nth-of-type(3) > td.sp-hide:nth-of-type(2) {
    padding-left: 47px;
  }
  .lower-price__line .lp-tbody .lp-row:nth-of-type(3) > td.sp-hide:nth-of-type(3) {
    padding-left: 50px;
  }
  .lower-price__line .lp-tbody .lp-row:nth-of-type(3) > td.sp-hide:last-of-type {
    padding-left: 50px;
  }
  .lower-price__set .lp-title {
    margin-left: 10px;
  }
  .lower-price__set .lp-table {
    margin-top: 71px;
  }
  .lower-price__set .lp-tbody .lp-row:first-of-type .lp-label {
    padding-right: 7px;
  }
  .lower-price__set .lp-tbody .lp-row:first-of-type > td.sp-hide:nth-of-type(2) {
    padding-left: 53px;
  }
  .lower-price__set .lp-tbody .lp-row:first-of-type > td.sp-hide:nth-of-type(3) {
    padding-left: 55px;
  }
  .lower-price__set .lp-tbody .lp-row:first-of-type > td.sp-hide:last-of-type {
    padding-left: 56px;
  }
  .lower-price__set .lp-tbody .lp-row:nth-of-type(2) .lp-label {
    padding-right: 3px;
  }
  .lower-price__set .lp-tbody .lp-row:nth-of-type(2) > td.sp-hide:nth-of-type(2) {
    padding-left: 48px;
  }
  .lower-price__set .lp-tbody .lp-row:nth-of-type(2) > td.sp-hide:nth-of-type(3) {
    padding-left: 50px;
  }
  .lower-price__set .lp-tbody .lp-row:nth-of-type(2) > td.sp-hide:last-of-type {
    padding-left: 51px;
  }
  .lower-price__set .lp-tbody .lp-row:nth-of-type(3) .lp-cell {
    padding-bottom: 21px;
  }
  .lower-price__set .lp-tbody .lp-row:nth-of-type(3) .lp-label {
    padding-right: 2px;
  }
  .lower-price__set .lp-tbody .lp-row:nth-of-type(3) > td.sp-hide:nth-of-type(2) {
    padding-left: 47px;
  }
  .lower-price__set .lp-tbody .lp-row:nth-of-type(3) > td.sp-hide:nth-of-type(3) {
    padding-left: 50px;
  }
  .lower-price__set .lp-tbody .lp-row:nth-of-type(3) > td.sp-hide:last-of-type {
    padding-left: 50px;
  }
  .lower-price__set .lp-tbody .lp-row:nth-of-type(4) .lp-cell {
    padding-bottom: 20px;
  }
  .lower-price__set .lp-tbody .lp-row:nth-of-type(4) .lp-label {
    padding-right: 3px;
  }
  .lower-price__set .lp-tbody .lp-row:nth-of-type(4) > td.sp-hide:nth-of-type(2) {
    padding-left: 48px;
  }
  .lower-price__set .lp-tbody .lp-row:nth-of-type(4) > td.sp-hide:nth-of-type(3) {
    padding-left: 48px;
  }
  .lower-price__set .lp-tbody .lp-row:nth-of-type(4) > td.sp-hide:last-of-type {
    padding-left: 50px;
  }
}
/*******************************************************************
* lp-custom
*******************************************************************/
.lp-custom {
  background: #fff;
}

.lp-custom__inner {
  padding-top: 80px;
  padding-bottom: 76px;
}
@media (min-width: 1024px) {
  .lp-custom__inner {
    width: 75%;
    margin-inline: auto;
    display: flex;
    gap: 60px;
    padding-top: 79px;
    padding-bottom: 78px;
  }
}

.lp-custom__img {
  width: 240px;
  aspect-ratio: 240/240;
  margin-inline: auto;
}
@media (min-width: 1024px) {
  .lp-custom__img {
    width: 480px;
    aspect-ratio: 480/480;
  }
}

.lp-custom__text-area {
  margin-top: 66px;
  color: #CA7F13;
}
@media (min-width: 1024px) {
  .lp-custom__text-area {
    margin-top: 0;
    padding-top: 14px;
    flex: 1;
  }
}

.lp-custom__title {
  font-size: 48px;
  letter-spacing: 0.1em;
}

.lp-custom__text {
  margin-top: clamp(12px, 3.75vw, 54px);
  font-size: clamp(14px, 1.25vw, 18px);
  line-height: 2;
  letter-spacing: 0.1em;
  font-family: "游ゴシック";
}
@media (min-width: 1024px) {
  .lp-custom__text {
    line-height: 2;
  }
}

/*******************************************************************
 * lr
 *******************************************************************/
.lr-top {
  color: #CA7F13;
  background: #F9F8F6;
  padding-bottom: clamp(80px, 8.3333333333vw, 120px);
}

@media (min-width: 1160px) {
  .lr-top__inner {
    width: 73.6805555556%;
    margin-inline: auto;
  }
}

@media (min-width: 1160px) {
  .lr-head__list {
    padding-top: clamp(12px, 0.9027777778vw, 13px);
    margin-left: 119px;
  }
}

.lr-head__title {
  margin-top: clamp(80px, 11.1111111111vw, 160px);
}

.lr-c-head__title {
  margin-top: clamp(80px, 11.9444444444vw, 172px);
}

.lr-top__consent-form-area {
  margin-top: clamp(74px, 8.1944444444vw, 118px);
}
@media (min-width: 1160px) {
  .lr-top__consent-form-area {
    display: flex;
    flex-direction: row-reverse;
    gap: 101px;
    margin-left: -10px;
  }
}

.lr-c-top__consent-form-area {
  margin-top: clamp(74px, 8.125vw, 117px);
}

.lr-t-top__consent-form-area {
  margin-top: clamp(74px, 7.0138888889vw, 101px);
}

.lr-top__cf-dl-area {
  margin-inline: auto;
  width: 240px;
  height: 147px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: #D4CEBE;
}
@media (min-width: 1160px) {
  .lr-top__cf-dl-area {
    margin-top: 9px;
    transform: translateX(-9px);
  }
}

.lr-top__cf-dl-title {
  display: inline-block;
  font-size: 18px;
  letter-spacing: 0.1em;
  font-family: "Yu Gothic";
  padding-left: 3px;
}

.lr-top__cf-dl-link {
  margin-top: 16px;
  width: 160px;
  height: 40px;
  display: flex;
  align-items: center;
  background: #949E33;
  border-radius: 40px;
  color: #fff;
}

.lr-top__cf-dl-link-text {
  font-size: 16px;
  letter-spacing: 0.1em;
  font-family: "游明朝";
  margin-top: 5px;
}

.lr-top__cf-dl-btn {
  margin-top: 3px;
  margin-left: 12px;
  margin-right: 9px;
}
@media (min-width: 1160px) {
  .lr-top__cf-dl-btn {
    margin-right: 5px;
  }
}

@media (min-width: 1160px) {
  .lr-top__cf-text-area {
    flex: 1;
  }
}

.lr-top__cf-title {
  margin-top: 25px;
  font-size: clamp(24px, 2.2222222222vw, 32px);
  letter-spacing: 0.1em;
  font-family: "游明朝";
  line-height: 1.3333333333;
}
@media (min-width: 1160px) {
  .lr-top__cf-title {
    margin-top: 0;
  }
}

.lr-top__cf-text {
  margin-top: clamp(14px, 2.7083333333vw, 39px);
  font-size: clamp(14px, 1.25vw, 18px);
  line-height: 1.5;
  letter-spacing: 0.1em;
  font-family: "Yu Gothic";
}
@media (min-width: 1160px) {
  .lr-top__cf-text {
    line-height: 1.5;
  }
}

.lr-top__tel-area {
  margin-top: clamp(33px, 8.8194444444vw, 127px);
}
@media (min-width: 1160px) {
  .lr-top__tel-area {
    display: flex;
    gap: 100px;
    align-items: center;
  }
}

@media (min-width: 1160px) {
  .lr-top__title-area {
    border-right: 1px solid #CA7F13;
    margin-left: -10px;
    padding-right: 61px;
  }
}

.lr-top__tel-title {
  font-size: clamp(24px, 3.3333333333vw, 48px);
  letter-spacing: 0.1em;
  text-align: center;
  text-transform: uppercase;
}
@media (min-width: 1160px) {
  .lr-top__tel-title {
    text-align: left;
  }
}

.lr-top__tel-title-text {
  margin-top: clamp(14px, 1.875vw, 27px);
  font-size: clamp(14px, 1.25vw, 18px);
  line-height: 1.5;
  letter-spacing: 0.1em;
  font-family: "Yu Gothic";
}
@media (min-width: 1160px) {
  .lr-top__tel-title-text {
    width: 578px;
    height: 131px;
    flex: 1;
  }
}

.lr-top__tel-btn-area {
  margin-top: 25px;
  padding-left: 12px;
  text-align: center;
}
@media (min-width: 1160px) {
  .lr-top__tel-btn-area {
    padding-left: 0;
    margin-left: -4px;
    margin-top: 21px;
  }
}

.lr-top__tel-btn {
  font-size: clamp(24px, 2.2222222222vw, 32px);
  letter-spacing: 0.1em;
}

.lr-top__tel-btn-text {
  margin-inline: auto;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 240px;
  height: 32px;
  margin-top: clamp(19px, 2.7083333333vw, 39px);
  border: 1px solid #CA7F13;
  border-radius: 16px;
  font-size: 14px;
  letter-spacing: 0.1em;
  font-family: "游ゴシック";
}

/*******************************************************************
* lr-mail-form
*******************************************************************/
.lr-mail-form {
  background: #ede9e4;
}

.lr-mf__inner {
  padding-top: clamp(64px, 5.5555555556vw, 80px);
  padding-bottom: clamp(33px, 3.8888888889vw, 56px);
}
@media (min-width: 1160px) {
  .lr-mf__inner {
    width: 75%;
    max-width: 80%;
    margin-inline: auto;
  }
}

.lr-c-mf__inner {
  padding-top: clamp(64px, 4.5833333333vw, 66px);
}

.lr-t-mf__inner {
  padding-top: clamp(64px, 4.5833333333vw, 66px);
  padding-bottom: 85px;
}

@media (min-width: 1160px) {
  .lr-mf__top {
    display: flex;
    justify-content: center;
    gap: 96px;
  }
}

@media (min-width: 1160px) {
  .lr-mf__title-area {
    margin-top: 10px;
  }
}

.lr-mf__title {
  font-size: clamp(32px, 3.3333333333vw, 48px);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #CA7F13;
}

.lr-mf-title-text {
  margin-top: clamp(16px, 3.3333333333vw, 48px);
  font-size: 14px;
  line-height: 2;
  letter-spacing: 0.1em;
  font-family: "Yu Gothic";
}

.lr-mf__list {
  margin-top: 26px;
  display: flex;
  justify-content: center;
  gap: clamp(19px, 1.8402777778vw, 26.5px);
}
@media (min-width: 1160px) {
  .lr-mf__list {
    margin-top: 0;
  }
}

.lr-mf__top-item {
  width: clamp(93px, 9.0972222222vw, 131px);
  height: clamp(129px, 12.7083333333vw, 183px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 19px;
  align-items: center;
  color: #707070;
  border-top: 1px solid #707070;
  border-bottom: 1px solid #707070;
}

.active {
  color: #CA7F13;
  border-color: #CA7F13;
}

.lr-mf__step {
  font-size: clamp(14px, 1.3888888889vw, 20px);
  letter-spacing: 0.1em;
}

.lr-mf__step-text {
  font-size: clamp(16px, 1.6666666667vw, 24px);
  letter-spacing: 0.1em;
}
@media (min-width: 1160px) {
  .lr-mf__step-text {
    margin-bottom: -5px;
  }
}

.lr-mf__main {
  margin-top: 60px;
}
@media (min-width: 1160px) {
  .lr-mf__main {
    width: -moz-fit-content;
    width: fit-content;
    margin-inline: auto;
    min-width: 1020px;
    margin-top: 56px;
  }
}
@media (min-width: 768px) and (max-width: 1160px) {
  .lr-mf__main {
    max-width: 70%;
    margin-inline: auto;
  }
}

.lr-mf__main-item {
  font-family: "Yu Mincho";
}
@media (min-width: 1160px) {
  .lr-mf__main-item {
    display: flex;
    align-items: center;
  }
}

.lr-mf__main-item-rubi,
.lr-mf__main-item-tel,
.lr-mf__main-item-mail,
.lr-mf__main-item-contact {
  margin-top: 32px;
}

.lr-mf__main-item-time,
.lr-mf__main-item-option,
.lr-mf__main-item-store,
.lr-mf__main-item-calender,
.lr-mf__main-item-content {
  margin-top: 37px;
}

@media (min-width: 1160px) {
  .lr-mf__main-item-time .lr-mf__label {
    margin-top: 11px;
  }
}

@media (min-width: 1160px) {
  .lr-mf__main-item-calender {
    margin-top: 38px;
  }
  .lr-mf__main-item-calender input {
    width: 300px;
  }
}

@media (min-width: 1160px) {
  .lr-mf__main-item-content {
    margin-top: 28px;
    align-items: start;
  }
  .lr-mf__main-item-content .lr-mf__label {
    margin-top: 22px;
  }
}

.lr-mf__label {
  display: flex;
  align-items: center;
  gap: 16px;
  font-size: 16px;
  letter-spacing: 0.1em;
}
@media (min-width: 1160px) {
  .lr-mf__label {
    width: 260px;
    flex-basis: 382px;
    padding-left: 10px;
  }
}

.lr-mf__required {
  width: 60px;
  height: 26px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #54372D;
  color: #fff;
  text-align: center;
  border-radius: 15px;
  font-size: 12px;
  letter-spacing: 0.1em;
}

.lr-mf__input {
  width: 100%;
  height: 50px;
  border: none;
  border-radius: 2px;
  padding: 20px;
  margin-top: 12px;
  font-size: clamp(14px, 1.1111111111vw, 16px);
  font-family: "Yu Gothic";
  color: #333333;
}
@media (min-width: 1160px) {
  .lr-mf__input {
    width: clamp(328px, 43.0555555556vw, 620px);
    margin-top: 0;
  }
}

.lr-mf__any {
  width: 60px;
  height: 26px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #D4CEBE;
  text-align: center;
  border-radius: 15px;
  font-size: 12px;
  letter-spacing: 0.1em;
}

.lr-mf__time-area {
  margin-top: 14px;
}
@media (min-width: 1160px) {
  .lr-mf__time-area {
    margin-top: 0;
    margin-left: 3px;
  }
}

@media (min-width: 1160px) {
  .lr-mf__weekdays-area,
  .lr-mf__holiday-area {
    display: flex;
    align-items: center;
    gap: 18px;
  }
}

@media (min-width: 1160px) {
  .lr-mf__holiday-area {
    margin-top: 12px;
  }
}
@media (min-width: 1160px) and (min-width: 1160px) {
  .lr-mf__holiday-area {
    margin-top: 7px;
  }
}

.lr-mf__weekdays-title {
  margin-top: 14px;
  font-size: 14px;
  letter-spacing: 0.1em;
  font-family: "Yu Gothic";
}
@media (min-width: 1160px) {
  .lr-mf__weekdays-title {
    margin-top: 0;
    margin-bottom: 5px;
  }
}

.lr-mf__holiday-title {
  margin-top: 19px;
  font-size: 14px;
  letter-spacing: 0.1em;
  font-family: "Yu Gothic";
}
@media (min-width: 1160px) {
  .lr-mf__holiday-title {
    margin-top: 0;
  }
}

.lr-mf__weekdays-list,
.lr-mf__holiday-list {
  display: flex;
  flex-wrap: wrap;
  row-gap: 10px;
  -moz-column-gap: clamp(24.5px, 6.25vw, 90px);
       column-gap: clamp(24.5px, 6.25vw, 90px);
  margin-top: 13px;
  align-items: center;
}
@media (min-width: 1160px) {
  .lr-mf__weekdays-list,
  .lr-mf__holiday-list {
    flex-wrap: nowrap;
    margin-top: 0;
  }
  .lr-mf__weekdays-list .wpcf7-form-control,
  .lr-mf__holiday-list .wpcf7-form-control {
    display: flex;
    gap: 89px;
  }
  .lr-mf__weekdays-list .wpcf7-list-item-label,
  .lr-mf__holiday-list .wpcf7-list-item-label {
    cursor: pointer;
  }
}

.lr-mf__weekdays-item,
.lr-mf__holiday-item {
  display: flex;
  align-items: center;
}

.lr-mf__weekdays-input,
.lr-mf__holiday-input {
  margin: 0;
}

input[type=checkbox],
input[type=radio i] {
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none;
  width: 30px;
  height: 30px;
  background: #fff;
  position: relative;
  cursor: pointer;
}
input[type=checkbox]:checked::after,
input[type=radio i]:checked::after {
  content: "";
  position: absolute;
  top: 7px;
  left: 13px;
  width: 4px;
  height: 9px;
  border-right: 2px solid #CA7F13;
  border-bottom: 2px solid #CA7F13;
  transform: rotate(45deg);
}

.lr-mf__weekdays-label,
.lr-mf__holiday-label {
  margin-left: 12px;
  font-size: 14px;
  letter-spacing: 0.1em;
  font-family: "Yu Gothic";
}

.wpcf7-list-item {
  margin: 0;
}
.wpcf7-list-item label {
  display: inline-flex;
  align-items: center;
  gap: 13px;
  font-size: 14px;
  letter-spacing: 0.1em;
  font-family: "Yu Gothic";
}
.wpcf7-list-item input {
  margin: 0;
}
.wpcf7-list-item:last-child {
  margin-top: 10px;
}
@media (min-width: 1160px) {
  .wpcf7-list-item:last-child {
    margin-top: 0;
  }
}
.wpcf7-list-item:nth-child(odd) {
  margin-right: 22px;
}
@media (min-width: 1160px) {
  .wpcf7-list-item:nth-child(odd) {
    margin-right: 0;
  }
}
.wpcf7-list-item:nth-child(2) {
  margin-right: 23px;
}
@media (min-width: 1160px) {
  .wpcf7-list-item:nth-child(2) {
    margin-right: 0;
  }
}

.lr-mf__main-item-option {
  margin-top: 36px;
}

.lr-mf__option-list {
  display: flex;
  flex-direction: column;
  row-gap: 12px;
  margin-top: 10px;
}
@media (min-width: 1160px) {
  .lr-mf__option-list {
    width: 620px;
    margin-top: -1px;
    flex-direction: row;
    flex-wrap: wrap;
  }
  .lr-mf__option-list .wpcf7-form-control {
    display: flex;
    flex-wrap: wrap;
    row-gap: 7px;
  }
  .lr-mf__option-list .wpcf7-list-item-label {
    cursor: pointer;
  }
}
@media (min-width: 1160px) {
  .lr-mf__option-list .wpcf7-list-item {
    width: 280px;
  }
}
.lr-mf__option-list .wpcf7-list-item:not(:first-child) {
  margin-top: 10px;
}
@media (min-width: 1160px) {
  .lr-mf__option-list .wpcf7-list-item:not(:first-child) {
    margin: 0;
  }
}

.lr-mf__option-item {
  display: flex;
  align-items: center;
}
@media (min-width: 1160px) {
  .lr-mf__option-item {
    width: 278px;
  }
}

@media (min-width: 1160px) {
  .lr-mf__option-input {
    margin: 0;
  }
}

.lr-mf__option-label {
  margin-left: 13px;
  font-size: 14px;
  letter-spacing: 0.1em;
  font-family: "Yu Gothic";
}

@media (min-width: 1160px) {
  .lr-mf__main-item-store {
    margin-top: 36px;
  }
}

@media (min-width: 1160px) {
  .lr-mf__input-store {
    width: 300px;
  }
}

.lr-mf__calendar {
  display: flex;
  align-items: center;
  position: relative;
}
@media (min-width: 1160px) {
  .lr-mf__calendar {
    align-items: flex-end;
    margin-top: -4px;
  }
}
.lr-mf__calendar .wpcf7-form-control-wrap {
  width: 100%;
}
@media (min-width: 1160px) {
  .lr-mf__calendar .wpcf7-form-control-wrap {
    width: 300px;
  }
}

.lr-mf__calendar {
  position: relative;
}

.lr-mf__input-calendar {
  width: 100%;
  color: #333333;
  font-size: 14px;
  letter-spacing: 0.1em;
  font-family: "Yu Gothic";
  cursor: pointer;
}

.lr-mf__input-calendar::-webkit-calendar-picker-indicator {
  opacity: 0;
  position: absolute;
  top: 0;
  right: 0;
  width: 50px;
  height: 50px;
  cursor: pointer;
}

.lr-mf__icon {
  position: absolute;
  top: 12px;
  right: 0;
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #CA7F13;
  font-size: 26px;
  color: #fff;
  pointer-events: none;
}
@media (min-width: 1160px) {
  .lr-mf__icon {
    top: initial;
  }
}

.lr-top__cf-dl-link {
  transition: all 0.5s ease;
}
@media (any-hover: hover) {
  .lr-top__cf-dl-link:hover .lr-top__cf-dl-btn,
  .lr-top__cf-dl-link:hover .lr-top__cf-dl-link-text {
    color: #54372D;
  }
}

.lr-mf__content {
  margin-top: 10px;
  border: none;
  width: 100%;
  height: 200px;
  display: block;
  padding: 20px;
}
@media (min-width: 1160px) {
  .lr-mf__content {
    width: 100%;
    height: 118px;
  }
}

.lr-mf__text-area {
  width: 100%;
  font-family: "游ゴシック";
  font-size: clamp(14px, 1.1111111111vw, 16px);
  color: #333333;
}
@media (min-width: 1160px) {
  .lr-mf__text-area {
    width: 620px;
  }
}

.lr-mf__text-area p {
  width: 100%;
}

.lr-mf__note {
  margin-top: 3px;
  font-size: 12px;
  line-height: 2.3333333333;
  letter-spacing: 0.1em;
  font-family: "Yu Gothic";
}

.lr-mf-btn {
  margin-inline: auto;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 32px;
  width: 160px;
  height: 40px;
  background: #949E33;
  border: none;
  border-radius: 40px;
  color: #fff;
  font-size: 16px;
  letter-spacing: 0.1em;
  font-family: "Yu Mincho";
}
@media (min-width: 1160px) {
  .lr-mf-btn {
    margin-top: 27px;
  }
}

/*******************************************************************
* confirm
*******************************************************************/
@media (min-width: 1160px) {
  .confirm__mf {
    max-width: 1024px;
    padding-top: 72px;
  }
}
@media (min-width: 1160px) {
  .confirm__mf:not(:first-child) {
    margin-top: 22px;
  }
}

@media (min-width: 1160px) {
  .confirm-item {
    width: 100%;
    display: flex;
    align-items: center;
    padding: 20px 0;
  }
}

.confirm-label {
  display: flex;
  align-items: center;
  gap: 16px;
  font-size: 16px;
  letter-spacing: 0.1em;
  font-family: "Yu Mincho";
}
@media (min-width: 1160px) {
  .confirm-label {
    width: 38%;
  }
}

.confirm-text {
  margin-top: 12px;
  font-size: clamp(14px, 1.1111111111vw, 16px);
  letter-spacing: 0.1em;
  font-family: "Yu Gothic";
}
@media (min-width: 1160px) {
  .confirm-text {
    margin-top: 0;
    flex: 1;
  }
}

.cl-mm {
  margin-top: 36px;
}
@media (min-width: 1160px) {
  .cl-mm {
    margin-top: 0;
  }
}

.cl-ml {
  margin-top: 41px;
}
@media (min-width: 1160px) {
  .cl-ml {
    margin-top: 0;
  }
}

@media (min-width: 1160px) {
  .contact-item {
    display: flex;
    align-items: center;
    height: auto;
    margin-top: 19px;
  }
  .contact-item .confirm-label {
    margin-top: 8px;
  }
}

.weekdays-select,
.holiday-select {
  line-height: 2em;
  cursor: pointer;
}

.confirm-contact {
  margin-top: 12px;
  font-size: 14px;
  line-height: 2;
  letter-spacing: 0.1em;
  font-family: "Yu Gothic";
  overflow-wrap: anywhere;
}
@media (min-width: 1160px) {
  .confirm-contact {
    margin-top: -7px;
    flex-wrap: wrap;
  }
}

.confirm-btn {
  margin-top: 34px;
  margin-inline: auto;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 160px;
  height: 40px;
  background: #949E33;
  border: none;
  border-radius: 40px;
  color: #fff;
  font-size: 16px;
  letter-spacing: 0.1em;
  font-family: "Yu Mincho";
}
@media (min-width: 1160px) {
  .confirm-btn {
    margin-top: 61px;
  }
}

@media (min-width: 768px) {
  .lr-c-mf__inner .confirm-item {
    width: 100%;
    display: flex;
    align-items: center;
    padding: 17px 10px;
  }
}

/*******************************************************************
* thanks
*******************************************************************/
.thanks__main {
  color: #CA7F13;
}

.thanks__title {
  margin-top: 48px;
  font-size: clamp(24px, 2.5vw, 36px);
  line-height: 1.5;
  letter-spacing: 0.1em;
  font-family: "Yu Mincho";
}
@media (min-width: 1160px) {
  .thanks__title {
    text-align: center;
    margin-top: 26px;
  }
}

.thanks__text-area {
  margin-top: clamp(12px, 1.5277777778vw, 32px);
  font-size: clamp(14px, 1.25vw, 18px);
  line-height: 1.5;
  letter-spacing: 0.04em;
  font-family: "Yu Gothic";
}
@media (min-width: 1160px) {
  .thanks__text-area {
    display: flex;
    justify-content: center;
    line-height: 2;
  }
}

.thanks__link {
  text-decoration-line: underline;
}

/*******************************************************************
* salons archive
*******************************************************************/
.ls-main__inner {
  padding-bottom: clamp(81px, 8.3333333333vw, 120px);
}

.ls__title-area {
  margin-top: clamp(110px, 7.9861111111vw, 115px);
  margin-left: 16px;
  width: -moz-fit-content;
  width: fit-content;
}
@media (min-width: 768px) {
  .ls__title-area {
    margin-left: clamp(16px, 8.2638888889vw, 119px);
    overflow: hidden;
  }
}

.ls__title-text {
  text-transform: uppercase;
  display: inline-block;
}

.ls__title-text-jp {
  margin-top: 9px;
}

.ls__title-back-text::after {
  content: "Prefectures";
  top: -40px;
  left: 67px;
}

/* ========================================
  inner
======================================== */
.ls-nav__inner,
.ls-area__inner {
  color: #CA7F13;
}

.ls-nav,
.ls-area {
  overflow: hidden;
}

/* ========================================
  都道府県ナビ
======================================== */
.ls-nav__list {
  margin-top: clamp(85px, 8.9583333333vw, 117px);
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 15px 20px;
}
@media (min-width: 768px) {
  .ls-nav__list {
    max-width: 910px;
    margin-left: 60px;
    gap: 32px 60px;
  }
}

.ls-nav__link {
  display: inline-flex;
  align-items: baseline;
  gap: 7px;
  position: relative;
  padding-left: 14px;
  transition: all 0.5s ease;
}
@media (min-width: 768px) {
  .ls-nav__link {
    padding-left: 35px;
    gap: 10px;
  }
}
@media (any-hover: hover) {
  .ls-nav__link:hover {
    color: #54372D;
  }
}

.ls-nav__link::before {
  content: "";
  position: absolute;
  left: 0;
  top: clamp(6.5px, 1.0416666667vw, 15px);
  width: 0;
  height: 0;
  border-top: 3px solid transparent;
  border-bottom: 4px solid transparent;
  border-left: 6px solid #54372D;
}
@media (min-width: 768px) {
  .ls-nav__link::before {
    border-top-width: 9px;
    border-bottom-width: 8px;
    border-left-width: 13px;
  }
}

.ls-nav__name-en {
  font-size: clamp(20px, 3.3333333333vw, 48px);
  letter-spacing: 0.1em;
}
.ls-nav__name-ja {
  font-size: clamp(12px, 0.9722222222vw, 14px);
  letter-spacing: 0.04em;
  font-family: "Yu Gothic";
}
/* ========================================
  エリア
======================================== */
.ls-area__inner {
  padding-top: clamp(83px, 6.0416666667vw, 87px);
}

.ls-area__title {
  font-size: clamp(24px, 3.3333333333vw, 48px);
  letter-spacing: 0.1em;
  text-align: center;
  background: #CA7F13;
  color: #fff;
  padding: clamp(18px, 2.4305555556vw, 35px) 0;
}

@media (min-width: 768px) {
  .ls-area__list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-top: 60px;
    row-gap: 60px;
  }
}

.ls-area__item {
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
}
@media (min-width: 768px) {
  .ls-area__item {
    margin-inline: 0;
  }
}

.ls-area-card {
  margin-top: 38px;
  display: block;
  color: inherit;
  text-decoration: none;
}
@media (min-width: 768px) {
  .ls-area-card {
    margin-top: 0;
  }
}

.ls-area-card__img iframe {
  pointer-events: none;
}

.ls-area-card__img {
  overflow: hidden;
  transition: transform 0.4s ease;
}

.ls-area-card__address-wrap {
  font-style: normal;
}

@media (any-hover: hover) {
  .ls-area-card:hover {
    color: #54372D;
  }
  .ls-area-card:hover .ls-area-card__address {
    color: #CA7F13;
  }
  .ls-area-card:hover .ls-area-card__img {
    transform: scale(1.05);
  }
}
/* ========================================
  カード
======================================== */
.ls-area-card {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.ls-area-card__img {
  display: block;
  overflow: hidden;
  width: clamp(315px, 39.5833333333vw, 570px);
  aspect-ratio: 315/200;
}
@media (min-width: 768px) {
  .ls-area-card__img {
    aspect-ratio: 570/360;
  }
}
.ls-area-card__img iframe {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
}

.ls-area-card__body-link {
  display: block;
  height: 100%;
  color: inherit;
  text-decoration: none;
}

.ls-area-card__name-en {
  margin-top: 13px;
  font-size: clamp(20px, 2.2222222222vw, 32px);
  letter-spacing: 0.1em;
}

.ls-area-card__name-ja {
  margin-top: 9px;
  font-size: clamp(14px, 1.1428571429vw, 16px);
  letter-spacing: 0.1em;
  font-family: "Yu Mincho";
}
@media (min-width: 768px) {
  .ls-area-card__name-ja {
    margin-top: 7px;
  }
}

.ls-area-card__address {
  margin-top: 9px;
  font-size: 14px;
  letter-spacing: 0.1em;
  color: #464646;
  font-family: "Yu Gothic";
  opacity: 1;
  transform: none;
  visibility: visible;
}

#kanagawa,
#saitama,
#osaka,
#kyoto {
  background: #fff;
}
@media (min-width: 768px) {
  #kanagawa .ls-area__inner,
  #saitama .ls-area__inner,
  #osaka .ls-area__inner,
  #kyoto .ls-area__inner {
    padding-top: 82px;
  }
}

#fukuoka,
#okinawa {
  background: #fff;
  padding-top: 12px;
}
@media (min-width: 768px) {
  #fukuoka .ls-area__inner,
  #okinawa .ls-area__inner {
    padding-top: 69px;
  }
}

/*******************************************************************
* salons single
*******************************************************************/
.ls-s-head__title-area {
  margin-top: clamp(94px, 12.0138888889vw, 173px);
  padding-top: clamp(64px, 7.0833333333vw, 102px);
  padding-bottom: clamp(64px, 7.2222222222vw, 104px);
  color: #CA7F13;
  background: #D4CEBE;
  text-align: center;
}

.ls-s-head__title {
  display: inline-block;
  text-transform: uppercase;
  font-size: clamp(24px, 3.3333333333vw, 48px);
  letter-spacing: 0.1em;
  margin-left: clamp(3px, 0.4166666667vw, 6px);
}

.ls-salons-fv__name {
  margin-top: clamp(16px, 1.8055555556vw, 26px);
  font-size: clamp(32px, 5.5555555556vw, 80px);
  letter-spacing: 0.1em;
  font-family: "游明朝";
  padding-left: clamp(4px, 0.4861111111vw, 7px);
}

.ls-s-top-desc__text {
  margin-top: clamp(70px, 7.5694444444vw, 109px);
  font-size: clamp(14px, 1.3888888889vw, 20px);
  letter-spacing: 0.1em;
  line-height: 2;
  font-family: "游明朝";
}
@media (min-width: 768px) {
  .ls-s-top-desc__text {
    text-align: center;
    line-height: 2;
  }
}

/*******************************************************************
* flow
*******************************************************************/
.ls-s-flow {
  overflow: hidden;
  background: #fff;
}
@media (min-width: 768px) {
  .ls-s-flow {
    transform: translateY(-1px);
  }
}

.ls-s-flow__inner {
  padding-bottom: clamp(77px, 8.1944444444vw, 118px);
}

.ls-s-flow__content {
  position: relative;
}

.ls-s-flow__list {
  margin-top: clamp(62px, 5.9027777778vw, 85px);
}
@media (min-width: 768px) {
  .ls-s-flow__list {
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
  }
}

.ls-s__title-area {
  margin-top: clamp(111px, 11.0416666667vw, 159px);
  margin-left: -14px;
}
@media (min-width: 768px) {
  .ls-s__title-area {
    margin-left: 0;
  }
}

.ls-s__title-text {
  text-transform: uppercase;
}

.ls-s__title-back-text::after {
  content: "Flow";
  top: -37px;
  left: clamp(50px, 5.4166666667vw, 78px);
}

.ls-s__title-text-jp {
  margin-top: 8px;
}
@media (min-width: 768px) {
  .ls-s__title-text-jp {
    margin-top: -1px;
  }
}

.ls-s-flow__item {
  position: relative;
}
.ls-s-flow__item:not(:last-child) {
  padding-bottom: 38px;
}
.ls-s-flow__item:not(:last-child)::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 7px;
  width: 2px;
  height: 26px;
  background: repeating-linear-gradient(to bottom, #949E33 0px, #949E33 1px, transparent 1px, transparent 7px);
}
@media (min-width: 768px) {
  .ls-s-flow__item:not(:last-child)::after {
    left: 30px;
    transform: translateX(-50%);
    top: 67px;
    bottom: auto;
    width: 1px;
    height: 80px;
    background: repeating-linear-gradient(to bottom, #949E33 0px, #949E33 1px, transparent 1px, transparent 7px);
  }
}
@media (min-width: 768px) {
  .ls-s-flow__item:not(:last-child) {
    padding-bottom: 0;
  }
  .ls-s-flow__item + .ls-s-flow__item {
    margin-top: 32px;
  }
}

.ls-s-flow__row {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(15px, 2.8472222222vw, 41px);
}
@media (min-width: 768px) {
  .ls-s-flow__row {
    flex-direction: row;
    align-items: flex-start;
  }
}

.ls-s-flow__num {
  position: relative;
  width: 60px;
  height: 60px;
  border-radius: 50px;
  background: #949E33;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-left: 4px;
}
.ls-s-flow__num::after {
  content: none;
}
@media (min-width: 768px) {
  .ls-s-flow__num {
    width: 67px;
    height: 60px;
  }
}

.ls-s-flow__num-text {
  font-size: 32px;
  letter-spacing: 0.1em;
  color: #fff;
}

.ls-s-flow__body {
  width: 100%;
}
@media (min-width: 768px) {
  .ls-s-flow__body {
    text-align: left;
    flex: 1 1 auto;
  }
}

.ls-s-flow__heading {
  text-align: center;
  color: #CA7F13;
  font-weight: 700;
  font-size: clamp(18px, 1.6666666667vw, 24px);
  letter-spacing: 0.04em;
  font-family: "游明朝";
}
@media (min-width: 768px) {
  .ls-s-flow__heading {
    text-align: left;
  }
}

.ls-s-flow__text {
  margin-top: 14px;
  color: #CA7F13;
  font-size: clamp(14px, 1.25vw, 18px);
  line-height: 1.5;
  letter-spacing: 0.1em;
  font-family: "游ゴシック";
}
@media (min-width: 768px) {
  .ls-s-flow__text {
    line-height: 1.5;
  }
}

.ls-s-flow__images {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

.ls-s-flow__images-item {
  position: relative;
  opacity: 1;
}
.ls-s-flow__images-item:first-child {
  position: absolute;
  top: clamp(400px, 503px + -103 * (100vw - 375px) / 392, 503px);
  right: -46px;
}
@media (min-width: 768px) {
  .ls-s-flow__images-item:first-child {
    top: clamp(248px, 317px + -69 * (100vw - 768px) / 672, 317px);
    right: initial;
    left: clamp(-63px, -63px + 30 * (100vw - 768px) / 672, -33px);
  }
}
.ls-s-flow__images-item:nth-child(2) {
  position: absolute;
  top: clamp(868px, 1052px + -184 * (100vw - 375px) / 392, 1052px);
  left: -40px;
}
@media (min-width: 768px) {
  .ls-s-flow__images-item:nth-child(2) {
    top: clamp(604px, 657px + -53 * (100vw - 767px) / 673, 657px);
    left: initial;
    right: clamp(-94px, -94px + 44 * (100vw - 768px) / 672, -50px);
  }
}
@media (min-width: 596px) and (max-width: 723px) {
  .ls-s-flow__images-item:nth-child(2) {
    top: 866px;
  }
}
.ls-s-flow__images-item:nth-child(3) {
  position: absolute;
  top: clamp(1570px, 1670px + -100 * (100vw - 375px) / 392, 1670px);
  right: -46px;
}
@media (min-width: 768px) {
  .ls-s-flow__images-item:nth-child(3) {
    top: clamp(964px, 964px + 66 * (100vw - 768px) / 672, 1030px);
    right: initial;
    left: clamp(-53px, -53px + 53 * (100vw - 768px) / 672, 0px);
  }
}

.img-hide {
  opacity: 0;
}

.ls-s-flow__images-img {
  border-radius: 50%;
  overflow: hidden;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

.ls-s-flow__images-item:nth-child(1) .ls-s-flow__images-img {
  width: clamp(80px, 10.4166666667vw, 150px);
  height: clamp(80px, 10.4166666667vw, 150px);
  aspect-ratio: 80/80;
}
@media (min-width: 768px) {
  .ls-s-flow__images-item:nth-child(1) .ls-s-flow__images-img {
    aspect-ratio: 150/150;
  }
}

.ls-s-flow__images-item:nth-child(2) .ls-s-flow__images-img {
  width: clamp(100px, 12.5vw, 180px);
  height: clamp(100px, 12.5vw, 180px);
  aspect-ratio: 100/100;
}
@media (min-width: 768px) {
  .ls-s-flow__images-item:nth-child(2) .ls-s-flow__images-img {
    aspect-ratio: 180/180;
  }
}

.ls-s-flow__images-item:nth-child(3) .ls-s-flow__images-img {
  width: clamp(90px, 11.1111111111vw, 160px);
  height: clamp(90px, 11.1111111111vw, 160px);
  aspect-ratio: 90/90;
}
@media (min-width: 768px) {
  .ls-s-flow__images-item:nth-child(3) .ls-s-flow__images-img {
    aspect-ratio: 160/160;
  }
}

/* =========================
   Staff
========================= */
.ls-s-staff-access__staff {
  background: #464646;
}

.ls-s-staff-access__staff-inner {
  width: 84%;
  margin-inline: auto;
  padding-top: clamp(61px, 5.4861111111vw, 79px);
  padding-bottom: clamp(34px, 5.5555555556vw, 80px);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(30px, 4.1666666667vw, 60px);
}
@media (min-width: 768px) {
  .ls-s-staff-access__staff-inner {
    width: 75%;
    max-width: 1080px;
    flex-direction: row;
    align-items: flex-start;
  }
}

.ls-s-staff-access__staff-img {
  width: clamp(240px, 33.3333333333vw, 480px);
  aspect-ratio: 240/240;
  overflow: hidden;
  -o-object-fit: cover;
     object-fit: cover;
  margin-right: 14px;
}
@media (min-width: 768px) {
  .ls-s-staff-access__staff-img {
    aspect-ratio: 480/480;
    margin-right: 0;
  }
}

.ls-s-staff-access__staff-body {
  width: 100%;
}
@media (min-width: 768px) {
  .ls-s-staff-access__staff-body {
    flex: 1;
    margin-top: 50px;
  }
}

.ls-s-staff-access__staff-title {
  color: #CA7F13;
  font-weight: 400;
  font-size: clamp(36px, 3.3333333333vw, 48px);
  letter-spacing: 0.1em;
  display: flex;
  align-items: baseline;
  gap: clamp(12px, 1.3194444444vw, 19px);
}

.ls-s-staff-access__staff-title-jp {
  font-size: 14px;
  letter-spacing: 0.1em;
  font-family: "游ゴシック";
}

.ls-s-staff-access__staff-text {
  margin-top: clamp(22px, 3.3333333333vw, 48px);
  font-size: clamp(14px, 1.25vw, 18px);
  line-height: 2;
  letter-spacing: 0.1em;
  color: #CA7F13;
  font-family: "游ゴシック";
}
@media (min-width: 768px) {
  .ls-s-staff-access__staff-text {
    line-height: 2;
  }
}

.ls-s-staff-access__staff-name {
  margin-top: clamp(14px, 1.3194444444vw, 19px);
  color: #CA7F13;
  font-size: clamp(20px, 1.6666666667vw, 24px);
  letter-spacing: 0.1em;
  font-family: "游明朝";
}
.ls-s-staff-access__staff-role {
  margin-left: clamp(2px, 0.7638888889vw, 11px);
  color: #CA7F13;
  font-size: 12px;
  letter-spacing: 0.1em;
}

/* =========================
   Access
========================= */
.ls-s-staff-access__access {
  background: #D4CEBE;
  border-bottom: 1px solid #707070;
}

.ls-s-staff-access__access-inner {
  width: 84%;
  margin-inline: auto;
  padding-top: clamp(60px, 5.5555555556vw, 80px);
  padding-bottom: clamp(60px, 5.5555555556vw, 80px);
  display: flex;
  flex-direction: column;
  gap: 22px;
}
@media (min-width: 768px) {
  .ls-s-staff-access__access-inner {
    width: 75%;
    max-width: 1080px;
    flex-direction: row;
    align-items: center;
    gap: 60px;
  }
}

.ls-s-staff-access__access-map {
  order: 1;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
}
@media (min-width: 768px) {
  .ls-s-staff-access__access-map {
    order: 2;
  }
}

.ls-s-staff-access__access-info {
  order: 2;
  width: -moz-fit-content;
  width: fit-content;
}
@media (min-width: 768px) {
  .ls-s-staff-access__access-info {
    order: 1;
    flex: 1;
    width: 100%;
  }
}

.ls-s-staff-access__map-frame {
  width: clamp(270px, 84vw, 540px);
  aspect-ratio: 315/200;
  background: #fff;
  overflow: hidden;
}
@media (min-width: 768px) {
  .ls-s-staff-access__map-frame {
    width: clamp(315px, 37.5vw, 540px);
    height: 360px;
    aspect-ratio: 520/360;
  }
}

/* =========================
   Access：dl
========================= */
.ls-s-staff-access__dl {
  margin-top: 18px;
  width: -moz-fit-content;
  width: fit-content;
}
@media (min-width: 768px) {
  .ls-s-staff-access__dl {
    width: 100%;
    max-width: 400px;
    margin-top: 0px;
  }
}

.ls-s-staff-access__dl-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 19px 0;
  border-bottom: 1px solid rgba(202, 127, 19, 0.55);
  font-family: "游ゴシック";
}
.ls-s-staff-access__dl-row:last-child {
  padding: 20px 0;
}
@media (min-width: 768px) {
  .ls-s-staff-access__dl-row:last-child {
    padding: 19px 0;
  }
}

.ls-s-staff-access__dt {
  margin: 0;
  color: #CA7F13;
  font-weight: 700;
  font-size: clamp(16px, 1.3888888889vw, 20px);
  letter-spacing: 0.1em;
  font-family: "游明朝";
  padding-left: 8px;
  flex: 0 0 114px;
}
@media (min-width: 768px) {
  .ls-s-staff-access__dt {
    flex-basis: 144px;
  }
}

.ls-s-staff-access__dd {
  margin: 0;
  color: #333333;
  font-size: clamp(12px, 0.9722222222vw, 14px);
  letter-spacing: 0.1em;
  font-family: "游ゴシック";
  text-transform: uppercase;
  flex: 1 1 auto;
  min-width: 0;
}
@media (min-width: 768px) {
  .ls-s-staff-access__dd a[href^="tel:"] {
    pointer-events: none;
  }
}

/* =========================
   Button
========================= */
.ls-s-staff-access__cta {
  padding-top: clamp(80px, 8.3333333333vw, 120px);
  padding-bottom: clamp(80px, 8.3333333333vw, 120px);
  display: flex;
  justify-content: center;
  background: #fff;
}

.ls-s-staff-access__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: clamp(156px, 11.5277777778vw, 166px);
  height: clamp(38px, 2.8472222222vw, 41px);
  border-radius: 50px;
  background: #949E33;
  color: #fff;
  font-family: "游明朝";
  font-size: clamp(14px, 1.1111111111vw, 16px);
  letter-spacing: 0.1em;
  transition: all 0.5s ease;
}
@media (min-width: 768px) {
  .ls-s-staff-access__btn {
    margin-left: 18px;
  }
}
@media (any-hover: hover) {
  .ls-s-staff-access__btn:hover {
    background: #54372D;
  }
}

/*******************************************************************
* 404
*******************************************************************/
.error404 {
  padding-block: clamp(120px, 12.5vw, 180px);
  background: #fff;
}
.error404__inner {
  text-align: center;
}
.error404__title {
  color: #CA7F13;
  font-size: clamp(40px, 4.4444444444vw, 64px);
  letter-spacing: 0.08em;
  line-height: 1.2;
}
.error404__text {
  margin-top: 24px;
  color: #333333;
  font-size: clamp(14px, 1.1111111111vw, 16px);
  line-height: 1.8;
}
.error404__link {
  width: -moz-fit-content;
  width: fit-content;
  margin-top: 40px;
  margin-inline: auto;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #54372D;
  font-size: 18px;
  letter-spacing: 0.1em;
  transition: color 0.3s ease;
}
@media (any-hover: hover) {
  .error404__link:hover {
    color: #CA7F13;
  }
}/*# sourceMappingURL=style.css.map */