@charset "utf-8";
/* --------------------
 base settings
-------------------- */
#referral {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  color: #000;
  line-height: 1.4;
  -webkit-text-size-adjust: 100%;
}
#referral * {
  margin: 0;
  padding: 0;
  box-sizing: inherit;
}
#areaWrapper1 {
  width: auto !important;
}

@media screen and (min-width: 769px), print {
  #camInfo {
    margin: 3rem auto !important;
    width: 970px;
  }
}

#referral ol,
#referral ul {
  list-style: none;
}
.btnPageBtn {
  z-index: 100;
}
/* --------------------
 Class
-------------------- */
.center {
  text-align: center;
}
.nw {
  display: inline-block;
}
.keepall {
  word-break: keep-all;
}
.mincho {
  font-family: Garamond, 'Times New Roman', '游明朝', 'Yu Mincho', '游明朝体', 'YuMincho', 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', 'HiraMinProN-W3', 'HGS明朝E', 'ＭＳ Ｐ明朝', 'MS PMincho', serif;
}
.gothic {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', '游ゴシック体', 'Original Yu Gothic', '游ゴシック', 'Yu Gothic', YuGothic, Verdana, 'Meiryo UI', 'メイリオ', Meiryo, sans-serif;
}
.clearfix::after {
  content: '';
  clear: both;
  display: table;
}
.strong {
  color: #34a763;
  font-weight: bold;
  font-size: 0.9rem;
}
/* --------------------
 Content
-------------------- */
#referral {
  font-family: 'Noto Sans JP', sans-serif;
  padding: 0 0 20px 0;
  background-color: #fff;
}
.privileges {
  background-color: #f2f2f6 !important;
}
#referral .acc-body a {
  font-weight: bold !important;
  border-bottom: 1px solid #225496 !important;
}

#referral #KV {
  background: #ff9c04;
  background-image: linear-gradient(to left top, transparent 49.9%, #018837 50.1%);
}
#referral #KV p {
  padding: 1rem;
  background-size: cover !important;
  background-position: center !important;
  background: url('/library/contents/products/app/referral/bg_line.png') no-repeat;
}
#referral #KV img {
  hheight: auto;
  width: 95%;
  display: block;
  margin: 0 auto;
}

#referral .TermAttention {
  font-size: 1rem;
  font-weight: bold;
  color: #dd0b23;
  background-color: #f9d5db;
  text-align: center;
  padding: 1rem 1em;
}

#referral .wrapper {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding: 20px 8px;
  background-color: #fffae5;
}
#referral .previous-background {
  background-color: #ffffff00 !important;
}

#referral #Attention {
  width: 100%;
  padding: 32px 17px;
  background-color: #f2f2f6 !important;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 40px;
}
#referral .hd h2 {
}
#referral .Outline__ttl {
  font-size: 1.2rem;
  text-align: center;
  font-weight: bold;
  padding: 0;
  margin-bottom: 1rem;
}
#referral .Outline__ttl::after {
  content: '';
  background: url(/library/contents/products/app/referral/ttl_star.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  position: relative;
  display: block;
  margin-left: auto;
  margin-right: auto;
  margin-top: 13px;
  width: 62px;
  height: 13px;
  line-height: 0;
}
#referral .hd_bk h2 {
  font-family: corporate-logo-ver2, sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 1.8rem;
  text-align: center;
  margin-bottom: 0.5rem;
  margin: 30px auto 0.4rem;
  padding: 0 0 0.5rem 0;
  color: #000;
  width: 100%;
  line-height: 1;
}
#referral .hd_bk h2 img {
  height: 24px;
  width: auto;
  margin: 0 auto;
}
#referral .hd_bk h2::after {
  content: '';
  background: url(/library/contents/products/app/referral/ttl_star.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  position: relative;
  display: block;
  margin-left: auto;
  margin-right: auto;
  margin-top: 13px;
  width: 62px;
  height: 13px;
  line-height: 0;
}
#referral #Attention h2 {
  font-size: 1.25rem;
}
#referral #Attention h2::after {
  display: none;
  line-height: 0;
  margin-top: 13px;
}
#referral .hd_wh h2 {
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  text-align: center;
  padding: 0.5rem 0 0.5rem 0;
  color: #fff;
  background: #dd0b23;
  width: 100%;
}
#referral .bg_gray {
  background-color: #f5f5f5;
  padding: 2rem 1rem;
}
#referral .bg_white {
  background-color: #fff;
  padding: 2rem 1rem;
}
#referral .btn {
  margin: 1.5rem 0 2.4rem;
}
#referral .btn_btm {
  margin: 1.5rem 0 4.4rem;
}
#referral .btn__green {
  text-align: center;
  padding: 1rem 0;
  width: 100%;
  max-width: 270px;
  margin: 0 auto;
  border-radius: 5px;
  background-color: #008837;
  color: #fff;
  position: relative;
  display: block;
}
#referral .btn__green::after {
  position: absolute;
  right: 5%;
  top: 50%;
  width: 0.5em;
  height: 0.5em;
  content: '';
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: rotate(45deg) translate(-50%, -50%);
}
#referral .term {
  padding: 10px 0;
  font-size: 1rem;
  margin: 0 auto;
}
#referral .term p {
  margin-bottom: 1rem;
  font-weight: bold;
  text-align: center;
}
#referral .term p span.thin {
  font-weight: normal;
}
#referral .expiration {
  margin: 0.3rem 0 0.5rem 0;
  color: #5e5e5e;
  text-align: center;
  font-size: 1rem;
}
#referral #Coupon .term {
  margin: 0 5%;
  text-align: center;
}
#referral #Coupon .term img {
  padding: 1rem 3% 1rem;
  width: 350px;
}
#referral #Coupon .term dt {
  font-size: 1rem;
  margin: 1.2rem 0 0.2rem 0;
  font-weight: bold;
  border-bottom: 6px dotted #6cd698;
  display: inline-block;
}
#referral .description {
  margin: 0 3% 1.8rem;
  border-radius: 6px;
}
#referral .txt_cc_red {
  color: #ff0000;
}
#referral .txt_cc_orange {
  color: #ff6600;
}
#referral .txt_cc_green {
  color: #008837;
}
#referral #mainImg .title {
  padding: 6vw 4vw;
}
#referral #mainImg .photo {
  background-color: aliceblue;
  display: block;
  width: 100%;
  height: 50vw;
}
#referral .coupon {
  margin: 0 auto;
  padding: 0 0.5rem;
  text-align: center;
}
/*前月のクーポン*/
#referral #Previous {
}
/*accordion*/
#referral .acc-box {
  background: #ffffff;
  border: 4px solid #ff9c04;
  width: 100%;
  max-width: 750px;
  margin: 0 auto;
}
#referral .acc-sw {
  position: relative;
  font-size: 1.2rem;
  font-weight: bold;
  text-align: center;
  padding: 8px 2.5rem 8px 0.8rem;

  margin: 0 auto 0;
  width: 100%;
  max-width: 750px;
}
#referral .acc-img {
  color: #ff9c04;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 9%;
  right: 0.8rem;
  max-width: 20px !important;
}
#referral .Howto .flexslider {
  margin: 0;
  padding: 0;
}
#referral .slick-slide img {
  width: 100%;
  max-width: 260px !important;
  margin: 1rem auto;
}
#referral .slick-slide h3 {
  text-align: center;
}
#referral .Howto .tab-sw {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  text-align: center;
}
#referral .Howto .get-coupon {
  background: linear-gradient(90deg, #cce7d7 0%, #cce7d7 50%, #ffebcd 50%, #ffebcd 100%);
  display: block;
  max-width: 750px;
  margin: 0 auto;
}
#referral .get-coupon__contents {
  margin-bottom: 1rem;
}
#referral .get-coupon__contents .get-coupon__img {
  margin: 0 auto;
  display: block;
  width: 95%;
  max-width: 398px;
}
#referral .get-coupon .get-coupon__ttl {
  display: flex;
  justify-content: space-around;
  margin-bottom: 1rem;
}
#referral .get-coupon__ttl h3 {
  text-align: center;
  width: 50%;
  padding: 0.5rem 0;
  position: relative;
  z-index: 2;
  font-family: corporate-logo-ver2, sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 1rem;
  color: #fff;
}
#referral .get-coupon__ttl h3.ttl__green {
  background-color: #018837;
}
#referral .get-coupon__ttl h3.ttl__orange {
  background-color: #ff9c04;
}
#referral .get-coupon__ttl h3 img {
  height: min(11vw, 3rem);
  width: auto;
  margin: 0 auto;
}
#referral .get-coupon__ttl h3 span {
  font-size: 1.25em;
  display: block;
}
#referral .get-coupon__ttl h3.ttl__green:after {
  content: '';
  display: block;
  position: absolute;
  bottom: -14px;
  left: 50%;
  z-index: 1;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 14.1px 8.5px 0 8.5px;
  border-color: #018837 transparent transparent transparent;
  transform: translateX(-50%);
}
#referral .get-coupon__ttl h3.ttl__orange:after {
  content: '';
  display: block;
  position: absolute;
  bottom: -14px;
  left: 50%;
  z-index: 1;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 14.1px 8.5px 0 8.5px;
  border-color: #ff9c04 transparent transparent transparent;
  transform: translateX(-50%);
}
#referral .Howto .tab-body {
  position: relative;
}
#referral .Howto #tab202,
#referral .Howto #tab201 {
  background: #fff;
  display: block !important;
}
#referral .Howto #tab202 {
  position: absolute;
  top: 0;
}
#referral .Howto .tab01 {
  width: 50%;
  color: #fff;
  background: #008837;
}
#referral .Howto .tab02 {
  width: 50%;
  color: #fff;
  background: #ff6600;
}
#referral .Howto .tab01 a,
#referral .Howto .tab02 a {
  display: block;
  color: #fff;
  padding: 0.8rem 0;
  font-size: min(4.3vw, 1.2rem);
}
#referral .Howto .step {
  margin: 1rem auto;
  padding: 0 8px;
  max-width: 750px;
}
#referral .Howto .step img {
  width: 100%;
}
#referral .Howto .step .hedge {
  margin: 1rem;
}
#referral .Howto .step .hedge li {
  text-indent: -1.75em;
  padding-left: 1.75em;
}
#referral .Howto .step .hedge li:nth-child(1)::before {
  content: '※1 ';
}
#referral .Howto .step .hedge li:nth-child(2)::before {
  content: '※2 ';
}
#referral .Howto .step .hedge li:nth-child(3)::before {
  content: '※3 ';
}
#referral .Howto .step img {
}
/*追従ナビゲーション */
#referral .app-g-navbody {
  width: 100%; /*横幅指定*/
  max-width: 300px;
  position: fixed;
  z-index: 100;
  left: 50%;
  bottom: 20px;
  transform: translateX(-50%);
  text-align: center;
}
#referral .app-g-nav {
}
#referral .app-g-nav li {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
#referral .app-g-nav li a {
  font-size: min(3.8vw, 1rem);
  width: 100%;
  color: #ffffff;
  display: block;
  position: relative;
  text-align: center;
  text-decoration: none;
  /* font-weight: bold; */
  background-color: #ff9c04;
  padding: 0.7rem 0.2rem 0.7rem 0.9rem;
  /* max-width: 384px; */
  margin: 0 auto;
  border-radius: 8rem;
  letter-spacing: 0.05em;
  font-weight: 700;
  border: 3px solid #000;
  box-shadow: 2.5px 2.5px rgba(0, 0, 0, 0.4);
}
/*#referral .app-g-nav li a::after {
  position: absolute;
  left: 8%;
  top: 54%;
  width: 0.5em;
  height: 0.5em;
  content: "";
  border-top: 1px solid #ffffff;
  border-right: 1px solid #ffffff;
  transform: rotate(45deg) translate(-50%, -50%);
}*/
#referral .app-g-nav li a::after {
  position: absolute;
  left: 8%;
  top: 50%;
  width: 1.2em;
  height: 1.2em;
  content: '';
  background-size: cover !important;
  background-position: center;
  background: url(/library/contents/products/app/referral/app-nav_icon.png) no-repeat;
  transform: translateY(-50%);
}

#referral .app-g-nav_pc li a {
  font-size: min(3.8vw, 1rem);
  width: 100%;
  color: #ffffff;
  display: block;
  position: relative;
  text-align: center;
  text-decoration: none;
  /* font-weight: bold; */
  background-color: #ff9c04;
  padding: 0.7rem 0.2rem 0.7rem 0.9rem;
  /* max-width: 384px; */
  border-radius: 8rem;
  letter-spacing: 0.05em;
  font-weight: 700;
  right: 0;
  text-orientation: upright;
}
#referral .app-g-nav_pc li a::after {
  position: absolute;
  text-orientation: upright;
  left: 8%;
  top: 50%;
  width: 1em;
  height: 1em;
  content: '';
  /* border-top: 1px solid #ffffff; */
  /* border-right: 1px solid #ffffff; */
  /* transform: rotate(45deg) translate(-50%, -50%); */
}
/*スライダー*/
#referral .flexslider {
  margin-bottom: 0 !important;
}
#referral .slider {
  margin-bottom: 3rem !important;
}
/* アプリダウンロード　上 */
#referral #DL-section {
  text-align: center;
  padding: 2rem 1rem;
  background-color: #0a9d30;
  border-radius: 6px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
}
#referral .DL-section__title {
  font-size: 1rem;
  text-align: center;
  line-height: 1.3;
  padding: 0.1em 1.5em;
  border-radius: 0.8em;
  margin-bottom: 1em;
  font-weight: bold;
  display: inline-block;
  color: #fff;
}
#referral .DL__list li:last-child {
  margin-right: 0;
}
#referral .DL-QR {
  display: none;
}
#referral .DL-link {
}
#referral .DL-link dt {
  font-weight: bold;
  font-size: 4vw;
  line-height: 1.2;
  margin-bottom: 0.5em;
}
#referral .DL-section__hedge {
  color: #fff;
  font-size: 0.8rem;
}
/* nanaco　movie */
#referral .app_merit {
}
#referral .yt_movie {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
#referral .yt_movie iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}
#referral .app_beginner {
}
#referral .app_beginner .subtit {
  font-size: 0.8rem;
  margin-bottom: 0.8rem;
  display: block;
}
#referral .app_beginner .subtit::before {
  content: '';
  display: inline-block;
  width: 1em;
  height: 1.5em;
  background-size: contain;
  vertical-align: middle;
  background-repeat: no-repeat;
  background-image: url('/library/contents/products/app2206/begin.svg');
}
#referral .app_beginner .yt_movie {
  margin-bottom: 0.8rem;
}
#referral .app_beginner .txt {
  margin-bottom: 0.8rem;
}
/* 汎用 */
#referral .section {
  border-top: none;
  padding: 1vw 2vw 1vw;
  margin: 1rem 1rem 0 1rem;
}
#referral .subTTL {
  font-size: 5vw;
  line-height: 1.3;
  text-align: center;
  color: #000;
  padding: 0.4em 0.5em;
  margin: 0 10px;
}
/*banner*/
#referral .banner {
  margin: 0 1rem;
}
#referral .banner a {
  width: 100%;
  max-width: 400px;
  margin: 0 auto;
  display: block;
}
#referral .banner a img {
  border-radius: 0.5rem;
}
/* キャンペーン情報 */
#referral #camInfo {
}
/* 新しくなった */
#referral #introduction {
}
#referral .introList {
  width: 85%;
  margin: 3vw auto 0;
}
#referral .introList li {
  text-align: center;
  margin-bottom: 9vw;
}
#referral .introList li:last-child {
  margin-bottom: 3vw;
}
/* アプリの使い方 */
#referral #howto {
  width: 100%;
}
#referral #howto .list {
  margin: 0 1rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
#referral #howto .list a {
  margin: 1rem 1% 0;
  width: 31%;
}
#referral #howto .list::after {
  display: block;
  content: '';
  margin: 1rem 1% 1rem;
  width: 31%;
}
#referral #howto .list a dl {
  display: block;
  border: 3px solid #008837;
  border-radius: 6px;
  text-align: center;
  background-color: #008837;
}
#referral #howto .list a dt {
  background-color: #fff;
  padding: 0 2.5vw;
  border-radius: 6px 6px 0 0;
  display: flex;
  align-items: center;
}
#referral #howto .list a dt img {
  width: 100%;
  display: flex;
  align-items: center;
}
#referral #howto .list a dd {
  color: #fff;
  font-weight: bold;
  padding: 1vw 0;
  position: relative;
  font-size: 0.8rem;
  display: block;
}
#referral #howto .list a dd::after {
  position: absolute;
  right: 5%;
  top: 50%;
  width: 0.5em;
  height: 0.5em;
  content: '';
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: rotate(45deg) translate(-50%, -50%);
}
#referral #howto .list a img {
}
#referral .howto__omni {
  margin: 1rem 0 0;
  text-align: center;
}
#referral .howto__omni dl dt {
  margin-bottom: 1rem;
}
/* アプリダウンロード　下 */
#referral #AppDL {
  text-align: center;
  padding: 2rem 1rem;
  background-color: #ff9c04;
  margin-top: 50px;
}
/* バナーエリア */
#referral #Bnr-section {
  margin: 10vw 10px 15vw;
}
#referral #Bnr-section ul {
}
#referral #Bnr-section li {
  margin-bottom: 5vw;
}
#referral .btn-normal a {
  display: block;
  text-align: center;
  font-size: 4.5vw;
  color: #fff;
  line-height: 1.3;
  text-decoration: none;
  background: #50a974; /* Old browsers */
  background: -moz-linear-gradient(top, #50a974 0%, #40a167 4%, #228349 94%, #1b663a 98%); /* FF3.6-15 */
  background: -webkit-linear-gradient(top, #50a974 0%, #40a167 4%, #228349 94%, #1b663a 98%); /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to bottom, #50a974 0%, #40a167 4%, #228349 94%, #1b663a 98%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  position: relative;
  padding: 1.1em 1em;
  border-radius: 0.3em;
  box-shadow: 1px 1px 3px #666;
}
#referral .btn-normal a:after {
  position: absolute;
  top: 50%;
  right: 0.5em;
  width: 0;
  height: 0;
  content: '';
  border-left: 0.6em solid #fff;
  border-top: 0.4em solid transparent;
  border-bottom: 0.4em solid transparent;
  transform: translate(0, -50%);
}
#referral a:hover {
  opacity: 0.8;
  text-decoration: none;
}
/* お問い合わせ */
#referral #contact {
  margin: 0 1rem;
  text-align: center;
}
#referral .contact__title {
  font-size: 5vw;
  text-align: center;
  font-weight: normal;
  margin-bottom: 1em;
}
#referral .contact__dl {
  margin-bottom: 5vw;
}
#referral .border_dotted {
  margin: 2rem auto;
  width: 90%;
  border-top: 1px dotted #ccc;
}
/*#referral .border_dotted__center{
	margin: 0 2rem;
	height: 114px;
	border-left: 1px dotted #ccc;
}*/
#referral .contact__dl dt {
  font-weight: bold;
  font-size: 0.9rem;
  margin-bottom: 1rem;
}
#referral .contact__dl dd {
  font-size: 0.85rem;
}
#referral .contact__dl dd.linktxt {
}
#referral .contact__faq {
}
#referral .contact__faq dd a {
  text-align: center;
  padding: 1rem 0;
  width: 100%;
  max-width: 500px;
  margin: 0 auto;
  border-radius: 5px;
  border: solid 1px #008837;
  background-color: #d5f3e3;
  color: #008837;
  position: relative;
  font-size: 1rem;
  display: block;
}
#referral .contact__faq dd a::after {
  position: absolute;
  right: 5%;
  top: 50%;
  width: 0.5em;
  height: 0.5em;
  content: '';
  border-top: 1px solid #008837;
  border-right: 1px solid #008837;
  transform: rotate(45deg) translate(-50%, -50%);
}
#referral .contact__dl dd.tel {
  font-size: 8.5vw;
  font-weight: bold;
  color: #008837;
}
#referral .contact__other {
  color: #008837;
  font-weight: bold;
  font-size: 1.4rem;
  margin: 2rem 0 3rem;
  position: relative;
  display: block;
}
#referral .contact__other::after {
  position: absolute;
  bottom: -4rem;
  height: 0.5em;
  content: '';
  transform: rotate(0) translateY(-50%) translateX(-50%); /* 縦軸をセンタリングする */
  border: 9px solid transparent;
  border-top: 16px solid #008837;
}
#referral .contact__dl dd .contact__hedge {
  display: block;
  font-size: 0.85rem;
  font-weight: normal;
  color: #000;
  line-height: 1.3;
}
#referral .contact__attention {
  font-size: 0.75rem;
  color: #fff;
  background-color: #ff6600;
  padding: 0.5rem;
}
/* 中バナー挿入プラグイン */
#referral #camInfo.section {
  padding: 6vw 2vw 2vw;
}
#referral .top-layout01.img-310 .block {
  padding: 0 5px;
  margin-bottom: 1em;
}
#referral .top-layout01 .block .txt-box {
  padding: 0.5em 0;
}
#referral .top-layout01 .block .txt-box p {
  font-size: 0.8rem;
}
/* 期間限定QR 202109 */
#referral ul.DL-separate {
  text-align: center;
}
#referral .DL-separate_QR {
  display: none;
}
#referral li.DL-separate_Btn {
  padding: 0 0 6vw;
}
#referral li.DL-separate_Btn a {
  display: block;
  text-align: center;
  text-decoration: none;
  color: #ff9c04;
  font-size: 1rem;
  font-weight: bold;
  background-color: #fff;
  padding: 1rem 0;
  width: 100%;
  max-width: 350px;
  margin: 0 auto;
  border-radius: 4rem;
  border: 3px solid #000;
  box-shadow: 5px 5px rgba(0, 0, 0, 0.4);
  position: relative;
}
#referral li.DL-separate_Btn a span {
  font-size: 1.5rem;
  font-weight: bold;
}
#referral li.DL-separate_Btn a:hover {
}
#referral li.DL-separate_Btn a:after {
  position: absolute;
  right: 5%;
  top: 50%;
  width: 0.5em;
  height: 0.5em;
  content: '';
  transform: rotate(45deg) translate(-50%, -50%);
}
#referral .tab_container {
  margin: 0 auto;
  width: 100%;
  max-width: 750px;
  background-color: #cce7d7;
}
#Faq {
  background-color: #fff !important;
}
/* スライダーの初期設定 */
#referral .slide {
  width: 100%;
  background: #ccc;
}
#referral .slick-arrow {
  top: 53%;
  transform: translateY(-50%);
  z-index: 88;
  width: 38px;
  height: 38px;
  white-space: nowrap;
  padding: 0;
}
.slick-prev:before,
.slick-next:before {
  color: rgba(255, 255, 255, 0) !important;
}
#referral .slick-prev {
  left: 0;
  background: url('/library/contents/products/app/referral/prev_referral_red__sp.png');
}

#referral .slick-next {
  right: 0;
  background: url('/library/contents/products/app/referral/next_referral_red__sp.png');
}
#referral .slick-prev.slick-disabled,
#referral .slick-next.slick-disabled {
  display: none !important;
}
#referral .slick-prev,
#referral .slick-next {
  overflow: visible;
  content: '';
  background-size: cover;
  width: 47px;
  height: 42.5px;
  position: absolute;
}
/*タブ切り替え全体のスタイル*/
#referral .tabs {
  margin-top: 50px;
  background-color: #fff;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
  width: 100%;
  margin: 0 auto;
}
/*タブのスタイル*/
#referral .tab_item {
  width: 100%;
  height: 50px;
  background-color: #d9d9d9;
  line-height: 50px;
  font-size: 16px;
  text-align: center;
  color: #fff;
  display: block;
  float: left;
  font-weight: bold;
  transition: all 0.2s ease;
}
#referral .tab_item.label01 {
  background: #018837;
}
#referral .tab_item.label02 {
  background: #ff9c04;
}
/*ラジオボタンを全て消す*/
#referral input[name='tab_item'] {
  display: none;
}
/*タブ切り替えの中身のスタイル*/
#referral .tab_content {
  display: none;
  padding: 40px 0;
  clear: both;
  overflow: hidden;
  position: relative;
}
/*選択されているタブのコンテンツのみを表示*/
#referral #tab01:checked ~ #tab01_content,
#referral #tab02:checked ~ #tab02_content {
  display: block;
}
#referral #tab01:checked ~ #tab01_content {
  background-color: #cce7d7;
}
#referral #tab02:checked ~ #tab02_content {
  background-color: #ffebcd;
}
#referral .label_box {
  height: 50px;
  /* width: 100%; */
  width: calc(100% / 2);
  display: inline-block;
  float: left;
} /*
#referral .label_box:hover {
  filter: brightness(115%);
}*/
/*#referral .label_box:hover:after {
  filter: brightness(150%);
}*/
#referral .box01.tab-active {
  position: relative;
}
#referral .box01.tab-active:after {
  content: '';
  display: block;
  position: absolute;
  bottom: -16px;
  left: 50%;
  z-index: 34;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 25.1px 14.5px 0 14.5px;
  border-color: #018837 transparent transparent transparent;
  transform: translateX(-50%);
}
#referral .box02.tab-active {
  position: relative;
}
#referral .box02.tab-active:after {
  content: '';
  display: block;
  position: absolute;
  bottom: -16px;
  left: 50%;
  z-index: 34;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 25.1px 14.5px 0 14.5px;
  border-color: #ff9c04 transparent transparent transparent;
  transform: translateX(-50%);
}
/*選択されているタブのスタイルを変える*/
#referral .tabs input:checked + #referral .tab_item {
  background-color: #5ab4bd;
  color: #fff;
}
#referral #tab02_content {
  background: #c1ffff;
}
#referral #tab03_content {
  background: #c1ffe0;
}

#referral .contact__dl {
  text-align: center;
  display: block;
  width: 100%;
  margin: 2rem auto 0;
  padding: 0 1rem;
}
#referral .contact__dl dt {
  font-weight: bold;
  font-size: 1.2rem;
  margin-bottom: 1rem;
  word-break: keep-all;
  line-break: strict;
  word-wrap: break-word;
  overflow-wrap: break-word;
}
#referral .btn__green {
  text-align: center;
  padding: 1rem 0;
  width: 100%;
  max-width: 500px !important;
  margin: 0 auto;
  font-size: 0.85rem;
  border-radius: 5px;
  background-color: #008837;
  color: #fff;
  position: relative;
  display: block;
}

/*#referral .slick-dots {
    display: flex;
}

#referral .slick-dots li {
        background: #fff;
    box-shadow: none;
    overflow: hidden;
    width: 12px !important;
    height: 12px !important;
    margin: 0 5px;
    border: 1px solid #555;
}*/
/* --------------------
 Smart device
-------------------- */
@media screen and (max-width: 425px) {
  /* TB-SP Switch */

  .btnPageBtn {
    bottom: 80px !important;
    right: 0% !important;
    transform: translateX(-25%);
  }
  /* アプリの使い方 */
  #referral #howto .list {
    margin: 0;
  }
  #referral #howto .list a {
    margin: 0 1% 1rem;
    width: 46%;
  }
  #referral #howto .list::after {
    display: none;
  }
  #referral #howto .list a dt {
    padding: 0 6px;
  }
  #referral #howto .list a dd {
    padding: 6px 0;
  }
  #referral .note {
    text-align: center;
    line-height: 1.5;
  }
  #referral .note ul {
    display: inline-block;
    text-align: left;
  }
  #referral .term-wrap {
    margin-bottom: 20px;
  }
  #referral .term-wrap .term-container {
    display: flex;
    justify-content: center;
  }
  #referral .data-container {
    display: flex;
    flex-direction: column;
    gap: 5px;
    padding: 30px;
    margin: 20px 20px 0 20px;
    border: solid 2px #000;
    font-weight: bold;
  }
  #referral .data-container dt {
    border-bottom: solid 1px #000;
    margin-bottom: 20px;
    font-size: clamp(1rem, 4.32vw, 1.5rem);
    font-weight: 800;
    text-align: center;
    width: 95%;
  }
  #referral .data-container dd {
    font-size: clamp(1rem, 4.32vw, 1rem);
  }
}
/* Flexslider */
#referral .slide-ttl {
  padding: 1.2em 1em 0.5em;
}
#referral .slide-caption {
  display: inline-block;
  text-align: center;
  margin-top: 0;
  padding: 0 1em;
  width: 100%;
  font-weight: bold;
  font-size: 90%;
}
#referral .slide-caption span {
  color: #666;
}
#referral .flex-control-nav {
  display: block !important;
  position: relative;
  bottom: 0 !important;
  line-height: 1;
}
#referral .flex-control-paging li a {
  background: #fff;
  -webkit-box-shadow: none;
  -moz-box-shadow: none;
  -o-box-shadow: none;
  box-shadow: none;
  overflow: hidden;
  width: 12px !important;
  height: 12px !important;
  margin: 0 5px;
  border: 1px solid #aaa;
}
#referral .flex-control-paging li a.flex-active,
#referral .flex-control-paging li a.active,
#referral .bx-wrapper .flex-control-paging li a:focus {
  background: #044a28;
  border: 1px solid #044a28;
}
#referral .flex-control-paging li a:hover {
  background: #91d7f3;
}
#referral .flex-direction-nav a.flex-prev {
  left: 10px;
  background: url('/library/contents/products/app/howto_20220324/controls_prev.png') no-repeat 0 0;
  background-size: contain;
}
#referral .flex-direction-nav a.flex-next {
  right: 10px;
  background: url('/library/contents/products/app/howto_20220324/controls_next.png') no-repeat 0 0;
  background-size: contain;
}
#referral .flex-direction-nav a {
  position: absolute;
  top: 33%;
  margin-top: -16px;
  outline: 0;
  width: 32px;
  height: 32px;
  text-indent: -9999px;
  z-index: 9999;
  line-height: 2;
}
#referral #Faq .acc-box {
  border: 2px solid #000;
  margin: 1rem auto;
  max-width: 750px;
  border-radius: 5px;
}
#referral #Faq .acc-box h3 {
  text-align: left;
  font-size: min(4.5vw, 1.2rem);
}
#referral #Faq .ans {
  text-align: left;
  margin: 0;
  /* font-size: 0.8rem; */
  padding: 0.2rem 0.8rem 1rem;
  line-height: 1.4;
}
#referral #Attention .att_item {
  margin: 0 auto 2rem;
  max-width: 750px;
  width: 100%;
}
#referral #Attention h3 {
  font-size: 1.1rem;
  margin: 0.5rem 0;
  position: relative;
  padding-left: 1em;
}
#referral #Attention h3::before {
  display: block;
  position: absolute;
  width: 0.55em;
  height: 1.2em;
  left: 0.1em;
  top: 0;
  transform: translateY(5%);
  content: '';
  background-color: #018837;
}
#referral #Attention .h3_bl::before {
  background-color: #ff9c04;
}
#referral #Attention .h3_privieges::before {
  background-color: #018837;
}
#referral #Attention .dual::before {
  background: linear-gradient(180deg, #018837 0%, #018837 50%, #ff9c04 50%, #ff9c04 100%);
}
#referral #Attention .txt {
  line-height: 1.4;
  margin-left: 1em;
  text-indent: -1em;
}
#referral #Attention .indent0 {
  text-indent: 0;
}
#referral #Attention .txt_indent2 {
  margin-left: 2em;
  text-indent: 0;
}
#referral #Attention .red {
  color: #dd0b23;
}
#referral .app-bottom-nav {
  display: flex;
  width: 100%;
  margin: 0 auto;
  justify-content: center;
  align-items: center;
  padding: 10px 0;
}
#referral .app-bottom-nav li {
  width: 70%;
  display: flex;
  justify-content: center;
  align-items: center;
  max-width: 300px;
}
#referral .app-bottom-nav li a {
  font-size: min(3.8vw, 1rem);
  width: 100%;
  color: #ffffff;
  display: block;
  position: relative;
  text-align: center;
  text-decoration: none;
  /* font-weight: bold; */
  background-color: #ff9c04;
  padding: 0.7rem 0.2rem 0.7rem 0.9rem;
  /* max-width: 384px; */
  margin: 0 auto;
  border-radius: 8rem;
  letter-spacing: 0.05em;
  font-weight: 700;
  border: 3px solid #000;
  box-shadow: 2.5px 2.5px rgb(0 0 0 / 40%);
}
#referral .app-bottom-nav li a::after {
  position: absolute;
  left: 8%;
  top: 50%;
  width: 1.2em;
  height: 1.2em;
  content: '';
  background-size: cover !important;
  background-position: center;
  background: url(/library/contents/products/app/referral/app-nav_icon.png) no-repeat;
  transform: translateY(-50%);
}
.slick-dots li.slick-active button:before {
  color: #044a28 !important;
  opacity: 1 !important;
}
.slick-dots li button:before {
  font-size: 13px !important;
}

/* アプリダウンロード */
#AppDL {
  padding: 0;
}
#AppDL p {
  text-align: center;
  font-size: 120%;
}
#AppDL .gray {
  color: #666666;
  font-size: 0.75rem;
}
#AppDL .AppDL__title {
  color: #000;
  font-size: 4.5vw;
  text-align: center;
  padding-bottom: 1rem;
}
#AppDL .AppDL__list {
  overflow: hidden;
}
#AppDL .AppDL__list li {
  float: left;
  margin-top: 0.8rem;
}
#AppDL .AppDL__list li .AppDL__ios_ttl {
  width: 70%;
  margin: 0 auto;
  padding: 0;
}
#AppDL__ios {
  width: 44%;
}
#AppDL__android {
  width: 56%;
}
#AppDL .AppDL__list li dl {
  padding: 0 2%;
}
#AppDL .AppDL__list li dt {
  color: #000;
  text-align: center;
  font-size: 3.5vw;
  margin-bottom: 0.4em;
}
#referral #AppDL li.DL-separate_Btn a:after {
  position: absolute;
  display: block;
  left: 10%;
  top: 2em;
  width: 1.8em;
  height: 1.8em;
  content: '';
  background: url('/library/contents/products/app/referral/app-nav_icon_or.png') no-repeat center center;
  background-size: 100% 100%;
  transform: translate(0, -50%);
}

/*スライドドット*/
.slick-dots li button:before {
  position: absolute;
  top: 0;
  left: 0;
  content: ' ' !important;
  background-image: url('/library/contents/products/app/referral/dot02.png');
  background-size: contain;
  background-repeat: no-repeat !important;
  background-position: center !important;
  width: 12px !important;
  height: 16px !important;
  font-family: 'slick';
  font-size: 6px;
  line-height: 20px;
  text-align: center;
  color: black;
  opacity: 1 !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.slick-dots li.slick-active button:before {
  color: black;
  background-image: url('/library/contents/products/app/referral/dot01.png');
  opacity: 1 !important;
}
#referral .font-small {
  font-size: 0.9em;
}

/*獲得条件_privieges*/
#referral .privieges-title {
  font-size: 1.2rem;
  text-align: center;
  margin: 0 auto 0 0.2rem;
  padding: 1rem 0 0.5rem 0;
  color: #000;
  background: transparent;
  width: 100%;
}
#referral .conditions {
  padding: 0 8px;
  border-top: 2px #ccc solid;
}
#referral .conditions table {
  margin: 0 auto;
  max-width: 700px;
  border-collapse: separate;
}
#referral .conditions table tr {
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  background-color: #ebfff4;
}
#referral .left {
  background-color: #34a763;
  text-align: center;
  align-items: center;
  align-self: stretch;
  color: #fff;
  font-size: 1.15rem;
  line-height: 2;
  padding: 10px;
}
#referral .right {
  width: 92%;
  padding: 10px;
  line-height: 1.5;
  /*
  border-top: solid 2px #d9d9d9;
    border-right: solid 2px #d9d9d9;
    border-bottom: solid 2px #d9d9d9;*/
  font-weight: normal;
}
/*受け取れるクーポン_privieges*/
#coupon {
  padding: 0 8px;
}
#coupon .coupon-area {
  text-align: center;
}
#coupon .coupon-box {
  padding: 1rem 0.8rem;
  border: 2px solid #d9d9d9;
  background-color: #fff;
}
#coupon .coupon-box1 {
  margin-bottom: 1rem;
}
#coupon .coupon-box dt {
  font-size: 1rem;
  font-weight: bold;
  margin-bottom: 0.8rem;
  padding-bottom: 0.4rem;
}
#coupon .coupon-box dd {
  font-size: 0.785rem;
}
#coupon .coupon-box img {
  padding-top: 20px;
}
#coupon .coupon-box p {
  color: #5e5e5e;
  text-align: center;
  margin: 0.3rem 0 0;
}
/* --------------------
 Smart device
-------------------- */
@media screen and (max-width: 768px) {
  /* PC-SP Switch */
  .dispPC {
    display: none;
  }
  .btnPageBtn {
    bottom: 40px;
  }
  /*獲得条件_privieges*/
  #referral .conditions table tr {
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    background-color: #ebfff4;
  }

  /* クーポン */
  #referral .slick-next {
    right: 0 !important;
    background: url('/library/contents/products/app/referral/next_referral_red__sp.png') no-repeat 0 right !important;
  }
  #referral .slick-prev {
    left: 0 !important;
    background: url('/library/contents/products/app/referral/prev_referral_red__sp.png') no-repeat 0 left !important;
  }
  #referral .app-g-navbody_pc {
    display: none;
  }
  #referral .note {
    text-align: center;
    line-height: 1.5;
    text-indent: -1em;
    padding: 30px;
  }
  #referral .note ul {
    display: inline-block;
    text-align: left;
  }
  #referral .term-wrap {
    margin-bottom: 20px;
  }
  #referral .term-wrap .term-container {
    display: flex;
    justify-content: center;
  }
  #referral .data-container {
    display: flex;
    flex-direction: column;
    gap: 5px;
    padding: 30px;
    margin: 20px 20px 0 20px;
    border: solid 2px #000;
    font-weight: bold;
  }
  #referral .data-container dt {
    border-bottom: solid 1px #000;
    margin-bottom: 20px;
    font-size: clamp(1rem, 4.32vw, 1.5rem);
    font-weight: 800;
    text-align: center;
    width: 95%;
  }
  #referral .data-container dd {
    font-size: clamp(1rem, 4.32vw, 1rem);
  }
}
/* --------------------
 PC and Print
-------------------- */
@media screen and (min-width: 769px), print {
  /* PC-SP Switch */
  .dispSP {
    display: none;
  }
  /* ----- Content ----- */
  #referral #contsArea {
    width: 970px;
    margin: 0 auto;
  }
  /* 汎用 */
  #referral #KV img {
    width: 100%;
    max-width: 474px;
    margin: 0 auto;
  }
  #referral #KV p {
    position: relative;
  }
  #referral #KV p::after {
    content: url('/library/contents/products/app/referral/bg-star.png');
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    display: block;
  }
  #referral .wrapper {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
  #referral #Faq {
    padding: 31px 0 29px;
  }
  #referral h2 {
    font-size: 1.5rem;
    display: block;
    text-align: center;
    margin: 0 auto;
    width: 750px !important;
  }
  #referral .btn__green {
    max-width: 270px;
    font-size: 1rem;
  }
  #referral .term {
    padding: 15px 20px;
    font-size: 1.2rem;
    width: 100%;
    max-width: 750px;
    line-height: 1;
  }
  #referral .term p {
    font-size: 1.2rem;
  }
  #referral .hd_bk h2 {
    font-size: 2rem;
  }
  #referral .hd_bk h2 img {
    height: 26px;
  }
  #referral .hd_wh h2 {
    font-size: 1.5rem;
  }
  #referral .get-coupon__ttl h3 {
    line-height: 0;
  }
  #referral .get-coupon__ttl h3 img {
    height: 18px;
  }
  /*クーポン*/
  #referral .coupon img {
    width: 500px;
  }
  #referral .term {
    text-align: center;
  }
  /*前月*/
  #referral .expiration {
    margin: 0.7rem 0 1rem 0;
    font-size: 1.2rem;
  }
  #referral .acc-box {
    /*border: 4px solid #ff9c04;
    margin: 2rem auto;
    padding: 0;*/
  }
  /*slick*/
  #referral .label_box {
    height: 55px;
    font-size: 1.2rem;
  }
  #referral .tab_item {
    height: 55px;
    font-size: 1.2rem;
    padding: 0.1rem 0 0 0;
  }
  #referral .slickslide img {
    width: 275px;
    margin: 0 auto;
  }
  #referral .slick-arrow {
    position: absolute;
    top: 42%;
  }
  #referral .slick-next {
    right: 140px;
    background: url('/library/contents/products/app/referral/next_referral_red.png') no-repeat 0 0;
  }
  #referral .slick-prev {
    left: 140px;
    background: url('/library/contents/products/app/referral/prev_referral_red.png') no-repeat 0 0;
  }

  #referral #Faq .ans {
    font-size: 0.9rem;
  }

  #referral #Attention .dual::before {
    height: 1.2em;
  }

  /*追従ナビゲーション */
  #referral .app-g-navbody {
    width: 100%; /*横幅指定*/
    position: fixed;
    z-index: 100;
    left: 0;
    bottom: 0;
    /*  background:#0A9D30;*/
    text-align: center;
  }
  #referral .app-g-nav {
    display: flex;
    width: 970px;
    margin: 0 auto;
    justify-content: center;
    align-items: stretch;
    padding: 10px 0 20px;
  }
  #referral .app-g-nav li {
    width: 30%;
    display: none;
    justify-content: center;
    align-items: center;
    border-radius: 6px;
    margin: 0 2%;
  }
  #referral .app-g-navbody_pc {
    left: auto;
    bottom: 0;
    top: 30%;
    right: 0;
    width: 71px;
    height: 331px;
    position: fixed;
    z-index: 2;
    /*display: block;*/
  }
  #referral .app-g-navRight img {
    display: block;
    width: 71px;
    height: 331px;
    border-left: 3px solid #000;
    border-top: 3px solid #000;
    border-bottom: 3px solid #000;
    border-radius: 24px 0 0 24px;
    box-shadow: 5px 5px rgba(0, 0, 0, 0.4);
  }

  #referral .acc-img {
    width: 100%;
  }
  #referral ul.DL-separate {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 1rem;
  }
  #referral .DL-separate_QR {
    display: block;
    width: 112px;
    border-radius: 6px;
    padding: 11px;
    background-color: #fff;
  }
  #referral li.DL-separate_Btn {
    padding: 0;
  }

  #referral .Howto .step {
    padding: 0;
  }
  #referral .contact__dl {
    margin-bottom: 0;
  }
  #referral .contact__dl dt {
    margin-bottom: 1rem;
    font-size: 1rem;
  }
  #referral .slide-caption {
    padding: 0.5em 30px 1em;
    text-align: center;
    font-size: 0.95rem;
    line-height: 1.7;
  }

  /* アプリダウンロード */
  #AppDL {
    padding: 0;
    width: 100%;
    max-width: 750px;
    margin: 0 auto;
  }

  #AppDL h3 {
    color: #fff;
    font-size: 1.7rem;
    margin-bottom: 0.6em;
  }
  #referral #AppDL .DL-separate {
    padding: 10px 60px 0;
  }
  #referral #AppDL li.DL-separate_QR {
    width: 140px;
    margin: 0;
    display: inline-block;
    letter-spacing: normal;
    vertical-align: middle;
  }
  #referral li.DL-separate_Btn a span {
    font-size: 1em;
  }
  #referral #AppDL li.DL-separate_QR img {
    width: 100%;
  }
  #referral #AppDL li.DL-separate_Btn {
    padding: 0 0 0 30px;
    display: inline-block;
    text-align: center;
    color: #fff;
  }
  #referral #AppDL li.DL-separate_Btn a {
    margin-bottom: 1rem;
  }
  #referral #AppDL li.DL-separate_Btn a:after {
    left: 35px;
    top: 50%;
    width: 25px;
    height: 25px;
    content: '';
    background-size: 100% auto;
  }
  #referral .note {
    text-align: center;
    line-height: 1.5;
  }
  #referral .note ul {
    display: inline-block;
    text-align: left;
  }
  #referral .term-wrap {
    margin-bottom: 20px;
  }
  #referral .term-wrap .term-container {
    display: flex;
    justify-content: center;
  }
  #referral .data-container {
    display: flex;
    flex-direction: column;
    gap: 5px;
    padding: 30px;
    margin: 20px 20px 0 20px;
    border: solid 2px #727272;
    font-weight: bold;
  }
  #referral .data-container dt {
    border-bottom: solid 1px #000;
    margin-bottom: 20px;
    font-size: clamp(1rem, 4.32vw, 1.5rem);
    font-weight: 800;
    text-align: center;
    width: 95%;
  }
  #referral .data-container dd {
    font-size: clamp(1rem, 4.32vw, 1rem);
  }
}

#referral .item {
  display: flex;
  flex-direction: column;
}
#referral .itemList {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  row-gap: min(7.4666666667vw, 2.5rem);
  margin-inline: auto;
  max-width: 28.75rem;
}
#referral .itemList__item {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 4;
  gap: 0.75rem;
  position: relative;
  width: 100%;
  margin: 0 auto;
  text-align: center;
}
#referral .itemList__img {
  margin: auto auto 0;
  width: 100%;
  max-width: 20rem;
}
#referral .itemList__name {
  font-weight: 700;
  font-size: min(4.2666666667vw, 1.125rem);
}
#referral .itemList__price {
  display: inline-block;
  background: linear-gradient(to right, #8a8a8a, #8a8a8a 2px, transparent 2px, transparent 8px) repeat-x left top/8px 2px, linear-gradient(to right, #8a8a8a, #8a8a8a 2px, transparent 2px, transparent 8px) repeat-x left bottom/8px 2px;
  padding: 0.75rem 0;
  width: 100%;
  font-weight: 700;
  font-size: 1rem;
  max-width: 23.4375rem;
  margin-inline: auto;
}
#referral .itemList.--2col {
  grid-template-columns: repeat(2, 1fr);
  -moz-column-gap: min(3.7333333333vw, 3rem);
  column-gap: min(3.7333333333vw, 3rem);
  max-width: -webkit-fit-content;
  max-width: -moz-fit-content;
  max-width: fit-content;
}
@media screen and (max-width: 768px), print {
  #referral .itemList.--2col {
    padding: 0 1.5rem;
  }
}
#referral .itemList.--2col .itemList__item {
  gap: 0.5rem;
  max-width: 17.5rem;
}
#referral .itemList.--2col .itemList__img > picture > img {
  width: 100%;
}
#referral .itemList__img:has(.prizeSeal) {
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: min(3.2vw, 1.5rem);
  justify-content: space-between;
  align-items: flex-start;
}
