@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: 160rem;
    /*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, "游ゴシック Medium", "Yu Gothic", sans-serif;
    font-size: 1.4rem;
    line-height: 2;
    letter-spacing: 0.1em;
    color: #343434;
    text-align: left;
    font-feature-settings: "palt";
    -ms-font-feature-settings: "normal";
  }

  .main_container a{
    color: #343434;
  }

  .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: 8rem;
    text-align: center;
  }

  .heading_img{
    margin-bottom: 6.5rem;
  }

  .heading_ttl{
    margin-bottom: 2.5rem;
    font-size: 2.3rem;
    line-height: 2;
    letter-spacing: 0.1em;
    font-weight: 400;
  }

  .heading_ttl .ttl01{
    font-size: 1.8rem;
    line-height: 2.2778;
    letter-spacing: 0.125em;
  }

  .heading_ttl .ttl02{
    letter-spacing: 0.18em;
  }

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


  /*basic*/
  .section{
    width: 68rem;
    margin: auto;
  }

  .content_ttl{
    position: relative;
    margin-bottom: 4rem;
    font-size: 2.2rem;
    line-height: 2.2;
    letter-spacing: 0.12em;
  }

  .content_ttl.border_bottom::before{
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 0;
    border-bottom: solid 0.1rem #999999;
    animation: border_anim 1.8s ease forwards;
    animation-delay: 1s;
  }

  @keyframes border_anim {
    0%{
      width: 0%;
    }
    100%{
      width: 100%;
    }
  }

  .content_list{
    display: flex;
    flex-wrap: wrap;
  }

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


/*1段目*/

  .sec01{
    margin-bottom: 15rem;
  }

  .sec01 .content_list{
    row-gap: 6rem;
    column-gap: 2rem;
  }

  .sec01 .content_img{
    width: 33rem;
  }

  .sec01 .content_inner{
    width: 32.5rem;
    margin-left: auto;
    padding-top: 12.3rem;
  }

/*2段目*/

  .sec02{
    margin-bottom: 12rem;
  }

  .sec02 .content_img{
    width: 50rem;
    margin: auto;
    margin-bottom: 2.2rem;
  }

/*3段目*/

  .sec03{
    margin-bottom: 12rem;
  }

  .sec03 .content_list{
    gap: 2rem;
    margin-bottom: 2.4rem;
  }

  .sec03 .content_img{
    width: 33rem;
  }

/*4段目*/

.sec04{
  margin-bottom: 15.4rem;
}

.sec04 .content_img{
  width: 50rem;
  margin: auto;
  margin-bottom: 2.2rem;
}

.sec04 .content_txt{
  margin-bottom: 1.8rem;
  letter-spacing: 0.05em;
}

.sec04 .content_price{
  font-size: 1.3rem;
  line-height: 2;
  letter-spacing: 0.055em;
}

/*5段目*/
.sec05{
  margin-bottom: 11.3rem;
}

.sec05 .content_ttl{
  width: 59rem;
  margin: auto;
  margin-bottom: 2rem;
  background: #e4e4e4;
  font-size: 2.1rem;
  line-height: 0.8;
  letter-spacing: 0.18em;
  text-align: center;
  z-index: 1;
}

.sec05::after{
  position: absolute;
  content: '';
  width: 100%;
  border-bottom: 0.1rem #999999 solid;
  top: 0.5rem;
  left: 0;
}

.sec05 .content_ttl .sub_ttl{
  font-size: 2rem;
  line-height: 2.6;
  letter-spacing: 0.14em;
}

.sec05 .content_list{
  gap: 5.4rem 2rem;
}

.sec05 .content_inner{
  width: 33rem;
}

.sec05 .content_img{
  margin-bottom: 1.1rem;
}

.sec05 .item_ttl{
  text-align: center;
  font-size: 1.6rem;
  line-height: 2.3;
  letter-spacing: 0.1em;
}

.sec05 .item_price{
  margin-bottom: 1.4rem;
  text-align: center;
  font-size: 1.6rem;
  line-height: 1.625;
  letter-spacing: 0.085em;
}

.sec05 .content_txt {
  width: 30rem;
  margin: auto;
  letter-spacing: 0.05em;
  text-align: justify;
}

.sec05 .price01{
  font-size: 1.4rem;
  margin-left: 0.4rem;
}

.sec05 .txt02{
  display: block;
  margin-top: 1rem;
  font-size: 1.3rem;
  line-height: 2;
  letter-spacing: 0.01em;
}


/*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) {

  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(120 * (100vw / 750));
  }

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

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

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

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

.heading_ttl{
  margin-bottom: calc(32* (100vw/750));
  font-size: calc(40* (100vw/750));
  line-height: 2;
  letter-spacing: 0.1em;
}

.heading_ttl .ttl01{
  font-size: calc(30* (100vw/750));
  line-height: 2.2778;
  letter-spacing: 0.125em;
}

.heading_ttl .ttl02{
  letter-spacing: 0.12em;
}

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


/*basic*/
.section{
  width: calc(650* (100vw/750));
  margin: auto;
}

.content_ttl{
  position: relative;
  margin-bottom: calc(58* (100vw/750));
  font-size: calc(36* (100vw/750));
  line-height: 2.2;
  letter-spacing: 0.12em;
  font-weight: 400;
}

.content_ttl.border_bottom::before{
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  border-bottom: solid 0.1rem #999999;
  animation: border_anim 1.8s ease forwards;
  animation-delay: 1s;
}

@keyframes border_anim {
  0%{
    width: 0%;
  }
  100%{
    width: 100%;
  }
}

.content_list{
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
}

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


/*1段目*/

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

.sec01 .content_list{
  display: block;
  width: calc(650* (100vw/750));
  row-gap: 0;
  column-gap: 0;
}

.sec01 .content_img{
  width: calc(650* (100vw/750));
}

.sec01 .content_inner{
  width: calc(650* (100vw/750));
  margin-left: auto;
  padding-top: calc(34* (100vw/750));
}

/*2段目*/

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

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

/*3段目*/

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

.sec03 .content_list{
  display: block;
  gap: 0;
  margin-bottom: calc(35* (100vw/750));
}

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

/*4段目*/

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

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

.sec04 .content_txt{
margin-bottom: calc(18* (100vw/750));
letter-spacing: 0.05em;
}

.sec04 .content_price{
  font-size: calc(23* (100vw/750));
line-height: 2;
letter-spacing: 0.055em;
}

/*5段目*/
.sec05{
margin-bottom: calc(124* (100vw/750));
}

.sec05 .content_ttl{
width: calc(560* (100vw/750));
margin: auto;
margin-bottom: calc(84* (100vw/750));
background: #e4e4e4;
font-size: calc(38* (100vw/750));
line-height: 1.9;
letter-spacing: 0.18em;
text-align: center;
z-index: 1;
}

.sec05::after{
position: absolute;
content: '';
width: 100%;
border-bottom: 0.1rem #999999 solid;
top: calc(77* (100vw/750));
left: 0;
}

.sec05 .content_ttl .sub_ttl{
  font-size: calc(30* (100vw/750));
  line-height: 2;
  letter-spacing: 0.14em;
}

.sec05 .content_list{
  gap: calc(108* (100vw/750)) 0;
}

.sec05 .content_inner{
  width: calc(650* (100vw/750));
}

.sec05 .content_img{
  margin-bottom: calc(28* (100vw/750));
}

.sec05 .item_ttl{
text-align: center;
font-size: calc(33* (100vw/750));
line-height: 2;
letter-spacing: 0.1em;
}

.sec05 .item_price{
  margin-bottom: calc(14* (100vw/750));
text-align: center;
font-size: calc(28* (100vw/750));
line-height: 1.625;
letter-spacing: 0.085em;
}

.sec05 .content_txt {
width: calc(650* (100vw/750));
margin: auto;
letter-spacing: 0.01em;
}

.sec05 .price01{
  font-size: calc(20* (100vw/750));
  margin-left: calc(8* (100vw/750));
}

.sec05 .txt02{
  margin-top: calc(13* (100vw/750));
  font-size: calc(24* (100vw/750));
  line-height: 2;
  letter-spacing: 0.01em;
}


.main_container .slick-prev {
  top: 49%;
  left: calc(20* (100vw/750));
  z-index: 1;
}

.main_container .slick-prev:before{
  background-size: contain;
  content: "";
  display: block;
  width: calc(30* (100vw/750));
  height: calc(47* (100vw/750));
  background-repeat: no-repeat;
  background-image: url(../../../../../../../page/lp/mensboxers/230517/img/prev.png);
}

.main_container .slick-next {
  top: 49%;
  right: calc(8* (100vw/750));
}

.main_container .slick-next:before {
    background-size: contain;
    content: "";
    display: block;
    width: calc(30* (100vw/750));
    height: calc(47* (100vw/750));
    background-repeat: no-repeat;
    background-image: url(../../../../../../../page/lp/mensboxers/230517/img/next.png);
}

/*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(5px);
  -ms-transform: translateY(5px);
  transform: translateY(5px);
}

.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));
  }

}


