@charset "utf-8";
/*
 common
============================================*/
html{overflow:auto;}
body{
  min-width:1024px;
  overflow-x:hidden;
  color: #333;
}
.all_contents{
  font-size: 14px;
  color: #333;
}

.main_section{
  padding: 80px 0 100px;
}
.main_section:nth-of-type(odd){
  background-color: #fbf4d8;
}
.main_section:nth-of-type(even){
  background-color: #fff;
}

.section_inner{
  width: 960px;
  margin: 0 auto;
}

/*
rule_notice
============================================*/
.rule{
  padding: 60px 0;
  background-color: #f7f7f7;
}
.noticeWrap01{
  margin: 0 0 32px;
  padding: 26px 30px 32px;
  background-color: #ffffff;
  border:#bf0000 1px solid;
  font-size: 14px;
  color: #bf0000!important;
  margin-bottom:16px;
}
.noticeTxt{
  font-weight:bold;
  margin-bottom:10px;
}

.award-banner{
  text-align: center;
}
.award-banner a:hover{
  opacity: 0.8;
  text-decoration: none;
}
.award-banner img{
  max-width: 576px;
}

/*
 title
============================================*/
.main_title{
  position: relative;
  font-weight: bold;
  color: #333333;
  text-align: center;
  font-size: 36px;
  line-height: 1.6;
  margin-bottom: 52px;
  padding-bottom: 32px;
}
.main_title::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 60px;
  height: 4px;
  background-color: #c84605;
  transform: translateX(-50%);
}
.category_title{
  text-align: center;
}
.category_title span{
  position: relative;
  display: inline-block;
  color: #c84605;
  font-weight: bold;
  margin-bottom: 35px;
  padding: 0px 50px;
  font-size: 30px;
}
.category_title span::before,
.category_title span::after{
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 12px;
  height: 30px;
  border-right: 2px solid #c84605;
  border-top: 2px solid #c84605;
  border-bottom: 2px solid #c84605;
}
.category_title span::before{
  right: 0;
}
.category_title span::after{
  left: 0;
  transform: rotate( 180deg );
}

.shoplist_title{
  font-size: 18px;
  font-weight: bold;
  padding-left: 10px;
  border-left: 2px solid #c84605;
  line-height: 1.0;
  margin-bottom: 15px;
  color: #c84605;
}

/*
 btn
============================================*/
.default_btn > a{
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 56px auto 0;
  width: 480px;
  height: 72px;
  border-radius: 36px;
  font-size: 18px;
  font-weight: bold;
  color: #fff;
  background-color: #c84605;
  text-align: center;
}
.default_btn > a .right_icon{
  display: inline-block;
  position: absolute;
  top: 0;
  bottom: 0;
  width: 1em;
  height: 1em;
  right: 32px;
  margin: auto 0;
  line-height: 1;
}
.default_btn > a:hover{
  opacity: .8;
  text-decoration: none;
}

/*
 mainNavi
============================================*/
.mainNavi_container{
  border-bottom: none!important;
}
.mainNavi_navi{
  height: 72px;
}
.mainNavi_navi .mainNavi_anchor{
  width: calc(960px/7);
  padding: 0;
  font-size: 14px;
  font-weight: normal;
  color: #333;
  border: none;
  line-height: 1.3;
}
.mainNavi_navi .mainNavi_anchor::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 1px;
  height: 44px;
  background-color: #c84605;
  display: block;
  z-index: 1;
}
.mainNavi_navi .mainNavi_anchor:last-of-type::after{
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 1px;
  height: 44px;
  background-color: #c84605;
  display: block;
  z-index: 1;
}
.mainNavi_navi .mainNavi_anchor:hover,
.mainNavi_navi .mainNavi_anchor[data-in-viewport=true]{
  background-color: #c84605;
  font-weight: normal;
  color: #fff;
}
.mainNavi_navi .mainNavi_anchor:hover + .mainNavi_anchor::before,
.mainNavi_navi .mainNavi_anchor[data-in-viewport=true] + .mainNavi_anchor::before{
  background-color: #fff;
}

/*
 entry
============================================*/
.notes_wrap{
  padding: 20px 0;
  text-align: center;
  line-height: 1.5;
  background-color: #fac698;
}
.notes_wrap p{
  font-size: 12px;
}
.entry_wrap{
  margin: 28px 0 0;
}
.entry_wrap .rcEntryButton-button:hover{
  opacity: .8;
}
.periodTxt{
  margin-bottom: 36px;
  text-align: center;
  font-size: 18px;
  letter-spacing: 0.02em;
}
.periodTxt_title{
  font-weight: bold;
}
.couponNote{
  margin-top: 44px;
}
.couponNote_Info{
  width: 628px;
  margin: 24px auto 0;
  font-size: 12px;
  color: #333;
  line-height: 1.5;
}
.couponNote_Info a{
  text-decoration: underline;
}
.couponNote_Info a:hover{
  opacity: .8;
  text-decoration: underline;
}
.entry_wrap .campaignLinkList{
  justify-content: center;
  flex-wrap: nowrap;
  width: 420px;
  margin: 32px auto 40px;
}
.entry_wrap .campaignLink{
  width: 100%;
  font-size: 14px;
  line-height: 1.1;
  text-align: center;
  box-sizing: border-box;
}
.entry_wrap .campaignLink a{
  position: relative;
  display: inline-block;;
  box-sizing: border-box;
  text-decoration: underline;
}
.entry_wrap .campaignLink a:hover{
  opacity: .8;
  text-decoration: underline;
}
.entry_wrap .campaignLink + .campaignLink{
  border-left: solid 1px #333;
}

.modal_prize_btn{
  position: relative;
  border: none;
  cursor: pointer;
  appearance: none;
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 278px;
  height: 56px;
  margin: 0 auto;
  border-radius: 28px;
  font-size: 18px;
  color: #fff;
  background-color: #c84605;
  box-sizing: border-box;
}
.modal_prize_btn:hover{
  opacity: .8;
  text-decoration: none;
}
.modal_prize_btn .right_icon{
  margin-left: 8px;
}
.modal_content_wrapper{
  width: 100%;
  max-width: 940px;
}
.modal_close_topRight{
  top: 56px;
  right: 12px;
  width: 48px;
  height: 48px;
  margin: 0;
  padding: 0;
  border-radius: 4px;
  color: #fff;
  font-size: 28px;
  background-color: #c84605;
  background-image: none;
  box-shadow: none;
  z-index: 2;
}
.modal_content{
  border-radius: 0;
  padding: 100px 30px;
  background-color: #fff;
}
.modal_close_bottom{
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 190px;
  height: 48px;
  margin: 44px auto 0;
  border: none;
  font-size: 16px;
  box-sizing: border-box;
  border-radius: 24px;
  background-color: #c84605;
  color: #fff;
  letter-spacing: 0.05em;
}
.modal_close_bottom .left_icon{
  font-size: 26px;
  padding-right: 8px;
}
.modal_close_topRight:hover,
.modal_close_bottom:hover{
  opacity: .8;
  text-decoration: none;
}
.prize_note_wrap{
  width: 826px;
  margin: 24px auto 0;
  font-size: 14px;
  line-height: 1.5;
}
.prize_note_wrap li{
  text-indent: -1em;
  padding-left: 1em;
}

/*
 stamp_card
======================================================= */
.stamp_wrap{
  margin: 80px auto 92px; 
}
.stamp_title{
  margin-bottom: 28px;
  font-size: 36px;
  color: #c84605;
  font-weight: bold;
  text-align: center;
}
.stamp_subText{
  width: 600px;
  margin: 20px auto;
}
.stamp_subText li{
  font-size: 12px;
  padding-left: 1em;
  text-indent: -1em;
}

/*
 category
======================================================= */
.category_wrap + .category_wrap{
  margin-top: 100px;
}
.index_wrap{
  margin: 0 0 56px;
}
.index_wrap ul{
  width: 410px;
  margin:  0 auto;
}
.index_wrap ul li a{
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  height: 64px;
  border-radius: 4px;
  padding: 12px 0 0;
  background: #c84605;
  color: #fff;
  font-size: 16px;
  text-align: center;
  line-height: 1.2;
  box-sizing: border-box;
}
.index_wrap ul li a span{
  display: inline-block;
  margin-bottom: 8px;
}
.index_wrap ul li a:hover{
  opacity: .8;
  text-decoration: none;
}

/*
 search
============================================*/
.searchBox_wrap{
  width: 680px;
  margin: 0 auto 40px;
}
.searchBox_wrap .search_box {
  height: 56px;
  border: 2px solid #c84605;
  border-radius: 4px;
}
.searchBox_wrap .search_box_submit {
  padding: 0;
  width: 56px;
  border-radius: 0 2px 2px 0;
  background-color: #c84605;
}
.searchBox_wrap .search_input {
  padding-left: 20px;
  font-size: 16px;
}
.searchBox_wrap .search_input::placeholder {
  color: #999999;
}
.searchBox_wrap .search_box_ic {
  font-size: 28px;
  color: #fff;
}

.keyword_wrap{
  width: 900px;
  margin: 0 auto;
}
.keyword_list li a{
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 52px;
  border-radius: 26px;
  text-align: center;
  font-size: 16px;
  color: #333;
  background-color: #fac698;
  line-height: 1.2;
}
.keyword_list li a:hover{
  opacity: .8;
  text-decoration: none;
}

.stop20_area{
  display: flex;
  justify-content: center;
  align-items: center;
  width: 562px;
  margin: 48px auto 0;
}
.stop20_img01{
  width: 46px;
}
.stop20_img02{
  width: 57px;
}
.stop20_text{
  font-size: 14px;
  flex: 1;
  padding: 0 11px;
}

/*
 shop
============================================*/
.modal_shop_btn{
  border: none;
  cursor: pointer;
  appearance: none;
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 480px;
  height: 72px;
  margin: 0 auto;
  border-radius: 36px;
  font-size: 18px;
  color: #fff;
  background-color: #c84605;
  box-sizing: border-box;
}
.modal_shop_btn .right_icon{
  margin-left: 8px;
}
.modal_shop_btn:hover{
  opacity: .8!important;
  text-decoration: none;
}

.shoplist_wrap + .shoplist_wrap{
  margin-top: 52px;
}
.shoplist_list li a{
  position: relative;
  display: inline-block;
  font-size: 12px;
  color: #333;
  padding: 4px 0 4px 12px;
  line-height: 1.1;
}
.shoplist_list li a::before{
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 2px;
  width: 2px;
  height: 2px;
  border-radius: 50%;
  margin: auto 0;
  background-color: #333;
}
.shoplist_list li a:hover{
  text-decoration: underline;
}

/*
 faq
============================================*/
.faq{
  padding-bottom: 100px;
}
.faq .title01 {
  padding-bottom: 80px;
}
.faq-anchorList {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 18px;
  justify-content: space-between;
}
.faq-anchorList__item {
  display: flex;
  width: 310px;
  height: 66px;
  margin-bottom: 64px;
  background-color: #c84605;
  box-sizing: border-box;
  border-radius: 4px;
}
.faq-anchorList__item:hover{
  opacity: .8;
  cursor: pointer;
}
.faq-anchorList__link {
  display: flex;
  align-items: center;
  width: 100%;
  height: 66px;
  font-size: 18px;
  padding-left: 16px;
  line-height: 1.2;
  position: relative;
  color: #fff !important;
}
.faq-anchorList__link:hover{
  text-decoration: none!important;
}
.faq-anchorList__link .down_icon {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 16px;
  margin: auto 0;
  font-size: 14px;
  widows: 1em;
  height: 1em;
  color: #fff;
  line-height: 1;
}
.faq-list + .faq-list{
  margin-top: 80px;
}
.faq-list__title {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #fac698;
  font-size: 28px;
  font-weight: bold;
  padding: 8px;
  margin-bottom: 20px;
}
.faq-list__subTitle {
  font-size: 14px;
  font-weight: bold;
  text-align: center;
  margin-bottom: 11px;
}
.faq-list__wrap {
  margin: 0 0 20px;
  border-radius: 4px;
  background-color: #fff;
  box-shadow: 0px 0px 12px 0px rgb(0 0 0 / 20%);
}
.faq-list__wrap:last-child {
  margin-bottom: 0;
}
.faq-list__question{
  margin: 0;
  cursor: pointer;
}
.faq-list__answer{
  margin: 0;
  display: none;
}
.faq-list__question:not(:first-child) {
  margin-top: 1px;
}
.faq-list__questionInner,
.faq-list__answerInner {
  display: flex;
  padding: 14px 16px;
}
.faq-list__questionInner {
  position: relative;
  font-weight: bold;
}
.faq-list__questionInner::before,
.faq-list__answerInner::before {
  font-size: 20px;
  font-weight: bold;
  min-width: 1.5em;
}
.faq-list__questionInner::before {
  content: "Q.";
  color: #c84605;
}
.faq-list__questionIcon {
  position: absolute;
  top: 50%;
  right: 15px;
}
.faq-list__questionIcon:before, .faq-list__questionIcon:after {
  content: "";
  width: 15px;
  position: absolute;
  display: block;
  right: 0;
  background: #c84605;
  transition: 0.3s ease;
  height: 2px;
}
.faq-list__questionIcon:after {
  transform: rotate(90deg);
}
.faq-list__question--open .faq-list__questionIcon:before {
  display: none;
}
.faq-list__question--open .faq-list__questionIcon:after {
  content: "";
  transform: rotate(180deg);
}
.faq-list__answerInner {
  background-color: #fff;
}
.faq-list__answerInner::before {
  content: "A.";
  color: #c84605;
  line-height: 1.2;
}
.faq-list__questionText,
.faq-list__answerText {
  font-size: 20px;
  line-height: 1.33;
  align-self: center;
  padding: 0 24px 0 4px;
}
.faq-list__questionText{
  font-weight: bold;
  padding: 0 24px 0 4px;
}
.faq-list__answerText{
  padding: 0 12px 0 4px;
}
.faq-list__answerImage {
  margin: -8px 8px 8px;
}
.faq-list__answerText a{
  text-decoration: underline;
  display: inline-block;
}
.faq-list__answerText a:hover{
  opacity:.8;
  text-decoration: underline!important;
}
.faq-button {
  margin-top: 16px;
}
.faq-button__list {
  background-color: #fff;
}
.faq-button__list:not(:first-child) {
  margin-top: 16px;
}
.faq-button__link {
  display: flex;
  flex-direction: column;
  padding: 10px 18px;
  border: 1px solid #bf0000 !important;
  border-radius: 4px;
}
.faq-button__text {
  text-align: center;
  line-height: 1.3;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #bf0000;
}
.faq-button__text .rex-icon {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  color: #bf0000;
}
.faq-button__subText {
  margin-top: 3px;
  display: block;
  line-height: 1.3;
  font-size: 11px;
  color: #333;
  text-align: center;
}
.faq-button__note {
  font-size: 12px;
  line-height: 1.33;
  margin-top: 16px;
  color: #8b8a8a;
  text-indent: -1em;
  padding-left: 1em;
}
.faq-list__questionInner:hover{
  opacity: .8;
  text-decoration: none;
}

/*
 alcor・ad
============================================*/
.alcor_wrap + .alcor_wrap{
  margin-top: 32px;
}
.alcor_item{
  border-radius: 8px;
  background-color: #fff;
  overflow: hidden;
  box-shadow: 0 0 6px rgba(0,0,0,.2);
}
.searchalcor_item{
  border-radius: 8px;
  background-color: #fff;
  overflow: hidden;
  box-shadow: 0 0 6px rgba(0,0,0,.2);
}
.ad_wrap + .ad_wrap{
  margin-top: 32px;
}
/* SP1カラム・PC1,2,3カラム */
.ad_wrap .ad_item01{
  padding: 16px;
  border-radius: 8px;
  background-color: #fff;
  overflow: hidden;
  box-shadow: 0 0 6px rgba(0,0,0,.2);
}
/* SP2カラム・PC4カラム */
.ad_wrap .ad_item02{
  border-radius: 8px;
  background-color: #fff;
  overflow: hidden;
  box-shadow: 0 0 6px rgba(0,0,0,.2);
}

#survey *{
  box-sizing: content-box;
}
