@import url("https://use.typekit.net/bnf7jzd.css");

@font-face {
  font-family: "classical-garamond-bt";
  src: url(../fonts/classical_garamond_bt.ttf) format("truetype"), url(../fonts/classical_garamond_bt.woff) format("woff");
  }

/* ==========================================================================
    Typograpgy
   ========================================================================== */
   @media only screen and (min-width: 768px) and (max-width: 1600px) {
    html {
      font-size: calc(10* (100vw / 1600))!important;

    }
  }

   @media (max-width: 767px) {
    .lp * {
      -webkit-box-sizing: border-box;
      box-sizing: border-box;
    }
  }

  @media (min-width: 768px) {
  .sp {
    display: none!important;
  }
}

  html {
    font-size: 62.5%;
  }

  * {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }

  img,
  video,
  svg {
    width: 100%;
    height: auto;
  }

/* for pc*/

  body{
    background: #e4e4e4;
  }

  #Contents {
    /*width: 100%;*/
    background-size: 100%;
    background-repeat: no-repeat;
    background-position: center -156px;
    height: auto;
    margin: 0 auto;
  }

/*basic*/

  .main_container {
    margin: 0 auto;
    width: 100%;
    font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
    font-size: 1.4rem;
    line-height: 2;
    letter-spacing: 0.1em;
    color: #555555;
    text-align: left;
    font-feature-settings: "palt";
    -ms-font-feature-settings: "palt";
  }

  .main_container a{
    color: #555555;
    font-weight: 500;
  }

  .main_container p{
    font-weight: 500;
  }

  .font_eng{
    font-family: "jaf-bernina-sans", sans-serif;
    font-weight: 400;
    font-style: normal;
    letter-spacing: 0.14em;
  }

/*ヘッド部分*/
  .heading{
    width: 90rem;
    margin: auto;
    margin-bottom: 11.1rem;
    text-align: center;
  }

  .heading_img{
    margin-bottom: 6.8rem;
  }

  .heading_ttl{
    width: 51rem;
    margin: 0 auto;
    margin-bottom: 2.4rem;
  }

  .heading_sub_ttl {
    margin-bottom: 2.6rem;
    font-size: 2rem;
    letter-spacing: 0.11em;
    font-weight: 500;
  }

  .heading_txt {
    font-size: 1.4rem;
    line-height: 2;
    letter-spacing: 0.085em;
  }


  /*basic*/
  .section{
    margin: auto;
  }

  .item_list{
    display: flex;
    justify-content: space-between;
  }

  .item_list p {
    width: 24.5rem;
    letter-spacing: 0.075em;
    text-align: justify;
}

.item_list .content_img {
  width: 30rem;
  margin-top: 0.6rem;
}

  .content_inner{
    width: 31.5rem;
    text-align: justify;
  }

  .content_txt{
    font-size: 1.4rem;
    line-height: 2;
    letter-spacing: 0.05em;
    font-weight: 500;
  }

  .content_price {
    font-size: 1.2rem;
  }


/*1段目*/

  .sec01{
    margin-bottom: 11.4rem;
  }

  .sec01 .content_inner{
    margin-top: 5.2rem;
  }

  .sec01 .content_ttl{
    font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
    position: relative;
    margin-bottom: 3rem;
    font-size: 2.4rem;
    line-height: 2.85;
    text-align: center;
    color: #FFF;
    background: #555555;
    letter-spacing: 0.1em;
    font-weight: 700;
    margin-bottom: 4.6rem;
  }

  .sec01 .content_img {
    width: 42.5rem;
    margin: 0 auto;
    margin-bottom: 3.4rem;
}

.sec01 .content_txt {
  position: relative;
  width: 38rem;
  margin: 0 auto;
  text-align: justify;
}

  .sec01 .content_txt::before,
  .sec01 .content_txt::after{
    content: '';
    position: absolute;
    height: 19.4rem;
    width: 1.6rem;
  }

  .sec01 .content_txt::before{
    border-left: 0.1rem solid #555555;
    border-top: 0.1rem solid #555555;
    border-bottom: 0.1rem solid #555555;
    top: -1.4rem;
    left: -3rem;
  }

  .sec01 .content_txt::after{
    border-right: 0.1rem solid #555555;
    border-top: 0.1rem solid #555555;
    border-bottom: 0.1rem solid #555555;
    top: -1.4rem;
    right: -3rem;
  }

/*2段目*/

  .sec02{
    width: 66rem;
    padding: 3.1rem 4rem;
    margin-bottom: 6.2rem;
    background-color:rgb(255, 255, 255, 0.7);
    border-radius: 0.5vw;
  }

  .sec02 .content_ttl,
  .sec03 .content_ttl{
    margin: 0 auto;
    margin-bottom: 3.2rem;
    font-size: 2rem;
    font-weight: 700;
    line-height: 2;
    border-bottom: 0.2rem solid #555555;
  }

  .sec02 .content_ttl{
    width: fit-content;
    margin-right: 23.5rem;
  }

  .sec02 .content_inner{
    margin-top: 7.6rem;
  }

  .sec02 .icon{
    position: absolute;
    width: 18.77rem;
    top: -1.4rem;
    right: -5.8rem;
  }

/*3段目*/

  .sec03{
    width: 66rem;
    padding: 3.1rem 4rem;
    background-color:rgb(255, 255, 255, 0.7);
    border-radius: 0.5vw;
    margin-bottom: 12rem;
  }

  .sec03 .content_ttl {
    width: fit-content;
    letter-spacing: 0.1em;
  }

  .sec03 .content_img{
    width: 30rem;
  }

  .sec03 .content_txt{
    width: 24rem;
    letter-spacing: 0.07em;
  }


/*all_item*/
  .all_item_btn{
    width: 44rem;
    margin:0 auto;
    margin-bottom: 12rem;
  }



/* ====== TABLET ===== */

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


}






/* ====== SP ===== */
@media only screen and (max-width: 750px) {

  .main_container a{
    font-weight: 400;
  }

  .main_container p{
    font-weight: 400;
  }

  a{
    color: #333;
  }

  .bredlist.lp {
    line-height: 5.33333vw;
    font-size: 2.66667vw;
    margin: 3.33333vw auto;
    width: 92.592%;
    text-align: left;
    padding: 0;
  }

 #Contents {
    max-width: calc(750* (100vw/750));
    background-position: center calc(198* (100vw/750));
    background: #e4e4e4;
  }

/*basic*/

  .lp{
    padding-bottom: calc(70 * (100vw / 750));
  }

  .pc {
    display: none!important;
  }
/*basic*/

.main_container {
  font-size: calc(24* (100vw / 750));
  line-height: 2;
  letter-spacing: 0.1em;
}

.font_eng{
  font-family: "jaf-bernina-sans", sans-serif;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0.14em;
}

/*ヘッド部分*/
.heading{
  width: 100%;
  margin-bottom: calc(130* (100vw / 750));
}

.heading_img{
  margin-bottom: calc(84* (100vw / 750));
}

.heading_ttl{
  width: calc(660* (100vw / 750));
  margin-bottom: calc(28* (100vw / 750));
}

.heading_sub_ttl {
  margin-bottom: calc(38* (100vw / 750));
  font-size: calc(33* (100vw / 750));
  letter-spacing: 0.1em;
}

.heading_txt {
  font-size: calc(24* (100vw / 750));
  letter-spacing: 0.1em;
}


/*basic*/
.section{
  margin: auto;
}

.item_list{
  display: flex;
  justify-content: space-between;
}

.item_list p {
  margin-top: calc(40* (100vw / 750));
  width: calc(540* (100vw / 750));
  letter-spacing: 0.06em;
}

.item_list .content_img {
width: calc(540* (100vw / 750));
margin-top: calc(4* (100vw / 750));
}

.content_txt{
  font-size: calc(24* (100vw / 750));
  letter-spacing: 0.1em;
}


/*1段目*/

.sec01{
  margin-bottom: calc(170* (100vw / 750));
}

.sec01 .content_inner{
  margin-top: 5.2rem;
}

.sec01 .content_ttl{
  font-size: calc(37* (100vw / 750));
  line-height: 3;
  margin-bottom: calc(64* (100vw / 750));
}

.sec01 .content_img {
  width: calc(650* (100vw / 750));
  margin: 0 auto;
  margin-bottom: calc(52* (100vw / 750));
}

.sec01 .content_txt {
width: calc(560* (100vw / 750));
}

.sec01 .content_txt::before,
.sec01 .content_txt::after{
  height: calc(391* (100vw / 750));
  width: calc(30* (100vw / 750));
}

.sec01 .content_txt::before{
  border-left: calc(2* (100vw / 750)) solid #555555;
  border-top: calc(2* (100vw / 750)) solid #555555;
  border-bottom: calc(2* (100vw / 750)) solid #555555;
  top: calc(-28* (100vw / 750));
  left: calc(-50* (100vw / 750));
}

.sec01 .content_txt::after{
  border-right: calc(2* (100vw / 750)) solid #555555;
  border-top: calc(2* (100vw / 750)) solid #555555;
  border-bottom: calc(2* (100vw / 750)) solid #555555;
  top: calc(-28* (100vw / 750));
  right: calc(-50* (100vw / 750));
}

/*2段目*/

.sec02{
  width: calc(660* (100vw / 750));
  padding: calc(44* (100vw / 750)) calc(60* (100vw / 750));
  margin-bottom: calc(82* (100vw / 750));
}

.sec02 .content_ttl,
.sec03 .content_ttl{
  margin: 0 auto;
  margin-bottom: calc(44* (100vw / 750));
  font-size: calc(32* (100vw / 750));
  font-weight: 700;
  line-height: 2;
  border-bottom: calc(4* (100vw / 750)) solid #555555;
}

.sec02 .item_list{
  flex-direction: column-reverse;
}

.sec02 .content_ttl{
  width: fit-content;
  margin-right: auto;
}

.sec02 .content_inner{
  margin-top: 7.6rem;
}

.sec02 .icon{
  width: calc(270* (100vw / 750));
  top: calc(-20* (100vw / 750));
  right: calc(-33* (100vw / 750));
}

/*3段目*/

.sec03{
  width: calc(660* (100vw / 750));
  padding: calc(38* (100vw / 750)) calc(60* (100vw / 750));
  margin-bottom: calc(150* (100vw / 750));
}

.sec03 .content_ttl {
  margin-bottom: calc(40* (100vw / 750));
  width: fit-content;
  border-bottom: none;
  line-height: 2.315;
  text-align: center;
}

.sec03 .content_ttl span {
  margin-bottom: calc(6* (100vw / 750));
  width: fit-content;
  display: inline-block;
  border-bottom: calc(4* (100vw / 750)) solid #555555;
  text-align: center;
  line-height: 2.1;
  letter-spacing: 0.1em;
  font-weight: 700;
}

.sec03 .content_img{
  width: calc(540* (100vw / 750));
}

.sec03 .item_list{
  flex-direction: column;
}

.sec03 .content_txt{
  width: calc(540* (100vw / 750));
  letter-spacing: 0.075em;
}

/*all_item*/
.all_item_btn{
  width: calc(536* (100vw / 750));
  margin:0 auto;
}



  }

  /************ fade **********/
.fade {
  -webkit-transition-duration: 2s;
  -o-transition-duration: 2s;
  transition-duration: 2s;
  opacity: 0;
  -webkit-transform: translateY(1.5rem);
  -ms-transform: translateY(1.5rem);
  transform: translateY(1.5rem);
}

.fade.onView {
  opacity: 1;
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0);
}


.fade._02 {
  -webkit-transition-duration: 2s;
  -o-transition-duration: 2s;
  transition-duration: 2s;
  transition-delay: 1s;
  opacity: 0;
  -webkit-transform: translateY(5px);
  -ms-transform: translateY(5px);
  transform: translateY(5px);
}

.fade._02.onView {
  opacity: 1;
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0);
}


/* 追加 css 0515 */


/* =======================================
  PC only
=======================================*/

@media (min-width: 768px) {
  .content_txt.txt01 {
    letter-spacing: 0.085em;
    font-feature-settings: "palt";
    text-align: justify;
    width: 32rem;
  }

  .content_txt.txt02 {
    text-align: justify;
    font-feature-settings: "palt";
    width: 68rem;
    height: auto;
    letter-spacing: 0.1em;
  }

  .content_txt.txt03 {
    letter-spacing: 0.078em;
    font-feature-settings: "palt";
    text-align: justify;
    width: 68rem;
  }

  .content_txt.txtArea01 {
    text-align: justify;
    letter-spacing: 0.01em;
  }

  .item_price.txtArea04__item_price {
    margin-bottom: 1rem;
  }

  span.DBRW_txt {
    margin-left: 0.8rem;
  }

}


/* =======================================
  SP only
=======================================*/

@media (max-width: 767px) {
  .content_txt {
    text-align: justify;
  }

  p.content_txt.txt01.sp {
    letter-spacing: 0.08em;
  }

  p.content_txt.txt03 {
    letter-spacing: 0.08em;
    font-feature-settings: unset;
  }

  p.content_txt.txt04 {
    letter-spacing: 0.065em;
  }

  p.content_txt.txtArea01,
  p.content_txt.txtArea02,
  p.content_txt.txtArea03,
  p.content_txt.txtArea04,
  p.content_txt.txtArea05 {
    letter-spacing: 0.05em;
  }

  span.DBRW_txt {
    margin-left: calc(25 *(100vw /750));
  }

}


