/* =====================
ABOUT PAGE
===================== */

/* PC */

.about-page{
  color:#111;
  background:#fff;
  font-family:"Noto Serif JP","Yu Mincho","Hiragino Mincho ProN",serif;
}

.about-page-inner{
  max-width:1120px;
  margin:0 auto;
}


/* =====================
HERO
===================== */

/* PC */

.about-page-hero{
  padding:220px 30px 130px;
  background:linear-gradient(180deg,#fff 0%,#faf8f3 100%);
  text-align:center;
}

.about-page-label{
  color:#b89b5e;
  letter-spacing:4px;
  font-size:13px;
  margin-bottom:28px;
  font-family:"Cormorant Garamond","Noto Serif JP",serif;
}

.about-page-title{
  font-size:68px;
  line-height:1.45;
  font-weight:400;
  letter-spacing:.06em;
}

/* スマホ */

@media screen and (max-width:768px){

  .about-page-hero{
    padding:170px 20px 90px;
  }

  .about-page-title{
    font-size:38px;
  }

}


/* =====================
MESSAGE
===================== */

/* PC */

.about-page-message{
  padding:120px 30px;
  background:#f8f8f8;
  text-align:center;
}

.about-page-message p{
  font-size:19px;
  line-height:2.4;
  color:#444;
  margin-bottom:32px;
}

/* スマホ */

@media screen and (max-width:768px){

  .about-page-message{
    padding:86px 20px;
  }

  .about-page-message p{
    font-size:16px;
    line-height:2.2;
  }

}


/* =====================
COMMON SECTION
===================== */

/* PC */

.about-page-business,
.about-page-health,
.about-page-concept,
.about-page-company{
  padding:130px 30px;
}

.about-page-business{
  background:#fff;
  text-align:center;
}

.about-page-health{
  background:#faf8f3;
  text-align:center;
}

.about-page-concept{
  background:#f8f8f8;
  text-align:center;
}

.about-page-company{
  background:#fff;
}

.about-page-business h2,
.about-page-health h2,
.about-page-concept h2,
.about-page-company h2{
  font-size:46px;
  line-height:1.5;
  font-weight:400;
  letter-spacing:.08em;
  margin-bottom:60px;
}

/* スマホ */

@media screen and (max-width:768px){

  .about-page-business,
  .about-page-health,
  .about-page-concept,
  .about-page-company{
    padding:86px 20px;
  }

  .about-page-business h2,
  .about-page-health h2,
  .about-page-concept h2,
  .about-page-company h2{
    font-size:32px;
    margin-bottom:38px;
  }

}


/* =====================
BUSINESS CARD
===================== */

/* PC */

.about-business-list{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}

.about-business-card{
  background:#fff;
  border:1px solid #eee7d8;
  text-align:left;
  overflow:hidden;
  transition:.35s ease;
}

.about-business-card:hover{
  transform:translateY(-8px);
  box-shadow:0 24px 50px rgba(0,0,0,.08);
}

.about-business-card > img{
  width:100%;
  height:220px;
  object-fit:cover;
  display:block;
}

.about-business-content{
  position:relative;
  padding:54px 30px 34px;
}

.about-business-icon{
  position:absolute;
  top:-34px;
  left:30px;
  width:68px;
  height:68px;
  border-radius:50%;
  background:#fff;
  border:1px solid #e8dcc4;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 10px 25px rgba(0,0,0,.08);
}

.about-business-icon img{
  width:38px;
  height:38px;
  object-fit:contain;
}

.about-business-card h3{
  font-size:28px;
  color:#111;
  letter-spacing:2px;
  margin-bottom:10px;
  font-weight:400;
}

.about-business-sub{
  color:#b89b5e !important;
  font-size:14px;
  letter-spacing:.08em;
  margin-bottom:18px;
}

.about-business-card p{
  color:#555;
  line-height:2;
  font-size:15px;
}

.about-business-btn{
  display:inline-block;
  margin-top:24px;
  padding:12px 24px;
  border:1px solid #b89b5e;
  color:#8a6f35;
  text-decoration:none;
  font-size:14px;
  letter-spacing:.08em;
  transition:.3s;
}

.about-business-btn:hover{
  background:#b89b5e;
  color:#fff;
}

/* スマホ */

@media screen and (max-width:768px){

  .about-business-list{
    grid-template-columns:1fr;
  }

  .about-business-card > img{
    height:210px;
  }

  .about-business-content{
    padding:52px 24px 30px;
  }

}


/* =====================
HEALTH
===================== */

/* PC */

.about-health-declaration{
  max-width:820px;
  margin:0 auto 50px;
  padding:44px 42px;
  background:#fff;
  border:1px solid #eee7d8;
}

.about-health-declaration h3{
  color:#b89b5e;
  font-size:24px;
  font-weight:400;
  letter-spacing:.12em;
  margin-bottom:24px;
}

.about-health-declaration p,
.about-page-health > .about-page-inner > p{
  font-size:17px;
  line-height:2.2;
  color:#444;
  margin-bottom:26px;
}

.about-health-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  margin-top:46px;
}

.about-health-card{
  background:#fff;
  border:1px solid #eee7d8;
  padding:34px 24px;
  text-align:left;
}

.about-health-card span{
  color:#b89b5e;
  font-family:"Cormorant Garamond","Noto Serif JP",serif;
  font-size:34px;
  font-style:italic;
}

.about-health-card h3{
  font-size:18px;
  line-height:1.7;
  font-weight:400;
  margin:10px 0 14px;
}

.about-health-card p{
  font-size:14px;
  line-height:1.9;
  color:#555;
}

.about-health-note{
  max-width:820px;
  margin:42px auto 0;
  padding:18px 24px;
  border-top:1px solid #d8c79f;
  border-bottom:1px solid #d8c79f;
  color:#6f5a2f;
  font-size:14px;
  line-height:1.9;
}

/* スマホ */

@media screen and (max-width:768px){

  .about-health-declaration{
    padding:34px 24px;
  }

  .about-health-grid{
    grid-template-columns:1fr;
  }

  .about-health-card{
    padding:28px 22px;
  }

}


/* =====================
CONCEPT
===================== */

/* PC */

.about-page-concept p{
  font-size:18px;
  line-height:2.3;
  color:#444;
  margin-bottom:28px;
}

/* スマホ */

@media screen and (max-width:768px){

  .about-page-concept p{
    font-size:16px;
    line-height:2.2;
  }

}


/* =====================
COMPANY
===================== */

/* PC */

.about-page-company .about-page-label,
.about-page-company h2{
  text-align:center;
}

.company-list{
  max-width:850px;
  margin:0 auto;
  border-top:1px solid #e5e5e5;
}

.company-list div{
  display:grid;
  grid-template-columns:200px 1fr;
  border-bottom:1px solid #e5e5e5;
  padding:28px 0;
}

.company-list dt{
  color:#b89b5e;
  font-weight:400;
  letter-spacing:2px;
}

.company-list dd{
  color:#333;
  line-height:1.8;
}

/* スマホ */

@media screen and (max-width:768px){

  .company-list div{
    grid-template-columns:1fr;
    gap:8px;
  }

}