/* =========================
   Base / Common
========================= */

body{
  
}
ol, ul {
    padding-left: 1rem;
}
.pc {
  display: block;
}

.sp {
  display: none;
}

@media (max-width: 767px) {
  .pc {
    display: none;
  }

  .sp {
    display: block;
  }
}

/*キャンペーンバナー*/
.campaign{
  width: 100vw;
  height: 100vh;
  position: absolute;
  z-index: 10000;
}
.campaign .overray{
  width: 100%;
  height: 100%;
  background-color: rgb(255 255 255 / 0.7);
}
.campaign .modal_campaign{
  width: 400px;
  margin: 0 auto;
  position: absolute;
  top:30%;
  left:50%;
  transform: translate(-50%, -30%);
  
}
@media (max-width: 767px) {
  .campaign .modal_campaign{
    width: 80%;
  }
}


.campaign .modal_campaign a.camp_image{
  display: block;
}
.campaign .modal_campaign img{
  width: 100%;
  height: auto;
  border-radius: 8px;
}
.campaign .modal_campaign a.camp_image{
  display: block;
  box-shadow: 4px 4px 8px gray;
  border-radius: 8px;
}
.campaign .modal_campaign a.button_close{
  width: 30px;
  height: auto;
  position: absolute;
  top:-12px;
  right: -12px;
}
.campaign .modal_campaign a.button_close:hover{
  opacity: 0.7;
}


.campaign .modal_campaign a.button_close img{
  width: 100%;
  height: auto;
}




.background-gradient{
  background: linear-gradient(
    135deg,
    #f6d6df 0%,
    #e8eaf6 35%,
    #dff0f5 65%,
    #f8f2e6 100%
  );
}

.ec-productRole .ec-productRole__tags {
  display: block;
}

/* タグ全体の並び */
.ec-productRole__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 10px 0 15px;
    padding: 0;
    list-style: none;
}

/* バッジ本体 */
.ec-productRole__tag {
    display: inline-block;
    padding: 0.6em 1em !important;
    list-style: none;
    font-size: 70% !important;
    color: #ffffff !important;
    border: solid 1px #D7DADD;
    border-radius: 20px !important;
    background-color: #101010 !important;
}

.tag_4{
    background-color: #83cf62 !important;
}
.tag_5{
    background-color: #a262cf !important;
}


.ec-headerTitle img {
  width: 100%;
}

.english {
  font: normal 90%/1.6 sans-serif;
  color: #7f7f7f;
  margin: 0 0 2em;
}

.ec-headerTitle .ec-headerTitle__title a {
  margin-bottom: 0;
}

.recomend_imageWarp {
  width: 100%;
  height: auto;
  background: #f8f8f8;
  padding: 10%;
  margin: 0 0 15px;
}

.ec-searchnavRole .ec-searchnavRole__counter {
        margin-bottom: 0;
        width: 100%;
        
}
    .ec-searchnavRole .ec-searchnavRole__infos {
        
        padding-top: 30px;
        
        width: 100%;
    }


/* Buttons */
.ec-blockBtn--action,
.ec-productRole__btn,
.ec-blockBtn--cancel {
  margin: 0 auto;
  border: 1px solid #e8e8e8;
  border-radius: 55px;
  background: #fff;
  color: #000;
  width: 100%;
}

.ec-cartNaviIsset .ec-cartNaviIsset__action .ec-blockBtn--action {
  color: #000;
}

.ec-blockBtn--action:hover,
.ec-productRole__btn:hover,
.ec-blockBtn--cancel:hover {
  background: #000 !important;
  color: #fff;
}

.ec-cartNaviIsset .ec-cartNaviIsset__action .ec-blockBtn--action:hover {
  background: #000 !important;
  color: #fff;
}


.ec-blockBtn--action:disabled, .ec-blockBtn--action.disabled {
    color: #fff;
    background-color: #000000;
    border-color: #000000;
    color: #fff !important;
}


a.list {
    margin: 40px auto 40px auto;
    display: block;
    text-align: center;
    color: #fff;
    background-color: #000;
    padding: 1em 3em;
    width: fit-content;
    border-radius: 50px;
    border: solid 1px #000;
}


.ec-guest .ec-guest__actions,
.ec-guest .ec-guest__actions a,
.ec-totalBox .ec-totalBox__btn a{
    color: #000000 !important;
}
.ec-guest .ec-guest__actions,
.ec-guest .ec-guest__actions a:hover,
.ec-totalBox .ec-totalBox__btn a:hover{
    color: #fff !important;
}

/* =========================
   Layout
========================= */
.ec-layoutRole__header {
  position: fixed;
  z-index: 100;
  width: 98%;
  max-width: 1130px;
  left: 50%;
  transform: translateX(-50%);
  margin: 0 auto;
}

.ec-layoutRole .ec-layoutRole__contents {
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
  display: flex;
  flex-wrap: nowrap;
  flex-grow: 1;
  position: relative;
  padding-top: 70px;
  
  background: linear-gradient(
    135deg,
    #f6d6df 0%,
    #e8eaf6 35%,
    #dff0f5 65%,
    #f8f2e6 100%
  );
  
}





.ec-layoutRole__contentBottom {
  width: 100%;
  max-width: 1150px;
  margin: 40px auto 0;
  display: flex;
  flex-wrap: nowrap;
  flex-grow: 1;
  padding: 30px 0;
  border-top: 1px solid #ddd !important;
  border-bottom: 1px solid #ddd !important;
}

.ec-layoutRole__footer {
  position: relative;
  background-color: #000;
}



.ec-role {
    max-width: 100%;
}



.ec-role .inner,
.ec-pageHeader,
.ec-off1Grid {
  width: 100%;
  max-width: 1130px;
  margin: 0 auto;
}

@media (max-width: 767px) {
    .ec-role .inner,
.ec-pageHeader,
.ec-off1Grid {
  width: 95%;
  max-width: 1130px;
  margin: 0 auto;
}
.ec-role {
    margin: 0 auto;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box;
    font-size: 16px;
    line-height: 1.4;
    color: #525263;
    -webkit-text-size-adjust: 100%;
    width: 100%;
    max-width: 1130px;
    
      
}
}






.ec-off1Grid .ec-off1Grid__cell {
  width: 100%;
  margin: 0;
}

.ec-pageHeader h1,
.ec-pageHeader .h1 {
  margin: 40px 16px 20px;
  padding: 8px 8px 1em;
  font-size: 30px;
  font-weight: bold;
  text-align: center;
  border: none;
}

@media (max-width: 767px) {
    .ec-pageHeader h1,
.ec-pageHeader .h1 {
    font-size: 20px;
}
}






/* =========================
   Header Navi
========================= */
.ec-headerNaviRole {
  position: absolute;
  width: 100%;
  max-width: 1130px;
  margin: 0 auto;
  padding: 15px 20px 0;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  font-size: 16px;
  line-height: 1.4;
  color: #525263;
  -webkit-text-size-adjust: 100%;
}

.ec-headerNaviRole .ec-headerNaviRole__right {
  position: absolute;
  top: 15px;
  right: 0;
  width: 100%;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

.ec-headerRole,
.ec-headerRole .ec-headerRole__title {
  width: 170px;
  float: left;
  max-width: 200px;
  margin: 0 auto;
  display: block;
  padding: 3px 0 0 0;
}

@media (max-width: 767px) {
  .ec-headerRole,
  .ec-headerRole .ec-headerRole__title {
    float: none;
  }
  .ec-topicpath {
      font-size: 16px;
  }
}






/* =========================
   Main Visual
========================= */
.main_visual_original {
  width: 100%;
  height: 100vh;
  margin-top: -70px;
  position: relative;
  overflow: hidden;
  background-image: url("/html/user_data/assets/img/common/main_v_bg.png");
}

.main_visual_original .model {
  height: 100%;
  width: auto;
  margin: 0 auto;
  position: relative;
  z-index: 0;
}

@media (max-width: 767px) {
  .main_visual_original .model {
    left: 50%;
    transform: translateX(-50%) !important;
    top: 40px;
  }
}

.mv-art-layer {
  z-index: 1;
}

.main_visual_original .inner {
  width: 100%;
  max-width: 1130px;
  height: 90vh;
  margin: 0 auto;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}

.cach01 {
  width: 500px;
  position: absolute;
  right: 3%;
  top: 30vh;
  z-index: 10;
}

.cach02 {
  width: 200px;
  position: absolute;
  left: 1%;
  bottom: 0;
  z-index: 10;
}



.ec-layoutRole__main {
  margin-top: 70px;
}

.ec-layoutRole__mainBottom {
}

/* =========================
   noise
========================= */
#bg-noise {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1; /* 背景の上・コンテンツの下 */
  opacity: 0.1; /* ← ここ重要。かなり薄め */
}

/* =========================
   Category / Color Helpers
========================= */
.ec-categoryRole {
  padding: 40px 0;
  color: #000;
  background-image: url("/html/user_data/assets/img/common/bg_banner.png");
  background-size: cover;
  background-attachment: fixed;
  background-color: #ff9d30;
}

.ec-categoryRole .ec-categoryRole__listItem {
  margin-bottom: 0;
}

h2.white {
  color: #fff !important;
}

.bgColo_white {
  background: #fff;
  background: linear-gradient(
    135deg,
    #f6d6df 0%,
    #e8eaf6 35%,
    #dff0f5 65%,
    #f8f2e6 100%
  );
  
  
}
.ec-login,
.ec-guest,
.ec-newsRole__news{
    background: #Fff;
}

@media (max-width: 767px) {
  .ec-newsRole__news{
      background: none;
  }
}


.bgColo_purple {
  background: #a22f9d;
}

.item_box_bggray {
  background: #f7f6f2;
  background: #fff;
}

.item_box_white {
  background: #fff;
}

.ec-categoryRole__listItem a img {
    width: 100%;
    border-radius: 8px;
}


/* =========================
   New Items
========================= */
.ec-newItemRole {
  padding: 15vh 0;
}

.ec-newItemRole h2 {
  width: 100%;
  margin: 0 auto 60px;
  color: #000;
  text-align: center;
  font-family: Sans-Serif;
  font-weight: bold;
  letter-spacing: 0.2em;
}

.ec-shelfGrid .ec-shelfGrid__item,
.ec-newItemRole .ec-newItemRole__listItem {
  position: relative;
  margin-top: 50px;
  margin-right: 30px;
  padding: 26px 26px 40px;
  border-radius: 14px;
  width: 32%;
  padding-bottom: 40px;
}



@media (max-width: 767px) {
  .ec-shelfGrid .ec-shelfGrid__item,
  .ec-newItemRole .ec-newItemRole__listItem {
    position: relative;
    margin-top: 50px;
    margin-right: 0px;
    padding: 20px 20px 30px 20px;
    border-radius: 6px;
    width: 32%;
  }
}


.ec-newItemRole .ec-newItemRole__listItem:last-child {
  margin-right: 0;
}

.ec-newItemRole .ec-newItemRole__listItem a:link,
.ec-newItemRole .ec-newItemRole__listItem a:visited {
  color: #000;
}

.ec-newItemRole .ec-newItemRole__listItemTitle {
  margin: 6px 0;
  font-size: 20px;
  font-weight: bold;
}

.ec-newItemRole__listItem img {
  width: 100%;
  margin: -50% 0 10% 0;
}



a.incart {
  width: 80%;
  padding: 0.6em 1.5em;
  text-align: center;
  position: absolute;
  left: 50%;
  bottom: -15px;
  transform: translateX(-50%);
  font-size: 12px;
  background: #fff;
  border: 1px solid #e2e2e2;
  border-radius: 20px;
  
}

a.incart::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  padding-right: 0.5em;
  background: url("/html/user_data/assets/img/common/icon_incart.png") no-repeat;
  background-size: cover;
}

/* =========================
   Greeting
========================= */
.bgGreeting {
  background-image: url("/html/user_data/assets/img/common/bg_greeting.png");
  background-size: cover;
  background-attachment: fixed;
}
@media (max-width: 767px) {
    .bgGreeting {
  background: url("/html/user_data/assets/img/common/bg_greeting_sp.png") no-repeat;
  background-size: cover;
  background-color: #38B5DB;
  
}
}


.bgGreeting .inner {
  padding: 15vh 0;
  display: grid;
  grid-template-columns: 0.8fr 1fr;
  overflow: hidden;
}
.bgGreeting .inner .risu_image{
    position: relative;
    
}

.bgGreeting .inner h2 {
  color: #000;
  font-weight: bold;
  letter-spacing: 0.2em;
}

.bgGreeting .inner p {
  margin-top: 4em;
  font-size: 18px;
  line-height: 2em;
  color: #000;
}
.bgGreeting .inner img.risu{
     width: 64%;
    height: auto;
    position: absolute;
    bottom: -100px;
    right: 0;
    margin-right: 10%;
    
}
.bgGreeting .inner img.risu_bg{
    width: 100%;
    height: auto;
    top:-100px;
    
}

/* =========================
   Product / Slick
========================= */
.item_visual {
  height: auto;
  width: auto;
}

.item_visual img {
  height: 100%;
  width: auto;
  margin: 0 auto;
}

/*
.slick-slide {
  width: 100% !important;
  height: 100%;
}

.slick-list {
  position: relative;
  display: block;
  overflow: hidden;
  margin: 0;
  padding: 0;
  height: 100%;
}

.slick-track {
  position: relative;
  top: 0;
  left: 0;
  display: block;
  margin: 0 auto;
  height: 100% !important;
}
*/
/* 商品詳細のSlick画像だけ正す */
.ps-slickMain img{
  width: 100% !important;
  height: auto !important;
  max-width: 100% !important;
}
.ec-productRole{
  margin-top: 60px;
}
@media (max-width: 767px) {
  .ec-productRole{
    margin-top: 120px;
  }
}



.ec-productRole img {
  height: auto;
  width: 100%;
  max-width:100%;
}

.ec-productImage {
  height: 70vh;
}

.ec-productImage__main {
  height: 100%;
  text-align: center;
  padding-top: 10vh;
}

.ec-productRole .ec-productRole__description {
  margin: 40px 0 16px;
  
}
.ec-productRole .ec-productRole__description p{
    line-height: 1.5em;
    
}

.ec-productRole .ec-productRole__title .ec-headingTitle {
  margin-top: 1em;
  padding-bottom: 0.5em;
  font-size: 32px;
  font-weight: bold;
  color: #000;
  border-bottom: 1px solid #ddd;
}

.ec-productRole .ec-productRole__profile {
    margin-left: 0;
    
}

.ec-productRole__profile .ec-productRole__title .ec-headingTitle{
    font-size: 36px;
    
}
@media (max-width: 767px) {
    .ec-productRole .ec-productRole__profile {
    margin-top: 60px;
}
.ec-price__price{
    font-size: 24px !important;
}
    .ec-productRole__profile .ec-productRole__title .ec-headingTitle{
    font-size: 28px;
    
}
}
.ec-productRole .ec-productRole__price {
  padding: 8px 0;
  border-bottom: 1px dotted #ccc;
}

.ec-grid2 {
  padding-top: 8vh;
}

/* =========================
   Responsive
========================= */
/* SP image */
.sp_image {
  display: none;
  width: 70%;
  height: auto;
  overflow: hidden;
  margin: 0 auto 30px;
}

.sp_image img {
  width: 100%;
  height: auto;
}
.ec-newItemRole__listItemPrice {
    font-size: 12px !important;
    margin-bottom: 5px;
  }
  .ec-shelfGrid__item .ec-newItemRole__listItemPrice {
    font-size: 14px;
    margin-bottom: 5px;
  }
@media (max-width: 768px) {
  .sp_image {
    display: block;
  }
}

/* 767px以下（SP） */
@media (max-width: 767px) {
  .ec-headerNaviRole__nav {
    display: none !important;
  }

  .ec-headerRole__cart {
    margin-right: 20px;
  }

  /* NOTE:
     header.twigを標準nav_sp.twigに戻したので、
     ハンバーガーはEC-CUBE標準（ec-drawerRole）で動作します。
     ここではレイアウト崩れだけ調整。 */
  .ec-grid2 {
    padding-top: 0;
  }

  .ec-categoryRole {
    display: none;
  }

  .ec-newItemRole {
    padding: 10vh 0 0;
  }

  .ec-newItemRole .ec-newItemRole__list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3%;
  }

  .ec-newItemRole .ec-newItemRole__listItem {
    width: 100%;
    height: auto;
    margin-bottom: 8%;
  }

  .ec-newItemRole__listItem img {
    width: 100%;
    margin: -50% 0% 20px 0%;
  }

  .ec-newItemRole__listItemTitle {
    font-size: 28px;
  }
  .ec-shelfGrid__item .ec-newItemRole__listItemTitle {
    font-size: 20px;
    font-weight: bold;
  }

  .ec-newItemRole__listItemPrice {
    font-size: 18px;
    margin-bottom: 5px;
  }
  .ec-shelfGrid__item .ec-newItemRole__listItemPrice {
    font-size: 14px;
    margin-bottom: 5px;
  }

  a.incart {
    font-size: 11px;
    border-radius: 41px;
    
  }

  .ec-newItemRole h2 {
    margin: 0 auto 40px;
    font-size: 29px;
    letter-spacing: 0.5em;
  }

  .bgGreeting .inner {
    display: block;
    padding: 15vh 0;
  }

  .bgGreeting .inner h2 {
    font-size: 29px;
    letter-spacing: 0.5em;
    text-align: center;
  }

  .main_visual_original {
    height: 90vh;
  }

  .cach01 {
    width: 60%;
    right: 10px;
    top:30vh;
  }

  .cach02 {
    width: 157px;
    left: 10px;
    bottom: 0vh;
  }
}

/* =========================
   EC-CUBE Drawer (ec-drawerRole) skin
   ※ クラス名はテーマで微妙に違う場合があります
========================= */
@media (max-width: 767px) {
  /* ここは「EC-CUBE標準ドロワー」を右から出す見た目に寄せる */
  .ec-drawerRole {
    position: fixed;
    inset: 0;
    z-index: 10000;
    pointer-events: auto; /* 閉じてる時はクリック透過 */
  }

  /* overlay */
  .ec-drawerRole__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    opacity: 0;
    transition: opacity 0.2s ease;
  }

  /* drawer panel */
  .ec-drawerRole__content {
    position: absolute;
    top: 0;
    right: 0;
    width: 86vw;
    max-width: 360px;
    height: 100vh;
    background: #fff;
    transform: translateX(100%);
    transition: transform 0.2s ease;
    overflow-y: auto;
  }

  /* open state（テーマ差異に両対応） */
  .ec-drawerRole.is-active,
  .ec-drawerRole.is-open {
    pointer-events: auto;
  }

  .ec-drawerRole.is-active .ec-drawerRole__overlay,
  .ec-drawerRole.is-open .ec-drawerRole__overlay {
    opacity: 1;
  }

  .ec-drawerRole.is-active .ec-drawerRole__content,
  .ec-drawerRole.is-open .ec-drawerRole__content {
    transform: translateX(0);
  }
}

/* =========================
   Hamburger Button (SP)
   EC-CUBE standard nav_sp
========================= */
.ec-headerNavSP {
  background: none;
}

.fa-bars {
  font-size: 20px; /* 必要ならサイズ調整 */
}

/* =========================
   Product List -> TOP card style
   (ec-newItemRole__list の見た目を一覧にも適用)
========================= */
/* 一覧でよくある候補（テーマ差吸収） */
.ec-productListRole .ec-productList__list,
.ec-productListRole .ec-shelfGrid,
.ec-productList .ec-shelfGrid,
.ec-shelfGrid {
  /* TOPの newItem と同じ “横並びカード” の土台 */
  /*
  display: flex;
  flex-wrap: wrap;
  gap: 150px 20px;
  */
  margin-top: 110px;
  
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 110px 30px;
  margin-bottom:20px;
}

/* 1カード（一覧側の候補にまとめて適用） */
.ec-productListRole .ec-productList__listItem,
.ec-productListRole .ec-shelfGrid__item,
.ec-shelfGrid .ec-shelfGrid__item,
.ec-shelfGrid > li {
  position: relative;
  border-radius: 14px;
  padding: 26px 26px 40px !important;
  margin: 0;
  background: #fff; /* 必要なら */
  /* TOPの newItemRole と同じ “カード感” に寄せる */
  width: 100%;
}

@media (max-width: 767px) {
    /* 1カード（一覧側の候補にまとめて適用） */
.ec-productListRole .ec-productList__listItem,
.ec-productListRole .ec-shelfGrid__item,
.ec-shelfGrid .ec-shelfGrid__item,
.ec-shelfGrid > li {
  position: relative;
  border-radius: 7px;
  padding: 20px !important;
  margin: 0;
  background: #ffffff; /* 必要なら */
  /* TOPの newItemRole と同じ “カード感” に寄せる */
  width: 100%;
}
.ec-productListRole .ec-productList__list,
.ec-productListRole .ec-shelfGrid,
.ec-productList .ec-shelfGrid,
.ec-shelfGrid {
 
  margin-bottom: 0px;
}




}



/* 画像（TOPは少し浮かせて中央寄せ） */
.ec-productListRole .ec-productList__listItem img,
.ec-productListRole .ec-shelfGrid__item img,
.ec-shelfGrid .ec-shelfGrid__item img,
.ec-shelfGrid > li img {
  
  height: auto;
  
  display: block;
  width: 100%;
  margin: -40% 0 10% 0;
}

/* タイトル */
.ec-productListRole .ec-productList__listItemTitle,
.ec-productListRole .ec-shelfGrid__title,
.ec-shelfGrid .ec-shelfGrid__title,
.ec-shelfGrid > li .ec-shelfGrid__title {
  margin: 8px 0;
  font-size: 22px;
  font-weight: bold;
  color: #000;
}

/* 価格（クラス差があるので複数対応） */
.ec-productListRole .ec-productList__listItemPrice,
.ec-productListRole .ec-shelfGrid__price,
.ec-shelfGrid .ec-shelfGrid__price,
.ec-shelfGrid > li .ec-shelfGrid__price {
  color: #000;
}

/* リンク色 */
.ec-productListRole a:link,
.ec-productListRole a:visited {
  color: #000;
}

/* =========================
   SP（TOPと同じ大きさ感に寄せる）
========================= */
@media (max-width: 767px) {
  .ec-productListRole .ec-productList__list,
  .ec-productListRole .ec-shelfGrid,
  .ec-productList .ec-shelfGrid,
  .ec-shelfGrid {
    
  display: flex;
  flex-wrap: wrap;
  gap: 60px 4%;
  margin-top: 0px;
  }

  .ec-productListRole .ec-productList__listItem,
  .ec-productListRole .ec-shelfGrid__item,
  .ec-shelfGrid .ec-shelfGrid__item,
  .ec-shelfGrid > li {
    width: 48%;
    height: auto;
    margin-bottom: -5vh;
    margin-top: 6vh;
  }

  .ec-productListRole .ec-productList__listItem img,
  .ec-productListRole .ec-shelfGrid__item img,
  .ec-shelfGrid .ec-shelfGrid__item img,
  .ec-shelfGrid > li img {
    width: 100%;
    margin: -30% auto 20px auto;
  }

  .ec-productListRole .ec-productList__listItemTitle,
  .ec-productListRole .ec-shelfGrid__title,
  .ec-shelfGrid .ec-shelfGrid__title,
  .ec-shelfGrid > li .ec-shelfGrid__title {
    font-size: 28px;
  }
}

.ec-drawerRole .ec-headerLinkArea .ec-headerLink__item {
    display: block;
    border-bottom: 1px solid #4f4f4f;
    padding: 10px 20px;
    font-size: 14px;
    font-weight: bold;
    color: white;
}
.ec-drawerRole .ec-headerCategoryArea .ec-headerCategoryArea__heading {
    border-top: 1px solid #CCCCCC;
    border-bottom: 1px solid #fff;
    padding: 0.5em 10px;
    font-size: 16px;
    font-weight: bold;
    color: black;
    background: #F8F8F8;
}



/* ===== Poyo Animation ===== */
.poyo {
  opacity: 0;
  transform: translateY(24px) scale(0.96);
  transition: opacity 0.6s ease, transform 0.8s cubic-bezier(.22, 1.4, .36, 1);
}

.poyo.is-show {
  opacity: 1;
  transform: translateY(0) scale(1);
}



/* =========================
   Scroll Fade In
========================= */

/* 初期状態（見えない） */
.js-fadein {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity 0.8s ease,
    transform 0.8s cubic-bezier(.22, 1, .36, 1);
  will-change: opacity, transform;
}

/* 表示状態 */
.js-fadein.is-show {
  opacity: 1;
  transform: translateY(0);
}

/* 少し遅らせたい時用 */
.js-fadein.delay-1 { transition-delay: 0.15s; }
.js-fadein.delay-2 { transition-delay: 0.3s; }
.js-fadein.delay-3 { transition-delay: 0.45s; }




/* =========================
   Category hover effect
========================= */
.ec-categoryRole__listItem a:link {
  display: inline-block; /* transform/影を効かせる */
  transition: transform 0.22s ease, box-shadow 0.22s ease, opacity 0.22s ease;
  will-change: transform, box-shadow;
}

.ec-categoryRole__listItem a:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.10);
  opacity: 0.95;
}

/* キーボード操作のフォーカスも見えるように（任意だけど推奨） */
.ec-categoryRole__listItem a:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.15), 0 8px 20px rgba(0, 0, 0, 0.10);
  transform: translateY(-2px);
}

/* スマホでは hover を無効寄りに（誤作動防止） */
@media (hover: none) {
  .ec-categoryRole__listItem a:hover {
    transform: none;
    box-shadow: none;
    opacity: 1;
  }
}


/* =========================
  HOWTO
========================= */

#howto{
    width: 100%;
    background-color: #E8DF0A;
    margin: 0 auto;
}
#howto .inner{
    padding: 15vh 0;
}
#howto .inner h2{
    width: 510px;
    height: 175px;
    margin: 0 auto;
    text-indent: -99999px;
     background: url("/html/user_data/assets/img/common/title_howto.png") no-repeat;
     background-size: contain;
}







.howtoimage{
    width: 90%;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 50px;
    align-items: center;
	justify-items: end;
	margin: 40px auto;
}

.howtoimage img{
    width: 100%;
    height: auto;
}
.howtoimage p{
    text-align: center;
    font-weight: bold;
    color: #000;
    
}
.howtoimage p span{
    text-align: center;
    font-weight: normal;
}




@media (max-width: 767px) {
    .howtoimage{
    width: 100%;
    gap: 10px;
    }
    #howto .inner{
    padding: 10vh 0;
}
    #howto .inner h2{
    width: 300px;
    height: 109px;
    margin: 0 auto;
    }
    .howtoimage p{
        font-size: 12px;
    
}
   
}


#howto .inner p.title{
    margin-bottom: 0.8em;
    font-size: 1.1em;
    color: #000;
    font-weight: bold;
    border-bottom: solid 1px #b3b524;
    padding-bottom: 0.25em;
    
}
#howto .inner ul{
    margin-bottom: 30px;
    color: #000;
    
}
#howto .inner ul li{
    font-size: 1em;
    
}



/* =========================
  HOWTO
========================= */
.ec-newsRole {
        padding: 60px 0 0;
        padding: 10vh 0 10vh 0;
}
.ec-secHeading .ec-secHeading__en {
    font-size: 1.75rem;
    font-weight: bold;
    letter-spacing: 0.2em;
}



/* =========================
  FOOTER
========================= */

.ec-footerRole {
    border-top: 1px solid #7d7d7d;
    margin-top: 0px;
}

.ec-footerRole .banner{
    display: grid;
    grid-template-columns: 1fr 1fr;
    width: 450px;
    margin: 0 auto 30px auto;
    gap: 10px;
}

@media (max-width: 767px) {
    .ec-footerRole .banner{
        width: 95%;
        margin: 30px auto 10px auto;
    }
}



.ec-footerRole .banner a{
    display: block;
}
.ec-footerRole .banner a img{
    width: 100%;
    height: auto;
}



/* =========================
  CART
========================= */
.ec-cartRow .ec-cartRow__img {
    display: inline-block;
    min-width: 100px;
    max-width: 100px;
    height: 100px;
    padding-right: 0;
}
.ec-cartRow__img a:link{
    display: block;
    text-align: center;
    width: 100%;
    height: 100%;
    
}

.ec-cartRow__img a img{
    height: 100%;
    width: auto !important;
    max-width: none !important;
}
/* =========================
  ご注文手続き
========================= */

.ec-imageGrid .ec-imageGrid__img {
    padding: 10px;
    width: 100px;
    height: 100px;
}

.ec-imageGrid .ec-imageGrid__img img {
    height: 100%;
    width: auto;
}





.ec-newItemRole a.list {
    margin: 10vh auto 0 auto;
    display: block;
    text-align: center;
    color: #fff;
    background-color: #000;
    padding: 1em 3em;
    width: fit-content;
    border-radius: 50px;
    border: solid 1px #000;
}
.ec-newItemRole a.list:hover {
    color: #000;
    background-color: #fff;
    border: solid 1px #000;
}
.ec-productRole .ec-productRole__category ul {
    list-style: none;
    padding: 0;
    margin: 5px 0 0 0;
}
@media (max-width: 767px) {
    .ec-newItemRole a.list {
        margin: 100px auto 10vh auto;
        font-size: 18px;
        font-weight: bold;
    }
}


.attention{
    margin: 40px auto 50px auto;
    border: solid 6px #f1f1f1;
    padding: 30px;
    width: 100%;
}


@media (max-width: 767px) {
    .attention{
    padding: 20px;
    width: 90%;
}
}




.ec-shelfRole{
    margin-bottom: 100px;
    padding-left: 5%;
    padding-right: 5%;
}


.free_area_class { /* あなたのフリーエリアのクラス名 */
    white-space: pre-wrap; /* Enterキーによる改行を反映させる */
}
.free{
    margin-top: 10px;
    padding-top: 10px;
    border-top: solid 1px #ddd;
    
}

.ec-categoryNaviRole {
    padding-left: 0px;
    padding-right: 0px;
}

.ec-categoryNaviRole {
    display: block !important;
    background-color: #000
}
.ec-itemNav{
    background: none;
}
.ec-itemNav__nav li a:link,
.ec-itemNav__nav li a:visited,
.ec-itemNav__nav li a:hover{
    background: none;
    color: #fff;
    border: none;
}

p.ec-categoryNaviRole_title{
    width: 100%;
    padding: 0.5em 20px;
    text-align: left;
    background-color: #000;
    color: #fff;
}


.ec-itemNav__nav{
    padding-top: 1px;
}
.ec-itemNav__nav li a:link,
.ec-itemNav__nav li a:visited,
.ec-itemNav__nav li a:hover{
    font-size: 14px;
    padding: 16px 16px 16px 16px;
    border-bottom: 1px solid #3c3c3c;
}

/* ▼ pagetop（aタグなし対応・Arrow版） */
.pagetop {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 9999;

  width: 54px;
  height: 54px;
  border-radius: 999px;

  cursor: pointer;

  /* PeaceSeedっぽい柔らか背景 */
  background: radial-gradient(circle at 30% 25%, #ffffff 0 30%, #f3eee5 55%, #e5dccb 100%);
  box-shadow:
    0 10px 24px rgba(0,0,0,.18),
    inset 0 2px 0 rgba(255,255,255,.9);

  display: grid;
  place-items: center;

  /* 元テキストを消す */
  font-size: 0;
  line-height: 0;

  transition: transform .15s ease, box-shadow .15s ease;
}

.pagetop:hover {
  transform: translateY(-3px);
  box-shadow:
    0 14px 28px rgba(0,0,0,.22),
    inset 0 2px 0 rgba(255,255,255,.9);
}

/* Arrow本体（↑） */
.pagetop::before {
  content: "";
  width: 14px;
  height: 14px;
  border-top: 3px solid #6b5b3e;
  border-right: 3px solid #6b5b3e;
  transform: rotate(-45deg);
  margin-top: 16px;
}

/* スマホ */
@media (max-width: 768px) {
  .pagetop {
    width: 48px;
    height: 48px;
    right: 14px;
    bottom: 14px;
  }
}


.ec-layoutRole__main{
    margin: 0vh 0 10vh 0;
}
#page_homepage .ec-layoutRole__main{
     margin: 0vh 0 0vh 0;
    
}

.ec-cartNaviNull .ec-cartNaviNull__message {
    color: #fff;
    background-color: #ffb316;
}


.ec-productRole .ec-productRole__category {
    margin-bottom: 40px;
}

.ec-cartNaviIsset .ec-cartNaviIsset__cartImage {
    float: left;
    width: 45%;
    height: 100px;
}

.ec-cartNaviIsset .ec-cartNaviIsset__cartImage img {
    width: auto;
    height: 100%;
}




.ec-favoriteRole .ec-favoriteRole__item-image {
    height: 150px;
}
.ec-favoriteRole .ec-favoriteRole__itemThumb {
    height: 150px;
}


#workshop,
#photo{
    padding: 15vh 0;
    background: linear-gradient(
    135deg,
    #f6d6df 0%,
    #e8eaf6 35%,
    #dff0f5 65%,
    #f8f2e6 100%
  );
}

#workshop .inner,
#photo .inner{
    width: 90%;
    margin: 0 auto;
    
    
}
#workshop .inner h2,
#photo .inner h2{
    text-align: center;
    margin-bottom: 2em;
    color: #000;
    letter-spacing: 0.2em;
    font-size: 1.75rem;
    font-weight: bold;
    letter-spacing: 0.2em;
}

#workshop .inner p{
    line-height: 1.6em;
}
#workshop .inner p.title{
    font-size: 36px;
    text-align: center;
    font-weight: bold;
    margin-bottom: 0px;
    line-height: 1.5em;
    color: #41475f;
    
}
@media (max-width: 768px) {
    #workshop .inner p.title {
    font-size: 26px;
}
}
#workshop .inner .ws_image_wapper{
    width: 60%;
    margin: 0 auto 40px auto;
}

@media (max-width: 768px) {
    #workshop .inner .ws_image_wapper {
    width: 100%;
    margin: 0 auto 40px auto;
}
}




#workshop .inner .ws_image{
    width: 100%;
    height: auto;
    mix-blend-mode: multiply; 
    
}


#workshop .inner dl {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  margin: 5vh 0;
}


#workshop .inner dt {
  width: 20%;
  padding: 0.7em 0 0.7em 0.7em;
  margin-bottom: 1px;
  background-color: #f6f6f6;
}

#workshop .inner dd {
  width: 80%;
   padding: 0.7em 0 0.7em 0.7em;
  background-color: #fff;
  margin-bottom: 1px;
  border-bottom: solid 1px #f6f6f6;
}









/* popup 初期状態 */
.popup {
  opacity: 0;
  transform: scale(0.3);
  transition:
    opacity 400ms ease,
    transform 1420ms cubic-bezier(.2, 1.4, .4, 1);
  will-change: opacity, transform;
}

/* 表示状態 */
.popup.is-popup {
  opacity: 1;
  transform: scale(1);
}

/* motion配慮 */
@media (prefers-reduced-motion: reduce) {
  .popup {
    opacity: 1;
    transform: none;
    transition: none;
  }
}


.ec-newItemRole__soldout {
    margin-top: 8px;
    color: #ffffff;
    font-size: 12px;
    font-weight: bold;
    text-align: center;
    padding: 0.4em 0;
    background-color: #c8c8c8;
    border-radius: 4px;
}




.ec-404Role__title .ec-reportHeading{
    font-family: Serif !important;
}



.salesshop{
    margin-bottom: 30px;
    padding-bottom: 30px;
    display: grid;
    grid-template-columns: 0.4fr 1fr;
    gap: 20px;
    border-bottom: solid 1px #ddd;
}
.salesshop .thum_image{
    margin-bottom: 20px;
}


@media (max-width: 768px) {
    .salesshop{
    
    display: block;
}
}




/* 画像エリアを基準にする */
.ec-shelfGrid__item-image{
  position: relative;
}

/* SOLD OUT バッジ */
.ps-soldoutBadge{
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,.0);
  color: #fff;
  font-weight: 700;
  letter-spacing: .08em;
  font-size: 14px;
}
.ec-shelfGrid__item-image{
  position: relative;
}

/* SOLD OUT バッジ */
.ps-soldoutBadge{
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0);
  color: #fff;
  font-weight: 700;
  letter-spacing: .08em;
  font-size: 14px;
  display: none;
}

/* 在庫なしの商品だけ画像を薄く */
.ec-shelfGrid__item.is-soldout img{
  opacity: .4;
}




/* ===== swipe gallery ===== */
.ps-gallery__viewport{
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  overscroll-behavior-x: contain;
  border-radius: 8px; /* お好み */
}

/* スクロールバー非表示（見た目だけ） */
.ps-gallery__viewport::-webkit-scrollbar{ display:none; }
.ps-gallery__viewport{ scrollbar-width: none; }

.ps-gallery__track{
  display: flex;
}

.ps-gallery__slide{
  flex: 0 0 100%;
  scroll-snap-align: start;
  margin: 0;
}

.ps-gallery__slide img{
  width: 100%;
  height: auto;
  display: block;
  user-select: none;
  -webkit-user-drag: none;
}

/* thumbs */
.ps-gallery__thumbs{
  display:flex;
  gap: 8px;
  margin-top: 10px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.ps-gallery__thumb{
  border: 1px solid rgba(0,0,0,.15);
  padding: 0;
  background: transparent;
  border-radius: 6px;
  overflow: hidden;
  width: 72px;
  flex: 0 0 auto;
  cursor: pointer;
  opacity: .75;
}

.ps-gallery__thumb.is-active{
  opacity: 1;
  border-color: rgba(0,0,0,.5);
}

.ps-gallery__thumb img{
  width: 100%;
  height: auto;
  display:block;
}

/* dots（任意） */
.ps-gallery__dots{
  display:flex;
  gap: 6px;
  justify-content:center;
  margin-top: 10px;
}
.ps-gallery__dot{
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: rgba(0,0,0,.25);
}
.ps-gallery__dot.is-active{
  background: rgba(0,0,0,.65);
}


.ec-footerTitle img.kessai{
  width: 330px;
  height: auto;
  margin: 0 auto 20px auto;
}

@media (max-width: 768px) {
  .ec-footerTitle img.kessai{
    width: 200px;
    height: auto;
    margin: 0 auto 20px auto;
  }
}

.ec-footerTitle {
    padding: 0px 0 80px;
}


.ec-drawerRole .ec-headerLinkArea {
    background: #000;
}
.ec-headerSearch .ec-headerSearch__category .ec-select.ec-select_search {
    background: #212123;
    color: #fff;
}

@media (max-width: 768px) {
    .ec-footerNavi{
    padding: 0;
    color: white;
    list-style: none;
    text-align: center;
    display: grid;
    grid-template-columns: 1fr 1fr;
    width: 95%;
    margin: 0 auto 20px auto;
    gap:0px;
}
.ec-footerNavi .ec-footerNavi__link {
    display: block;
    border: solid 1px #484848;

}
.ec-footerNavi .ec-footerNavi__link a {
    border: none;
}
}




.ec-sliderItemRole .item_nav {
   
    text-align: center;
    justify-content: center;
    align-items: center;
    gap:2px;
   
}
.ec-sliderItemRole .slideThumb {
    margin-bottom: 0px;
    width: 33%;
    opacity: 0.8;
    cursor: pointer;
    background-color: rgb(255 255 255 / 0.2);
}

@media only screen and (min-width: 768px) {
    
    .ec-sliderItemRole .item_nav {
        
    }
    
}