 
/* ==========================================================================
    Typograpgy
   ========================================================================== */
   .main_inner * {
    color: #343434;
    font-family: toppan-bunkyu-mincho-pr6n, "Noto Serif JP", YuMincho, "Yu Mincho", "Hiragino Mincho ProN", 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;
  }
  
  .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: 60px;
    background-repeat: no-repeat;
  }
 
  #wrap .inner picture {
    display: block;
  }  
 
  #wrap .inner img {
    width: 100%;
    height: auto;
  }
 
  #wrap .inner {
    width: 108rem;
    margin: 0 auto;
  }

  .inner .txt {
    font-size: 1.4rem;
    line-height: 2;
    letter-spacing: 0.12em;
  }

  .inner .prc {
    font-size: 1.2rem;
    line-height: 2;
    letter-spacing:0.12em;
  }

  .inner .prcbox{
    text-align: center;
    display: inline-block;
  }

  .inner .mv {
    width: 100rem;
    margin: 8rem auto 0;
    text-align: center;
  }

  .inner .mv .ttl01  {
    margin-top:6.6rem;
    font-size: 2.6rem;
  }

  .inner .mv .ttl02 {
    display: inline-block;
    font-size:1.6rem;
    margin-top: -0.3rem;
    position: relative;
  }

  .inner .mv .ttl02::before{
    content: "";
    width: 5rem;
    height: 1px;   
    background-color: #343434;
    position: absolute;
    top: 2.7rem;
    left: -6.6rem;
  }

  .inner .mv .ttl02::after{
    content: "";
    width: 5rem;
    height: 1px;   
    background-color: #343434;
    position: absolute;
    top: 2.7rem;
    right: -6.6rem;
  }

  .inner .mv .txt03 {
    margin-top:2.1rem;
  }

  .inner .mv .nub {
    font-size: 2rem;
    line-height: 2.6;
    letter-spacing: 0.05em;
  }

  .inner .sec01 {
    margin-top: 11.5rem;
  }

  .inner .sec01 .box01{
    display: flex;
  }

  .inner .sec01 .box01 .img01 {
    width: 48rem;
    margin-left: 8rem;
  }

  .inner .sec01 .box01 .txtbox {
    margin: 14.4rem  0 0 4rem;
  }

  .inner .sec01 .box01 .txtbox .ttl01 {
    font-size:1.8rem ;
    letter-spacing: 0.05em;
  }

  .inner .sec01 .box01 .txtbox .ttl01 .nub02{
    font-size:2.6rem ;
  }

  .inner .sec01 .box01 .txtbox .ttl02 {
    font-size: 2rem;
    line-height:1.75 ;
    margin-top: 1.5rem;
  }

  .inner .sec01 .box01 .txtbox .txt03 {
    margin-top: 2.9rem;
    width: 38rem;
    letter-spacing: 0.09em;
    font-feature-settings: "palt";
  }

  .inner .sec01 .box02 {
    display: flex;
  }

  .inner .sec01 .box02 .itembox {
    display: flex;
    margin: 8rem 0 0 4rem;
  }

  .inner .sec01 .box02 .itembox .it01{
    width: 18rem;
  }

  .inner .sec01 .box02 .itembox .it01 .img02 {
    position: relative;
  }

  .inner .sec01 .box02 .itembox .it01 .img02::before{
    content: "+";
    font-size:3rem ;
    position: absolute;
    top: 9.1rem;
    right: -2.6rem;
    z-index: 10;
  } 

  .inner .sec01 .box02 .itembox .it01 .prcbox {
    margin: 1.8rem 0 0 2.3rem;
  }
  
  .inner .sec01 .box02 .itembox .it02 {
    width: 18rem;
    margin-left: 3.3rem;
  }

  .inner .sec01 .box02 .itembox .it02 .prcbox {
    margin: 1.8rem 0 0 3.4rem;
  }

  .inner .sec01 .box02 .itembox .it02 .img03 {
    position: relative;
  }

  .inner .sec01 .box02 .itembox .it02 .img03::before{
    content: "+";
    font-size:3rem ;
    position: absolute;
    top: 9.1rem;
    right: -2.8rem;
    z-index: 10;
  }

  .inner .sec01 .box02 .itembox .it03 {
    width: 15rem; 
    margin-left: 3.3rem;
  }

  .inner .sec01 .box02 .itembox .it03 .prcbox {
    margin: 1.8rem 0 0 1.2rem;
  }

  .inner .sec01 .box02 .img05{
    width: 33rem;
    margin: -4rem 0 0 5.4rem;
  }  

  .inner .sec01 .line {
    width: 100%;
    height: 1px;
    margin-top: 12rem;
    background-color: #bcbcbc;
  }

  /* sec02 */
  .inner .sec02 {
    margin-top: 11.9rem;
  }

  .inner .sec02 .box01{
    display: flex;
    flex-direction: row-reverse;
  }

  .inner .sec02 .box01 .img01 {
    margin-left: 4rem;
    margin-right: 8rem;
  }  

  .inner .sec02 .box02 {
    display: flex;
    flex-direction: row-reverse;
  }

  .inner .sec02 .box02 .itembox {
    display: flex;
    margin: 9rem 0 0 7rem;
  }

  .inner .sec02 .box02 .itembox .it01{
    width: 18rem;
  }

  .inner .sec02 .box02 .itembox .it01 .img02::before{
    top: 8.8rem;
    right: -4rem;
  } 

  .inner .sec02 .box02 .itembox .it01 .prcbox {
    margin: 1.5rem 0 0 3.3rem;
  }
  
  .inner .sec02 .box02 .itembox .it02 {
    width: 18rem;
    margin-left: 2.2rem;
  }

  .inner .sec02 .box02 .itembox .it02 .prcbox {
    margin: 1.5rem 0 0 5.3rem;
  }

  .inner .sec02 .box02 .itembox .it02 .img03::before{
    top: 8.8rem;
    right: 0.2rem;
  }

  .inner .sec02 .box02 .itembox .it03 {
    width: 15rem; 
    margin-left: 0.7rem;
    margin-right: 6rem;
  }

  .inner .sec02 .box02 .itembox .it03 .prcbox {
    margin: 1.5rem 0 0 2.4rem;
  }

  .inner .sec02 .box02 .img05{
    margin: -4rem 0 0 5.4rem;
  }  

  .inner .sec02 .line {
    margin-top: 12rem;
  }

  /* sec03 */

  .inner .sec03 {
    margin-top: 11.9rem;
  }

  .inner .sec03 .box01 .img01 {
    width: 48rem;
    margin-left: 8rem;
  }

  .inner .sec03 .box01 .txtbox {
    margin: 11.6rem 0 0 4rem;
  }

  .inner .sec03 .box02 .itembox {
    display: flex;
    margin: 9rem 0 0 6.4rem;
  }

  .inner .sec03 .box02 .itembox .it01{
    width: 18rem;
  }

  .inner .sec01 .box02 .itembox .it01 .img02 {
    position: relative;
  }

  .inner .sec03 .box02 .itembox .it01 .img02::before{
    top: 8rem;
    right: -2.8rem;
  } 

  .inner .sec03 .box02 .itembox .it01 .prcbox {
    margin: 0.7rem 0 0 3.8rem;
  }
  
  .inner .sec03 .box02 .itembox .it02 {
    width: 15rem;
    margin-left: 3.3rem;
  }

  .inner .sec03 .box02 .itembox .it02 .prcbox {
    margin: 0.7rem 0 0 1.4rem;
  }

  .inner .sec03 .box02 .itembox .it02 .img03::before{
    top: 8rem;
    right: -2.8rem;
  }

  .inner .sec03 .box02 .itembox .it03 {
    width: 15rem; 
    margin-left: 3.8rem;
    margin-top: -1.3rem;
  }

  .inner .sec03 .box02 .itembox .it03 .prcbox {
    margin: 2rem 0 0 2.4rem;
  }

  .inner .sec03 .box02 .img05{
    width: 33rem;
    margin: -4rem 0 0 5.4rem;
  }  

  .inner .sec03 .line {
    margin-top: 12rem;
  }

  .viewall {
    width: 46rem;
    margin: 15rem auto 0;
  }



  

  





 
  
  #wrap .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) {
  #wrap .sp_only {
    display: block!important;
  }
 
  #wrap .pc_only {
    display: none!important;
  } 
 
  #Contents {
    width: 100%;
    /* background-image: url(../img/sp.jpg); */
    background-size: 100%;
    background-position-x: center;
    background-position-y:-176px;
    background-repeat: no-repeat;
    color: #343434;
  }
 
  .bredlist.lp {
    line-height: 5.33333vw;
    font-size: 2.66667vw;
    margin: 3.33333vw auto;
    width: 92.592%;
    text-align: left;
    padding: 0;
  }
  
　.main_inner {
    padding: 0 calc(45 * (100vw / 750));
  }
  
  #wrap .inner {
    width: 100%;
    margin: 0 auto;
  }

  .inner .txt {
    font-size: calc(24 * (100vw / 750));
    line-height: 2;
    letter-spacing: 0.12em;
  }

  .inner .prc {
    font-size: calc(22 * (100vw / 750));
    line-height: 1.75;
    letter-spacing:0.12em;
  }

  .inner .prcbox  {
    text-align: center;
    display: inline-block;
  }

  .inner .mv {
    width: 100%;
    margin: calc(50 * (100vw / 750)) auto 0;
    text-align: center;
  }

  .inner .mv .ttl01  {
    margin-top: calc(66 * (100vw / 750));
    font-size: calc(40 * (100vw / 750));
    line-height:1.75;
  }

  .inner .mv .ttl02 {
    display: inline-block;
    font-size:calc(24 * (100vw / 750));
    margin-top: calc(8  * (100vw / 750));
    position: relative;
  }

  .inner .mv .ttl02::before{
    content: "";
    width: calc(80 * (100vw / 750));
    height: calc(1.4 * (100vw / 750));
    background-color: #343434;
    position: absolute;
    top: calc(42 * (100vw / 750));
    left: calc(-111 * (100vw / 750));
  }

  .inner .mv .ttl02::after{
    content: "";
    width: calc(80 * (100vw / 750));
    height: calc(1.4 * (100vw / 750)); 
    background-color: #343434;
    position: absolute;
    top: calc(41 * (100vw / 750));
    right: calc(-112 * (100vw / 750));
  }

  .inner .mv .txt03 {
    margin-top:calc(30 * (100vw / 750));
  }

  .inner .mv .nub {
    font-size: calc(30 * (100vw / 750));
    line-height: 2.6;
    letter-spacing: 0.05em;
  }

  .inner .sec01 {
    margin-top: calc(143  * (100vw / 750));
  }

  .inner .sec01 .box01 {
    display: flex;
    flex-direction: column;
  }

  .inner .sec01 .box01 .img01 {
    width: calc(675 * (100vw / 750));
    margin-left: 0;
  }

  .inner .sec01 .box01 .txtbox {
    margin: calc(34  * (100vw / 750)) 0 0 calc(75 * (100vw / 750));
  }

  .inner .sec01 .box01 .txtbox .ttl01 {
    font-size:calc(32 * (100vw / 750));
    letter-spacing: 0.08em;
  }

  .inner .sec01 .box01 .txtbox .ttl01 .nub02{
    font-size:calc(48 * (100vw / 750));
  }

  .inner .sec01 .box01 .txtbox .ttl02 {
    font-size: calc(36 * (100vw / 750));
    line-height:1.75 ;
    margin-top: calc(12 * (100vw / 750));
  }

  .inner .sec01 .box01 .txtbox .txt03 {
    margin-top: calc(42 * (100vw / 750));
    width: calc(600 * (100vw / 750));
    letter-spacing: 0.1em;
    font-feature-settings: "palt";
  }

  .inner .sec01 .box02 {
    display: flex;
    flex-direction: column-reverse;
  }

  .inner .sec01 .box02 .itembox {
    display: flex;
    margin: calc(66  * (100vw / 750)) 0 0 calc(31 * (100vw / 750));
  }

  .inner .sec01 .box02 .itembox .it01{
    width: calc(228 * (100vw / 750));
  }

  .inner .sec01 .box02 .itembox .it01 .img02::before{
    content: "+";
    font-size: calc(38 * (100vw / 750));
    position: absolute;
    top: calc(113 * (100vw / 750));
    right: calc(-26 * (100vw / 750));
  } 

  .inner .sec01 .box02 .itembox .it01 .prcbox {
    margin: calc(35 * (100vw / 750)) 0 0 calc(32 * (100vw / 750));
  }
  
  .inner .sec01 .box02 .itembox .it02 {
    width: calc(228 * (100vw / 750));
    margin-left: calc(22  * (100vw / 750));
  }

  .inner .sec01 .box02 .itembox .it02 .prcbox {
    margin: calc(35 * (100vw / 750)) 0 0 calc(42  * (100vw / 750));
  }

  .inner .sec01 .box02 .itembox .it02 .img03 {
    position: relative;
  }

  .inner .sec01 .box02 .itembox .it02 .img03::before{
    content: "+";
    font-size: calc(38* (100vw / 750));
    position: absolute;
    top: calc(113 * (100vw / 750));
    right: calc(-27 * (100vw / 750));
  }

  .inner .sec01 .box02 .itembox .it03 {
    width: calc(190 * (100vw / 750));
    margin-left: calc(21 * (100vw / 750));
  }

  .inner .sec01 .box02 .itembox .it03 .prcbox {
    margin: calc(35 * (100vw / 750)) 0 0 calc(3 * (100vw / 750));

  }

  .inner .sec01 .box02 .img05{
    width: calc(525 * (100vw / 750));
    margin: calc(68 * (100vw / 750)) 0 0 auto;
  }  

  .inner .sec01 .line {
    width: calc(700 * (100vw / 750));
    height: calc(1 * (100vw / 750));
    margin: calc(120 * (100vw / 750)) auto 0;
  }

  /* sec02 */
  .inner .sec02 {
    margin-top: calc(120 * (100vw / 750));
  }

  .inner .sec02 .box01 .img01 {
    margin: 0 0 0 auto;
  }  

  .inner .sec02 .box02 .itembox {
    display: flex;
    margin: calc(68 * (100vw / 750)) 0 0 calc(40 * (100vw / 750));
  }

  .inner .sec02 .box02 .itembox .it01 .img02::before{
    top: calc(109 * (100vw / 750));
    right: calc(-53 * (100vw / 750));
  } 

  .inner .sec02 .box02 .itembox .it01 .prcbox {
    margin: calc(27 * (100vw / 750)) 0 0 calc(36 * (100vw / 750));
  }
  
  .inner .sec02 .box02 .itembox .it02 {
    margin-left:calc(27  * (100vw / 750));
  }

  .inner .sec02 .box02 .itembox .it02 .prcbox {
    margin: calc(26 * (100vw / 750)) 0 0 calc(47 * (100vw / 750));
  }

  .inner .sec02 .box02 .itembox .it02 .img03::before{    
    top: calc(109 * (100vw / 750));
    right: calc(2 * (100vw / 750));
  }

  .inner .sec02 .box02 .itembox .it03 {
    width: calc(190* (100vw / 750));
    margin-left: calc(7 * (100vw / 750));
    margin-right: 0;
  }

  .inner .sec02 .box02 .itembox .it03 .prcbox {
    margin: calc(27 * (100vw / 750)) 0 0 calc(41 * (100vw / 750));  
  }

  .inner .sec02 .box02 .img05{
    margin: calc(68  * (100vw / 750)) 0 0 0;
  }  

  .inner .sec02 .line {
    margin-top: calc(114  * (100vw / 750));
  }

  /* sec03 */

  .inner .sec03 {
    margin-top: calc(120 * (100vw / 750));
  }

  .inner .sec03 .box01 .img01 {
    margin-left: 0;
  }

  .inner .sec03 .box01 .txtbox {
    margin: calc(36 * (100vw / 750)) 0 0 calc(75 * (100vw / 750));
  }

  .inner .sec03 .box01 .txtbox .ttl02 {
    margin-top: calc(22 * (100vw / 750));
  }

  .inner .sec03 .box02 .itembox {
    display: flex;
    margin: calc(76 * (100vw / 750)) 0 0 calc(37 * (100vw / 750));
  }

  .inner .sec01 .box02 .itembox .it01 .img02 {
    position: relative;
  }

  .inner .sec03 .box02 .itembox .it01 .img02::before{
    top: calc(98 * (100vw / 750));
    right: calc(-37 * (100vw / 750));
  } 

  .inner .sec03 .box02 .itembox .it01 .prcbox {
    margin: calc(19 * (100vw / 750)) 0 0 calc(19 * (100vw / 750));
  }
  
  .inner .sec03 .box02 .itembox .it02 {
    width: calc(190* (100vw / 750));
    margin-left: calc(41 * (100vw / 750));
  }

  .inner .sec03 .box02 .itembox .it02 .prcbox {
    margin: calc(19 * (100vw / 750)) 0 0 calc(-13 * (100vw / 750));
    white-space: nowrap;
  }

  .inner .sec03 .box02 .itembox .it02 .img03::before{
    top: calc(98 * (100vw / 750));
    right: calc(-37 * (100vw / 750));
  }

  .inner .sec03 .box02 .itembox .it03 {
    margin-left: calc(45 * (100vw / 750));
    margin-top: calc(-17 * (100vw / 750));
  }

  .inner .sec03 .box02 .itembox .it03 .prcbox {
    margin: calc(38 * (100vw / 750)) 0 0 calc(41 * (100vw / 750));
  }

  .inner .sec03 .line {
    margin-top: calc(12 * (100vw / 750));
  }

  .viewall {
    width: calc(570 * (100vw / 750));
    margin: calc(198 * (100vw / 750)) 0 0 calc(85* (100vw / 750));
  }
  
 
  
 
 
 
 
 
 
}
 
/* fade */
 .fade {
  transition-property: opacity, transform;
  transition-duration: 1.5s;
  opacity: 0;
  transform: translateY(1.5rem);
}
 
.fade.onView {
  opacity: 1;
  transform: translateY(0);
}

/* ie */

@media all and (-ms-high-contrast: none) {

  .inner .prc {
    white-space: nowrap;
  }

}


