@charset "UTF-8";
:root {
  --base-font: "Noto Sans JP", serif;
  --min-font: "Shippori Mincho", serif;
  --base-color: #514f4a;
  --white: #FFF;
  --black: #000;
  --beige1: #fcf9f2;
  --beige2: #F8F2E2;
  --beige3: #DEDAD2;
  --beige4: #C7C1B3;
  --beige5: #FFFEFD;
  --brown1: #998675;
  --brown2: #906D37;
  --brown3: #BD947B;
  --brown4: #EBE4D8;
  --orage1: #E98B00;
  --orage2: #ff7600;
  --orage3: #977745;
  --gray1: #E2DDD7;
  --gray2: #B9B9B7;
  --gray3: #F0EEEB;
}

/*------------------------------------------------------------
	汎用スタイル
------------------------------------------------------------*/
/* 81-LMX */
/* clearfix */
.clearfix:after {
  content: "";
  display: block;
  clear: both;
}

/* flex */
.flex, .flexA, .flexB, .flexC {
  display: flex;
  flex-wrap: wrap;
}

.flexA {
  justify-content: space-around;
}

.flexB {
  justify-content: space-between;
}

.flexC {
  justify-content: center;
}

/*------------------------------------------------------------
	font
------------------------------------------------------------*/
.min {
  font-weight: 400;
  font-family: var(--min-font);
}

/*------------------------------------------------------------
	color
------------------------------------------------------------*/
.yellow {
  color: var(--brown2);
}

.style {
  font-style: italic;
}

/*------------------------------------------------------------
	content
------------------------------------------------------------*/
.content {
  padding: 0 2rem;
  max-width: 114rem;
  margin: 0 auto;
  box-sizing: border-box;
}
.content.wid01 {
  max-width: 104rem;
}
@media all and (max-width: 896px) {
  .content {
    max-width: inherit !important;
  }
}

/*------------------------------------------------------------
	comContact
------------------------------------------------------------*/
.comContact {
  padding: 4.2rem 0 8.6rem;
  position: relative;
  background-color: var(--beige2);
}
.comContact::before {
  position: absolute;
  left: 0;
  top: -8.4rem;
  width: 100%;
  background: url(../img/common/contact_bg.webp) no-repeat;
  background-size: 100% 100%;
  height: 8.4rem;
  content: "";
}
.comContact .lBox {
  width: 47.2rem;
  margin-top: 0.6rem;
}
.comContact .lBox .logo {
  margin: 0 0 1.2rem 0.1rem;
  width: 42.7rem;
}
.comContact .lBox .logo span {
  margin: 1.3rem 0 0 0.3rem;
  display: block;
  font-size: 1.5rem;
  letter-spacing: 0.06em;
}
.comContact .lBox .tel {
  margin-bottom: 1.2rem;
  font-size: 3.9rem;
  letter-spacing: 0.08em;
  font-style: italic;
}
.comContact .lBox .tel a {
  display: inline-block;
}
.comContact .lBox .tabBox {
  margin-bottom: 2.6rem;
  padding: 1.6rem 3rem 1.3rem;
  border: 0.5rem solid var(--beige1);
}
.comContact .lBox .tabBox table {
  width: 100%;
  border-collapse: collapse;
}
.comContact .lBox .tabBox table th,
.comContact .lBox .tabBox table td {
  padding-top: 1.6rem;
  font-weight: 400;
  font-size: 1.5rem;
  vertical-align: middle;
  text-align: center;
  box-sizing: border-box;
}
.comContact .lBox .tabBox table th {
  letter-spacing: 0.07em;
  padding-right: 1.6rem !important;
}
.comContact .lBox .tabBox table td {
  width: 9.5%;
}
.comContact .lBox .tabBox table tbody tr:last-child th, .comContact .lBox .tabBox table tbody tr:last-child td {
  padding-top: 0.6rem;
}
.comContact .lBox .tabBox table tbody td {
  color: var(--orage1);
}
.comContact .lBox .tabBox table tbody td.sml {
  font-size: 1.3rem;
}
.comContact .lBox .tabBox table tbody td.color {
  color: var(--gray2);
}
.comContact .lBox .tabBox table thead th,
.comContact .lBox .tabBox table thead td {
  font-size: 1.6rem;
  padding: 0 0 1.4rem;
  border-bottom: 1px solid var(--gray1);
  font-family: var(--min-font);
}
.comContact .lBox .tabBox p {
  border-top: 1px solid var(--gray1);
  margin-top: 1.8rem;
  padding-top: 0.8rem;
  font-size: 1.3rem;
}
.comContact .lBox .link {
  background: linear-gradient(90deg, rgb(201, 128, 18) 0%, rgb(222, 177, 110) 50%, rgb(201, 128, 18) 100%);
  border-radius: 5rem;
  overflow: hidden;
}
.comContact .lBox .link a {
  height: 6.4rem;
  padding: 0 1.5rem 0.4rem 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: var(--beige1);
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  background: var(--base-color) url(../img/common/icon10.webp) no-repeat right 2.3rem top 47%;
  background-size: 2.4rem auto;
  box-sizing: border-box;
}
.comContact .lBox .link a span {
  padding: 0.2rem 0 0 2.6rem;
  display: inline-block;
  background: url(../img/common/icon09.webp) no-repeat left top 0.6rem;
  background-size: 1.8rem auto;
}
@media all and (min-width: 897px) {
  .comContact .lBox .link a:hover {
    background-color: transparent;
  }
}
.comContact .rBox {
  width: 47.2rem;
}
.comContact .rBox .map {
  margin-bottom: 2.8rem;
  overflow: hidden;
  border-radius: 4rem 0 4rem 0;
}
.comContact .rBox .map img {
  width: 100%;
}
.comContact .rBox ul li:first-child {
  padding-bottom: 2.6rem;
  margin-bottom: 2.5rem;
  border-bottom: 1px solid var(--gray1);
}
.comContact .rBox ul li .ttl {
  padding: 0 0 1.4rem 3.4rem;
  position: relative;
  font-weight: 700;
  letter-spacing: 0.1em;
}
.comContact .rBox ul li .ttl img {
  position: absolute;
  left: 0;
  top: -1px;
  width: 2.7rem;
}
.comContact .rBox ul li .txt {
  font-size: 1.8rem;
  line-height: 1.55;
  letter-spacing: 0.02em;
}
.comContact .rBox ul li .txt .num {
  color: var(--orage2);
  font-size: 3.2rem;
  line-height: 1;
  font-style: italic;
}
.comContact .rBox ul li:last-child .ttl {
  padding-bottom: 0.5rem;
}
@media all and (max-width: 896px) {
  .comContact {
    padding: 5.4rem 0 6rem;
  }
  .comContact::before {
    top: -2.2rem;
    height: 2.2rem;
  }
  .comContact .content {
    padding-bottom: 9.1rem;
    display: block;
    position: relative;
  }
  .comContact .lBox {
    width: auto;
    margin: 0 0 3.1rem;
  }
  .comContact .lBox .logo {
    margin: 0 auto 1.4rem;
    width: 30rem;
  }
  .comContact .lBox .logo span {
    margin: 1rem -2rem 0 -0.8rem;
  }
  .comContact .lBox .tel {
    margin-bottom: 2.3rem;
    font-size: 3.2rem;
    text-align: center;
  }
  .comContact .lBox .tabBox {
    margin-bottom: 0;
    padding: 1.4rem 1.5rem 1.2rem;
    border-color: var(--beige5);
  }
  .comContact .lBox .tabBox table th,
  .comContact .lBox .tabBox table td {
    padding-top: 0.8rem;
    font-size: 1.3rem;
  }
  .comContact .lBox .tabBox table th {
    padding-right: 1.6rem !important;
  }
  .comContact .lBox .tabBox table td {
    width: 9%;
  }
  .comContact .lBox .tabBox table tbody tr:last-child th, .comContact .lBox .tabBox table tbody tr:last-child td {
    padding-top: 0.1rem;
  }
  .comContact .lBox .tabBox table tbody td {
    font-size: 1.2rem;
  }
  .comContact .lBox .tabBox table tbody td.sml {
    font-size: 1.1rem;
    letter-spacing: -0.03em;
  }
  .comContact .lBox .tabBox table thead th,
  .comContact .lBox .tabBox table thead td {
    font-size: 1.2rem;
    padding: 0 0 1rem;
  }
  .comContact .lBox .tabBox table thead th {
    font-size: 1.3rem;
  }
  .comContact .lBox .tabBox p {
    margin-top: 1.2rem;
    padding-top: 0.7rem;
    font-size: 1.2rem;
  }
  .comContact .lBox .link {
    width: 33.5rem;
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
  }
  .comContact .rBox {
    width: auto;
  }
  .comContact .rBox .map {
    margin-bottom: 1.9rem;
  }
  .comContact .rBox ul li:first-child {
    padding-bottom: 1.6rem;
    margin-bottom: 2rem;
  }
  .comContact .rBox ul li .ttl {
    padding-bottom: 0.6rem;
  }
  .comContact .rBox ul li .txt {
    font-size: 1.5rem;
    line-height: 1.49;
    letter-spacing: 0.02em;
  }
  .comContact .rBox ul li .txt .num {
    font-size: 2.5rem;
  }
  .comContact .rBox ul li:last-child .ttl {
    padding-bottom: 0.1rem;
  }
}

/*------------------------------------------------------------
	comEn
------------------------------------------------------------*/
.comEn {
  margin: 0 -1.2rem 3.4rem;
  color: var(--brown2);
  opacity: 0.15;
  font-size: 14.6rem;
  line-height: 1;
  font-weight: 300;
  font-family: var(--min-font);
}
.comEn.center {
  margin: 0 0 1.5rem;
  text-align: center;
}
@media all and (max-width: 896px) {
  .comEn {
    margin: 0 0 0.3rem;
    font-size: 6.6rem;
    text-align: right;
  }
  .comEn.center {
    margin: 0 0 0.5rem;
  }
}

/*------------------------------------------------------------
	comLink
------------------------------------------------------------*/
.comLink {
  width: 33.5rem;
  background: linear-gradient(90deg, rgb(201, 128, 18) 0%, rgb(222, 177, 110) 50%, rgb(201, 128, 18) 100%);
  border-radius: 5rem;
  overflow: hidden;
  font-family: var(--min-font);
}
.comLink a, .comLink button {
  height: 6.6rem;
  padding: 0 1rem 0.4rem 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  letter-spacing: 0.1em;
  background: var(--white) url(../img/common/icon06.webp) no-repeat right 2.9rem center;
  background-size: 2.4rem auto;
  border: 1px solid var(--base-color);
  border-radius: 5rem;
}
@media all and (min-width: 897px) {
  .comLink a:hover, .comLink button:hover {
    color: var(--white);
    background-image: url(../img/common/icon10.webp);
    background-color: transparent;
    border-color: transparent;
  }
}
.comLink.center {
  margin: 0 auto;
}
@media all and (max-width: 896px) {
  .comLink {
    margin: 0 auto;
  }
  .comLink a, .comLink button {
    height: 5.8rem;
    background-position: right 1.9rem center;
  }
}

/*------------------------------------------------------------
	comCv
------------------------------------------------------------*/
.comCv {
  padding: 8.5rem 0 13.5rem;
  box-sizing: border-box;
  background: url(../img/index/cv_bg.webp) no-repeat top center;
  background-size: cover;
}
.comCv .content {
  position: relative;
}
.comCv .content h2 {
  margin-bottom: 1.6rem;
  text-align: center;
  font-size: 4rem;
  line-height: 1.58;
  letter-spacing: 0.11em;
}
.comCv .content p {
  margin-bottom: 3.9rem;
  text-align: center;
  line-height: 1.93;
  font-weight: 700;
}
.comCv .content .linkList {
  margin-bottom: 0.9rem;
}
.comCv .content .linkList li {
  margin: 0 2rem;
  width: 28.8rem;
}
.comCv .content .linkList li a {
  padding: 2.3rem 0 2.8rem 2.2rem;
  display: block;
  text-align: center;
  font-size: 2.5rem;
  letter-spacing: 0.1rem;
  background: var(--beige4) url(../img/common/icon01.webp) no-repeat left 6.5rem center;
  background-size: 2.5rem auto;
  border-radius: 5rem;
  box-shadow: 1rem 1rem 1.5rem rgba(0, 0, 0, 0.3);
}
.comCv .content .linkList li a span {
  font-style: italic;
}
@media all and (min-width: 897px) {
  .comCv .content .linkList li a:hover {
    opacity: 0.6;
  }
}
.comCv .content .linkList li:last-child a {
  color: var(--white);
  background: var(--base-color) url(../img/common/icon02.webp) no-repeat left 5.9rem center;
  background-size: 3rem auto;
}
.comCv .content .tel {
  text-align: center;
  font-size: 4.77rem;
  font-style: italic;
  font-weight: 400;
}
.comCv .content .tel a {
  display: inline-block;
  color: var(--white);
  letter-spacing: 0.1em;
}
.comCv .content .pho {
  position: absolute;
  left: 50%;
  bottom: -5.3rem;
  width: 121.6rem;
  transform: translateX(-50%);
  cursor: default;
  pointer-events: none;
}
@media all and (max-width: 896px) {
  .comCv {
    padding: 4.7rem 0 6rem;
  }
  .comCv .content h2 {
    margin: 0 -1rem 1.9rem;
    font-size: 2.6rem;
    line-height: 1.53;
    letter-spacing: 0;
  }
  .comCv .content p {
    margin-bottom: 2.7rem;
    text-align: left;
    line-height: 2;
    font-size: 1.4rem;
  }
  .comCv .content .linkList {
    margin: 0 auto 0.9rem;
    width: 33.5rem;
    justify-content: space-between;
  }
  .comCv .content .linkList li {
    margin: 0;
    width: 16rem;
  }
  .comCv .content .linkList li a {
    padding: 0.8rem 0 1.3rem 2.2rem;
    font-size: 1.8rem;
    letter-spacing: 0.1rem;
    background-position: left 2.6rem center;
    background-size: 1.7rem auto;
  }
  .comCv .content .linkList li:last-child a {
    background-position: left 2.3rem center;
    background-size: 2.1rem auto;
  }
  .comCv .content .tel {
    margin-bottom: 0.8rem;
    font-size: 3rem;
  }
  .comCv .content .pho {
    position: static;
    width: 31.8rem;
    margin: 0 auto;
    transform: none;
  }
}

/*------------------------------------------------------------
	headLine01
------------------------------------------------------------*/
.headLine01 {
  margin-bottom: 1rem;
  text-align: center;
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.15em;
}

/*------------------------------------------------------------
	headLine02
------------------------------------------------------------*/
.headLine02 {
  margin-bottom: 5.7rem;
  position: relative;
  font-size: 3rem;
  font-weight: 400;
  letter-spacing: 0.17em;
  font-family: var(--min-font);
}
.headLine02::before {
  position: absolute;
  left: 0;
  bottom: -2.6rem;
  width: 7rem;
  height: 1px;
  background-color: var(--base-color);
  content: "";
}
@media all and (max-width: 896px) {
  .headLine02 {
    margin-bottom: 3.8rem;
    font-size: 2.2rem;
    line-height: 1.54;
  }
  .headLine02::before {
    bottom: -2.2rem;
    width: 3.6rem;
  }
}

/*------------------------------------------------------------
	fixBox
------------------------------------------------------------*/
.fixBox {
  position: fixed;
  left: 0;
  bottom: 0;
  width: 100%;
  z-index: 90;
}
.fixBox ul li {
  width: 25%;
}
.fixBox ul li a {
  height: 5.6rem;
  padding-top: 3rem;
  display: block;
  text-align: center;
  color: var(--white);
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  background: var(--orage3) url(../img/common/fix_icon01.webp) no-repeat top 1rem center;
  background-size: 1.7rem auto;
  box-sizing: border-box;
}
.fixBox ul li:nth-child(2n) a {
  background-color: var(--orage1);
}
.fixBox ul li:nth-child(2) a {
  background-image: url(../img/common/fix_icon02.webp);
}
.fixBox ul li:nth-child(3) a {
  background-image: url(../img/common/fix_icon03.webp);
}
.fixBox ul li:nth-child(4) a {
  background-image: url(../img/common/fix_icon04.webp);
}
.treatment {
  padding: 12rem 0 36rem;
  background: url(../img/index/treatment_bg.webp) no-repeat top center;
  background-size: cover;
  border-top-left-radius: 12rem;
}
.treatment .content {
  max-width: 104rem;
}
.treatment .content .comEn {
  color: var(--white);
  opacity: 0.8;
}
.treatment .content .headLine01 {
  margin-bottom: 7.4rem;
  color: var(--white);
  opacity: 0.8;
  letter-spacing: 0.26em;
}
.treatment .content .linkUl {
  margin-bottom: 6.6rem;
  position: relative;
}
.treatment .content .linkUl::after {
  content: "";
  width: 31.2rem;
}
.treatment .content .linkUl li {
  width: 31.2rem;
}
.treatment .content .linkUl li a {
  display: block;
  border-radius: 50rem 50rem 0 0;
  overflow: hidden;
}
.treatment .content .linkUl li a .pho img {
  width: 100%;
}
.treatment .content .linkUl li a p {
  padding: 1.5rem 0 1.8rem;
  text-align: center;
  font-size: 1.8rem;
  letter-spacing: 0.05em;
  background: var(--white) url(../img/common/icon06.webp) no-repeat right 2.3rem top 2.6rem;
  background-size: 2.4rem auto;
}
@media all and (min-width: 897px) {
  .treatment .content .linkUl li a:hover {
    opacity: 0.6;
  }
}
.treatment .content .linkList {
  margin: -2.9rem 0 8rem;
}
.treatment .content .linkList li {
  margin: 2.9rem 3.7rem 0 0;
  width: 17rem;
}
.treatment .content .linkList li:nth-child(5n) {
  margin-right: 0;
}
.treatment .content .linkList li a {
  height: 17rem;
  padding-bottom: 3.1rem;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background-color: rgba(255, 255, 255, 0.7);
  box-sizing: border-box;
  border-radius: 100%;
}
.treatment .content .linkList li a .ico img {
  width: 8.1rem;
}
.treatment .content .linkList li a .txt {
  position: absolute;
  left: 0;
  width: 100%;
  bottom: 3.7rem;
  text-align: center;
  letter-spacing: 0.2em;
}
.treatment .content .linkList li a .txt.sml {
  letter-spacing: 0;
}
@media all and (min-width: 897px) {
  .treatment .content .linkList li a:hover {
    opacity: 0.6;
  }
}
.treatment .content .linkList li:nth-child(2n) a {
  background-color: rgba(250, 232, 201, 0.8);
}
.treatment .content .phoUl {
  margin-bottom: 8rem;
}
.treatment .content .phoUl li {
  width: 47.2rem;
  position: relative;
  overflow: hidden;
  border-radius: 8rem 0;
}
.treatment .content .phoUl li::before {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: var(--brown3);
  opacity: 0.88;
  mix-blend-mode: multiply;
  content: "";
}
.treatment .content .phoUl li .pho {
  position: relative;
  z-index: 1;
}
.treatment .content .phoUl li .pho img {
  width: 100%;
}
.treatment .content .phoUl li .textBox {
  padding: 3.2rem 4.6rem 4.2rem;
  position: relative;
  z-index: 1;
  color: var(--beige1);
}
.treatment .content .phoUl li .textBox .ttl {
  margin-bottom: 2.7rem;
  font-size: 3.4rem;
  font-weight: 400;
  line-height: 1.41;
  letter-spacing: 0.15em;
  font-family: var(--min-font);
}
.treatment .content .phoUl li .textBox .title {
  margin-bottom: 2.4rem;
  padding: 1rem 0 1.1rem;
  font-weight: 700;
  font-size: 2rem;
  letter-spacing: 0.26em;
  border-top: 1px solid var(--white);
  border-bottom: 1px solid var(--white);
}
.treatment .content .phoUl li .textBox .txt {
  text-align: justify;
  line-height: 2;
  font-weight: 500;
  letter-spacing: 0.04em;
}
.treatment .content .phoUl li .textBox .txt .price {
  margin: -0.2rem 0 0;
  display: block;
  letter-spacing: 0.14em;
}
.treatment .content .phoUl li .textBox .txt .price span {
  display: inline-block;
  font-size: 2.6rem;
  font-weight: 700;
}
.treatment .content .phoUl li:last-child::before {
  background-color: var(--orage1);
}
.treatment .content .phoUl li:last-child .textBox .ttl {
  margin-bottom: 1.6rem;
  letter-spacing: 0;
}
.treatment .content .phoUl li:last-child .textBox .txt {
  letter-spacing: 0;
}
@media all and (max-width: 896px) {
  .treatment {
    padding: 7rem 0 16.8rem;
    border-top-left-radius: 8rem;
  }
  .treatment .content .comEn {
    margin-bottom: 1.3rem;
  }
  .treatment .content .headLine01 {
    margin-bottom: 3.4rem;
  }
  .treatment .content .linkUl {
    margin-bottom: 2.5rem;
  }
  .treatment .content .linkUl li {
    margin-bottom: 1.6rem;
    width: 47.7%;
  }
  .treatment .content .linkUl li a p {
    padding: 0.4rem 1rem 0.6rem 0;
    font-size: 1.4rem;
    letter-spacing: 0;
    background-position: right 1.1rem top 1.2rem;
  }
  .treatment .content .linkUl li:first-child a p {
    padding-right: 3rem;
  }
  .treatment .content .linkList {
    margin: -5.7rem auto 7.5rem;
    width: 33.5rem;
    justify-content: space-between;
  }
  .treatment .content .linkList::after {
    content: "";
    width: 10rem;
  }
  .treatment .content .linkList li {
    margin: 5.7rem 0 0 !important;
    width: 10rem;
  }
  .treatment .content .linkList li a {
    height: 10rem;
    padding-bottom: 0;
  }
  .treatment .content .linkList li a .ico img {
    width: 6.5rem;
  }
  .treatment .content .linkList li a .txt {
    left: -2rem;
    width: auto;
    right: -2rem;
    bottom: -3.4rem;
    color: var(--white);
  }
  .treatment .content .phoUl {
    margin-bottom: 4.7rem;
    display: block;
  }
  .treatment .content .phoUl li {
    width: auto;
    border-radius: 4rem 0;
  }
  .treatment .content .phoUl li .textBox {
    padding: 2.9rem 2rem 3.3rem;
  }
  .treatment .content .phoUl li .textBox .ttl {
    margin-bottom: 2rem;
    font-size: 2.8rem;
    line-height: 1.28;
    letter-spacing: 0.05em;
  }
  .treatment .content .phoUl li .textBox .title {
    margin-bottom: 1.7rem;
    padding: 1rem 0.5rem 1.1rem;
  }
  .treatment .content .phoUl li .textBox .txt {
    margin-right: -1rem;
    font-size: 1.4rem;
    letter-spacing: 0.02em;
  }
  .treatment .content .phoUl li .textBox .txt .price {
    margin: -0.5rem 0 -0.3rem;
  }
  .treatment .content .phoUl li:last-child {
    margin-top: 3.3rem;
  }
  .treatment .content .phoUl li:last-child .textBox {
    padding-bottom: 3rem;
  }
  .treatment .content .phoUl li:last-child .textBox .ttl {
    margin-bottom: 1.4rem;
  }
  .treatment .content .phoUl li:last-child .textBox .txt {
    margin-right: 0;
  }
}