@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');


/*-----------------------------------------
-------------------------------------------
-------------------------------------------
目次　※各々レスポンシブ対応あり
00 リセットCSS
01 共通部分の設定
02 ヘッダーの設定
03 用途から選ぶの設定
04 メイン1の設定　炭酸ジェルパック
05 メイン2の設定　アイマスク
06 メイン3の設定　首もとシート
07 チラシはこちらボタンの設定
08 こちらもチェック！の設定　オフィスめぐりズム
09 他の商品をチェックの設定
-------------------------------------------
-------------------------------------------
-----------------------------------------*/


/*-------------------------------------------
00 リセットCSS
-------------------------------------------*/

body {
    margin: 0;
}

body,
.body * {
    margin: 0;
    padding: 0;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    text-shadow: none;
    box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    font-size:14px; 
}

.body ul,
.body li {
    list-style: none;
}

.body a{
    text-decoration: none;
    color: inherit;
}

/*-------------------------------------------
01 共通部分の設定
-------------------------------------------*/
.body{
    color: #1D1D1F;
    line-height: 1;
    background-color: #fff;
}

.body img {
    max-width: 100%;
    vertical-align: bottom;
}

.center {
    margin: auto;
    text-align: center;
 }

.wrap01 {
    max-width: 1200px;
    width: calc(100% - 30px);
    margin: auto;
    padding: 40px 0;
}

.wrap02 {
    max-width: 1100px;
    width: calc(100% - 30px);
    margin: auto;
    padding: 80px 0;
}

.wrap03 {
    max-width: 1100px;
    width: 100%;
    margin: auto;
    padding-bottom: 80px;
}

@media screen and (max-width: 768px) {
.wrap01 {
    max-width: 100%;
    padding: 50px 0 80px 0;
}

.wrap02 {
    max-width: 100%;
    padding: 50px 0;
}

.wrap03 {
    max-width: 100%;
    width: calc(100% - 50px);
}

}

.flex {
    display:flex;
}

.body a {
    cursor: pointer;
    transition: 0.3s;        
}

.sp {
    display: none;
}

@media screen and (max-width:768px) {
.flex {
    flex-direction: column;
    /* justify-content: center; */
}

.center {
    max-width: 500px;
}

.pc {
    display: none;
}

.sp {
    display: block;
}

}

:root {
    --black01:#1D1D1F;
    --gray01:#4D4D4D;
    --blue01: #0058A0;
    --purple01: #74206D;
    --red01: #D80049;
    --red02: #D73750;
    --gradation01: linear-gradient(120deg, rgba(253, 157, 135, 1), rgba(246, 155, 199, 1) 50%, rgba(145, 167, 255, 1));
    --gradation02: linear-gradient(120deg, rgba(255, 255, 255, 1), rgba(255, 138, 142, 1));
    --gradation03: linear-gradient(120deg, rgba(255, 255, 205, 1), rgba(255, 139, 1, 1));
}

div.product_item{
    padding-bottom: 20px;
    /* grid-column: span 2 / span 2; */
    /* display: grid; */
    /* grid-template-columns: repeat(4,1fr); */
    /* grid-template-columns: 300px; */
    /* gap: 20px; */
    margin-bottom: 40px;
    width: 300px;
}

@media screen and (max-width:768px) {
div.product_item{
    padding-bottom: 20px;
    grid-template-columns: repeat(2,1fr);
    gap: 10px;    
    order: 2;    
}
}



/*下からフェードイン*/
.fadeIn-down{
    opacity: 0;
  }
  .fadeIn-down.is-active {
    animation: fadeIn-down 1s cubic-bezier(0.25, 0.1, 0.25, 1) forwards;
  }
  @keyframes fadeIn-down {
    0% {
      opacity: 0;
      transform: translateY(50px);
    }
    100% {
      opacity: 1;
      transform: translateY(0px);
    }
}

/*-------------------------------------------
02 ヘッダーの設定
-------------------------------------------*/
#headerGrp {
    background: url(https://d11w49g8ylcixs.cloudfront.net/resource/20250808/bg_top.png) no-repeat;
    background-size: cover;
    
}

#headerGrp .grid {
    display: grid;
    grid-template-columns: 400px 800px;
    grid-template-rows: 200px 400px;
}

#headerGrp h2 {
    display: block;
    z-index: 10;
    margin-top: 60px;
}

#headerGrp h2.sp {
    display: none;
}

#headerGrp .illust {
    width: 500px;
}

#headerGrp .image {
    margin: 80px auto 0 130px;
}

@media screen and (max-width:768px) {

#headerGrp .grid {
    grid-template-columns: 1fr;
    grid-template-rows: 1fr;
}

.logo {
    margin: 0 auto;
    z-index: 10;
}

#headerGrp h2.pc {
    display: none;
}

#headerGrp h2.sp {
    display: block;
    order: 3;
    margin-top: 0px;
}

#headerGrp .illust {
    order: 2;
    margin-top: -40px;
    margin-left: 14px;
    width: 100%;
    background-size: cover;
}

#headerGrp .image {
    order: 4;
    width: 100%;
    margin: 40px auto 0 auto;
}

}



/*-------------------------------------------
03 用途から選ぶの設定
-------------------------------------------*/

.menuGrp {
    margin: 80px 0;
}

.menuGrp>h2 {
    padding-bottom:50px;
    margin: 0 auto;
    /* width: 60%; */
    text-align: center;
}

.menuGrp .flex {
    justify-content: center;
}

.menuGrp .box {
    margin-right: 50px;
}

.menuGrp .box:last-of-type {
    margin-right: 0;
}

.button-copy {
    font-size: 14px;
    font-weight: bold;
    text-align: center;
    margin-bottom: 10px;
}

.menu01_box .button-copy {
    color: var(--blue01);
}

.menu02_box .button-copy {
    color: var(--purple01);
}

.menu03_box .button-copy {
    color: var(--red01);
}

.link-btn {
    width: 300px;
    box-shadow: 0px 0px 15px -5px #777777;
    text-align: center;
    border-radius: 8px;
    display: block;
}

.link-btn.menu01 {
    background-color: var(--blue01);
}

.link-btn.menu02 {
    background-color: var(--purple01);    
}

.link-btn.menu03 {
    background-color: var(--red01);    
}

.link-btn p {
    margin: 0 auto;
    color: #ffffff;
    font-size: 20px;
    font-weight: bold;
    padding: 20px;
}

.link-btn p small {
    color: #fff;
}

div.menu_Button.fixed_menu_Button {
  position: fixed;
  top: 0px;
  z-index: 999;
  background: #fff;
  width: 100%;
  padding: 10px 0;
  filter: drop-shadow(0 0 5px rgba(0, 0, 0, 0.2));
      transition: 0.3s;        

}

div.menu_Button.fixed_menu_Button a.link-btn p {
  padding: 10px;
}

@media screen and (max-width: 768px) {
.menuGrp {
    margin: 50px 0;
}

.menuGrp>h2 {
    width: 60%;
}

.menuGrp .flex {
    align-items: center;
}

.menuGrp .box {
    margin-right: 0;
    margin-bottom: 50px;
}

.menuGrp .box:last-child {
    margin-bottom: 0;
}

.link-btn p {
    padding: 10px;
}
}

/*ハンバーガーメニュー-----------------------------*/
#g-nav {
  /*position:fixed;にし、z-indexの数値を大きくして前面へ*/
  position: fixed;
  z-index: 999;
  /*ナビのスタート位置と形状*/
  top: 0;
  right: -120%;
  width: 25%;
  height: 100vh;
  /*ナビの高さ*/
  background: #fff;
  /*動き*/
  transition: all 0.6s;
}

/*アクティブクラスがついたら位置を0に*/
#g-nav.panelactive {
  right: 0;
}

/*ナビゲーションの縦スクロール*/
#g-nav.panelactive #g-nav-list {
  /*ナビの数が増えた場合縦スクロール*/
  position: fixed;
  z-index: 999;
  width: 25%;
  height: 100vh;
  /*表示する高さ*/
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

/*ナビゲーション*/
#g-nav ul {
  display: grid;
  grid-template-columns: 1fr;
  /*ナビゲーション天地中央揃え*/
  position: absolute;
  z-index: 999;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  max-width: 400px;
  max-width: fit-content;
  padding-left: 0;
}

/*リストのレイアウト設定*/
#g-nav li {
  list-style: none;
  text-align: center;
  padding: 0 0 10px;
}

#g-nav li a {
  color: var(--blue03);
  text-decoration: none;
  padding: 0.65em 1.25em;
  display: block;
  text-transform: uppercase;
  text-align: center;
  letter-spacing: 0.1em;
  font-weight: bold;
  font-size: 24px;
  letter-spacing: 0.1em;
  white-space: nowrap;
  vertical-align: baseline;
}
#g-nav li.menu_offerBtn,
#g-nav li.menu_LW-Btn,
#g-nav li.menu_LWR-Btn{
  padding-top: 10px;
}
#g-nav li.menu_offerBtn a{
background: var(--blue03);
color: #fff!important;
border-radius: 100px;
}

#g-nav li.menu_LW-Btn a{
background: var(--green01);
color: #fff!important;
border-radius: 100px;
}

#g-nav li a i{
  vertical-align: baseline;
  color: #fff!important;
  margin-right: 7px;
}
#g-nav li a:hover{
  opacity: 0.75;
}

/*========= ボタンのためのCSS ===============*/
.openbtn {
  position: fixed;
  z-index: 9999;
  /*ボタンを最前面に*/
  bottom: 90px;
  right: -4px;
  cursor: pointer;
  width: 70px;
  height: 70px;
  background: var(--blue01)!important;
  border: 3px solid #fff;
  border-radius: 3px 0 0 3px;
}

/*×に変化*/
.openbtn span {
  display: inline-block;
  transition: all .4s;
  position: absolute;
  left: 17px;
  height: 3px;
  border-radius: 2px;
  background-color: #fff;
  width: 45%;
}

.openbtn span:nth-of-type(1) {
  top: 17px;
}

.openbtn span:nth-of-type(2) {
  top: 30px;
}

.openbtn span:nth-of-type(3) {
  top: 43px;
}

.openbtn.active span:nth-of-type(1) {
  top: 26px;
  left: 22px;
  transform: translateY(6px) rotate(-45deg);
  width: 40%;
}

.openbtn.active span:nth-of-type(2) {
  opacity: 0;
}

.openbtn.active span:nth-of-type(3) {
  top: 38px;
  left: 22px;
  transform: translateY(-6px) rotate(45deg);
  width: 40%;
}

@media (max-width: 768px) {
  #g-nav li a{
    font-size: 20px;
  }
  .openbtn {
    width: 60px;
    height: 55px;
    bottom: 80px;
  }

  .openbtn span {
    left: 15px;
  }

  .openbtn span:nth-of-type(1) {
    top: 15px;
  }

  .openbtn span:nth-of-type(2) {
    top: 25px;
  }

  .openbtn span:nth-of-type(3) {
    top: 35px;
  }

  .openbtn.active span:nth-of-type(1) {
    top: 18px;
    left: 17px;
  }

  .openbtn.active span:nth-of-type(3) {
    top: 30px;
    left: 17px;
  }

  #g-nav {
    width: 100%;
  }

    #g-nav h2 {
    width: 60%;
    margin: 50px auto;
    }

    #g-nav .box {
    margin-bottom: 20px;
    }

    #g-nav .link-btn p {
    padding: 0;
    }  

  /*ナビゲーションの縦スクロール*/
  #g-nav.panelactive #g-nav-list {
    /*ナビの数が増えた場合縦スクロール*/
    width: 100%;
  }

}

/*ハンバーガーメニューここまで---------------*/

/*-------------------------------------------
04 メイン1の設定　炭酸ジェルパック
-------------------------------------------*/
#main01Grp {
    background: url(https://d11w49g8ylcixs.cloudfront.net/resource/20250808/bg_main01Grp.jpg) no-repeat;
    background-size: cover;
    position: relative;
    z-index: 5;
    padding-bottom: 100px;
}

#main01Grp::after {
    background: url(https://d11w49g8ylcixs.cloudfront.net/resource/20250808/bg_main01Grp_end.png) no-repeat;
    content: "";
    display: block;
    width: 100%;
    height: 155px;
    position: absolute;
    bottom: -89px;
}

#main01Grp>h2 {
    padding: 80px 10px 50px 10px;
    margin: 0 auto;
    text-align: center;
}

.intro{
    align-items: center;
    background-color:rgba(255,255,255,0.7);
    margin-bottom: 80px;
    height: 150px;
    position: relative;
}

.intro_contents {
    width: 100%;
    position: absolute;
    align-items: center;
    top: 20%;
    left: 50%;
    transform: translate(-25%, -25%);
}

.intro p {
    text-align: left;
    font-size: 18px;
    font-weight: bold;
    line-height: 1.5;
    color: var(--gray01);
    margin-left: 50px;
}

#main01Grp .intro_contents {
    top: 10%;
    transform: translate(-25%, -25%);
}

#main01Grp .image {
    width: 350px;
}

#main01Grp .fukidashi {
    margin-bottom: 30px;
}

#main01Grp .point {
    justify-content: space-between;
}

.point_note {
    text-align: right;
    color: var(--blue01);
    font-size: 14px;
    font-weight: bold;
    margin-top: 20px;
    line-height: 1.2;
}

.gelpack_intro {
    width: 1000px;
    background-color: #ffffff;
    padding: 50px;
    position: relative;
    filter: drop-shadow(2px 2px 5px rgba(0, 0, 0, 0.15));
}

.gelpack_intro::before {
    content: "";
    display: block;
    width: 80px;
    height: 80px;
    background: var(--blue01);
    clip-path: polygon(0 0, 100% 0, 0 100%);
    position: absolute;
    top: 0;
    left: 0;    
}

.gelpack_intro .flex {
    justify-content: center;
    align-items: center;
}

.gelpack_intro .image01 {
    margin-right: 60px;
}

.osusume {
    border-radius: 10px;
    position: relative;    
    margin-right: 30px;
}

.osusume::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 100%;
    margin-top: -10px;
    border: 10px solid transparent;
}

#main01Grp .osusume {
    background-color: var(--blue01);    
}

#main01Grp .osusume::before {
    border-left: 20px solid var(--blue01);
}

.osusume p {
    color: #ffffff;
    font-size: 18px;
    font-weight: bold;
    line-height: 1.2;
    padding: 20px;
    text-align: center;
}

.image-box {
    margin-bottom: 30px;
}

@media screen and (max-width: 768px) {
#main01Grp {
    padding-bottom: 20px;
}

#main01Grp>h2 {
    padding: 50px 10px 60px 10px;
}

.intro {
    margin-bottom: 80px;
    height: 370px;    
}

.intro p {
    text-align: center;
    font-size: 15px;
    margin-left: 0px;
    margin-top: 30px;
}

#main01Grp .intro_contents {
    width: 100%;
    position: relative;
    align-items: center;
    left: auto;
    transform: none;
    padding: 0 10px;    
}

#main01Grp .fukidashi {
    width: 90%;
    margin: 0 auto 30px auto;
}

#main01Grp .point {
    margin-bottom: 30px;
}

#main01Grp .point:last-child {
    margin-bottom: 0px;
}

#main01Grp .point img {
    width: 100%;
}

.gelpack_intro {
    width: 100%;
    padding: 50px 30px 30px 30px;
}

.gelpack_intro::before {
    width: 60px;
    height: 60px;
}

.gelpack_intro .image01 {
    margin-right: 0;
    width: 80%;
    margin-bottom: 30px;
}  

.osusume {
    border-radius: 5px;
    margin-right: 0;
    margin-bottom: 20px;
    width: 100%;
}

#main01Grp .osusume::before {
  content: "";
  position: absolute;
  top: 105%;
  left: 50%;
  margin-left: -10px;
  border: 10px solid transparent;
}

#main01Grp .osusume::before {
    border-top: 20px solid var(--blue01);
}

.osusume p {
    padding: 10px;
}

#main01Grp .image.flex {
    flex-direction: row;
    justify-content: center;
}

#main01Grp .image {
    margin-left: 0;
    width: 85%;
}
    
}

/*-------------------------------------------
05 メイン2の設定　アイマスク
-------------------------------------------*/
#main02Grp {
    background: url(https://d11w49g8ylcixs.cloudfront.net/resource/20250808/bg_main02Grp.jpg) no-repeat;
    background-size: cover;
    position: relative;
    padding-bottom: 20px;
}

#main02Grp::after {
    background: url(https://d11w49g8ylcixs.cloudfront.net/resource/20250808/bg_main02Grp_end_new.png) no-repeat;
    content: "";
    display: block;
    width: 100%;
    height: 153px;
    position: absolute;
    bottom: -85px;

}

#main02Grp>h2 {
    padding: 150px 10px 50px 10px;
    margin: 0 auto;
    text-align: center;
}

#main02Grp .intro {
    position: relative;
}

#main02Grp .image {
    width: 500px;
}

.osusume-scene.flex {
    align-items: center;
    justify-content: center;
}

#main02Grp .osusume {
    background-color: var(--purple01);    
}

#main02Grp .osusume::before {
  border-left: 20px solid var(--purple01);
}

.eyemask {
    width: 550px;
}

#main02Grp div.product_item{
    padding-bottom: 20px;
    display: grid;
    grid-template-columns: 300px 300px 300px;
    gap: 20px;
    margin-bottom: 40px;
    width: 940px;
}

@media screen and (max-width:768px) {
#main02Grp {
    padding-bottom: 20px;
}

#main02Grp::after {
    bottom: -50px;
}


#main02Grp>h2 {
    padding: 150px 10px 60px 10px;
}

#main02Grp .intro {
    height: 340px;
}

#main02Grp .intro_contents {
    width: 100%;
    position: relative;
    align-items: center;
    left: auto;
    transform: none;    
    padding: 0 25px;
} 

#main02Grp .image {
    width: 100%;
}

#main02Grp div.product_item{
    grid-template-columns: repeat(2,1fr);
    gap: 10px;
    margin-bottom: 0;
    width: 100%;
}

}

/*-------------------------------------------
06 メイン3の設定　首もとシート
-------------------------------------------*/
#main03Grp {
    background: url(https://d11w49g8ylcixs.cloudfront.net/resource/20250808/bg_main03Grp_new.jpg) no-repeat;
    background-size: cover;
    padding-bottom: 40px;
}

#main03Grp>h2 {
    padding: 150px 10px 50px 10px;
    margin: 0 auto;
    text-align: center;
}

#main03Grp .intro {
    position: relative;
}

#main03Grp .intro_contents {
    top: 10%;
    transform: translate(-25%, -25%);
}

#main03Grp .intro_contents span {
    font-size: 14px;
    line-height: 1.4;
}


#main03Grp .image {
    width: 350px;
}

#main03Grp .osusume {
    background-color: var(--red02);    
}

#main03Grp .osusume::before {
  border-left: 20px solid var(--red02);
}

@media screen and (max-width:768px) {
#main03Grp {
    padding-bottom: 20px;
    background-position: right;
}

#main03Grp>h2 {
    padding: 120px 10px 60px 10px;
}

#main03Grp .intro {
    height: 460px;
}
    
#main03Grp .intro_contents {
    top: 8%;
    left: auto;
    transform: none;    
} 

#main03Grp .intro_contents span {
    font-size: 14px;
    display: inline-block;
    margin-top: 5px;
}

#main03Grp .image {
    width: 80%;
    margin-left: 0;
}

#main03Grp .osusume::before {
  content: "";
  position: absolute;
  top: 105%;
  left: 50%;
  margin-left: -10px;
  border: 10px solid transparent;
}

#main03Grp .osusume::before {
    border-top: 20px solid var(--red01);
}
}

/*-------------------------------------------
07 チラシはこちらボタンの設定
-------------------------------------------*/
.flyer-btn a {
    display: block;
    width: 300px;
    background-color: var(--blue01);
    margin: 0 auto;
    padding: 20px;
    border-radius: 40px;
    color: #ffffff;
    font-weight: 600;
    font-size: 20px;
    text-align: center;
}

.flyer-btn:hover {
    opacity: 0.8;
}


/*-------------------------------------------
08 こちらもチェック！の設定　オフィスめぐりズム
-------------------------------------------*/
#officeMegrythmGrp {
    background: var(--gradation03);
}

#officeMegrythmGrp h2 {
    padding: 0 10px 50px 10px;
    margin: 0 auto;
    text-align: center;
}

#officeMegrythmGrp p {
    font-size: 20px;
    font-weight: bold;
    color: #603813;
    margin-bottom: 10px;
}

#officeMegrythmGrp .banner {
    box-shadow: 0px 0px 15px -5px #777777;
    display: inline-block;
    margin-bottom: 40px;
}

#officeMegrythmGrp .banner:hover {
    opacity: 0.8;
}

@media screen and (max-width:768px) {
#officeMegrythmGrp p {
    font-size: 16px;
}
}

/*-------------------------------------------
09 他の商品をチェックの設定
-------------------------------------------*/
/* 
#othersGrp {
    margin: 80px 0;
} */

#othersGrp h2 {
    font-size: 40px;
    font-weight: 800;
    color: var(--blue01);
    line-height: 1.3;
    padding-bottom: 50px;
    margin: 0 auto;
    text-align: center;
}

.banner-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: 20px;
    width: calc(100% - 30px);
}

@media screen and (max-width:768px) {
#othersGrp h2 {
    width: 80%;
}

.banner-grid {
    grid-template-columns: 1fr;
    gap: 20px;
    margin: 0 auto;
}
}

/*TOPに戻る*/
section.footGrp{
  padding: 0 20px;
}
div.backBtn {
    width: 100%;
    max-width: 500px;
    margin: auto;
    padding-bottom:100px;
}
div.backBtn a {
    display: block;
    width: 100%;
    padding: 20px 20px 20px 40px;
    font-size: 16px;
    text-align: center;
    color: #353535;
    background: #ebebeb;
    border: 1px solid #8f8f8f;
    border-radius: 5px;
    position: relative;
    line-height: 1.2;
}
div.backBtn a::after {
    content: "";
    display: block;
    width: 10px;
    height: 10px;
    border-bottom: 1px solid #353535;
    border-left: 1px solid #353535;
    position: absolute;
    top: 50%;
    left: 30px;
    transform: translate(0, -50%) rotate(45deg);
}

@media screen and (max-width:500px) {
  div.backBtn a{
    font-size: 4vw;
  }
}


/* スマ介_____EC-CUBE対策 */

main.l-container {
  width: 100%;
}

.c-main {
  padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
}

#contentInner {
  width: auto;
  padding-bottom: 0;
}

#wide_main_contents {
  width: 100%;
}

.c-breadcrumb {
  width: 1200px;
  margin: auto;
}

h2 {
    background: none;
}

@media (max-width: 1230px) {
  main.l-container {
    width: 123rem;
  }
}

@media (max-width: 768px) {
  .pc {
    display: none !important;
  }

  .sp {
    display: block;
  }

  .l-container {
    width: 120rem;
  }

  #contentInner {
    width: 1200px;
    padding-bottom: 0;
  }

  #wide_main_contents {
    width: 1200px
  }
}

