@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200..900&display=swap");
/*-----------------------------
//local common
-----------------------------*/
@media screen and (max-width: 640px) {
  [data-sc-pc] {
    display: none !important;
  }
}
@media print, screen and (min-width: 641px) {
  [data-sc-sp] {
    display: none !important;
  }
}
body {
  background-color: #fff;
}
body #container {
  color: #333;
  font-weight: 400;
  font-style: normal;
}
@media screen and (max-width: 640px) {
  body #container {
    width: 100%;
  }
}

.mod_main {
  overflow: hidden;
}

ul,
ol {
  list-style: none;
}

.of img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.pagetop_2021 {
  z-index: 10;
}

/*-----------------------------
//contents
-----------------------------*/
.mv {
  margin-top: 123px;
}
@media screen and (max-width: 640px) {
  .mv {
    margin-top: 29px;
  }
}
.mv .mv_wrap {
  position: relative;
}
@media screen and (max-width: 640px) {
  .mv .mv_wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    height: auto;
  }
}
.mv .mv_img_box {
  display: block;
  max-width: 1353px;
  width: 100%;
  height: 580px;
  margin: 0 auto;
}
@media screen and (max-width: 640px) {
  .mv .mv_img_box {
    width: 100%;
    height: auto;
    aspect-ratio: 375/338;
  }
}

.mv_contents {
  height: 696px;
  padding: 93px 30px 0;
  position: relative;
  max-width: 1380px;
  margin: 0 auto;
  z-index: 2;
}
@media screen and (max-width: 640px) {
  .mv_contents {
    height: auto;
    padding: 119.42px 0 171.45px;
  }
}
.mv_contents .mv_text_box .contTit .title {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 38px;
  letter-spacing: 0.11em;
  line-height: 1.84;
  text-align: center;
  color: #611F20;
}
@media screen and (max-width: 640px) {
  .mv_contents .mv_text_box .contTit .title {
    font-size: 19.62px;
    letter-spacing: 0.15em;
  }
}
.mv_contents .mv_text_box .contTit .title .en {
  font-family: "ltc-caslon-pro", serif;
  font-weight: 500;
  display: block;
  font-size: 20px;
  letter-spacing: 0;
  margin-top: 21px;
  color: #611F20;
}
@media screen and (max-width: 640px) {
  .mv_contents .mv_text_box .contTit .title .en {
    font-size: 11.09px;
    letter-spacing: 0;
    line-height: 1.6;
    margin-top: 3.41px;
  }
}
.mv_contents .mv_text_box .ttl {
  margin-top: 50px;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 22px;
  letter-spacing: 0.11em;
  line-height: 1.91;
  text-align: center;
}
@media screen and (max-width: 640px) {
  .mv_contents .mv_text_box .ttl {
    margin-top: 25.59px;
    font-size: 11.94px;
    letter-spacing: 0.06em;
    line-height: 2.15;
  }
}
.mv_contents .mv_text_box .txt {
  font-family: "Noto Serif JP", serif;
  font-size: 16px;
  letter-spacing: 0.07em;
  line-height: 2.06;
  text-align: center;
  margin-top: 30px;
}
@media screen and (max-width: 640px) {
  .mv_contents .mv_text_box .txt {
    margin-top: 12.8px;
    font-size: 10.24px;
    letter-spacing: 0.06em;
  }
}
.mv_contents .mv_ph .mv_ph_img {
  position: absolute;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}
.mv_contents .mv_ph .mv_ph_img:first-of-type {
  top: -50px;
  left: 7.97%;
  aspect-ratio: 380/253;
  max-width: 26.4%;
  z-index: 1;
}
@media screen and (max-width: 640px) {
  .mv_contents .mv_ph .mv_ph_img:first-of-type {
    top: -12.8px;
    left: 0;
    aspect-ratio: 242/160;
    max-width: 170.6px;
  }
}
.mv_contents .mv_ph .mv_ph_img:nth-child(2) {
  top: 133px;
  right: 10.51%;
  aspect-ratio: 220/318;
  max-width: 15%;
}
@media screen and (max-width: 640px) {
  .mv_contents .mv_ph .mv_ph_img:nth-child(2) {
    top: 32.41px;
    right: 0;
    aspect-ratio: 110/158;
    max-width: 93.83px;
    z-index: -1;
  }
}
.mv_contents .mv_ph .mv_ph_img:nth-child(3) {
  bottom: 223px;
  left: 0;
  aspect-ratio: 1/1;
  max-width: 14.6%;
}
@media screen and (max-width: 640px) {
  .mv_contents .mv_ph .mv_ph_img:nth-child(3) {
    bottom: 116.86px;
    left: -11.09px;
    max-width: 72.51px;
    z-index: -1;
  }
}
.mv_contents .mv_ph .mv_ph_img:nth-child(4) {
  bottom: -32px;
  left: 11.52%;
  aspect-ratio: 320/212;
  max-width: 21%;
}
@media screen and (max-width: 640px) {
  .mv_contents .mv_ph .mv_ph_img:nth-child(4) {
    bottom: 53.74px;
    left: 44.36px;
    max-width: 112.6px;
  }
}
.mv_contents .mv_ph .mv_ph_img:nth-child(5) {
  bottom: -64px;
  right: 4.93%;
  aspect-ratio: 462/309;
  max-width: 27.2%;
  z-index: 1;
}
@media screen and (max-width: 640px) {
  .mv_contents .mv_ph .mv_ph_img:nth-child(5) {
    bottom: -25.59px;
    right: 0;
    aspect-ratio: 1/1;
    -o-object-fit: cover;
       object-fit: cover;
    max-width: 127.95px;
  }
}

/* ----------- WEDDING ----------- */
.wedding {
  padding-top: 115px;
  padding-bottom: 106px;
  background-color: #F8F7F4;
  position: relative;
}
@media screen and (max-width: 640px) {
  .wedding {
    padding-top: 48.62px;
    padding-bottom: 42.65px;
  }
}
.wedding .wedding_link {
  position: absolute;
  top: 121px;
  right: 18px;
  width: 110px;
  aspect-ratio: 1/1;
  height: auto;
  background-color: #611F20;
  border-radius: 50%;
  -webkit-box-shadow: 2.4px 2px #000;
          box-shadow: 2.4px 2px #000;
  opacity: 1;
  -webkit-transition: opacity 0.5s;
  transition: opacity 0.5s;
  z-index: 2;
  -webkit-transition-duration: 0.6s;
          transition-duration: 0.6s;
  cursor: pointer;
}
.wedding .wedding_link.fixed {
  position: fixed;
  top: 140px;
  right: 18px;
  z-index: 11;
  max-width: 1440px;
  margin: 0 auto;
}
.wedding .wedding_link.fixed.none {
  opacity: 0;
}
@media screen and (max-width: 640px) {
  .wedding .wedding_link {
    display: none;
  }
}
.wedding .wedding_link:hover {
  opacity: 0.6;
}
.wedding .wedding_link .link_inner {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  height: 100%;
  text-decoration: none;
}
.wedding .wedding_link .link_inner::before {
  content: "";
  position: absolute;
  aspect-ratio: 269/221;
  width: 74px;
  height: auto;
  bottom: -10px;
  left: -26px;
  background-image: url("../img/pet_image.png");
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
.wedding .wedding_link .link_inner .link_txt {
  color: #fff;
  font-size: 14px;
  letter-spacing: 0;
  font-weight: 700;
  font-family: "Noto Serif JP", serif;
  text-align: center;
}
.wedding .secTit {
  width: 100%;
  max-width: 1060px;
  margin: 0 auto;
  padding-left: 60px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media screen and (max-width: 640px) {
  .wedding .secTit {
    padding-left: 17.06px;
  }
}
.wedding .secTit .title {
  font-family: "ltc-caslon-pro", serif;
  font-weight: 500;
  font-size: 42px;
  letter-spacing: 0.04em;
  color: #611F20;
}
@media screen and (max-width: 640px) {
  .wedding .secTit .title {
    font-size: 23.03px;
    letter-spacing: 0.06em;
  }
}
.wedding .secTit .title .ja {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  display: block;
  font-size: 14px;
  letter-spacing: 0.25em;
  margin-top: 7px;
  color: #611F20;
}
@media screen and (max-width: 640px) {
  .wedding .secTit .title .ja {
    font-size: 10.24px;
    letter-spacing: 0.25em;
    line-height: 1.66;
    margin-top: 0;
  }
}
.wedding .wedding_title {
  max-width: 1060px;
  margin: 0 auto 184px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-flow: row-reverse;
          flex-flow: row-reverse;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
  height: 387px;
}
@media screen and (max-width: 640px) {
  .wedding .wedding_title {
    padding-bottom: 42.65px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-flow: column;
            flex-flow: column;
    margin-bottom: 0;
    height: auto;
  }
}
.wedding .wedding_title .ph {
  width: calc(50% + 56px);
  margin-left: -56px;
}
@media screen and (max-width: 640px) {
  .wedding .wedding_title .ph {
    width: calc(100% - 34.12px);
    margin-top: 42.65px;
    margin-left: auto;
    margin-right: 0;
    font-size: 0;
    z-index: 1;
  }
}
.wedding .wedding_title .ph img {
  aspect-ratio: 580/387;
  width: 100%;
}
@media screen and (max-width: 640px) {
  .wedding .wedding_title .ph img {
    aspect-ratio: 334/233;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
.wedding .wedding_title .col {
  position: relative;
  width: 50%;
  background-color: rgba(255, 255, 255, 0.9);
  z-index: 10;
  margin-top: 70px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 72px 60px;
  min-height: 400px;
}
@media screen and (max-width: 640px) {
  .wedding .wedding_title .col {
    width: 85.35%;
    margin-top: -17.91px;
    margin-left: 12.8px;
    padding: 24.74px 17.06px 27.3px;
    min-height: 221.78px;
  }
}
.wedding .wedding_title .col:before {
  pointer-events: none;
  content: "";
  position: absolute;
  border: 1px solid #C2A4A5;
  pointer-events: none;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 95%;
  height: 95%;
  pointer-events: none;
}
.wedding .wedding_title .col .ttl {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 22px;
  letter-spacing: 0.04em;
  line-height: 1.91;
  margin-bottom: 30px;
}
@media screen and (max-width: 640px) {
  .wedding .wedding_title .col .ttl {
    font-size: 13.65px;
    margin-bottom: 12.8px;
    letter-spacing: 0.04em;
    line-height: 1.75;
  }
}
.wedding .wedding_title .col .txt {
  font-size: 14px;
  line-height: 1.785;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 640px) {
  .wedding .wedding_title .col .txt {
    font-size: 10.24px;
    letter-spacing: 0.02em;
    line-height: 1.66;
  }
}
.wedding .col3 {
  max-width: 970px;
  margin: 0 auto 100px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 640px) {
  .wedding .col3 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 0 21.33px;
    margin-bottom: 42.65px;
  }
}
.wedding .col3 .col {
  width: 300px;
}
@media screen and (max-width: 640px) {
  .wedding .col3 .col {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-column-gap: 17.06px;
       -moz-column-gap: 17.06px;
            column-gap: 17.06px;
    padding: 17.06px 0;
    border-bottom: 0.85px solid rgba(158, 158, 158, 0.5);
  }
  .wedding .col3 .col:first-of-type {
    padding-top: 0;
  }
}
.wedding .col3 .col .ph {
  width: 100%;
  margin: 0 0 22px;
  font-size: 0;
}
@media screen and (max-width: 640px) {
  .wedding .col3 .col .ph {
    width: 127.95px;
    margin: 0;
  }
}
.wedding .col3 .col .ph img {
  aspect-ratio: 3/2;
  width: 100%;
  height: auto;
}
.wedding .col3 .col .catch {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 18px;
  letter-spacing: 0.04em;
  text-align: center;
  line-height: 1.78;
}
@media screen and (max-width: 640px) {
  .wedding .col3 .col .catch {
    font-size: 12.8px;
    text-align: left;
    line-height: 1.86;
  }
}
.wedding {
  /* --------------- POINT --------------- */
}
.wedding .point {
  max-width: 1050px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 46px;
     -moz-column-gap: 46px;
          column-gap: 46px;
  margin: 0 auto;
}
@media screen and (max-width: 640px) {
  .wedding .point {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 46.06px 13.65px auto;
    grid-template-columns: 46.06px auto;
    -ms-grid-rows: auto 7.68px auto;
    grid-template-rows: repeat(2, auto);
    padding: 0;
    gap: 7.68px 13.65px;
    max-width: calc(100% - 17.06px);
  }
  .wedding .point > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .wedding .point > *:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .wedding .point > *:nth-child(3) {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .wedding .point > *:nth-child(4) {
    -ms-grid-row: 3;
    -ms-grid-column: 3;
  }
}
.wedding .point .ttl {
  max-width: 14px;
  height: 106px;
  width: 100%;
}
@media screen and (max-width: 640px) {
  .wedding .point .ttl {
    -ms-grid-column: 1;
    grid-column: 1;
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    grid-row: 1/3;
    max-width: 9.38px;
    height: 72.08px;
  }
}
.wedding .point .txt_box {
  width: 80%;
}
@media screen and (max-width: 640px) {
  .wedding .point .txt_box {
    display: contents;
  }
}
.wedding .point .txt_box .txt {
  font-size: 14px;
  letter-spacing: 0.02em;
  color: #601e1f;
  line-height: 1.78;
}
@media screen and (max-width: 640px) {
  .wedding .point .txt_box .txt {
    line-height: 1.78;
    -ms-grid-column: 2;
    grid-column: 2;
    -ms-grid-row: 1;
    grid-row: 1;
  }
}
.wedding .point .txt_box .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 20px 50px;
  margin-top: 20px;
}
@media screen and (max-width: 640px) {
  .wedding .point .txt_box .list {
    -ms-grid-column: 1;
    -ms-grid-column-span: 2;
    grid-column: 1/3;
    -ms-grid-row: 2;
    grid-row: 2;
    gap: 0;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: 0;
  }
}
.wedding .point .txt_box .list .item {
  padding-left: 20px;
  position: relative;
  font-family: "Noto Serif JP", serif;
  font-size: 18px;
  letter-spacing: 0.04em;
  line-height: 1.78;
}
@media screen and (max-width: 640px) {
  .wedding .point .txt_box .list .item {
    padding-left: 10.24px;
    line-height: 2.13;
    display: block;
    width: 56%;
    font-size: 12.8px;
  }
}
.wedding .point .txt_box .list .item:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  display: inline-block;
  background-color: #601e1f;
  border-radius: 50%;
  width: 8px;
  aspect-ratio: 1/1;
  height: auto;
}
@media screen and (max-width: 640px) {
  .wedding .point .txt_box .list .item:before {
    width: 5.12px;
  }
}

/* --------------- PICK UP --------------- */
.pickup {
  max-width: 1050px;
  margin: 75px auto 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}
@media screen and (max-width: 640px) {
  .pickup {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    margin-top: 34.12px;
    padding: 0 34.12px 0 0;
  }
}
.pickup .pickup_img {
  position: absolute;
  width: 18px;
  height: 69px;
  top: 140px;
  left: 0;
  z-index: 1;
}
@media screen and (max-width: 640px) {
  .pickup .pickup_img {
    max-width: 10.66px;
    height: 40.94px;
    left: 8.53px;
    top: 0;
  }
}
.pickup .txt_box {
  position: relative;
  width: calc(50% + 75px);
  margin-top: 48px;
  padding: 80px 0 80px 54px;
  z-index: 0;
}
@media screen and (max-width: 640px) {
  .pickup .txt_box {
    width: 82.7%;
    margin-top: 0;
    padding: 17.06px 23.03px 42.65px 34.12px;
    height: auto;
  }
}
.pickup .txt_box::before {
  content: "";
  position: absolute;
  background-color: #fff;
  pointer-events: none;
  top: 0;
  left: -23vw;
  width: 92vw;
  height: 100%;
  z-index: -1;
}
@media screen and (max-width: 640px) {
  .pickup .txt_box::before {
    height: 163%;
    top: auto;
    bottom: 0;
    left: 0;
  }
}
.pickup .txt_box .ttl {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 20px;
  letter-spacing: 0.06em;
  line-height: 1.81;
}
@media screen and (max-width: 640px) {
  .pickup .txt_box .ttl {
    font-size: 13.65px;
    letter-spacing: 0;
    line-height: 1.875;
  }
}
.pickup .txt_box .txt {
  font-size: 14px;
  letter-spacing: 0.07em;
  line-height: 2.14;
  font-weight: 400;
  margin-top: 21px;
}
@media screen and (max-width: 640px) {
  .pickup .txt_box .txt {
    font-size: 10.24px;
    letter-spacing: 0.02em;
    line-height: 1.66;
    margin-top: 12.8px;
  }
}
.pickup .ph {
  position: absolute;
  right: 40px;
  top: 0;
  font-size: 0;
  display: block;
  width: 454px;
  aspect-ratio: 454/283;
  z-index: 1;
}
@media screen and (max-width: 640px) {
  .pickup .ph {
    position: static;
    padding-left: 34.12px;
    z-index: 2;
    max-width: calc(100% - 51.18px);
    aspect-ratio: 275/171;
  }
}

/*------------------- PHOTO -----------------*/
.photo {
  margin: 116px auto 100px;
}
@media screen and (max-width: 640px) {
  .photo {
    margin: 51.18px auto 61.42px;
  }
}
.photo .secTit {
  width: 100%;
  max-width: 1060px;
  margin: 0 auto;
  padding-left: 60px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media screen and (max-width: 640px) {
  .photo .secTit {
    padding-left: 17.06px;
  }
}
.photo .secTit .title {
  font-family: "ltc-caslon-pro", serif;
  font-weight: 500;
  font-size: 42px;
  letter-spacing: 0.04em;
  color: #611F20;
}
@media screen and (max-width: 640px) {
  .photo .secTit .title {
    font-size: 23.03px;
    letter-spacing: 0.06em;
  }
}
.photo .secTit .title .ja {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  display: block;
  font-size: 14px;
  letter-spacing: 0.25em;
  margin-top: 7px;
  color: #611F20;
}
@media screen and (max-width: 640px) {
  .photo .secTit .title .ja {
    font-size: 10.24px;
    letter-spacing: 0.25em;
    line-height: 1.66;
    margin-top: 0;
  }
}
.photo .photo_title {
  max-width: 1060px;
  margin: 0 auto 100px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 640px) {
  .photo .photo_title {
    margin: 39.24px auto 43.5px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding-right: 12.8px;
  }
}
.photo .photo_title .ph {
  width: calc(50% + 55px);
  margin-right: -55px;
  margin-top: 52px;
  font-size: 0;
}
@media screen and (max-width: 640px) {
  .photo .photo_title .ph {
    width: 92.8%;
    margin-right: auto;
    margin-top: 0;
  }
}
.photo .photo_title .ph img {
  aspect-ratio: 580/387;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 640px) {
  .photo .photo_title .ph img {
    aspect-ratio: 334/233;
  }
}
.photo .photo_title .col {
  position: relative;
  width: 50%;
  background-color: rgba(248, 247, 244, 0.9);
  z-index: 10;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 74px 60px 70px;
  height: 400px;
}
@media screen and (max-width: 640px) {
  .photo .photo_title .col {
    width: 88.9%;
    margin-top: -17.91px;
    margin-left: auto;
    padding: 24.74px 17.06px 27.3px;
    height: 221.78px;
  }
}
.photo .photo_title .col:before {
  content: "";
  position: absolute;
  border: 1px solid #C2A4A5;
  pointer-events: none;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 95%;
  height: 95%;
}
.photo .photo_title .col .ttl {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 22px;
  letter-spacing: 0.04em;
  margin-bottom: 30px;
  line-height: 1.9;
}
@media screen and (max-width: 640px) {
  .photo .photo_title .col .ttl {
    font-size: 13.65px;
    margin-bottom: 12.8px;
    line-height: 1.75;
    letter-spacing: 0.04em;
  }
}
.photo .photo_title .col .txt {
  font-size: 14px;
  letter-spacing: 0.02em;
  line-height: 1.78;
}
@media screen and (max-width: 640px) {
  .photo .photo_title .col .txt {
    font-size: 10.24px;
    letter-spacing: 0.02em;
    line-height: 1.66;
  }
}
.photo .ph_box {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 25px;
  position: relative;
  z-index: 0;
}
.photo .ph_box::before {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  width: 100%;
  background-color: #F8F7F4;
  height: calc(100% - 60px);
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 640px) {
  .photo .ph_box {
    padding: 0 12.8px;
  }
  .photo .ph_box::before {
    width: calc(100% - 25.59px);
    height: calc(100% + 34.12px);
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
  .photo .ph_box img {
    margin: 59.71px auto 0;
    padding: 0 8.53px;
    width: calc(100% - 17.06px);
  }
}

/* --------------- family ---------------- */
.family {
  padding: 114px 0 146px;
  background-color: #F1F0EC;
  position: relative;
}
@media screen and (max-width: 640px) {
  .family {
    padding: 51.18px 0 93.83px;
  }
  .family::before {
    top: 8.1px;
    left: 50%;
    -webkit-transform: translate(-80%, 0);
            transform: translate(-80%, 0);
    max-width: 196.19px;
  }
}
.family .secTit .title {
  font-family: "ltc-caslon-pro", serif;
  font-weight: 500;
  font-size: 42px;
  letter-spacing: 0.04em;
  text-align: center;
  color: #611F20;
}
@media screen and (max-width: 640px) {
  .family .secTit .title {
    font-size: 23.03px;
    letter-spacing: 0.06em;
  }
}
.family .secTit .title .ja {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  display: block;
  font-size: 14px;
  letter-spacing: 0.25em;
  margin-top: 7px;
  text-align: center;
  color: #611F20;
}
@media screen and (max-width: 640px) {
  .family .secTit .title .ja {
    font-size: 10.24px;
    letter-spacing: 0.25em;
    line-height: 1.66;
    margin-top: 0;
  }
}
.family .txt {
  font-family: "Noto Serif JP", serif;
  font-size: 15px;
  letter-spacing: 0.04em;
  line-height: 1.8;
  margin-top: 50px;
  margin-bottom: 80px;
  text-align: center;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 640px) {
  .family .txt {
    font-size: 12.8px;
    margin-top: 25.59px;
    margin-bottom: 29px;
    line-height: 1.86;
  }
}
.family .col3 {
  max-width: 970px;
  margin: 0 auto 100px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 640px) {
  .family .col3 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 0 21.33px;
    margin-bottom: 0;
  }
}
.family .col3 .col {
  width: 300px;
}
@media screen and (max-width: 640px) {
  .family .col3 .col {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-column-gap: 17.06px;
       -moz-column-gap: 17.06px;
            column-gap: 17.06px;
    padding: 17.06px 0;
    border-bottom: 0.85px solid rgba(158, 158, 158, 0.5);
  }
  .family .col3 .col:first-of-type {
    padding-top: 0;
  }
}
.family .col3 .col .ph {
  width: 100%;
  margin: 0 0 22px;
  font-size: 0;
}
@media screen and (max-width: 640px) {
  .family .col3 .col .ph {
    width: 127.95px;
    margin: 0;
  }
}
.family .col3 .col .ph img {
  aspect-ratio: 3/2;
  width: 100%;
  height: auto;
}
.family .col3 .col .catch {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 18px;
  letter-spacing: 0.04em;
  text-align: center;
  line-height: 1.78;
}
@media screen and (max-width: 640px) {
  .family .col3 .col .catch {
    font-size: 12.8px;
    text-align: left;
    line-height: 1.86;
  }
}

/* --------------- voice ---------------- */
.voice {
  position: relative;
  max-width: 1016px;
  margin: 75px auto 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-column-gap: 46px;
     -moz-column-gap: 46px;
          column-gap: 46px;
  z-index: 1;
}
@media screen and (max-width: 640px) {
  .voice {
    margin: 55.45px auto 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 0 12.8px;
  }
}
.voice:before {
  content: "";
  position: absolute;
  background-color: #F5F5F5;
  width: 100%;
  height: 130%;
  z-index: -1;
  top: 50%;
  left: -26vw;
  width: 92vw;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (max-width: 640px) {
  .voice:before {
    width: 90%;
    height: calc(100% + 46.92px);
    top: -21.33px;
    left: 0;
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
}
.voice .ttl {
  width: 100%;
  max-width: 296px;
  height: 135px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 640px) {
  .voice .ttl {
    max-width: 100%;
  }
}
.voice .ttl img {
  width: 14px;
  height: 135px;
}
@media screen and (max-width: 640px) {
  .voice .ttl img {
    width: 9.38px;
    height: 91.27px;
  }
}
.voice .ttl span {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  display: block;
  width: 212px;
  padding-left: 40px;
  font-size: 20px;
  letter-spacing: 0.06em;
  line-height: 1.9;
}
@media screen and (max-width: 640px) {
  .voice .ttl span {
    width: 80%;
    padding-left: 0;
    text-align: center;
    font-size: 12.8px;
    letter-spacing: 0.04em;
    line-height: 1.86;
  }
}
.voice .list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 30px 1fr;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px;
  width: 670px;
  margin-right: 23px;
}
@media screen and (max-width: 640px) {
  .voice .list {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: 12.8px;
    width: calc(100% - 72.51px);
    padding-left: 17.06px;
  }
}
.voice .list .item {
  background-color: #fff;
  height: 125px;
  padding: 25px 35px 0;
  font-size: 14px;
  letter-spacing: 0.02em;
  line-height: 1.785;
}
@media screen and (max-width: 640px) {
  .voice .list .item {
    height: auto;
    padding: 21.33px 25.59px;
    font-size: 10.24px;
    line-height: 1.66;
  }
}

/* --------------- faq ---------------- */
.sec_faq > .in {
  max-width: 990px;
  width: 100%;
  margin: auto;
  margin-top: 100px;
  margin-bottom: 100px;
  padding: 50px 65px 50px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background-color: #fff;
  border: 2px solid #efefef;
}
@media screen and (max-width: 640px) {
  .sec_faq > .in {
    max-width: calc(100% - 34.12px);
    margin-top: 42.65px;
    margin-bottom: 42.65px;
    padding: 17.06px;
    padding-top: 30.71px;
    padding-bottom: 25.59px;
  }
}
.sec_faq .secTit .title {
  font-family: "ltc-caslon-pro", serif;
  font-weight: 500;
  font-size: 32px;
  letter-spacing: 0.04em;
  text-align: center;
  color: #611F20;
}
@media screen and (max-width: 640px) {
  .sec_faq .secTit .title {
    font-size: 23.03px;
    letter-spacing: 0.06em;
  }
}
.sec_faq .secTit .title .ja {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  display: block;
  font-size: 14px;
  letter-spacing: 0.25em;
  margin-top: 7px;
  text-align: center;
  color: #611F20;
}
@media screen and (max-width: 640px) {
  .sec_faq .secTit .title .ja {
    font-size: 10.24px;
    letter-spacing: 0.25em;
    line-height: 1.66;
    margin-top: 0;
  }
}
.sec_faq .faqBox .item {
  padding: 50px 0;
  padding-left: 105px;
  padding-right: 68px;
}
@media screen and (max-width: 640px) {
  .sec_faq .faqBox .item {
    padding: 29.86px 0;
    padding-left: 17.06px;
    padding-right: 0;
  }
}
.sec_faq .faqBox .item > dt, .sec_faq .faqBox .item > dd {
  position: relative;
}
.sec_faq .faqBox .item > dt:before, .sec_faq .faqBox .item > dd:before {
  content: attr(data-txt);
  position: absolute;
  left: -40px;
  top: 0.325em;
  font-family: "ltc-caslon-pro", serif;
  font-size: 20px;
  letter-spacing: 0.04em;
  line-height: 1;
  color: #611F20;
}
@media screen and (max-width: 640px) {
  .sec_faq .faqBox .item > dt:before, .sec_faq .faqBox .item > dd:before {
    left: -17.06px;
    font-size: 12.8px;
  }
}
.sec_faq .faqBox .item > dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 640px) {
  .sec_faq .faqBox .item > dt {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}
.sec_faq .faqBox .item > dt span {
  font-family: "Noto Serif JP", serif;
  font-size: 18px;
  letter-spacing: 0.07em;
  line-height: 1.39;
  color: #611F20;
}
@media screen and (max-width: 640px) {
  .sec_faq .faqBox .item > dt span {
    font-size: 11.94px;
    letter-spacing: 0.06em;
    line-height: 1.57;
    width: 100%;
  }
}
.sec_faq .faqBox .item > dt img {
  width: 32px;
  height: 32px;
  margin-left: 20px;
}
.sec_faq .faqBox .item > dt img + img {
  margin-left: 10px;
  margin-left: 7px;
}
@media screen and (max-width: 640px) {
  .sec_faq .faqBox .item > dt img {
    width: 21.33px;
    height: 21.33px;
    margin-top: 2.56px;
    margin-left: 0;
  }
}
.sec_faq .faqBox .item > dd {
  font-size: 14px;
  letter-spacing: 0.07em;
  line-height: 1.78;
  margin-top: 20px;
}
@media screen and (max-width: 640px) {
  .sec_faq .faqBox .item > dd {
    font-size: 10.24px;
    letter-spacing: 0.04em;
    line-height: 1.91;
    margin-top: 10.24px;
  }
}
.sec_faq .faqBox .item + .item {
  border-top: 1px solid #efefef;
}
.sec_faq .faqBox .item:last-of-type {
  border-bottom: 1px solid #efefef;
}
.sec_faq .faqBox .explanation {
  margin-top: 30px;
  padding-left: 60px;
}
@media screen and (max-width: 640px) {
  .sec_faq .faqBox .explanation {
    padding-left: 0;
  }
}
.sec_faq .faqBox .explanation .name {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 12px;
  letter-spacing: 0.02em;
  -webkit-column-gap: 4px;
     -moz-column-gap: 4px;
          column-gap: 4px;
  line-height: 1.83;
}
@media screen and (max-width: 640px) {
  .sec_faq .faqBox .explanation .name {
    font-size: 9.38px;
    -webkit-column-gap: 4.26px;
       -moz-column-gap: 4.26px;
            column-gap: 4.26px;
    line-height: 2.2;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
.sec_faq .faqBox .explanation .name:last-child {
  margin-left: 20px;
}
@media screen and (max-width: 640px) {
  .sec_faq .faqBox .explanation .name:last-child {
    margin-left: 0;
    margin-top: 5.97px;
  }
}
@media screen and (max-width: 640px) {
  .sec_faq .faqBox .explanation .name > img {
    width: 21.33px;
  }
}

#to_top .wrap {
  width: 950px;
  margin: 0 auto;
  text-align: center;
  padding-bottom: 25px;
}

.topics_131018 {
  padding: 0;
}
.topics_131018 #facility_fiftyth {
  background-color: #f4f4f4;
}
/*# sourceMappingURL=index.css.map */