@charset "utf-8";

/*------------------------------------------------------------
    method
------------------------------------------------------------*/

/* 共通スタイル */
.content {
  max-width: 103.2rem;
}

.headLine01 .num {
  display: block;
  margin-bottom: 1.1rem;
  font-size: 4.9rem;
  font-style: italic;
  line-height: 1;
}

p {
  line-height: 2.125;
  margin-bottom: 3.4rem;
}

p:last-child {
  margin-bottom: 0;
}

strong {
  font-size: 1.8rem;
  font-weight: 700;
}

.subBox {
  margin-bottom: 14.3rem;
}

.txtUl {
  max-width: 40rem;
  margin: 0 auto;
  padding: 0.8rem 0 2.7rem 11.6rem;
  font-size: 2rem;
}

.txtUl li {
  position: relative;
  margin-bottom: 0.4rem;
  padding-left: 2.1rem;
}

.txtUl li:last-child {
  margin-bottom: 0;
}

.txtUl li::before {
  position: absolute;
  top: 0.8rem;
  left: 0;
  width: 1.6rem;
  height: 1.6rem;
  background-color: #754C24;
  content: "";
}

.listDl dt {
  margin-bottom: 1.6rem;
}

.listDl dt span {
  display: inline-block;
  padding: 0.6rem 1.3rem 0.9rem;
  background-color: #ECE4D9;
  font-size: 1.6rem;
  vertical-align: top;
}

.listDl dd {
  margin-bottom: 4.2rem;
  font-size: 1.8rem;
  line-height: 1.88;
}

.listDl dd:last-child {
  margin-bottom: 0;
}

.listDl ul li {
  position: relative;
  margin-bottom: 1.1rem;
  padding-left: 4.2rem;
}

.listDl ul li:last-child {
  margin-bottom: 0;
}

.listDl ul li::before {
  position: absolute;
  top: 0.9rem;
  left: 0.7rem;
  width: 1.3rem;
  height: 1.5rem;
  background: url("../img/about/icon01.png") no-repeat left top / 100% 100%;
  content: "";
}

/*------------------------------------------------------------
    sec01 -「妊娠から育児まで」
------------------------------------------------------------*/
.sec01 {
  margin-bottom: 10.7rem;
  background: url("../img/about/bg01.jpg") no-repeat left top / cover;
}

.sec01 .bgBox {
  padding: 6.1rem 0 7.4rem;
}

.sec01 .headLine01 {
  margin-bottom: 3.6rem;
}

.sec01 .txtUl {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-bottom: 1.2rem;
    padding: 0;
    max-width: 100rem;
}

.sec01 .txtUl li {
    position: relative;
    width: 30%;
    font-size: min(max(14px, 1.5vw), 20px);
    line-height: 1.4;
    padding: 1rem;
    border: 1px solid #ccc;
    box-sizing: border-box;
    border-radius: 10px;
}

.sec01 .txtUl li::before {
  width: 0;
  height: 0;
}

.sec01 .txtUl li:not(:last-child)::after {
    content: "▶";
    position: absolute;
    right: max(-45px, -3vw);
    top: 50%;
    transform: translateY(-50%);
    font-size: min(max(14px, 2vw), 30px);
    color: #BD512D;
    padding: 0 0.5rem;
}

/* その他のスタイル */
.sec01 .txtUl li .col {
    margin-top: 0.1rem;
    font-size: 3rem;
    color: #BD512D;
}

/*------------------------------------------------------------
    sec02 -「麻酔を使わない減痛分娩」
------------------------------------------------------------*/
.sec02 {
  margin-bottom: 8.2rem;
}

.sec02 .headLine01 {
  margin-bottom: 5.2rem;
}

.sec02 p {
  font-size: 2rem;
  line-height: 1.7;
  text-align: center;
}

.sec02 .movieBox {
  margin: 4rem 0 2.5rem;
  padding: 6.4rem 0;
  background-color: #F6F5F4;
}

.sec02 .movieBox .content {
  position: relative;
  height: 31.3rem;
  max-width: 100rem;
  overflow: hidden;
}

.sec02 .movieBox .content img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sec02 .movieBox img {
  width: 100%;
}

/*------------------------------------------------------------
    sec03 -「簡単なイメージトレーニング」
------------------------------------------------------------*/
.sec03 {
  background: url("../img/about/bg02.jpg") no-repeat left center / 100% auto;
}

.sec03 .borBox {
  max-width: 74rem;
  margin: 6.3rem auto 0;
  padding: 5.4rem 2.7rem;
  border: 1px solid #B1B1B1;
  font-size: 1.2rem;
  font-weight: 500;
}

.sec03 .borBox p {
  margin-bottom: 2.3rem;
  line-height: 1.75;
  letter-spacing: 0.05em;
  text-align: left;
}

.sec03 .borBox p:last-child {
  margin-bottom: 0;
}

.sec03 .borBox .photoBox {
  width: 26.1rem;
}

.sec03 .borBox .rightBox {
  flex: 1;
  margin: 0.2rem 0 0 2.6rem;
}

.sec03 .borBox .title {
  margin-bottom: 0.8rem;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.75;
}

.sec03 .borBox .txtDl dt {
  float: left;
}

.sec03 .borBox .txtDl dd {
  padding: 0 0 0.3rem 4em;
}

.sec03 .subBox:last-child {
  margin-bottom: 0;
}

/*------------------------------------------------------------
    sec04 -「出産の時に役立つヨガのエクササイズ」
------------------------------------------------------------*/
.sec04 {
  margin-bottom: 11.3rem;
  background: url("../img/about/bg03.png") no-repeat left center / 47.4rem auto;
}

/*------------------------------------------------------------
    sec05 -「呼吸と自律神経」
------------------------------------------------------------*/
.sec05 {
  margin-bottom: 11.3rem;
  background:
    linear-gradient(rgba(255, 255, 255, 0.5), rgba(255, 255, 255, 0.5)) 0 0 / cover no-repeat,
    url("../img/about/bg04.png") right top 20% / 53.3rem auto no-repeat,
    url("../img/about/bg06.png") left top 80% / 30.3rem auto no-repeat,
    url("../img/about/bg05.jpg") left top 50% / 100% auto no-repeat;
}

.sec05 .borBox {
  margin: 3.5rem auto 3.6rem;
  padding: 2.8rem 7.8rem 2.6rem;
}

.sec05 .bgBox {
  margin-top: -13.2rem;
  padding-top: 17.8rem;
}


/*------------------------------------------------------------
    sec06 -「息を吐くだけの呼吸のエクササイズ」
------------------------------------------------------------*/
.sec06 {
  margin-bottom: 11.3rem;
  background: url("../img/about/bg07.png") no-repeat right center / 47.4rem auto;
}

/*------------------------------------------------------------
    Media Query
------------------------------------------------------------*/
@media all and (min-width: 896.98px) {
  .sec05 .borBox02 {
    margin-bottom: 1.5rem;
    padding: 3.8rem 4.8rem 5.6rem;
  }

  .sec05 .borBox02 .photoBox {
    width: 29.2rem;
  }

  .sec05 .borBox02 p {
    margin-bottom: 0;
    line-height: 2.42;
  }

  .sec05 .borBox02 .rightBox {
    margin-left: 1.7rem;
    font-size: 1.4rem;
  }
}

@media all and (max-width: 896.98px) {
  /* 共通 */
  .subBox {
    margin-bottom: 9rem;
    padding: 0 1.8rem;
    letter-spacing: -0.05em;
  }

  .subBox p {
    text-shadow: 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff;
  }
  
  p {
    line-height: 1.9;
    text-align: left;
  }

  strong {
    font-size: 1.6rem;
  }

  /* sec01 */
  .sec01 {
    margin-bottom: 7.7rem;
  }

  .sec01 .bgBox {
    padding: 5.1rem 0 5.4rem;
    background-position: center top;
  }

  .sec01 .txtUl {
    display: block;
    margin-bottom: 0;
  }

  .sec01 .txtUl li {
    position: relative;
    width: auto;
    margin-bottom: 5rem;
    font-size: 1.8rem;
    text-align: center;
    border: 0;
    border-radius: 0;
  }

  .sec01 .txtUl li:last-child {
    margin-bottom: 0;
  }

  .sec01 .txtUl li::after {
    display: none;
  }

  .sec01 .txtUl .col {
    font-size: 2.3rem;
    text-shadow: 0 0 5px #fff, 0 0 10px #fff, 0 0 5px #fff, 0 0 10px #fff, 0 0 15px #fff, 0 0 20px #fff;
  }

  .sec01 .txtUl .image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }

  .sec01 .txtUl .image::before {
    position: absolute;
    top: 0;
    left: 0.05rem;
    z-index: 1;
    width: 100%;
    height: 124%;
    background-color: rgba(255, 255, 255, 0.2);
    content: '';
    box-shadow: inset 0 0 20px 10px #fff;
  }

  .sec01 .txtUl .image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .sec01 .txtUl li p {
    position: relative;
    z-index: 2;
  }

  .sec01 .txtUl li:not(:last-child)::after {
    position: absolute;
    left: 50%;
    z-index: 10;
    display: block;
    font-size: 2.5rem;
    color: #BD512D;
    content: '▼';
    transform: translateX(-50%) translateY(11rem);
  }

  /* sec02 */
  .sec02 {
    margin: 0 1.8rem 50px;
  }

  .sec02 p {
    font-size: 1.6rem;
    text-align: left;
  }

  .sec02 .movieBox {
    margin: 4rem -1.8rem 2.5rem;
  }

  /* sec03 */
  .sec03 .borBox {
    display: block;
    max-width: inherit;
    padding: 3rem 2rem;
    text-shadow: none;
  }

  .sec03 .borBox .photoBox {
    width: auto;
  }

  .sec03 .borBox .rightBox {
    width: 100%;
    margin: 2rem 0 0;
  }

  .sec03 .txtUl {
    padding: 0.8rem 0 2.7rem 8.6rem;
    font-size: 1.8rem;
  }

  .sec03 .txtUl li::before {
    width: 1.4rem;
    height: 1.4rem;
  }

  .sec03 .headLine02 {
    font-size: 2.4rem;
  }

  .sec03 .marTxt {
    margin-bottom: 3.4rem;
  }

  .sec03 .listDl dt span {
    font-size: 1.4rem;
  }

  .sec03 .listDl dd {
    margin-bottom: 4.2rem;
    font-size: 1.4rem;
    line-height: 1.6;
  }

  .sec03 .listDl ul li {
    padding-left: 2rem;
  }

  .sec03 .listDl ul li::before {
    top: 0.6rem;
    width: 1.1rem;
    height: 1.2rem;
  }

  /* sec04 */
  .sec04 {
    background-size: 25rem auto;
  }

  /* sec05 */

  .sec05 .borBox {
    padding: 3rem 2rem;
  }

  .sec05 .bgBox {
    margin: 0 -1.8rem;
    padding: 5.8rem 1.8rem 0;
    background-position: left top 14.8rem;
  }

  .sec05 .borBox02 .headLine02 {
    margin-bottom: 2.7rem;
    font-size: 1.6rem;
  }

  .sec05 .bgBox02 {
    margin: 0 -1.8rem;
    padding: 5.8rem 1.8rem 0;
    background-size: 13rem auto;
  }

  .sec05 .borBox02 .flex {
    display: block;
  }
}