body {
  background-color: #F9F9F9;
  font-family: 'dnp-shuei-mgothic-std', sans-serif;
  color:#505050;
  margin: 0;
}

/* header */
header img {
  margin: 40px 0 50px;
}
.logo {
  display: block;
  width:320px;
  margin-right: auto;
  margin-left: auto;
}
.menu{
  width: 800px;
  margin-right: auto;
  margin-left: auto;
  font-family: Arial;
  font-size: 20px;
  margin-bottom: 55px;
}
.menu ul {
  display:flex;
}
.menu li {
  list-style-type: none;
  margin-right: 45px;
}
.menu li:hover {
  opacity: 0.5;
}
.menu a {
  text-decoration: none;
  color: #777676;
}

.toppic {
  width: 800px;
  margin: 0 auto;
}
.toppic img {
  width: 100%;
}

/* common */
.BrSp{
  display: none;
}
.BrPc {
  display: block;;
}
.ContentTtl img {
  width: 250px;
  margin: 0 auto 10px;
  display: block;
}
.ContentTtl h1 {
  font-family: 'the-seasons', serif;
  letter-spacing: 0.05em;
  line-height: 1;
  font-size: 38px;
  text-align: center;
  margin: 0;
  font-weight: normal;
}
.ContentTtl h2 {
  margin: 10px 0 60px;
  font-weight: normal;
  font-size: 16px;
  text-align: center;
}

/* PHILOSOPHY */
.sectionPink {
  padding-top: 100px;
  padding-bottom: 100px;
  background-color: #B5A5AC;
  color: white;
  width: 100%;
}
.PhiloSmallp {
  text-align: center;
  line-height: 3;
}
.PhiloBigp {
  text-align: center;
  font-size: 30px;
  margin: 50px 0;
  line-height: 1.5;
}

/* ABOUT */
.sectionWhite {
  padding-top: 100px;
  padding-bottom: 100px;
  text-align: center;
  line-height: 2.5;
}
.sectionWhite .ContentTtl {
  color:#8E7783;
}
.aboutFlex {
  display: flex;
  margin: 45px auto 55px;
  width: 800px;
}
.aboutFlex img {
  width: 350px;
  display: block;
}
.aboutFlex p {
  margin: 126px auto 0 40px;
  text-align: left;
}

/* CONTENTS */
.sectionRightPink {
  background-color: #D6CBD0;
  padding-top: 100px;
  padding-bottom: 100px;
}
.sectionRightPink .ContentTtl {
  color:#8E7783;
}
.contents-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr); /* 3列を均等に配置 */
    gap: 30px; /* セクション間のスペース */
    margin-bottom: 50px;
    width: 740px;
    margin-left: auto;
    margin-right: auto;
}
/* 各コンテンツアイテム (01, 02, 03) */
.content-item {
    border: 0.5px solid #505050;
    padding: 40px 10px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 220px;
    height: 200px;
    justify-content: flex-start;
}
.content-item .number {
    font-size: 38px;
    font-family: 'the-seasons', serif;
    line-height: 1;
    letter-spacing: 0.05em;
    margin-bottom: 20px;
    color: #505050;
}
.content-item .description {
    font-size: 14px;
    line-height: 2;
    color: #505050;
    text-align: center;
}
.sectionRightPink > p {
  text-align: center;
  margin: 0;
}

.conceptImg {
  width: 100%;
}

/* COMPANY */
.sectionGray {
  background-color: #878E98;
  padding-top: 100px;
  padding-bottom: 100px;
  color: white;
}
.company-details-box {
    width: 400px;
    max-width: 600px; /* 詳細ボックスの最大幅 */
    margin: 0 auto;
    padding: 50px 135px;
    border: 0.5px solid white;
    text-align: left;
}
.company-details-box dl {
    display: grid;
    /* dtとddを2列で配置 (タイトルと内容) */
    grid-template-columns: 100px 1fr; 
    gap: 10px 20px;
    margin: 0;
    padding: 0;
}
.company-details-box dt {
    font-weight: normal;
    grid-column: 1; /* 1列目 */
}
.company-details-box dd {
    margin: 0;
    grid-column: 2; /* 2列目 */
}

/* CONTACT */
.contactBtn {
  margin-top: 40px;
  text-decoration: none;
  color: white;
  background-color: #C5A3B1;
  display: inline-block;
  padding: 7px 70px;
  border-radius: 40px;
  transition: 0.3s;
}
.contactBtn:hover {
    background-color: #e9c8d6; /* ホバー時の色変化 */
}
.contactP {
  margin: 0;
}

/* PRIVACY POLICY */
.sectionRightgray {
  background-color: #E7ECF2;
  padding-top: 100px;
}
.PPContents {
  width: 800px;
  margin: 0 auto;
  padding-bottom: 100px;
}
.PPtop {
  margin: 0 auto 45px;
  font-size: 16px;
}
.PP01 {
  font-size: 16px;
}
.PP02 {
  font-size: 13px;
  margin: 0px auto 0px 30px;
}
.PP03 {
  font-size: 13px;
  margin: 0px auto 0px 45px;
}
.mb15 {
  margin-bottom: 15px;
}
.mb35 {
  margin-bottom: 35px;
}

/* footer */
footer{
  background-color: #878E98;
  color: white;
  text-align: center;
  padding-top: 30px;
  padding-bottom: 30px;
}
footer img {
  width: 250px;
  display:block;
  margin: 0 auto 20px;
}
footer p {
  margin: 0;
}


@media (max-width:767px) {
  .logo {
  width:200px;
}
.menu{
  width: 85%;
  /* margin-right: auto;
  margin-left: auto;
  font-family: Arial; */
  font-size: 15px;
  margin-bottom: 25px;
}
.menu ul {
  flex-wrap: wrap;
  justify-content: center;
  padding: 0;
  margin: 0;
}
.menu li {
  /* list-style-type: none; */
  margin-right: 0;
  width: 30%;
  text-align: center;
  margin-bottom: 15px;
}
.menu a {
  display: block;
  font-size: 15px;
  /* text-align: center; */
}

.toppic {
  width: 90%;
  margin: 0 auto;
}
.toppic img {
  width: 100%;
  padding-left: 10px;
}

/* common */
.BrSp{
  display: block;
}
.BrPc {
  display: none;
}
.ContentTtl img {
  width: 200px;
  /* margin: 0 auto 10px;
  display: block; */
}
.ContentTtl h1 {
  /* font-family: 'the-seasons', serif;
  letter-spacing: 0.05em;
  line-height: 1; */
  font-size: 30px;
  /* text-align: center;
  margin: 0;
  font-weight: normal; */
}
.ContentTtl h2 {
  margin: 10px 0 50px;
  /* font-weight: normal; */
  font-size: 14px;
  /* text-align: center; */
}

/* PHILOSOPHY */
.sectionPink {
  padding-top: 70px;
  padding-bottom: 70px;
  /* background-color: #B5A5AC;
  color: white;
  width: 100%; */
}
.PhiloSmallp {
  /* text-align: center;
  line-height: 3; */
  font-size: 15px;
  margin: 0;
}
.PhiloBigp {
  /* text-align: center; */
  font-size: 22px;
  /* margin: 50px 0;
  line-height: 1.5; */
}

/* ABOUT */
.sectionWhite {
  padding-top: 70px;
  padding-bottom: 70px;
  /* text-align: center;
  line-height: 2.5; */
}
/* .sectionWhite .ContentTtl {
  color:#8E7783;
} */
.aboutFlex {
  display: block;
  margin: 45px auto 20px;
  width: 100%;
}
.aboutFlex img {
  width: 80%;
  display: block;
  margin: 0 auto;
}
.aboutFlex p {
  margin: 20px auto 40px;
  text-align: left;
  width: 80%;
  font-size: 15px;
}
.aboutFirstp {
  font-size: 15px;
}
.aboutLastp {
  width: 95%;
  margin: 0 auto;
  font-size: 15px;
}

/* CONTENTS */
.sectionRightPink {
  /* background-color: #D6CBD0; */
  padding-top: 70px;
  padding-bottom: 70px;
}
/* .sectionRightPink .ContentTtl {
  color:#8E7783;
} */
.contents-grid {
  grid-template-columns: 1fr;
  width: 90%;
    /* display: grid;
    grid-template-columns: repeat(3, 1fr); 
    gap: 30px;
    margin-bottom: 50px;
    width: 740px;
    margin-left: auto;
    margin-right: auto; */
}
/* 各コンテンツアイテム (01, 02, 03) */
.content-item {
    /* border: 0.5px solid #505050; */
    padding: 30px 10px 20px;
    /* display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 220px; */
    height: auto;
    /* justify-content: flex-start; */
    margin: 0 auto;
}
.content-item .number {
    font-size: 30px;
    /* font-family: 'the-seasons', serif;
    line-height: 1;
    letter-spacing: 0.05em;
    margin-bottom: 20px;
    color: #505050; */
}
/* .content-item .description {
    font-size: 14px;
    line-height: 2;
    color: #505050;
    text-align: center;
} */
.sectionRightPink > p {
  /* text-align: center;
  margin: 0; */
  font-size: 13px;;
}

/* .conceptImg {
  width: 100%;
  display: block;
} */

/* COMPANY */
.sectionGray {
  /* background-color: #878E98; */
  padding-top: 70px;
  padding-bottom: 70px;
  /* color: white; */
}
.company-details-box {
    width: 90%;
    /* max-width: 600px; 
    margin: 0 auto; */
    padding: 40px 0 40px 15px;
    /* border: 0.5px solid white;
    text-align: left; */
    font-size: 15px;
}

/* CONTACT */
/* .contactBtn {
  margin-top: 40px;
  text-decoration: none;
  color: white;
  background-color: #C5A3B1;
  display: inline-block;
  padding: 7px 70px;
  border-radius: 40px;
  transition: 0.3s;
}
.contactP {
  margin: 0;
} */

/* PRIVACY POLICY */
.sectionRightgray {
  /* background-color: #E7ECF2; */
  padding-top: 70px;
}
.PPContents {
  width: 95%;
  /* margin: 0 auto; */
  padding-bottom: 70px;
}
.PPtop {
  margin: 0 auto 30px;
  font-size: 15px;
}
/* .PP01 {
  font-size: 15px;
} */
.PP02 {
  /* font-size: 13px; */
  margin: 0px auto 0px 20px;
}
.PP03 {
  /* font-size: 13px; */
  margin: 0px auto 0px 30px;
}
.mb15 {
  margin-bottom: 15px;
}
.mb35 {
  margin-bottom: 35px;
}

/* footer */
footer{
  background-color: #878E98;
  color: white;
  text-align: center;
  padding-top: 30px;
  padding-bottom: 30px;
}
footer img {
  width: 180px;
  /* display:block; */
  margin: 0 auto 30px;
}
footer p {
  /* margin: 0; */
  font-size: 13px;
}
}