@font-face {
  font-family: "OptimaLTStd-Medium";
  src: url(../fonts/OptimaLTStd-Medium.otf);
  }
 
/* ==========================================================================
    Typograpgy
   ========================================================================== */
   .main_inner * {
    color: #343434;
    font-family: toppan-bunkyu-mincho-pr6n, serif;
    font-weight: 400;
    font-style: normal;
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
  }
  
  /* ==========================================================================
     Base
     ========================================================================== */
  .main_inner,
  .main {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 0 !important;
  }
  
  .main_inner *,
  .main * {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
  
  #wrap {
    width: 100%;
    /* background-image: url(../img/pc.jpg); */
    background-size: 1600px;
    background-position-x: center;
    background-position-y: -190px;
    background-repeat: no-repeat;
  }
 
  .inner {
    width: 90rem;
    margin: 0 auto;
  }
  
  .inner img {
    width: 100%;
    /* opacity: 0.5; */
  }

  .inner02 {
    width: 70rem;
    margin: 0 auto;
  }

  .txt {
    font-size: 1.4rem;
    line-height: 2.15;
    letter-spacing: 0.12em;
  }

  .opt {
    font-size: 2.7rem;
    line-height: 2.14;
    letter-spacing: 0.12em;
    font-family: "OptimaLTStd-Medium";
    font-weight: 500;
    color: #000;
  }

  .sec01 {
    margin-top: 3rem;
    text-align: center;
  }

  .sec01 .ttl01 {
    margin-top: 4rem;
    font-size: 3rem;
    line-height: 1.67;
    letter-spacing: 0.18em;
  }
  
  .sec01 .txt01 {
    margin-top: 3rem;
  }

  .sec01 .txt02 {
    margin-top: 1.3rem;
  }
  .sec01 .mg {
    margin-left: 2rem;
  }

  .sec02 {
    margin-top: 9.2rem;
  }

  .line {
    width: 100%;
    height: 2px;
    background-color:#222222;
  }

  .sec02 .opt01 {
    margin-top: 1.3rem;
    text-align: center;
  }
  
  .sec02 .box01 {
    margin-top: -1.2rem;
    display: flex;
    justify-content: space-between;
  }

  .sec02 .img01 {
    width:34rem;
    margin-top: 4rem; 
  }

  .sec02 .txt01 {
    margin-top: 2.2rem;
  }

  .sec02 .ttl01 {
    width: 54.6rem;
    margin: -0.4rem 0 0 7.4rem;
  }

  .sec03 {
    margin-top: 9.2rem;
  }

  .sec03 .opt01 {
    margin-top: 1.3rem;
  }
  
  .sec03 .box01 {
    margin-top: -1.2rem;
  }

  .sec03 .img01 {
    width:100%;
    margin-top: 3.2rem;
  }

  .sec03 .txt01 {
    margin-top: 2.2rem;
  }

  .sec03 .ttl01 {
    width: 39.7rem;
    margin: -0.9rem 0 0 14.9rem;
  }

  .sec04 {
    margin-top: 9rem;
  }

  .sec04 .opt01 {
    margin-top: 1.3rem;
  }

  .sec04 .ttl01 {
    width: 48.4rem;
    margin: -0.9rem 0 0 10.5rem;

  }

  .button {
    display: block;
    padding-right: 0.1rem;
    margin: 14rem auto 0;
    width: 45.9rem;
    height: 6rem;
    font-size: 1.4rem;
    line-height: 6.5rem;
    letter-spacing: 0.12em;
    background-color: #ebebeb;
    text-align: center;
  }
    
  .button span {
    display: inline-block;width: 0.6rem;
    height: 0.6rem;
    margin-left: 0.5rem;
    margin-bottom: 0.3rem;
    border-top: 1px solid #414141;
    border-right: 1px solid #414141;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    vertical-align : middle;
    }
  
  .sp_only {
      display: none!important;
  }
  
  
  
  
  
  
  
  
  
  
  /* ====== TABLET ===== */
  @media screen and (max-width: 1280px) and (min-width:751px){
    html{
      font-size: calc(10*(100vw/1280));
    }
  }
 
 
 
 
 
 
  /* ====== SP ===== */
@media only screen and (max-width: 750px) {
 
 
  #Contents {
    width: 100%;
    /* background-image: url(../img/sp.jpg); */
    background-size: 100%;
    background-position-x: center;
    background-position-y:79px;
    background-repeat: no-repeat;
    color: #343434;
  }
 
  .breadlist.lp {
    line-height: 5.33333vw;
    font-size: 2.66667vw;
    margin: 3.33333vw auto;
    width: 92.592%;
    text-align: left;
    padding: 0;
  }
  
  .inner {
    width: calc(650 *(100vw/750));
    margin: 0 auto;
  }

  .inner02 {
    width: 100%;
    margin: 0 auto;
  }

  .txt {
    font-size: calc(22 *(100vw/750));;
    line-height: 1.64;
  }

  .opt {
    font-size: calc(27 *(100vw/750));
    line-height:1.85;
  }

  .sec01 {
    margin-top: calc(30 *(100vw/750));
    text-align: center;
  }

  .sec01 .ttl01 {
    margin-top: calc(30  *(100vw/750));
    font-size: calc(35 *(100vw/750));
    line-height: 1.89;
  }
  
  .sec01 .txt01 {
    margin-top: calc(25  *(100vw/750));
  }

  .sec01 .txt02 {
    margin-top:calc(16 *(100vw/750));
  }
  .sec01 .mg {
    margin-left: calc(40 *(100vw/750));
  }

  .sec02 {
    margin-top: calc(91 *(100vw/750));
  }

  .line {
    width: 100%;
    height: 2px;
    background-color:#222222;
  }

  .sec02 .opt01 {
    margin-top: calc(36  *(100vw/750));
    text-align: center;
  }
  
  .sec02 .box01 {
    margin-top: calc(-12 *(100vw/750));
    flex-direction: column;
  }

  .sec02 .img01 {
    width:100%;
    margin-top: calc(30  *(100vw/750));
  }

  .sec02 .txt01 {
    margin-top:calc(42  *(100vw/750));
  }

  .sec02 .txt02 {
    margin-top:calc(25  *(100vw/750));
  }
  .sec02 .txt03 {
    margin-top:calc(25  *(100vw/750));
  }

  .sec02 .ttl01 {
    width: calc(545.8*(100vw/750));
    margin: calc(2 *(100vw/750)) 0 calc(32 *(100vw/750)) calc(48 *(100vw/750));
  }

  .sec03 {
    margin-top: calc(93  *(100vw/750));
  }

  .sec03 .opt01 {
    margin-top: calc(36  *(100vw/750));
  }
  
  .sec03 .box01 {
    margin-top: calc(-12 *(100vw/750));
  }

  .sec03 .img01 {
    width:100%;
    margin-top: calc(51 *(100vw/750));
  }

  .sec03 .txt01 {
    margin-top: calc(47  *(100vw/750));
  }

  .sec03 .ttl01 {
    width: calc(395.8 *(100vw/750));
    margin: calc(-1*(100vw/750)) 0 0 calc(125*(100vw/750));
  }

  .sec04 {
    margin-top: calc(92  *(100vw/750));
  }

  .sec04 .opt01 {
    margin-top: calc(36  *(100vw/750));
  }

  .sec04 .ttl01 {
    width: calc(483 *(100vw/750));
    margin: calc(0*(100vw/750)) 0 0 calc(80*(100vw/750));
  }
  
 
  
  .button {
    margin: calc(143*(100vw/750)) auto 0;
    padding-left: calc(119*(100vw/750));
    width: calc(570*(100vw/750));
    font-size: calc(28*(100vw/750));
    line-height: calc(65*(100vw/750));
    height: calc(70*(100vw/750));
    letter-spacing: 0.09em;
    background-color: #ebebeb;
    text-align: left;
    color: #333333;
    }
  
  .button span {
    display: inline-block;
    margin-left:calc(3*(100vw/750)); 
    width: calc(14*(100vw/750));
    height: calc(14*(100vw/750));
    margin-bottom: calc(6*(100vw/750));
    border-top: 1px solid #333333;
    border-right: 1px solid #333333;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    color: #333333;
  }
 
  .sp_only {
    display: block!important;
  }
 
  .pc_only {
    display: none!important;
  }
 
 
 
}

