@charset "UTF-8";
/* ===================================================================
CSS information

file name  : bridal_engagement.css
author     : Abilive
style info : 結納・顔合わせ
=================================================================== */
/* ===================================================================
CSS information

file name  : _settings.scss
author     : Abilive
style info : 汎用設定
=================================================================== */
.layout_4col, .page-eng_deco_inner, .page-eng_plan_inner, .page-eng_res_inner, .page-eng-intro {
  width: 90%;
  max-width: 1280px;
  margin: auto;
}
@media only screen and (max-width: 1199px) {
  .layout_4col, .page-eng_deco_inner, .page-eng_plan_inner, .page-eng_res_inner, .page-eng-intro {
    width: 91.6666666667%;
  }
}

.page-eng-intro {
  margin-top: 130px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .page-eng-intro {
    margin-top: 100px;
  }
}
@media only screen and (max-width: 767px) {
  .page-eng-intro {
    margin-top: 2em;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .page-eng-intro {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
@media only screen and (max-width: 767px) {
  .page-eng-intro {
    display: block;
  }
}
.page-eng-intro-txt {
  width: 45%;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .page-eng-intro-txt {
    width: 45%;
  }
}
@media only screen and (max-width: 767px) {
  .page-eng-intro-txt {
    width: 100%;
  }
}
.page-eng-intro-txt .ttl--m {
  margin-bottom: 2em;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .page-eng-intro-txt .ttl--m {
    margin-bottom: 1em;
  }
}
@media only screen and (max-width: 767px) {
  .page-eng-intro-txt .ttl--m {
    margin-bottom: 1em;
  }
}
@media only screen and (max-width: 767px) {
  .page-eng-intro-txt .ttl--m {
    text-align: center;
  }
}
.page-eng-intro-img {
  width: 50%;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .page-eng-intro-img {
    width: 50%;
  }
}
@media only screen and (max-width: 767px) {
  .page-eng-intro-img {
    width: 100%;
  }
}
.page-eng-intro-img img {
  width: 100%;
}
@media only screen and (max-width: 767px) {
  .page-eng-intro-img {
    margin-top: 1em;
  }
}
.page-eng-intro_sec {
  background: url(../images/home/bg_bridal.png);
  background-size: cover;
  padding: 160px 0;
  margin-top: 130px;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .page-eng-intro_sec {
    padding: 100px 0;
  }
}
@media only screen and (max-width: 767px) {
  .page-eng-intro_sec {
    padding: 80px 0;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .page-eng-intro_sec {
    margin-top: 100px;
  }
}
@media only screen and (max-width: 767px) {
  .page-eng-intro_sec {
    margin-top: 6em;
  }
}
.page-eng-intro_sec_inner .ttl--m {
  margin-bottom: 1em;
}
@media only screen and (max-width: 767px) {
  .page-eng-intro_sec_inner .ttl--m {
    text-align: center;
  }
}
.page-eng-intro_sec_inner .txt--m {
  width: 90%;
  margin: 0 auto;
}
.page-eng_res {
  position: relative;
}
.page-eng_res_inner {
  padding-top: 130px;
  padding-bottom: 160px;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .page-eng_res_inner {
    padding-top: 100px;
  }
}
@media only screen and (max-width: 767px) {
  .page-eng_res_inner {
    padding-top: 5em;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .page-eng_res_inner {
    padding-bottom: 120px;
  }
}
@media only screen and (max-width: 767px) {
  .page-eng_res_inner {
    padding-bottom: 4em;
  }
}
.page-eng_res_inner .ttl {
  margin-bottom: 40px;
}
@media only screen and (max-width: 767px) {
  .page-eng_res_inner .ttl {
    margin-bottom: 1.5em;
  }
}
.page-eng_res_inner > .txt--m {
  margin-bottom: 60px;
}
@media only screen and (max-width: 767px) {
  .page-eng_res_inner > .txt--m {
    margin-bottom: 1.5em;
  }
}
.page-eng_res_inner_img {
  margin-bottom: 60px;
}
@media only screen and (max-width: 767px) {
  .page-eng_res_inner_img {
    margin-bottom: 1.5em;
  }
}
.page-eng_res_inner p img {
  width: 100%;
}
@media only screen and (max-width: 767px) {
  .page-eng_res_inner p img {
    height: 250px;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
.page-eng_res:before {
  background: url(../images/home/il_bridal_left.png);
  background-size: cover;
  position: absolute;
  content: "";
  left: 0;
  top: 7%;
  width: 26%;
  aspect-ratio: 507/594;
  z-index: 0;
}
@media only screen and (max-width: 767px) {
  .page-eng_res:before {
    top: 9%;
  }
}
.page-eng_res:after {
  background: url(../images/home/il_bridal_right.png);
  background-size: cover;
  position: absolute;
  content: "";
  right: 0;
  bottom: 65%;
  width: 18%;
  aspect-ratio: 346/643;
  z-index: 0;
}
@media only screen and (max-width: 767px) {
  .page-eng_res:after {
    bottom: 80%;
  }
}
.page-eng_res h4 {
  width: 90%;
  margin: 0 auto;
}
.page-eng_plan {
  padding-top: 80px;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .page-eng_plan {
    padding-top: 60px;
  }
}
@media only screen and (max-width: 767px) {
  .page-eng_plan {
    padding-top: 4em;
  }
}
.page-eng_plan_inner .ttl {
  margin-bottom: 40px;
}
@media only screen and (max-width: 767px) {
  .page-eng_plan_inner .ttl {
    margin-bottom: 1.5em;
  }
}
.page-eng_plan ul .box_txt .txt--m {
  margin-bottom: 1em;
}
.page-eng_plan ul .box_txt .txt--m span {
  font-size: 130%;
}
.page-eng_deco {
  padding-top: 110px;
  padding-bottom: 130px;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .page-eng_deco {
    padding-top: 90px;
  }
}
@media only screen and (max-width: 767px) {
  .page-eng_deco {
    padding-top: 3em;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .page-eng_deco {
    padding-bottom: 100px;
  }
}
@media only screen and (max-width: 767px) {
  .page-eng_deco {
    padding-bottom: 5em;
  }
}
.page-eng_deco_inner {
  padding-bottom: 4em;
}
.page-eng_deco_inner .ttl {
  margin-bottom: 40px;
}
@media only screen and (max-width: 767px) {
  .page-eng_deco_inner .ttl {
    margin-bottom: 1.5em;
  }
}

.layout_4col {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-top: 60px;
}
@media only screen and (max-width: 767px) {
  .layout_4col {
    margin-top: 30px;
  }
}
.layout_4col li {
  width: 49.5%;
  margin-bottom: 80px;
}
@media only screen and (max-width: 767px) {
  .layout_4col li {
    width: 100%;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .layout_4col li {
    margin-bottom: 60px;
  }
}
@media only screen and (max-width: 767px) {
  .layout_4col li {
    margin-bottom: 3em;
  }
}
@media only screen and (min-width: 768px) {
  .layout_4col li {
    margin-right: 1%;
  }
  .layout_4col li:nth-child(2n) {
    margin-right: 0;
  }
}
.layout_4col li .img img {
  width: 100%;
}
.layout_4col li .txt--m {
  width: 80%;
  margin: auto;
  margin: 1em auto;
}

.layout_2col {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .layout_2col {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
@media only screen and (max-width: 767px) {
  .layout_2col {
    display: block;
  }
}
.layout_2col li {
  width: 49.5%;
}
@media only screen and (max-width: 767px) {
  .layout_2col li {
    width: 100%;
  }
}
@media only screen and (min-width: 768px) {
  .layout_2col li {
    margin-right: 1%;
  }
  .layout_2col li:nth-child(2n) {
    margin-right: 0;
  }
}
.layout_2col li.box_txt {
  padding: 1em 70px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .layout_2col li.box_txt {
    padding: 1em 40px;
  }
}
@media only screen and (max-width: 767px) {
  .layout_2col li.box_txt {
    padding: 1em;
  }
}
.layout_2col li.box_txt .btn {
  margin-top: 2em;
}
@media only screen and (max-width: 767px) {
  .layout_2col li.box_img {
    margin-bottom: 1em;
  }
}
.layout_2col li.box_img img {
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .layout_2col li.order1 {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
}
@media only screen and (min-width: 768px) {
  .layout_2col li.order2 {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
}