@charset "UTF-8";


/* =============================================================

    TOP ObyF CSS

============================================================= */

/*  Base
======================================================= */

html {
  overflow: auto;
  overflow-x: hidden;
}

.headerWrap {
  height: auto;
}

.customorinfo li {
  margin-top: calc(60 * (100vw / 750));
  letter-spacing: .1em;
}

.submenu li {
  padding-top: calc(50 * (100vw / 750));
}

.companyinfo {
  font-family: 'Poppins', 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}

.cam_bnr_wrap {
  position: relative;
  z-index: 9999;
}

.searcharea_sp_inner {
  display: flex;
}

.searcharea_sp input,
.searcharea_sp input[type="search"] {
  border: none;
  border-radius: 0;
  outline: none;
  background: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  font-size: 16px;
}

.searcharea_sp input {
  border-right: none !important;
  box-sizing: border-box;
}

.searcharea_sp .searchbtn_sp {
  border: 1px solid #b5b5b5!important;
  border-left: none!important;
  position: static;
  transform: translateY(0);
  margin-left: 0;
  box-sizing: border-box;
}

.bg-slider_pc {
  width: 100vw;
  /* height: calc(100vh - 90px); */
  height: 100vh;
  background-position: center top;
  background-size: cover;
  background-attachment: fixed;
  position: relative;
}

.bg-slider_pc p {
  font-size: calc(22 * (100vw / 1400));
  font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  color: #000000;
  position: absolute;
  top: calc(280 * (100vh / 720));
  left: calc(90 * (100vw / 1400));
  text-align: left;
  font-weight: normal;
  letter-spacing: 0.8rem;
  line-height: 2.5;
}


.bo100 div {
  /* width: 100%!important;
	top:60px!important; */
  margin-top: -41px;
}

.bg-slider_sp {
  display: none;
}

.fuwatto-wrap [class*='fuwatto'] {
  opacity: 0;
  transform: translate(0, 30px);
  transition: all 1.2s;
}

.fuwatto-wrap [class*='fuwatto'].f-act {
  opacity: 1;
  transform: translate(0, 0);
}

/* コンテンツラップ ニュース出すときにmarginを消す*/

.contentsWrap {
  padding-top: 90px;
  /* margin-top: -41px; */
}


/* コンテンツラップ ニュース出すときにmarginを消す*/

.contentsWrap_styling,
.contentsWrap.obyftop {
  padding-top: 90px;
  /* margin-top: -41px; */
}


/*  プロダクト
======================================================= */

.background1 {
  width: 100%;
  height: 626px;
  /* height: 67.525vh; */
  background-image: url('../../Contents/ImagesPkg/obyf/top/product_pc.jpg');
  background-repeat: no-repeat;
  background-position: 50% 0%;
  position: relative;
  margin-top: 126px;
}

.contentsWrap .ttl {
  font-size: 32px;
  font-weight: 300;
  letter-spacing: 1rem;
}

.contentsWrap .background1 .ttl {
  position: absolute;
  top: -38px;
  left: 0;
  right: 0;
}

.contentsWrap .ttl._rect {
  display: flex;
  justify-content: center;
  align-items: center;
}

.contentsWrap .ttl._rect.alignc {
  text-align: center;
}

.contentsWrap .ttl._rect img {
  width: 20px;
}

.contentsWrap .ttl._rect span {
  margin: 8px 0 0 8px;
}

.background1 .itemWrap {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
  width: 100%;
  max-width: 1040px;
  text-align: center;
}

.background1 .itemWrap .itemArea {
  margin: 0 auto;
}

.background1 .itemWrap .itemArea {
  display: none;
}

.background1 .itemWrap .itemArea .slick-list {
  margin: 0;
  padding: 0!important;
}

.background1 .itemWrap .itemArea.slick-initialized {
  display: block;
}

.background1 .itemWrap .itemArea .slick-slide {
  max-width: 220px;
  width: calc(25% - 40px)!important;
  margin: 0 20px;
}

.background1 .itemWrap .itemArea .slick-slide img {
  width: 100%;
}

.background1 .itemWrap .itemArea .itemDetail {
  font-size: 13px;
  margin-top: 13px;
  line-height: 2.3;
}

.background1 .itemWrap .btnArea {
  margin: 60px auto 0;
}


/*  コンセプト
======================================================= */

.conceptArea {
  margin-top: 120px;
  position: relative;
  width: 100%;
  /* height: 61.1vh; */
  height: 550px;
}

.background2 {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
  background-image: url('../../Contents/ImagesPkg/obyf/top/obi_02_02.jpg');
  background-repeat: no-repeat;
  background-position: 50% 0%;
  width: 100%;
  height: 255px;
  /* height: 27.6vh; */
}

.conceptArea .innerArea {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
  max-width: 950px;
  width: 100%;
  height: 550px;
}

.conceptArea .innerArea .innerArea_depth {
  position: relative;
  height: 550px;
}

.contentsWrap .conceptArea .ttl._rect span {
  margin: 0;
}

.conceptArea .imgWrap {
  position: absolute;
  right: 0;
}

.conceptArea .imgWrap img {
  max-width: 500px;
  width: 100%;
}

.conceptArea .ttlWrap {
  position: absolute;
  right: 0;
  /*top:-29px;*/
  /*20220630削除*/
  top: -106px;
  /*20220630追記*/
  z-index: 100;
  /*20220630追記*/
}

.conceptArea .ttlArea {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.conceptArea .ttlArea p {
  font-size: 13px;
  margin: 5px 0 0 8px;
  letter-spacing: 0.15rem;
}

.conceptArea .leftArea {
  /*position: absolute;*/
  /*20220630削除*/
  /*left: 0;*/
  /*20220630削除*/
}

.conceptArea .leftArea .maintext {
  font-size: 22px;
  font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 2.4;
  /* font-weight: 200; */
  /*text-align: left;*/
  /*20220630削除*/
  text-align: center;
  /*20220630追記*/
  margin-top: 226px;
  letter-spacing: 0.8rem;
  color: #000000;
}

.btn_more.con {
  margin: 124px auto 0;
}


/* スタイリング */

.stylingArea {
  margin: 100px auto 0;
  max-width: 970px;
  width: 100%;
  display: flex;
  align-items: center;
}

.stylingArea .leftArea_s {
  position: relative;
  height: 540px;
  width: 50%;
}

.stylingArea .leftArea_s .back {
  position: absolute;
  top: 60px;
  left: 60px;
  background-image: url('../../Contents/ImagesPkg/obyf/top/img_styling_back.jpg');
  background-repeat: no-repeat;
  background-position: 0% 0%;
  /* width: 82.475%;
	height: 51.228vh; */
  width: 400px;
  height: 480px;
}

.stylingArea .leftArea_s .front {
  position: absolute;
  top: 0;
  width: 400px;
}

.stylingArea .rightArea_s {
  display: flex;
  flex-direction: column;
  width: 50%;
}

.btn_more.sty,
.btn_comingsoon.sty {
  margin: 30px auto 0;
}


/* ニュース */

.newsArea_contents {
  display: flex;
  flex-direction: row-reverse;
  align-items: flex-start;
  max-width: 1040px;
  width: 100%;
  margin: 140px auto 60px;
  padding: 0 20px;
}

.newsArea_contents .newsinner_contents {
  /* max-width: 955px; */
  width: 100%;
  background: #f5f8f9;
}

.newsArea_contents .newsinner_contents .infobox {
  margin: 40px 110px 40px 144px;
  /* height: 110px; */
  /* overflow-y: scroll; */
}

.newsArea_contents .newsinner_contents .infobox .newscontents {
  display: flex;
  /* align-items: center; */
  margin-bottom: 8px;
  color: #000000;
  text-align: left;
  letter-spacing: 0.2rem;
}

.newsArea_contents .newsinner_contents .infobox .newscontents .date {
  margin-right: 46px;
  font-size: 13px;
  width: 11%;
}

.newsArea_contents .newsinner_contents .infobox .newscontents .tag_cate {
  position: absolute;
  top: 2px;
  left: 0;
  display: inline-block;
  font-size: 12px;
  min-width: 85px;
  height: 20px;
  line-height: 20px;
  text-align: center;
  background: #bfbfbf;
  color: #ffffff;
  margin-right: 20px;
  letter-spacing: 0.1rem;
}

.newsArea_contents .newsinner_contents .infobox .newscontents .newsdetail {
  position: relative;
  padding-left: 105px;
  font-size: 12px;
}

.contentsWrap .newsArea_contents .ttl._rect.news_cfontents {
  margin-top: -36px;
}

/* バナーエリア */

.bnr_Area {
  margin: 140px auto 0;
  max-width: 920px;
  width: 100%;
}

.bnr_Area .bnr_inner {
  display: flex;
  justify-content: space-between;
  padding: 0 20px;
}

.bnr_Area .bnr_inner li {
  margin-left: 20px;
}

.bnr_Area .bnr_inner li:first-child {
  margin-left: 0;
}


/* ボタン */

.btn_more {
  width: 260px;
  display: block;
  text-align: center;
  font-size: 16px;
  height: 50px;
  line-height: 50px;
  color: #000000;
  -webkit-backface-visibility: hidden;
  /* 追加 */
  backface-visibility: hidden;
  /* 追加 */
  -webkit-transition: 0.2s ease-in;
  transition: 0.2s ease-in;
  margin: 0 auto;
  letter-spacing: 0.2rem;
  font-weight: 300;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.btn_comingsoon {
  width: 260px;
  display: block;
  text-align: center;
  font-size: 16px;
  height: 50px;
  line-height: 50px;
  color: #ffffff;
  margin: 0 auto;
  letter-spacing: 0.2rem;
  font-weight: 300;
  background: #b3b3b3;
}

.bc_border {
  border: 1px solid #b7b7b7;
}


/* 追従バナー */

.Bnr {
  position: relative;
  display: none;
}

.Bnr .Bnr__img {
  position: fixed;
  bottom: 0;
  right: 0;
  z-index: 0;
}

.Bnr__img__inner {
  width: 300px;
  height: 250px;
  box-sizing: border-box;
}

.Bnr__img__inner img {
  width: 100%;
}

.Bnr .Bnr__img__inner a {
  display: block;
}

.Bnr .Bnr__img p.close {
  position: absolute;
  right: 3px;
  top: -28px;
}

.Bnr .Bnr__img p.close a {
  display: block;
  width: 20px;
  height: 25px;
  text-align: center;
}

.Bnr .Bnr__img p.close a span {
  display: block;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.Bnr .Bnr__img p.close a i {
  font-size: 20px;
  z-index: 888;
  color: #222;
}


/*//////////////////////////////////////////////////

　　　　　　　　　　SP ONLY SETTING

//////////////////////////////////////////////////*/


@media screen and (min-width: 768px) {
  .btn_more:hover {
    background: #b3b3b3;
    color: #ffffff;
    opacity: 0.9;
    border: 1px solid #b3b3b3;
  }
}

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

  /* MV調整 */
  .contentsWrap_inner >  .pc_only + .sp_only > div:first-child {
    top: 0 !important;
  }

  .bg-slider_sp {
    display: block;
  }

  /* ニュース */
  .newsArea_contents {
    margin: 140px auto 60px;
    padding: 0 20px;
  }
  .newsArea_contents .newsinner_contents .infobox {
    margin: 40px 50px 40px 50px;
  }
  .newsArea_contents .newsinner_contents .infobox .newscontents .date {
    width: 13%;
  }
}

@media screen and (max-width: 768px) {
  .hamburger__line {
    transform: translateX(-50%);
  }

  .bg-slider_sp img {
    display: block;
    margin: calc(510 * (100vw / 750)) auto 0;
  }

  .contentsWrap {
    font-feature-settings: normal !important;
  }

  .contentsWrap .ttl {
    font-size: calc(33 * (100vw / 750));
    letter-spacing: 0.3em;
  }
  /* タイトル */
  .contentsWrap .ttl {
    font-size: calc(33 * (100vw / 750));
  }
  .contentsWrap .ttl._rect img {
    width: calc(20 * (100vw / 750));
  }
  .contentsWrap .ttl._rect span {
    margin: calc(12 * (100vw / 750)) 0 0 calc(12 * (100vw / 750));
  }
  /* プロダクト */
  .background1 {
    width: 100%;
    height: calc(710 * (100vw / 750));
    background-image: url('../../Contents/ImagesPkg/obyf/top/product_sp.jpg');
    background-repeat: no-repeat;
    background-position: 50% 0%;
    background-size: 140%;
    position: relative;
    margin-top: calc(40 * (100vw / 750))
  }
  .contentsWrap .background1 .ttl {
    position: absolute;
    top: calc(-40 * (100vw / 750));
    left: 0;
    right: 0;
  }
  .background1 .itemWrap {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
    width: 100%;
    max-width: 1040px;
  }
  .background1 .itemWrap .itemArea {
    margin: 0 auto;
  }
  .background1 .itemWrap .itemArea.slick-initialized {
    display: block;
  }
  .background1 .itemWrap .itemArea .slick-slide {
    max-width: calc(314 * (100vw / 750));
    width: 100%!important;
    margin: 0 calc( 15 * (100vw / 750)) 0 calc( 15 * (100vw / 750));
  }
  .background1 .itemWrap .itemArea .slick-slide img {
    width: 100%;
    margin: 0 auto;
  }
  .background1 .itemWrap .itemArea .itemDetail {
    font-size: calc( 24 * (100vw / 750));
    margin-top: calc( 22 * (100vw / 750));
    line-height: 1.8;
  }
  .background1 .itemWrap .btnArea {
    margin: calc( 50 * (100vw / 750)) auto 0;
  }

  /* コンセプト */
  .conceptArea {
    margin-top: calc(170 * (100vw / 750));
    position: relative;
    width: 100%;
    height: calc(550 * (100vw / 750));
  }
  .background2 {
    position: absolute;
    top: calc(110 * (100vw / 750));
    left: 50%;
    transform: translateY(0) translateX(-50%);
    -webkit- transform: translateY(0) translateX(-50%);
    background-image: url('../../Contents/ImagesPkg/obyf/top/obi_02_sp.jpg');
    background-repeat: no-repeat;
    background-position: 50% 0%;
    background-size: 140%;
    width: 100%;
    height: calc(290 * (100vw / 750));
  }
  .conceptArea .innerArea {
    position: absolute;
    top: 0%;
    left: 50%;
    transform: translateY(0) translateX(-50%);
    -webkit- transform: translateY(0) translateX(-50%);
    max-width: 950px;
    width: 100%;
    height: calc(550 * (100vw / 750));
  }
  .conceptArea .innerArea .innerArea_depth {
    position: relative;
    height: calc(550 * (100vw / 750));
  }
  .contentsWrap .conceptArea .ttl._rect span {
    margin: 0;
  }
  .conceptArea .imgWrap {
    position: absolute;
    right: calc(30 * (100vw / 750));
  }
  .conceptArea .imgWrap img {
    max-width: inherit;
    width: calc(440 * (100vw / 750));
  }
  .conceptArea .ttlWrap {
    position: absolute;
    right: 0;
    /*top:calc(-30 * (100vw / 750));*/
    /*20220630削除*/
    top: calc(82 * (100vw / 750));
    /*20220630追記*/
    padding-right: calc(30 * (100vw / 750));
  }
  .conceptArea .ttlArea {
    display: flex;
    align-items: center;
    justify-content: flex-end;
  }
  .conceptArea .ttlArea p {
    font-size: calc(12 * (100vw / 750));
    margin: 5px 0 0 8px;
    letter-spacing: 0.3em;
  }
  .conceptArea .leftArea {
    position: absolute;
    /*left: 0;*/
    /*20220630削除*/
    left: 25%;
    /*20220630追記*/
  }
  .conceptArea .leftArea .maintext {
    font-size: calc(22 * (100vw / 750));
    margin: calc(180 * (100vw / 750)) 0 0 calc(60 * (100vw / 750));
    letter-spacing: 0.2em;
  }
  .conceptArea .btnArea {
    position: absolute;
    bottom: calc(30 * (100vw / 750));
    left: 50%;
    transform: translateY(0) translateX(-50%)!important;
    -webkit- transform: translateY(0) translateX(-50%);
    margin: 0 auto auto;
  }
  .sp_only .btn_more.con {
    margin: 0 auto;
    background: rgba(255, 255, 255, 0.5);
  }

  /* スタイリング */
  .stylingArea {
    margin: calc(150 * (100vw / 750)) auto 0;
    max-width: 970px;
    width: 100%;
    display: flex;
    align-items: center;
    flex-direction: column;
  }
  .stylingArea .leftArea_s {
    position: relative;
    height: calc(530 * (100vw / 750));
    width: 100%;
  }
  .stylingArea .leftArea_s .back {
    position: absolute;
    top: calc(50 * (100vw / 750));
    left: calc(50 * (100vw / 750));
    background-image: url('../../Contents/ImagesPkg/obyf/top/img_styling_back_sp.jpg');
    background-repeat: no-repeat;
    background-position: 0% 0%;
    background-size: 160%;
    /* width: 82.475%; */
    height: calc(480 * (100vw / 750));
    width: calc(400 * (100vw / 750));
    right: 0;
    margin: 0 auto;
  }
  .stylingArea .leftArea_s .front {
    position: absolute;
    top: 0;
    left: calc(-50 * (100vw / 750));
    width: calc(400 * (100vw / 750));
    right: 0;
    margin: 0 auto;
  }
  .stylingArea .rightArea_s {
    display: flex;
    flex-direction: column;
    width: 100%;
  }
  .styling_ttl_sp {
    position: absolute;
    bottom: calc(20 * (100vw / 750));
    right: 0;
    left: calc(150 * (100vw / 750));
    width: calc(400 * (100vw / 750));
    margin: 0 auto;
  }
  .btn_more.sty,
  .btn_comingsoon.sty {
    margin: calc(40 * (100vw / 750)) auto 0;
  }
  /* ニュース */
  .newsArea_contents {
    flex-direction: column-reverse;
    max-width: 1040px;
    width: 100%;
    margin: calc(175 * (100vw / 750)) auto calc(40 * (100vw / 750));
    padding: 0 20px;
  }
  .newsArea_contents .newsinner_contents {
    margin: calc(-28 * (100vw / 750)) 0 0 0;
  }
  .newsArea_contents .newsinner_contents .infobox {
    margin: calc(60 * (100vw / 750)) calc(30 * (100vw / 750)) calc(44 * (100vw / 750));
    /* height: initial; */
  }
  .newsArea_contents .newsinner_contents .infobox .newscontents {
    position: relative;
    margin-top: calc(40 * (100vw / 750));
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    letter-spacing: .1em;
  }
  .newsArea_contents .newsinner_contents .infobox .newscontents .tag_cate {
    top: calc(-57 * (100vw / 750));
    left: calc(180 * (100vw / 750));
    font-size: calc(24 * (100vw / 750));
    min-width: calc(170 * (100vw / 750));
    height: 20px;
    line-height: 20px;
    margin-right: 0;
    letter-spacing: 0.1rem;
  }
  .newsArea_contents .newsinner_contents .infobox .newscontents:first-child {
    margin-top: 0;
  }
  .newsArea_contents .newsinner_contents .infobox .newscontents .date {
    margin-right: calc(10 * (100vw / 750));
    font-size: calc(24 * (100vw / 750));
    width: 28%;
  }
  .newsArea_contents .newsinner_contents .infobox .newscontents .newsdetail {
    display: block;
    position: inherit;
    width: 100%;
    font-size: calc(24 * (100vw / 750));
    margin-top: calc(16 * (100vw / 750));
    padding-left: 0;
  }
  .contentsWrap .newsArea_contents .ttl._rect.news_cfontents {
    margin-top: -36px;
  }
  /* バナーエリア */
  .bnr_Area {
    margin: calc(150* (100vw / 750)) auto 0;
  }
  .bnr_Area .bnr_inner {
    display: flex;
    justify-content: center;
    flex-direction: column;
    padding: 0 calc(50 * (100vw / 750));
  }
  .bnr_Area .bnr_inner li {
    margin: calc(40 * (100vw / 750)) 0 0;
  }
  .bnr_Area .bnr_inner li:first-child {
    margin: 0;
  }
  /* ボタン */
  .btn_more {
    width: calc(360 * (100vw / 750));
    display: block;
    text-align: center;
    font-size: calc(23 * (100vw / 750));
    height: calc(90 * (100vw / 750));
    line-height: calc(90 * (100vw / 750));
    letter-spacing: .2em;
  }
  .btn_comingsoon {
    width: calc(360 * (100vw / 750));
    display: block;
    text-align: center;
    font-size: calc(23 * (100vw / 750));
    height: calc(90 * (100vw / 750));
    line-height: calc(90 * (100vw / 750));
  }

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


/* NEWS
============================================================= */

.news_main .infobox li:nth-child(n+6) {
  display: none !important;
}







/*//////////////////////////////////////////////////

Title : 2024 0801 ObyF TOP 改修 CSS

//////////////////////////////////////////////////*/


/* ========================================================
                      * Layout style *
========================================================= */

html {
  font-size: 62.5%;
}

main {
  max-width: 100%;
}

.wapper {
  padding-bottom: 0;
  }


/* ===================
    FONT FACE
=================== */
@font-face {
  font-family: "century-gothic-Regular";
  src: url('../../obyf/font/GOTHIC.otf') format('opentype'),
  url('../../obyf/font/GOTHIC.TTF') format('ttf'),
  url('../../obyf/font/GOTHIC.woff') format('woff'),
  url('../../obyf/font/GOTHIC.woff2') format('woff2');
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: "century-gothic-Bold";
  src: url('../../obyf/font/GOTHICB.otf') format('opentype'),
  url('../../obyf/font/GOTHICB.TTF') format('ttf'),
  url('../../obyf/font/GOTHICB.woff') format('woff'),
  url('../../obyf/font/GOTHICB.woff2') format('woff2');
  font-weight: normal;
  font-style: normal;
}
/* ===================
      ROOTS
=================== */
:root {
  --color-bg:#f5f8f9;
  --color-text:#000000;
  --color-border:#B7B7B7;
  --color-rank:#BCCBD0;
  --color-label:#BEBEBE;
  --color-white:#ffffff;
  --font-english-regular-safari: "century-gothic-Regular";
  --font-english-bold-safari: "century-gothic-Bold";
  --font-english: 'Century Gothic', sans-serif;
}
/* ===================
  LP Contents
=================== */

#container {
  position: relative;
  z-index: 1;
  margin: 0 auto;
  padding-bottom: 12rem;
  background: #fff;
  font-weight: 400;
  font-style: normal;
  font-family: "Roboto","ヒラギノ角ゴ ProN W3", HiraKakuProN-W3, 游ゴシック, "Yu Gothic", メイリオ, Meiryo, Verdana, Helvetica, Arial, sans-serif;
  letter-spacing: 0.075em;
  color: var(--color-text);
  overflow: hidden;
}

#container *,
#container *:before,
#container *:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

#container ul,
#container li {
  list-style: none;
}

#container a:hover {
  opacity: 0.6;
}

#container sup {
  font-size: 60%;
  vertical-align: 0.4rem;
}

#container a,
#container a:before,
#container a:after,
#container a img {
  transition: opacity .3s ease-in-out,
  color .3s ease-in-out,
  background-color .3s ease-in-out,
  background-image .3s ease-in-out,
  border-color .3s ease-in-out,
  text-shadow .3s ease-in-out,
  text-weight .3s ease-in-out;
}

#container h1 {
  padding: 0;
}

#container a {
  color: var(--color-text);
}

/* ===================
  　　　Animation
=================== */
#container .ef1{
  opacity: 0;
}
#container .ef1.effect {
  -webkit-animation: fade 1.3s cubic-bezier(0.09, 0.26, 0.58, 1) forwards;
          animation: fade 1.3s cubic-bezier(0.09, 0.26, 0.58, 1) forwards;
}
@-webkit-keyframes fade {
  0% {
    opacity: 0;
    transform: translateY(22px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes fade {
  0% {
    opacity: 0;
    transform: translateY(22px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ===================
      Button Setting
=================== */
#container .btn {
  width: fit-content;
  display: block;
  background: white;
  border: none;
  max-width: 100%;
  margin: 0 auto;
}

#container .btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  transition: all 0.1s ease-in-out;
  backface-visibility: hidden;
}

#container .btn a:hover {
  opacity: 0.6;
}

/* ===================
  　　MV SECTION 
=================== */
#container .bg-slider_pc p {
  font-size: 2.2rem;
  font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  color: #000000;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 8.6rem;
  text-align: left;
  font-weight: normal;
  letter-spacing: 0.8rem;
  line-height: 2.5;
}

/* ===================
    　　Anchor 
=================== */
#container .anchor_area {
  padding: 6rem 0 6rem;
  background-color: var(--color-bg);
}

#container .anchor_area .anchor_link {
  width: 72rem;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 3rem;
  row-gap: 2rem;
}

#container .anchor_area .anchor_link .link{
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-inline: auto;
  padding-top: 2rem;
  position: relative;
  width: 22rem;
  height: 10.3rem;
  background-color: var(--color-white);

}

#container .anchor_area .anchor_link .anchor_en {
  margin-bottom: 1rem;
  font-family: var(--font-english);
  font-size: 2rem;
  line-height: 1;
  letter-spacing: 0.075em;
  font-feature-settings: "pkna";
  color: var(--color-text);
  text-transform: uppercase;
  font-weight: 400;
}

_::-webkit-full-page-media, _:future, :root #container .anchor_area .anchor_link .anchor_en {
  font-family: var(--font-english-regular-safari);
}

#container .anchor_area .anchor_link .anchor_jp {
  font-size: 1.2rem;
  line-height: 1;
  letter-spacing: 0.075em;
  font-feature-settings: "pkna";
  color: var(--color-text);
}


#container .anchor_area .anchor_link .link:after {
  margin: auto;
  content: "";
  position: absolute;
  right: 0;
  bottom: 2rem;
  left: 0;
  width: 2rem;
  height: 0.6rem;
  background-image: url(../../Contents/ImagesPkg/obyf/top/arrow.svg);
  background-size: contain;
  background-repeat: no-repeat;

}

/* ===================
      SEC COMMON 
=================== */
#container .area {
  padding: 8rem 0 8rem;
}

#container .ttl_group {
  margin-bottom: 6rem;
  
}

#container .ttl_en {
  margin-bottom: 1.5rem;
  font-family: var(--font-english);
  font-size: 2.4rem;
  line-height: 1;
  letter-spacing: 0.075em;
  font-feature-settings: "pkna";
  color: var(--color-text);
  text-transform: uppercase;
  text-align: center;
  font-weight: 400;
}

_::-webkit-full-page-media, _:future, :root #container .ttl_en {
  font-family: var(--font-english-regular-safari);
}


#container .ttl_jp {
  font-size: 1.2rem;
  line-height: 1;
  letter-spacing: 0.075em;
  font-feature-settings: "pkna";
  color: var(--color-text);
  text-align: center;
}

#container .btn {
  display: block;
  background: transparent;
  border: none;
  padding: 0;
  width: fit-content;
  height: auto;
  max-width: 100%;
}

#container .btn:hover {
  background: none;
  border: none;
  color: var(--color-border);
}

#container .btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  border: var(--color-border) 1px solid;
  background-color: var(--color-white);
  color: var(--color-text);
  font-weight: 400;
  transition: all 0.1s ease-in-out;
}


#container .btn.btn_see_more a {
  width: 36rem;
  height: 4.6rem;
  margin: 0 auto;
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  font-feature-settings: "pkna";
  background: transparent;
}

#container .btn a:hover {
  opacity: 0.6;
}


/* Common Swiper style */
#container .lp_swiper01,
#container .lp_swiper02{
  position: relative;
}

/* Dot */
#container .swiper-pagination{
  position: absolute;
  right: 0;
  left: 0;
  bottom: -5.7rem;
}

#container .swiper-pagination-bullets.swiper-pagination-horizontal{
  bottom: -1rem;
}

#container .swiper-pagination-bullet {
  position: static;
  margin: 0.6rem;
  border-radius: 50%;
  width: 0.6rem;
  height: 0.6rem;
  opacity: 1;
  background-color: #E4E4E4;
}

#container .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 1rem);
}

/* Dot Active */
#container .swiper-pagination-bullet-active {
  background-color: #8B8B8B;
  border: none;
  height: 0.6rem;
  width: 0.6rem;
}

/* ===================
      PRODUCTS 
=================== */

#container .products_inner .itm_img {
  width: 25rem;
}

#container .products_inner .itm_name {
  margin-top: 1.2rem;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 2.4;
  letter-spacing: 0.075em;
  font-feature-settings: "pkna";
  text-align: center;
  color: var(--color-text);
}

/* Product Swiper style */
#container .lp_swiper01 {
  height: 34rem;
  margin-bottom: 10.6rem;
}

#container .lp_swiper01 .swiper-slide {
	width: 25rem;
	transition: transform .4s ;
}

#container .lp_swiper01 .swiper-slide .swipe_inner_group {
  width: 25rem;
  margin: 2.5rem auto 0;
  max-height: 29rem;
  transition: margin-top .5s, width .5s, max-height .5s, height .5s;
}

#container .lp_swiper01 .swiper-slide img {
  max-width: 100%;
  transition: width .5s;
}

#container .lp_swiper01 .swiper-slide-active .swipe_inner_group {
  width: 30rem;
  max-height: none;
  margin-top: 0;
  z-index: 1;
}

#container .lp_swiper01 .swiper-slide-active .swipe_inner_group {
  height: auto;
}

#container .lp_swiper01 .swiper-slide-active .itm_img {
  width: 30rem;
}

/* ===================
      CONTENTS 
=================== */
#container .contents_area{
  background-color: var(--color-bg);
  padding-bottom: 15rem;
}

#container .contents_area .ttl_group {
  margin-bottom: 3.5rem;
}

#container .contents_area .btn_detail a {
  width: 22rem;
  height: 3rem;
  margin: 2.8rem auto 0;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  font-feature-settings: "pkna";
  background-color: transparent;
}

/* Contents Swiper style */
#container .lp_swiper02 {
  height: 33.5rem;
  margin-top: 5.9rem;
}

#container .lp_swiper02 .swiper-pagination {
  bottom: -8.2rem;
}
/* Slide数が > 3の設定 */
#container .lp_swiper02 .swiper-slide {
	width: 25rem;
	transition: transform .4s ;
}

#container .lp_swiper02 .swiper-slide .swipe_inner_group {
  width: 25rem;
  margin: 2.5rem auto 0;
  max-height: 29rem;
  transition: margin-top .5s, width .5s, max-height .5s, height .5s;
}

#container .lp_swiper02 .swiper-slide img {
  max-width: 100%;
  transition: width .5s;
}

#container .lp_swiper02 .swiper-slide-active .swipe_inner_group {
  width: 30rem;
  max-height: none;
  margin-top: 0;
  z-index: 1;
}

#container .lp_swiper02 .swiper-slide-active .swipe_inner_group {
  height: auto;
}

#container .lp_swiper02 .swiper-slide-active .itm_img {
  width: 30rem;
}

/* Slide数が < 3の設定 */
#container .lp_swiper02.under_3_only {
  height: auto;
}
#container .lp_swiper02.under_3_only .swiper-slide {
	width: 30rem;
  margin: 0 2rem;
	transition: transform .4s ;
}

#container .lp_swiper02.under_3_only .swiper-slide .swipe_inner_group {
  width: 30rem;
  margin: 2.5rem auto 0;
  max-height: 29rem;
  transition: margin-top .5s, width .5s, max-height .5s, height .5s;
	/* transform: scale(1); */
}

/* ===================
      RANKING
=================== */
#container .ranking_area .ttl_group {
  margin-bottom: 9rem;
}

#container .item_list__inner {
  width: 83rem;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 4rem;
  row-gap: 9rem;
}

#container .item_rank1 {
  margin-left: 12.5rem;
}

#container .item_rank2 {
  margin-right: 12.5rem;
}

#container .item_list__item {
  width: 25rem;
  position: relative;
}

#container .item_list__review.reviewFeature__RankingParts,
#container .item_list__cat,
#container .soldout {
  display: none;
}

#container .item_list__img {
  width: 78%;
  margin: 0 auto 2rem;
}

#container .item_list__title {
  margin-bottom: 1rem;
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0.075em;
  color: var(--color-text);
  font-feature-settings: "pkna";
  text-align: center;
}

#container .item_list__title a {
  color: var(--color-text);
}

#container .item_list__price {
  font-family: var(--font-english);
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.1em;
  color: var(--color-text);
  font-feature-settings: "pkna";
  text-align: center;
}

_::-webkit-full-page-media, _:future, :root #container .item_list__price {
  font-family: var(--font-english-regular-safari);
}

#container .item_list__price .txt_price_tax {
  font-size: 1.1rem;
  margin-left: -.3rem;
}

#container .icn_rank {
  width: 5rem;
  height: 5rem;
  padding-top: 1.5rem;
  background-color: #BCCBD0;
  font-family: var(--font-english);
  color: var(--color-white);
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.05em;
  color: var(--color-white);
  font-feature-settings: "pkna";
  text-align: center;
  border-radius: 50%;
  position: absolute;
  top: -1.9rem;
  left: 1rem;
  z-index: 3;
}

#container .icn_rank_no {
  font-family: var(--font-english);
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.05em;
  color: var(--color-white);
  font-feature-settings: "pkna";
  text-align: center;
}

_::-webkit-full-page-media, _:future, :root #container .icn_rank,
_::-webkit-full-page-media, _:future, :root #container .icn_rank_no {
  font-family: var(--font-english-regular-safari);
}

/* ===================
      SUBSCRIPTION
=================== */

#container .subscription_area {
  background-color: var(--color-bg);
}

#container .subscription_detail_group {
  width: 50rem;
  margin: 0 auto;
  background-color: var(--color-white);
  padding: 3.6rem 0 3.3rem;
}

#container .subscription_detail_ttl {
  width: fit-content;
  margin: 0 auto;
  position: relative;
  margin-bottom: 1rem;
  font-size: 1.6rem;
  letter-spacing: 0.075em;
  color: var(--color-text);
  font-feature-settings: "pkna";
  text-align: center;
}

#container .subscription_detail_ttl:after {
  position: absolute;
  top: 50%;
  translate: transformY(-50%);
  right: -2.4rem;
  width: 1.4rem;
  height: 0.1rem;
  background-color: #8b8b8b;
  content: "";
}

#container .subscription_detail_ttl:before {
  position: absolute;
  top: 50%;
  translate: transformY(-50%);
  left: -2.4rem;
  width: 1.4rem;
  height: 0.1rem;
  background-color: #8b8b8b;
  content: "";
}

#container .subscription_detail {
  font-size: 1.3rem;
  line-height: 2;
  letter-spacing: 0.075em;
  color: var(--color-text);
  font-feature-settings: "palt";
  text-align: center;
}

#container .subscription_list {
  width: 103rem;
  margin: 8.1rem auto 6rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 5rem;
  row-gap: 4rem;

}

#container .subscription_list .itm_img {
  width: 22rem;
}

#container .subscription_list .itm_name {
  margin-top: 1.3rem;
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0.075em;
  color: var(--color-text);
  font-feature-settings: "pkna";
  text-align: center;
}

#container .subscription_list .itm_price_before {
  position: relative;
  width: fit-content;
  margin: 0.9rem auto 0.5rem;
  font-family: var(--font-english);
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.75;
  letter-spacing: 0.1em;
  color: var(--color-text);
  font-feature-settings: "pkna";
  text-align: center;
}

#container .subscription_list .itm_price_before:before {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: .1rem;
  background: var(--color-text);
  content: "";
}

_::-webkit-full-page-media, _:future, :root #container .subscription_list .itm_price_before {
  font-family: var(--font-english-regular-safari);
}

#container .subscription_list .itm_normal_price {
  font-style: normal;
  font-family: "Roboto","ヒラギノ角ゴ ProN W3", HiraKakuProN-W3, 游ゴシック, "Yu Gothic", メイリオ, Meiryo, Verdana, Helvetica, Arial, sans-serif;
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1.75;
  letter-spacing: 0.1em;
  color: var(--color-text);
  font-feature-settings: "pkna";
}

#container .subscription_list .tax {
  font-family: var(--font-english);
  font-size: 1.1rem;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.1em;
  color: var(--color-text);
  font-feature-settings: "pkna";
}

_::-webkit-full-page-media, _:future, :root #container .subscription_list .tax {
  font-family: var(--font-english-regular-safari);
}

#container .subscription_list .itm_price_group {
  display: flex;
  justify-content: center;
  margin-bottom: 0.5rem;
}

#container .subscription_list .itm_price_group:last-of-type {
  display: flex;
  margin-bottom: 0;
}

#container .subscription_list .itm_price_label {
  margin-right: 1rem;
  width: 7rem;
  height: 2rem;
  padding: 0.4rem 0;
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.1em;
  color: var(--color-white);
  font-feature-settings: "pkna";
  background-color: #BEBEBE;
  text-align: center;
}

#container .subscription_list .itm_price {
  font-family: var(--font-english);
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.1em;
  color: var(--color-text);
  font-feature-settings: "pkna";
}

_::-webkit-full-page-media, _:future, :root #container .subscription_list .itm_price {
  font-family: var(--font-english-regular-safari);
}

#container .subscription_list .itm_price .tax {
  font-family: var(--font-english);
  font-size: 1.1rem;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.1em;
  color: var(--color-text);
  font-feature-settings: "pkna";
}
_::-webkit-full-page-media, _:future, :root #container .subscription_list .itm_price .tax {
  font-family: var(--font-english-regular-safari);
}

#container .subscription_area .btn_detail a {
  width: 22rem;
  height: 3rem;
  margin: 1.5rem auto 0;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  font-feature-settings: "pkna";
  background-color: transparent;
}

/* ===================
      CONCEPT
=================== */
#container .conceptArea {
  margin-top: 0;
}

#container .background2 {
  position: absolute;
  top: 31.6rem;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  background-image: url(../../Contents/ImagesPkg/obyf/top/obi_02_02.jpg);
  background-repeat: no-repeat;
  background-position: 50% 0%;
  width: 100%;
  height: 25rem;
}

#container .conceptArea .leftArea .maintext {
  font-size: 1.8rem;
  font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 2.4;
  font-weight: 400;
  text-align: center;
  margin-top: 27.2rem;
  letter-spacing: 0.4em;
  color: #000000;
  font-feature-settings: "palt";
}

#container .conceptArea .btn_more {
  margin-top: 12.1rem;
}

/* ===================
      NEWS
=================== */
#container .news_area .ttl_group {
  margin-bottom: 3.7rem;
}

#container .news_area {
  background-color: var(--color-bg);
  margin-top: 4rem;
}

#container .newsArea_contents {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  margin: 0 auto 2.5rem;
  padding: 0;
}

#container .newsArea_contents .newscontents {
  align-items: flex-start;
}

#container .newsArea_contents .infobox {
  width: 64.6rem;
  margin: 0 auto;
}

#container .newsArea_contents .date {
  width: fit-content;
  margin-top: 0.3rem;
  margin-right: 2rem;
  font-family: var(--font-english);
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.07em;
  color: var(--color-text);
  font-feature-settings: "pkna";
}

_::-webkit-full-page-media, _:future, :root #container .newsArea_contents .date {
  font-family: var(--font-english-regular-safari);
}

#container .newsArea_contents .tag_cate {
  position: absolute;
  top: 0.3rem;
  left: 0;
  display: inline-block;
  font-size: 1.2rem;
  max-width: 8rem;
  min-width: 8rem;
  height: 1.5rem;
  line-height: 1.3;
  text-align: center;
  background: #bfbfbf;
  color: #ffffff;
  margin-right: 2rem;
  letter-spacing: 0.075rem;
}

#container .newscontents .newsdetail {
  position: relative;
  padding-left: 10rem;
  font-size: 1.3rem;
  letter-spacing: 0.075em;
  line-height: 1.846;
  color: var(--color-text);
}

#container .newscontents .newsdetail a {
  color: var(--color-text);
}

#container .btn_more a{
  font-family: var(--font-english);
  width: 22rem;
  height: 3rem;
  margin: 0 auto;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  font-feature-settings: "pkna";
  text-transform: uppercase;
  background-color: transparent;
}

_::-webkit-full-page-media, _:future, :root #container .btn_more a {
  font-family: var(--font-english-regular-safari);
}

/*=======================================
               Responsive
========================================*/


/* only PC */

@media screen and (min-width: 769px) {
  .sp_only {
    display: none;
  }
}

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

@media screen and (min-width: 769px) {

  #Wrap,
  .wrapBottom,
  .wrapTop,
  #Contents {
    width: 100%;
  }

}

/* only tablet */

@media screen and (min-width: 769px) and (max-width: 1200px) {
  html {
    font-size: calc(10* (100vw / 1200));
  }
}


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


/* only SP */

@media only screen and (max-width: 768px) {
  .pc_only {
    display: none;
  }

/* ===================
  LP Contents
=================== */

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

#container {
  padding-bottom: calc(0 * (100vw / 750));
}


/* ===================
  　　MV SECTION 
=================== */
#container .bg-slider_sp {
  position: relative;
}

#container .bg-slider_sp p {
  position: absolute;
  top: calc(100*(100vw / 750));
  left: calc(70*(100vw / 750));
  margin-top: 0;
  text-align: left;
  font-feature-settings: "palt";
  letter-spacing: 0.7rem;
  color: #000000;
}

.bg-slider_sp img {
  display: block;
  margin: 0;
}
/* ===================
    　　Anchor 
=================== */
#container .anchor_area {
  padding: calc(80 * (100vw / 750)) 0 calc(80 * (100vw / 750));
}

#container .anchor_area .anchor_link {
  width: calc(630 * (100vw / 750));
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: calc(30 * (100vw / 750));
  row-gap: calc(30 * (100vw / 750));
}

#container .anchor_area .anchor_link .link{
  width: calc(300*(100vw / 750));
  height: calc(174*(100vw / 750));
  padding-top: calc(34*(100vw / 750));
  justify-content: flex-start;
}


#container .anchor_area .anchor_link .anchor_en {
  margin-bottom: calc(20 * (100vw / 750));
  font-size: calc(32 * (100vw / 750));
}

#container .anchor_area .anchor_link .anchor_jp {
  font-size: calc(22 * (100vw / 750));
  letter-spacing: 0.06em;
}

#container .anchor_area .anchor_link .link:after {
  bottom: calc(30 * (100vw / 750));
  left: 0;
  width: calc(30 * (100vw / 750));
  height: calc(10 * (100vw / 750));
}

/* ===================
      SEC COMMON 
=================== */
#container .area {
  padding: calc(100 * (100vw / 750)) 0 calc(100 * (100vw / 750));
}

#container .ttl_group {
  margin-bottom: calc(60 * (100vw / 750));
  
}

#container .ttl_en {
  margin-bottom: calc(21 * (100vw / 750));
  font-size: calc(40 * (100vw / 750));
}


#container .ttl_jp {
  font-size: calc(22 * (100vw / 750));
}

#container .btn.btn_see_more a {
  width: calc(650 * (100vw / 750));
  height: calc(72 * (100vw / 750));
  font-size: calc(28 * (100vw / 750));
}


/* Common Swiper style */
/* Dot */
#container .swiper-pagination{
  position: absolute;
  right: 0;
  left: 0;
  bottom: calc(-102 * (100vw / 750));
}

#container .swiper-pagination-bullets.swiper-pagination-horizontal{
  bottom: calc(0 * (100vw / 750));
}

#container .swiper-pagination-bullet {
  margin: calc(12 * (100vw / 750));
  width: calc(12 * (100vw / 750));
  height: calc(12 * (100vw / 750));
}

#container .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 1rem);
}

/* Dot Active */
#container .swiper-pagination-bullet-active {
  width: calc(12 * (100vw / 750));
  height: calc(12 * (100vw / 750));
}

/* ===================
      PRODUCTS 
=================== */

#container .products_inner .itm_img {
  width: calc(400 * (100vw / 750));
}

#container .products_inner .itm_name {
  margin-top: calc(20 * (100vw / 750));
  font-size: calc(24 * (100vw / 750));
}

/* Product Swiper style */
#container .lp_swiper01 {
  height: calc(514 * (100vw / 750));
  margin-bottom: calc(140 * (100vw / 750));
}

#container .lp_swiper01 .swiper-slide {
	width: calc(400 * (100vw / 750));
	transition: transform .4s ;
}

#container .lp_swiper01 .swiper-slide .swipe_inner_group {
  width: calc(400 * (100vw / 750));
  margin:  calc(40 * (100vw / 750)) auto 0;
  max-height: calc(540 * (100vw / 750));
  transition: margin-top .5s, width .5s, max-height .5s, height .5s;
}

#container .lp_swiper01 .swiper-slide img {
  max-width: 100%;
  transition: width .5s;
}

#container .lp_swiper01 .swiper-slide-active .swipe_inner_group {
  width: calc(480 * (100vw / 750));
  max-height: none;
  margin-top: 0;
  z-index: 1;
}

#container .lp_swiper01 .swiper-slide-active .swipe_inner_group {
  height: auto;
}

#container .lp_swiper01 .swiper-slide-active .itm_img {
  width: calc(480 * (100vw / 750));
}

/* ===================
      CONTENTS 
=================== */
#container .contents_area {
  padding: calc(100*(100vw / 750)) 0 calc(80*(100vw / 750));
}

#container .contents_area .ttl_group {
  margin-bottom: calc(57 * (100vw / 750));
  
}
#container .contents_area .btn_detail a {
  width: calc(360 * (100vw / 750));
  height: calc(50 * (100vw / 750));
  margin: calc(36 * (100vw / 750)) auto 0;
  font-size: calc(24 * (100vw / 750));
}

/* Contents Swiper style */
#container .lp_swiper02 {
  height: calc(642 * (100vw / 750));
  margin-top: calc(0 * (100vw / 750));
}

#container .lp_swiper02 .swiper-pagination {
  bottom: calc(-4 * (100vw / 750));
}
/* Slide数が > 3の設定 */
#container .lp_swiper02 .swiper-slide {
	width: calc(400 * (100vw / 750));
	transition: transform .4s ;
}

#container .lp_swiper02 .swiper-slide .swipe_inner_group {
  width: calc(400 * (100vw / 750));
  margin: calc(40 * (100vw / 750)) auto 0;
  max-height: calc(540 * (100vw / 750));
  transition: margin-top .5s, width .5s, max-height .5s, height .5s;
}

#container .lp_swiper02 .swiper-slide img {
  max-width: 100%;
  transition: width .5s;
}

#container .lp_swiper02 .swiper-slide-active .swipe_inner_group {
  width: calc(480 * (100vw / 750));
  max-height: none;
  margin-top: 0;
  z-index: 1;
}

#container .lp_swiper02 .swiper-slide-active .swipe_inner_group {
  height: auto;
}

#container .lp_swiper02 .swiper-slide-active .itm_img {
  width: calc(480 * (100vw / 750));
}

/* Slide数が < 3の設定 */
#container .lp_swiper02.under_3_only {
  height: auto;
}
#container .lp_swiper02.under_3_only .swiper-slide {
	width: calc(300 * (100vw / 750));
  margin: 0 calc(25 * (100vw / 750));
	transition: transform .4s ;
}

#container .lp_swiper02.under_3_only .swiper-slide .swipe_inner_group {
  width: calc(300 * (100vw / 750));
  margin: calc(25 * (100vw / 750)) auto 0;
  max-height: calc(540 * (100vw / 750));
  transition: margin-top .5s, width .5s, max-height .5s, height .5s;
}

#container .lp_swiper02.under_3_only .btn_detail a {
  width: calc(300 * (100vw / 750));
}

/* ===================
      RANKING
=================== */
#container .ranking_area .ttl_group {
  margin-bottom: calc(106 * (100vw / 750));
}

#container .item_list__inner {
  width: calc(690*(100vw / 750));
  gap: calc(15*(100vw / 750));
  row-gap: calc(150*(100vw / 750));
  justify-content: space-around;
}

#container .item_rank1 {
  margin: calc(0 * (100vw / 750));
}

#container .item_rank2 {
  margin: calc(0 * (100vw / 750));
}

#container .item_list__item {
  width: calc(220 * (100vw / 750));
}

#container .item_rank1,
#container .item_rank2 {
  width: calc(300 * (100vw / 750));
}

#container .item_list__img {
  width: 100%;
  margin: 0 auto calc(30 * (100vw / 750));
}

#container .item_list__title {
  margin-bottom: calc(20 * (100vw / 750));
  font-size: calc(24 * (100vw / 750));
}

#container .item_list__price {
  font-size: calc(22 * (100vw / 750));
}


#container .item_list__price .txt_price_tax {
  font-size: calc(20 * (100vw / 750));
  margin-left: calc(-1 * (100vw / 750));
}

#container .icn_rank {
  width: calc(70*(100vw / 750));
  height: calc(70*(100vw / 750));
  padding-top: calc(20*(100vw / 750));
  font-size: calc(28 * (100vw / 750));
  top: calc(-45*(100vw / 750));
  left: calc(0*(100vw / 750));
}

#container .icn_rank_no {
  font-size: calc(20 * (100vw / 750));
}

/* ===================
      SUBSCRIPTION
=================== */

#container .subscription_detail_group {
  width: calc(650 * (100vw / 750));
  padding: calc(43 * (100vw / 750)) 0 calc(40 * (100vw / 750));
}

#container .subscription_detail_ttl {
  margin-bottom: calc(20 * (100vw / 750));
  font-size: calc(30 * (100vw / 750));
}

#container .subscription_detail_ttl:after {
  right: calc(-45*(100vw / 750));
  width: calc(20 * (100vw / 750));
  height: 1px;
}

#container .subscription_detail_ttl:before {
  left: calc(-45*(100vw / 750));
  width: calc(20*(100vw / 750));
  height: 1px;
}

#container .subscription_detail {
  font-size: calc(24 * (100vw / 750));
}

#container .subscription_list {
  width: calc(685*(100vw / 750));
  margin: calc(61*(100vw / 750)) auto calc(60*(100vw / 750));
  gap: calc(25*(100vw / 750));
  row-gap: calc(40*(100vw / 750));
  justify-content: flex-start;
}

#container .subscription_list .itm_img {
  width: calc(330 * (100vw / 750))
}

#container .subscription_list .itm_name {
  margin-top: calc(16 * (100vw / 750));
  font-size: calc(24 * (100vw / 750));
}

#container .subscription_list .itm_price_before {
  margin: calc(15*(100vw / 750)) auto calc(8*(100vw / 750));
  font-size: calc(22 * (100vw / 750));
}

#container .subscription_list .itm_price_before:before {
  height: 1px;
}

#container .subscription_list .itm_normal_price {
  font-size: calc(22 * (100vw / 750));
  margin-left: calc(4*(100vw / 750));
}

#container .subscription_list .tax {
  font-size: calc(20 * (100vw / 750));
}


#container .subscription_list .itm_price_group {
  margin-bottom: calc(10 * (100vw / 750));
}

#container .subscription_list .itm_price_label {
  margin-right: calc(15 * (100vw / 750));
  width: calc(120 * (100vw / 750));
  height: calc(34 * (100vw / 750));
  padding: calc(7 * (100vw / 750)) 0;
  font-size: calc(22 * (100vw / 750));
}

#container .subscription_list .itm_price {
  font-size: calc(22 * (100vw / 750));
  margin-top: calc(4*(100vw / 750));
}

#container .subscription_list .itm_price .tax {
  font-size:calc(20 * (100vw / 750));
}

#container .subscription_area .btn_detail a {
  width: calc(300 * (100vw / 750));
  height: calc(45 * (100vw / 750));
  margin: calc(25 * (100vw / 750)) auto 0;
  font-size: calc(22 * (100vw / 750));
}

/* ===================
      CONCEPT
=================== */
#container .conceptArea {
  margin-top: 0;
}

#container .background2 {
  position: absolute;
  top: calc(240*(100vw / 750));
  left: 50%;
  transform: translateY(0) translateX(-50%);
  background-image: url(../../Contents/ImagesPkg/obyf/top/obi_02_sp.jpg);
  background-repeat: no-repeat;
  background-position: 50% 0%;
  background-size: 140%;
  width: 100%;
  height: calc(280*(100vw / 750));
}

#container .conceptArea .leftArea {
  position: absolute;
  left: 0;
  right: 0;
}

#container .conceptArea .leftArea .maintext {
  font-size: calc(22 * (100vw / 750));
  line-height: 2.3;
  margin: calc(306 * (100vw / 750)) 0 0;
  color: #000000;
}

#container .conceptArea .btn_more {
  margin-top: calc(115 * (100vw / 750));
}

/* ===================
      NEWS
=================== */
#container .news_area .ttl_group {
  margin-bottom: calc(90 * (100vw / 750));;
}

#container .news_area {
  margin-top: calc(170*(100vw / 750));
}

#container .newsArea_contents {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  margin: 0 auto calc(20*(100vw / 750));
  padding: 0;
}

.newsArea_contents .newsinner_contents {
  margin-left: 0;
}

#container .newsArea_contents .newscontents {
  align-items: flex-start;
}

.newsArea_contents .newsinner_contents .infobox .newscontents {
  margin-top: calc(30*(100vw / 750));
}


#container .newsArea_contents .infobox {
  width: calc(650 * (100vw / 750));
  margin: 0 auto;
}

#container .newsArea_contents .date {
  margin-top: 0;
  margin-right: calc(0 * (100vw / 750));
  font-size: calc(24 * (100vw / 750));

}

#container .newsArea_contents .tag_cate {
  top: calc(-40*(100vw / 750));
  left: calc(170*(100vw / 750));
  font-size: calc(22 * (100vw / 750));
  min-width: calc(120*(100vw / 750));
  height: calc(30 * (100vw / 750));
  line-height: 1.3;
  margin-right: 0;
}

#container .newscontents .newsdetail {
  padding-left: 0;
  font-size: calc(24 * (100vw / 750));
  line-height: 2;
}

#container .btn_more a{
  width:calc(360 * (100vw / 750));
  height: calc(50 * (100vw / 750));
  margin: 0 auto;
  font-size: calc(24 * (100vw / 750));
}



}