@charset "UTF-8";
/* --------------------------------------------------------------

	01.初期設定
	02.メインビジュアル
	03.リード文
	04.ナビメニュー,ボタン
	05.商品一覧自動表示枠

----------------------------------------------------------------- */
/* --------------------------------------------------------------

	01.初期設定

----------------------------------------------------------------- */
.ec-layoutRole {
    width: 100%;
    transition: transform 0.3s;
    background: #FFFFFF !important;
}

.ec-featureRole__head > h1 {
  display: none; }

.ec-featureRole__head {
    margin: 0 !important;
    padding: 0 !important;
}

.ec-topicpath {
    padding-bottom: 0 !important;
}

@media only screen and (max-width: 767px) {

  .contents_, .mainframe_ {
    width: 100% !important; } }

.contentWrapper * {
  box-sizing: border-box;
}

  .contentWrapper *::before, .contentWrapper *::after {
    box-sizing: border-box; }

.contentWrapper02{
    padding: 10px 0;
    background: #fff;
}

@media only screen and (max-width: 767px) {
.contentWrapper02{
    padding: 10px 0 0;
}}

figure {
  margin: 0;
  padding: 0; }


.hp_pcOnly {
  display: inline-block; }
  @media only screen and (max-width: 767px) {

    .hp_pcOnly {
      display: none; } }


.hp_spOnly {
  display: none; }
  @media only screen and (max-width: 767px) {

    .hp_spOnly {
      display: inline-block; } }

@media only screen and (max-width: 767px) {

  .image_sp_w100 {
    width: 100%;
    height: auto; } }
/* margin */

.hp_mb0 {
  margin-bottom: 0 !important; }


.hp_mb5 {
  margin-bottom: 5px !important; }


.hp_mb20 {
  margin-bottom: 20px !important; }


.hp_mt5 {
  margin-top: 5px !important; }


.hp_mt10 {
  margin-top: 10px !important; }


.hp_mt15 {
  margin-top: 15px !important; }


.hp_mt20 {
  margin-top: 20px !important; }


.hp_mt25 {
  margin-top: 25px !important; }


.hp_mt30 {
  margin-top: 30px !important; }


.hp_mt40 {
  margin-top: 40px !important; }


.hp_mt50 {
  margin-top: 50px !important; }


.hp_mt60 {
  margin-top: 60px !important; }


.hp_mt70 {
  margin-top: 70px !important; }

.hp_mt80 {
  margin-top: 80px !important; }

/* font-size */

.hp_fontSize80 {
  font-size: 80%; }


.hp_fontSize120 {
  font-size: 120%;
  vertical-align: -1px; }


.hp_fontSize130 {
  font-size: 130%;
  vertical-align: -1px; }


.hp_fontSize140 {
  font-size: 140%;
  vertical-align: -1px; }

/* font-family */

.hp_fontFamily {
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, sans-serif;
  line-height: 1.8;
  font-feature-settings: "palt";
  letter-spacing: .08em; }


.hp_fontArial {
  font-family: Arial, Helvetica, sans-serif; }

/* テキストラインマーカー */

.hp_textMarker {
  color: #ccc;
  background: linear-gradient(transparent 50%, #ffecec 50%); }

/* 文字間ひろく */

.hp_textSpace {
  letter-spacing: .2em; }

/* キャプション */

.bl_captionList {
  font-size: 0.75rem; }

  .bl_captionList > li {
    margin-top: .2em;
    padding-left: 1em;
    text-indent: -1em; }

/* フォントウェイト */

.fw-normal {
  font-weight: normal !important; }


.fw-bold {
  font-weight: bold !important; }

/* フォントカラー */

.fc-orange {
  color: #ed4400 !important; }

/* セクション */

.bl_section {
  margin-top: 70px; }


.bl_sectionHeading {
  margin-bottom: 25px;
  text-align: center; }

/* h1とソート機能を非表示 */

.event_name_header_,
.event_name_,
.category_name_ {
  display: none !important; }

/* 見出し */

.el_wgTtl {
  margin: 120px auto 0;
  text-align: center; }

  .el_wgTtl.first-item {
    margin: 50px 0 20px; }

      .el_wgTtl > img {
      width: 100%;}

  @media only screen and (max-width: 767px) {

    .el_wgTtl {
      margin-top: 80px; }

      .el_wgTtl.first-item {
        margin-top: 20px; }

      #wg-ranking .el_wgTtl > img {
        max-height: 100px;} 
}

.head02 {
	text-align: center;
    margin: 40px 0;
    padding: 20px;
    color: #fff;
    background: #454743;
    font-weight: bold;
    font-size: 130%;
	border-bottom: 5px solid #FFEF66;
}

.itemTll
{
	border-bottom: solid #c72324 2px;
    border-top: solid #c72324 2px;
    padding: 0;
	text-align: center;
}
.itemTll img
{
	width: initial;
}

  @media only screen and (max-width: 767px) {
   .head02 {
        margin: 40px 0 30px;
        padding: 15px 0;
        text-align: center;
}
}

.el_wgTtl2 {
  position: relative;
  margin-top: 60px;
  border: solid #ccc;
  border-width: 1px 0;
  padding: 0.8em 0 0.6em;
  text-align: center;
  font-weight: bold;
  font-size: 1.25rem; }

  .el_wgTtl2.first-item {
    margin-top: 50px; }
  @media only screen and (max-width: 767px) {

    .el_wgTtl2 {
      margin-top: 40px;
      margin-left: 10px;
      margin-right: 10px;
      padding: 0.8em 0;
      font-size: 1.125rem; }

      .el_wgTtl2.first-item {

        margin-top: 20px; } }

/* 次のタイトルからデザイン変更【ランキング】 */

.event_title_ {
  margin-bottom: 0;
  padding: 0;
  font-size: unset;
  font-weight: normal;
  line-height: normal;
  border-bottom: none;
  clear: none !important;
  position: static; }

  .event_title_ .title_desing_line_ {}

  .event_title_::after {
    content: normal !important; }


.event_title_ {
  position: relative;
  margin-top: 20px;
  margin-bottom: 40px;
  border: solid #ccc;
  border-width: 1px 0 !important;
  padding: 0.65em 0 0.45rem !important;
  text-align: center;
  font-weight: bold;
  font-size: 1.25rem;
}
  @media only screen and (max-width: 767px) {

    .event_title_ {
      margin: 40px 10px 10px;
      padding: 0.4em 0; } }

/* ランキング背景色 */
@media only screen and (max-width: 767px) {

  .goods_r_,
  .shoppage_wrap_ .event_ .bx-wrapper {
    background: unset !important; } }

@media only screen and (max-width: 767px) {

  .ranking_.more_ {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
    background: unset !important; } }

/* ランキングの高さリセット */
@media only screen and (max-width: 767px) {

  .bx-viewport {
    height: auto !important; } }

/* もっと見るボタン */
@media (min-width: 641px) {

  .event_design_bottom_.more_ {
    margin-top: -20px; } }


.more_btn_ a:hover {
  text-decoration: none !important; }

/* --------------------------------------------------------------

	02.メインビジュアル

----------------------------------------------------------------- */

.el_mainVisual {
  display: block; }

  .el_mainVisual > img {
    width: 100%; }

/* --------------------------------------------------------------

	03.リード文

----------------------------------------------------------------- */

.bl_leadWrapper {
  padding: 20px 0;
  text-align: center;
  line-height: 1.8;
  color: #000;
}
  @media only screen and (max-width: 767px) {
    .bl_leadWrapper {
      padding: 20px;} }

  .bl_leadWrapper .txt_lead {
    font-size: 1.8rem; }
    @media only screen and (max-width: 767px) {
      .bl_leadWrapper .txt_lead {
          font-size: 1.6rem;
          line-height: 2.4rem;
          text-align: center; } }
.txt_lead span {
	font-size: 2.6rem;
	font-weight: 700;
	line-height: 1.4em;
}
@media only screen and (max-width: 767px) {
	.txt_lead span {
		font-size: 2.2rem;
		line-height: 1.4em;
	}
}

  .bl_leadWrapper{
    margin: 40px 50px 0;
    padding: 20px;
}
    @media only screen and (max-width: 767px) {
      .bl_leadWrapper{
        margin: 20px 5px 0;
        padding: 10px 15px;} }

    .bl_leadWrapper .special-txt {
      font-size: 2rem;
        font-weight: bold;
}
    .bl_leadWrapper .special-txt .special-txtL {
      font-size: 2.5rem;
}
      @media only screen and (max-width: 767px) {
        .bl_leadWrapper .special-txt {
          text-align: center;
          font-size: 1.8rem;
          }
        .bl_leadWrapper .special-txt .special-txtL {
          font-size: 2rem;
}
}

    .bl_leadWrapper .num {
      line-height: 1.3;
      vertical-align: -0.1em;
      font-size: 1.575rem; }
      @media only screen and (max-width: 767px) {

        .bl_leadWrapper .num {
          vertical-align: 0;
          font-size: 1.375rem; } }

    .bl_leadWrapper .txt-present {
      font-size: 1.125rem; }
      @media only screen and (max-width: 767px) {

        .bl_leadWrapper .txt-present {
          font-size: 1rem; } }


/* --------------------------------------------------------------

	04.ナビメニュー,ボタン

----------------------------------------------------------------- */

    
#wg-item {
		padding-bottom: 0 !important;
        margin-top: 50px !important;
        text-align: center !important;
}
.wg-item {
        text-align: center !important;
        padding-bottom: 20px;
}


#wg-article {
		padding-bottom: 0 !important;
        margin-bottom: 15px !important;
        text-align: center !important;
}

#wg-shop {
		padding-bottom: 0 !important;
        margin-bottom: 15px !important;
        text-align: center !important;
}

#wg-tokushu {
		padding-bottom: 0 !important;
        margin-bottom: 15px !important;
        text-align: center !important;
}
.bl_naviList {
  display: flex; }
  @media only screen and (max-width: 767px) {

    .bl_naviList {
      flex-wrap: wrap;
      padding: 0px;
      justify-content: center; } }

@media (min-width: 641px) {

  .bl_naviListItem {
    flex-basis: calc(100% / 4);
    margin-left: 10px; }

    .bl_naviListItem:first-child {
      margin-left: 0; }

    .bl_naviListItem:nth-of-type(2n) {
      margin-left: 10px; }
}
@media only screen and (max-width: 767px) {
  .bl_naviListItem {
    flex-basis: calc(93% / 4); }

    .bl_naviListItem:first-child {
      margin-left: 0; }

    .bl_naviListItem:nth-of-type(2n) {
      margin-left: 5px; }

    .bl_naviListItem:nth-of-type(3n) {
      margin-left: 5px; }
}

.bl_naviListItem > a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 5px 0;
  font-weight: bold;
  text-align: center;
  text-decoration: none;
  color: #fff;
  transition: .2s ease all;
  /*border-bottom: 4px solid #FFEF66;*/
}

@media only screen and (max-width: 767px) {
.bl_naviListItem > a {
  font-size: 0.8rem;
  line-height: 1.6rem;
  height: 100%;
}
}

  .bl_naviListItem > a[href="#ctg"] {
    background: #454743;}
  .bl_naviListItem > a[href="#maker"] {
    background: #454743;}
  .bl_naviListItem > a[href="#keyword"] {
    background: #454743;}
  .bl_naviListItem > a[href="#article"] {
    background: #454743;}
  .bl_naviListItem > a .bbox {
    position: relative;
    display: flex;
    justify-content: center;
    padding: 10px 0 20px;
    width: 100%; }
  .bl_naviListItem > a::after {
    content: '';
    position: absolute;
    bottom: 10px;
    right: 0;
    left: 0;
    margin: auto;
    border-right: solid 3px #efe939;
    border-bottom: solid 3px #efe939;
    width: .7em;
    height: .7em;
    transform: translateY(-25%) rotate(45deg); }
 
  .bl_naviListItem > a:hover {
    opacity: 0.7 ; }

/* --------------------------------------------------------------

	05.商品一覧自動表示枠

----------------------------------------------------------------- */
.event_title_ {
  margin: 50px 0 35px !important;
  border: none !important;
  border-top: 3px solid #FF7085 !important;
  border-bottom: 3px solid #FF7085 !important;
  line-height: 1 !important;
  height: auto !important;
  width: auto !important;
  font-size: 24px !important;
  font-weight: bold !important;
  text-align: center !important;
  padding: 20px 0 22px !important;
  letter-spacing: 0.5px !important;
  color: #402c0a !important;
  font-family: -apple-system, BlinkMacSystemFont, Roboto, "Segoe UI", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, Meiryo, sans-serif !important;
}

.event_title_:nth-of-type(1) {
  margin-top: 35px !important;
}

.event_title_:after,
.event_title_:before {
  display: none !important;
  width: auto !important;
  height: auto !important;
  content: none !important;
  background: none !important;
}

span.title_desing_line_ {
  height: 0 !important;
}

.cart_ a {
  background-color: #FF7085 !important;
}

.shoppage_wrap_ ul.goods_t_ li div.cart_ a {
    background: #FF7085 !important;
}

@media screen and (max-width: 767px) {
  .event_title_ {
    margin: 20px 0 10px !important;
    border: none !important;
    border-top: 2px solid #FF7085 !important;
    border-bottom: 2px solid #FF7085 !important;
    line-height: 1 !important;
    height: auto !important;
    width: auto !important;
    font-size: 17px !important;
    font-weight: bold !important;
    text-align: center !important;
    padding: 10px 0 !important;
    color: #000 !important;
    font-family: -apple-system, BlinkMacSystemFont, Roboto, "Segoe UI", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, Meiryo, sans-serif !important;
  }

  .event_title_:nth-of-type(1) {
    margin-top: 30px !important;
  }

  .event_title_:after,
  .event_title_:before {
    display: none !important;
    width: auto !important;
    height: auto !important;
    content: none !important;
    background: none !important;
  }

  span.title_desing_line_ {
    height: 0 !important;
  }
}

.bnr_box {
    margin-bottom: 30px;
}
.bnr_box ul {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    text-align: center;
}
.bnr_box ul li {
    width: 49%;
    margin-bottom: 2%;
}
.bnr_box ul img {
	width: 100%;
}

@media only screen and (max-width: 767px) {
	.bnr_box ul {
		margin: 2% 0;
		display: block;
		justify-content: flex-start;
		flex-wrap: nowrap;
	}
	.bnr_box ul li {
		width: auto;
	}
	.bnr_box ul li+li {
		margin-top: 3%;
	}
}

.cpbnr_box {
    margin: 0 auto;
    width: 600px;
}
@media only screen and (max-width: 767px) {
.cpbnr_box {
    margin: 0 auto;
    width: 100%;
}
}
.cpbnr_box img{
    width: 100%;
}
.cpbnr_box > a:hover {
    opacity: 0.7 ;
    transition: .2s ease all;
}

.bnr_box ul li a:hover {
    opacity: 0.7 ;
    transition: .2s ease all;
}

.pc { display: block !important; }
.sp { display: none !important; }
 
@media only screen and (max-width: 767px) {
    .pc { display: none !important; }
    .sp { display: block !important; }
}


/* 関連記事スライド
---------------------------------------------------- */
.article_slide {
    margin: 0 0 40px 0;
}

.article_slide ul {
    max-width: 1500px;
    background-color: #f1f1f1;
    box-sizing: border-box;
    padding: 28px 0 28px 25px;
    display: flex;
    overflow-x: scroll;
}

.article_slide ul.gray {
    background-color: #F5F5F5;
}

.article_slide ul.brown {
    background-color: #ead6cd;
}

.article_slide ul.green {
    background-color: #d4efd4;
}

.article_slide ul.blue {
    background-color: #cee3f8;
}

.article_slide ul.pink {
    background-color: #fbdcd1;
}

.article_slide ul.yellow {
    background-color: #f9f6cf;
}

.article_slide ul::-webkit-scrollbar {
    height: 12px;
}

.article_slide ul::-webkit-scrollbar-thumb {
    background: #bbb;
    border-radius: 6px;
}

.article_slide ul::-webkit-scrollbar-track {
    background: #e7e7e7;
    border-radius: 0px;
}

.article_slide li {
    width: 260px;
    height: auto;
    display: block;
    margin: 0;
    box-sizing: border-box;
    text-align: left;
    flex-shrink: 0;
}

.article_slide li a {
    display: block;
    padding: 10px;
    transition: opacity .4s;
    color: #000;
}

.article_slide li a:hover {
    transition: opacity .4s;
    opacity: 0.6;
    color: #000;
}

.article_slide li p {
    font-size: 14px !important;
    line-height: 1.2;
    font-weight: bold;
    margin: 10px 0 0 0;
}

.article_slide li p span{
    font-size: 10px;
    font-weight: normal;
}

@media screen and (max-width: 640px) {
    .article_slide ul {
        padding: 20px 0 20px 20px;
    }

    .article_slide ul::-webkit-scrollbar {
        height: 10px;
    }

    .article_slide li {
        width: 40vw;
        height: 68vw;
        margin: 0 10px 0 0;
    }

    .article_slide li a {
        padding: 15px 5px 0;
        box-sizing: border-box;
        min-height: 185px;
    }

    .article_slide li p {
     font-size: 11px;
     line-height: 1.2;
     margin: 10px 0 0 0;
}
}

/* メーカー,キーワード
---------------------------------------------------- */
.btn_search ul{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 20px;
}
.btn_search ul li{
    position: relative;
    text-align: center;
}
@media screen and (max-width: 767px) {
	.btn_search ul {
		grid-template-columns: 1fr 1fr;
		gap: 15px;
	}
}
.btn_search ul li a{
	color: #000;
}
.btn_search ul li::after{
	content: "";
    display: block;
    position: absolute;
    width: 7px;
    height: 7px;
    border-right: 2px #6CAC92 solid;
    border-bottom: 2px #6CAC92 solid;
    transform: rotate(315deg);
    transform: -moz-rotate(45deg);
    transform: -webkit-rotate(315deg);
    bottom: 25px;
    right: 18px;
}
.btn_search ul li a{
	 display: block;
	border-radius: 20px;
    background-color: #fff;
	color: #000;
	border: 2px solid #6CAC92;
     padding: 15px 12px 16px;
}
.btn_search ul li a:hover{
	transition-duration: 0.2s;
	background-color: #e9f6f1;
}


/* -----------------------------
   関連特集バナー
----------------------------- */
.ec-travelRole__related ul {
  display: flex;
  justify-content: center;
  padding: 0;
}
.ec-travelRole__related ul li {
  list-style: none;
  width: 47.25%;
}
.ec-travelRole__related ul li + li {
  margin-left: 5.5%;
}
.ec-travelRole__related ul li a {
  display: block;
  transition: all 0.5s;
}
.ec-travelRole__related ul li a:hover {
  opacity: 0.7;
}
@media screen and (max-width: 768px) {
  .ec-travelRole__related ul {
    display: block;
  }
  .ec-travelRole__related ul li {
    width: 100%;
  }
  .ec-travelRole__related ul li + li {
    margin-left: 0;
    margin-top: calc(40 / 750 * 100vw);
  }
}

/* -----------------------------
   中央寄せ見出し
----------------------------- */
.ec-travelRole__fourthTtl {
  font-size: 32px;
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: 0.05em;
  text-align: center;
  margin-bottom: 32px;
}
@media screen and (max-width: 768px) {
  .ec-travelRole__fourthTtl {
    font-size: calc(34 / 750 * 100vw);
    margin-bottom: calc(34 / 750 * 100vw);
  }
}

/* -----------------------------
   おすすめ情報（article_slide）
----------------------------- */
.ec-travelRole__recommend {
  margin-bottom: 60px;
}
.ec-travelRole__recommend .article_slide ul {
  display: flex;
  overflow-x: scroll;
  margin: 0;
  padding: 0;
  list-style: none;
  background-color: #f5f5f5;
}
.ec-travelRole__recommend .article_slide li {
  width: 290px;
  flex-shrink: 0;
  margin: 0;
  box-sizing: border-box;
}
.ec-travelRole__recommend .article_slide li a {
  display: block;
  padding: 10px;
  transition: opacity 0.4s;
  color: #000;
}
.ec-travelRole__recommend .article_slide li a .imgwrap img {
  width: 100%;
  height: 180px;
  object-fit: cover;
}
.ec-travelRole__recommend .article_slide li p {
  font-size: 14px;
  font-weight: bold;
  margin: 10px 0 0;
}
@media screen and (max-width: 768px) {
  .ec-travelRole__recommend .article_slide li {
    width: 40vw;
    height: 50vw;
    margin-right: 20px;
  }
  .ec-travelRole__recommend .article_slide li a .imgwrap img {
    height: calc(200 / 750 * 100vw);
  }
}

/* -----------------------------
   人気キーワードタグ（丸ボタン）
----------------------------- */
.ec-travelRole__keywords__ul {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -3px;
  padding: 0;
}
.ec-travelRole__keywords__ul__li {
  list-style: none;
}
.ec-travelRole__keywords__ul__li__a {
  font-size: 12px;
  line-height: 1.2;
  border: 1px solid #d4d4d4;
  color: #2a2a2a;
  margin: 9px 3px;
  padding: 0.35em 0.81em;
  border-radius: 9999px;
  display: block;
  text-align: center;
  transition: all 0.5s;
}
.ec-travelRole__keywords__ul__li__a:hover {
  background-color: #d4d4d4;
  color: #fff;
}
@media screen and (max-width: 768px) {
  .ec-travelRole__keywords__ul__li__a {
    font-size: calc(24 / 750 * 100vw);
    margin: calc(15 / 750 * 100vw) calc(10 / 750 * 100vw);
  }
}