html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  vertical-align: baseline
}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block
}
ol, ul {
  list-style: none;
  -moz-padding-inline-start: 0;
  -webkit-padding-inline-start: 0;
  -o-padding-inline-start: 0;
  -webkit-padding-start: 0;
  -moz-padding-start: 0;
  padding-inline-start: 0;
  line-height: 1.5
}
blockquote, q {
  quotes: none
}
blockquote:before, blockquote:after {
  content: '';
  content: none
}
q:before, q:after {
  content: '';
  content: none
}
table {
  border-collapse: collapse;
  border-spacing: 0
}
html {
  font-size: 62.5%
}
.fs-12 {
  font-size: 1.2rem
}
.fs-14 {
  font-size: 1.4rem
}
.fs-16 {
  font-size: 1.6rem
}
.fs-18 {
  font-size: 1.8rem;
  margin-top: 30px;
  text-align: center
}
.fs-19 {
  font-size: 1.8rem;
  text-align: center
}
.fs-20 {
  font-size: 2.0rem
}
.fs-22 {
  font-size: 22px
}
.fs-24 {
  font-size: 24px
}
.fs-26 {
  font-size: 26px
}
.fs-28 {
  font-size: 28px
}
.fs-30 {
  font-size: 30px
}
.fs-32 {
  font-size: 32px
}
.fs-34 {
  font-size: 34px
}
.fs-36 {
  font-size: 36px
}
.fs-38 {
  font-size: 38px
}
.fs2em {
  font-size: 2em
}
.others {
  font-size: 2.4rem
}
p.others a {
  text-decoration: underline !important
}
.lh1 {
  line-height: 1
}
.lh2 {
  line-height: 2
}
.lh3 {
  line-height: 3
}
.lh05 {
  line-height: 0.5
}
.lh1_2 {
  line-height: 1.2
}
.lh1_5 {
  line-height: 1.5
}
.mt0 {
  margin-top: 0px !important
}
.mt5 {
  margin-top: 5px !important
}
.mt8 {
  margin-top: 8px !important
}
.mt10 {
  margin-top: 10px !important
}
.mt15 {
  margin-top: 15px !important
}
.mt16 {
  margin-top: 16px !important
}
.mt20 {
  margin-top: 20px !important
}
.mt24 {
  margin-top: 24px !important
}
.mt25 {
  margin-top: 25px !important
}
.mt30 {
  margin-top: 30px !important
}
.mt35 {
  margin-top: 35px !important
}
.mt40 {
  margin-top: 40px !important
}
.mt45 {
  margin-top: 45px !important
}
.mt50 {
  margin-top: 50px !important
}
.mr0 {
  margin-right: 0px !important
}
.mr5 {
  margin-right: 5px !important
}
.mr8 {
  margin-right: 8px !important
}
.mr10 {
  margin-right: 10px !important
}
.mr15 {
  margin-right: 15px !important
}
.mr16 {
  margin-right: 16px !important
}
.mr20 {
  margin-right: 20px !important
}
.mr24 {
  margin-right: 24px !important
}
.mr25 {
  margin-right: 25px !important
}
.mr30 {
  margin-right: 30px !important
}
.mr35 {
  margin-right: 35px !important
}
.mr40 {
  margin-right: 40px !important
}
.mr45 {
  margin-right: 45px !important
}
.mr50 {
  margin-right: 50px !important
}
.mb0 {
  margin-bottom: 0px !important
}
.mb5 {
  margin-bottom: 5px !important
}
.mb8 {
  margin-bottom: 8px !important
}
.mb10 {
  margin-bottom: 10px !important
}
.mb15 {
  margin-bottom: 15px !important
}
.mb16 {
  margin-bottom: 16px !important
}
.mb20 {
  margin-bottom: 20px !important
}
.mb24 {
  margin-bottom: 24px !important
}
.mb25 {
  margin-bottom: 25px !important
}
.mb30 {
  margin-bottom: 30px !important
}
.mb35 {
  margin-bottom: 35px !important
}
.mb40 {
  margin-bottom: 40px !important
}
.mb45 {
  margin-bottom: 45px !important
}
.mb50 {
  margin-bottom: 50px !important
}
.ml0 {
  margin-left: 0px !important
}
.ml5 {
  margin-left: 5px !important
}
.ml8 {
  margin-left: 8px !important
}
.ml10 {
  margin-left: 10px !important
}
.ml15 {
  margin-left: 15px !important
}
.ml16 {
  margin-left: 16px !important
}
.ml20 {
  margin-left: 20px !important
}
.ml24 {
  margin-left: 24px !important
}
.ml25 {
  margin-left: 25px !important
}
.ml30 {
  margin-left: 30px !important
}
.ml35 {
  margin-left: 35px !important
}
.ml40 {
  margin-left: 40px !important
}
.ml45 {
  margin-left: 45px !important
}
.ml50 {
  margin-left: 50px !important
}
.mv0 {
  margin-top: 0px !important;
  margin-bottom: 0px !important
}
.mv5 {
  margin-top: 5px !important;
  margin-bottom: 5px !important
}
.mv8 {
  margin-top: 8px !important;
  margin-bottom: 8px !important
}
.mv10 {
  margin-top: 10px !important;
  margin-bottom: 10px !important
}
.mv15 {
  margin-top: 15px !important;
  margin-bottom: 15px !important
}
.mv16 {
  margin-top: 16px !important;
  margin-bottom: 16px !important
}
.mv20 {
  margin-top: 20px !important;
  margin-bottom: 20px !important
}
.mv24 {
  margin-top: 24px !important;
  margin-bottom: 24px !important
}
.mv25 {
  margin-top: 25px !important;
  margin-bottom: 25px !important
}
.mv30 {
  margin-top: 30px !important;
  margin-bottom: 30px !important
}
.mv35 {
  margin-top: 35px !important;
  margin-bottom: 35px !important
}
.mv40 {
  margin-top: 40px !important;
  margin-bottom: 40px !important
}
.mv45 {
  margin-top: 45px !important;
  margin-bottom: 45px !important
}
.mv50 {
  margin-top: 50px !important;
  margin-bottom: 50px !important
}
.mh100 {
  margin-right: 100px !important;
  margin-left: 100px !important
}
.pt0 {
  padding-top: 0px !important
}
.pt5 {
  padding-top: 5px !important
}
.pt8 {
  padding-top: 8px !important
}
.pt10 {
  padding-top: 10px !important
}
.pt15 {
  padding-top: 15px !important
}
.pt20 {
  padding-top: 20px !important
}
.pt25 {
  padding-top: 25px !important
}
.pt30 {
  padding-top: 30px !important
}
.pt35 {
  padding-top: 35px !important
}
.pt40 {
  padding-top: 40px !important
}
.pt45 {
  padding-top: 45px !important
}
.pt50 {
  padding-top: 50px !important
}
.pr0 {
  padding-right: 0px !important
}
.pr5 {
  padding-right: 5px !important
}
.pr10 {
  padding-right: 10px !important
}
.pr15 {
  padding-right: 15px !important
}
.pr20 {
  padding-right: 20px !important
}
.pr25 {
  padding-right: 25px !important
}
.pr30 {
  padding-right: 30px !important
}
.pr35 {
  padding-right: 35px !important
}
.pr40 {
  padding-right: 40px !important
}
.pr45 {
  padding-right: 45px !important
}
.pr50 {
  padding-right: 50px !important
}
.pb0 {
  padding-bottom: 0px !important
}
.pb5 {
  padding-bottom: 5px !important
}
.pb8 {
  padding-bottom: 8px !important
}
.pb10 {
  padding-bottom: 10px !important
}
.pb15 {
  padding-bottom: 15px !important
}
.pb20 {
  padding-bottom: 20px !important
}
.pb25 {
  padding-bottom: 25px !important
}
.pb30 {
  padding-bottom: 30px !important
}
.pb35 {
  padding-bottom: 35px !important
}
.pb40 {
  padding-bottom: 40px !important
}
.pb45 {
  padding-bottom: 45px !important
}
.pb50 {
  padding-bottom: 50px !important
}
.pl0 {
  padding-left: 0px !important
}
.pl5 {
  padding-left: 5px !important
}
.pl10 {
  padding-left: 10px !important
}
.pl15 {
  padding-left: 15px !important
}
.pl20 {
  padding-left: 20px !important
}
.pl25 {
  padding-left: 25px !important
}
.pl30 {
  padding-left: 30px !important
}
.pl35 {
  padding-left: 35px !important
}
.pl40 {
  padding-left: 40px !important
}
.pl45 {
  padding-left: 45px !important
}
.pl50 {
  padding-left: 50px !important
}
.pa0 {
  padding: 0px !important
}
.pa5 {
  padding: 5px !important
}
.pa8 {
  padding: 8px !important
}
.pa10 {
  padding: 10px !important
}
.red {
  color: #eb5505
}
.underl {
  text-decoration: underline
}
.period_p {
  line-height: 1.5;
  font-size: 1.8rem
}
.roobot {
  font-family: 'Roboto', sans-serif
}
body {
  line-height: 1.5;
  font-family: "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "ヒラギノ角ゴ Pro", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", Meiryo, sans-serif;
  color: #2d2d2d
}
a {
  color: inherit;
  text-decoration: none
}
img {
  max-width: 100%;
  height:auto;
}
* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box
}
*:before, *:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box
}
strong {
  font-weight: bold !important
}
.wrap {
  position: relative;
  overflow: hidden;
  min-width: 100%
}
.wrap img {
  vertical-align: middle
}
.inner {
  position: relative;
  margin: auto
}
.under-link {
  text-decoration: underline
}
.root {
  position: relative;
  overflow: hidden;
  min-width: 100%;
  width: 100%;
  min-height: 100vh
}
#footer {
  padding: 50px 0 180px;
  width: 100%;
  line-height: 1.2em;
  text-align: center;
  color: #333;
  background: #F6F6F7;
  overflow: hidden;
  min-width: 100%
}
ul#footerNav {
  margin: 5px auto 10px;
  text-align: center
}
ul#footerNav li {
  display: inline-block;
  padding: 0 1em 0 0;
  background: url(../img/icon_blank_g.png) no-repeat right 10%;
  line-height: 1;
  font-size: 1.2rem
}
ul#footerNav li + li {
  margin-left: 20px
}
ul#footerNav li a {
  color: #0066aa
}
ul#footerNav li a:visited {
  color: #0066aa
}
ul#footerNav li a:hover, ul#footerNav li a:active {
  color: #eb5505;
  text-decoration: underline
}
#footer p {
  font-size: 1.2rem
}
.returmtop {
  display: none;
  position: fixed;
  bottom: 210px;
  right: 10px;
  z-index: 999
}
.returmtop a {
  display: block;
  width: 78px;
  height: 78px;
  background-color: #ea5504;
  text-align: center;
  color: #fff;
  font-size: 3.4rem;
  text-decoration: none;
  line-height: 78px;
  -moz-border-radius: 100%;
  border-radius: 100%;
  -webkit-box-shadow: 5px 5px #000;
  -moz-box-shadow: 5px 5px #000;
  box-shadow: 5px 5px #000
}
.returmtop a:hover, .returmtop a:active {
  text-decoration: none;
  opacity: 0.8;
  -webkit-transition: all .3s ease;
  -o-transition: all .3s ease;
  -moz-transition: all .3s ease;
  transition: all .3s ease
}
.header {
  padding-top: 5px;
  text-align: center;
  background: #fff;
  border-bottom: #ccc 1px solid;
}
.header img {
  margin: 4px 10px;
  max-width: 120px;
  height: auto
}
.c-row {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex
}
.c-shop-step-title {
  font-size: 1.5rem;
  color: #ea5504;
  font-weight: bold;
  margin-bottom: 1em
}
.c-shop-step__label {
  font-weight: bold;
  color: #ea5504;
  margin-bottom: 1em
}
.c-shop-step figcaption {
  margin-top: 1em;
  font-size: 1.1rem;
  line-height: 1.5
}
.c-shop-step figcaption img {
  width: 1em;
  vertical-align: middle
}
.c-cp {
  text-align: center;
  padding-top: 2em
}
.c-cp__title {
  margin: auto;
  position: relative;
  background-color: #008837;
  -moz-border-radius: 5px;
  border-radius: 5px;
  font-weight: bold;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -moz-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -moz-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}
.c-cp__title span {
  display: block
}
.c-cp__title-sub {
  color: #AD144E;
  position: absolute;
  left: -2.45em;
  top: -1.5em;
  background: url("../img/cp_title_tag.png") left top no-repeat;
  -moz-background-size: contain;
  background-size: contain;
  height: 3em;
  padding: .5em 1.5em .5em .5em;
  line-height: 1
}
.c-cp__title-label {
  color: #fff
}
.c-cp .c-frame {
  max-width: 664px;
  margin-top: -1em;
  line-height: 1.5
}
.c-cp .c-frame strong {
  font-size: 110%
}
.c-coupon-step {
  overflow: hidden;
  padding: 1em 2em 2em;
  text-align: center
}
.c-coupon-step__inner {
  border: 2px solid #ea5504;
  position: relative
}
.c-coupon-step__number {
  background-color: #fff;
  -moz-border-radius: 50%;
  border-radius: 50%;
  position: absolute
}
.c-coupon-step__item {
  background-color: #fff;
  padding: 3em 2em;
  position: unset;
  max-width: -webkit-calc(100% - 4px);
  max-width: -moz-calc(100% - 4px);
  max-width: calc(100% - 4px)
}
.c-coupon-step__img {
  position: relative;
  background-color: #fff;
  opacity: 0;
  -webkit-transition: opacity .4s;
  -o-transition: opacity .4s;
  -moz-transition: opacity .4s;
  transition: opacity .4s
}
.swiper-slide-active .c-coupon-step__img {
  opacity: 1
}
.c-coupon-step__text {
  opacity: 0;
  -webkit-transition: opacity .4s;
  -o-transition: opacity .4s;
  -moz-transition: opacity .4s;
  transition: opacity .4s
}
.swiper-slide-active .c-coupon-step__text {
  opacity: 1
}
.c-coupon-step__text p {
  margin-top: 1.5em
}
.c-coupon-step .swiper-pagination {
  bottom: 5px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  text-align: center
}
.c-coupon-step .swiper-pagination-bullet {
  background-color: #ea5504;
  height: 12px;
  margin: 0 6px;
  width: 12px
}
.swiper-button-prev, .swiper-button-next {
  outline: none;
  background: none
}
.swiper-button-prev:before {
  content: '';
  background: #FFF;
  display: block;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  width: 40px;
  height: 40px;
  border: 2px solid #eb5505;
  -moz-border-radius: 50%;
  border-radius: 50%;
  position: absolute;
  left: 0;
  opacity: 0.8
}
.swiper-button-prev:after {
  content: '';
  display: block;
  width: 12px;
  height: 12px;
  border-top: 4px solid #eb5505;
  border-left: 4px solid #eb5505;
  -webkit-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg);
  position: absolute;
  top: 14px;
  left: 16px;
  opacity: 0.8
}
.swiper-button-next:before {
  content: '';
  display: block;
  background: #FFF;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  width: 40px;
  height: 40px;
  border: 2px solid #eb5505;
  -moz-border-radius: 50%;
  border-radius: 50%;
  position: absolute;
  right: 1px;
  opacity: 0.8
}
.swiper-button-next:after {
  content: '';
  display: block;
  width: 12px;
  height: 12px;
  border-top: 4px solid #eb5505;
  border-right: 4px solid #eb5505;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 14px;
  right: 16px;
  opacity: 0.8
}
.c-note {
  text-align: left;
  font-size: 1.4rem
}
.note {
	font-size: 20px;
	text-align: center;
    margin-bottom: 1em;
}
.tac {
  text-align: center
}
.c-btn {
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  margin-left: auto;
  margin-right: auto
}
.c-btn a {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -moz-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -moz-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  color: #ea5504;
  -moz-border-radius: 2em;
  border-radius: 2em;
  border: solid 1px #ea5504;
  padding: .2em .5em;
  background-color: white
}
.c-btn.-orange a {
  background-color: #ea5504;
  color: white
}
.c-btn.-blue a {
  background-color: #0A287F;
  color: white;
  border: solid 1px #0A287F;
}
.c-btn.-red a {
  background-color: #D91C1D;
  color: white;
  border: solid 1px #D91C1D;
}
.c-btn.-normal {
  font-weight: normal
}
.c-btn.-border a {
  background-color: #ea5504;
  border: 4px solid white;
  -webkit-box-shadow: 0 0 0 4px #ea5504;
  -moz-box-shadow: 0 0 0 4px #ea5504;
  box-shadow: 0 0 0 4px #ea5504;
  color: white
}
.c-btn.-l {
  font-weight: bold
}
.c-title-normal {
  display: table;
  text-align: center;
  color: #ea5504;
  position: relative;
  font-weight: bold;
  line-height: 1.3;
  padding: 0 1.2em;
  margin: auto
}
.c-title-h2 {
  color: #ea5504;
  display: table;
  text-align: center;
  color: #ea5504;
  position: relative;
  font-weight: bold;
  line-height: 1.3;
  padding: 0;
  margin: auto
}
.c-title-h2 span {
  display: table-cell;
  vertical-align: middle
}
.c-title-round {
  margin: auto;
  text-align: center;
  color: #fff;
  background-color: #ea5504;
  -moz-border-radius: 2em;
  border-radius: 2em;
  font-weight: bold;
  display: table;
  width: 100%
}
.c-title-flag {
  background: url(../img/title_bg.png) left top no-repeat;
  -moz-background-size: 100% 100%;
  background-size: 100% 100%;
  margin: auto;
  text-align: center;
  color: #fff;
  font-weight: bold;
  display: table;
  margin-bottom: 0.5em;
  max-width: 640px;
  width: 100%
}
.-bg {
  padding: 4em 0
}
.-bg.-ccolor {
  background-color: #E31A84;
  color: #fff;
}
.-bg.-ccolor h2 {
  color: #fff !important
}
.-bg.-orange {
  background-color: #ea5504
}
.c-bubble {
  margin: 0 auto 2em;
  padding: .5em 1.5em;
  line-height: 1.5;
  background-color: #ff3544;
  display: table;
  -moz-border-radius: 3em;
  border-radius: 3em;
  text-align: center;
  color: #FFF;
  font-weight: bold;
  position: relative
}
.c-bubble:after {
  content: '';
  display: block;
  width: 1em;
  height: 1em;
  background: url("../img/bubble_arrow.png") center top no-repeat;
  -moz-background-size: contain;
  background-size: contain;
  position: absolute;
  top: 98%;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%)
}
.c-deco {
  display: block;
  position: absolute;
  background: url("../img/deco.jpg") center center no-repeat;
  -moz-background-size: contain;
  background-size: contain
}
.c-deco.-rt {
  -webkit-transform: rotate(90deg);
  -moz-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  transform: rotate(90deg)
}
.c-deco.-rb {
  -webkit-transform: rotate(180deg);
  -moz-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  transform: rotate(180deg)
}
.c-deco.-lb {
  -webkit-transform: rotate(270deg);
  -moz-transform: rotate(270deg);
  -ms-transform: rotate(270deg);
  transform: rotate(270deg)
}
.-ccolor .c-deco {
  background: url("../img/deco_ccolor.jpg") center center no-repeat;
  -moz-background-size: contain;
  background-size: contain
}
.c-frame {
  margin: auto;
  position: relative;
  padding: 2em 0 0;
  border: 2px solid #ea5504
}
.-ccolor .c-frame {
  border: 2px solid #fff
}
.c-frame__inner {
  position: relative;
  z-index: 2;
  -moz-border-radius: inherit;
  border-radius: inherit
}
.c-term-frame {
  background-color: #fff;
  border: none;
  -moz-border-radius: 1.5em;
  border-radius: 1.5em
}
.c-term-frame h2 {
  font-weight: bold;
  text-align: center;
  background-color: #fff;
  border: none;
  padding: 0 1em;
  margin: 0 auto 1em;
  color: #ea5504;
  position: relative
}
.c-note-list {
  text-align: left;
  max-width: 515px;
  margin: auto
}
.c-red {
  color: #e50012;
}
.c-orange {
  color: #ea5504
}
.indent {
  padding-left: 1em;
  text-indent: -1em;
}
.mt1em {
  margin-top: 1.5em !important
}
.mt2em {
  margin-top: 3em !important
}
.mt3em {
  margin-top: 4em !important
}
.p-mv {
  text-align: center;
  margin: 0 auto;
}
.p-coupon .c-frame__inner {
  background-color: #fff;
  -moz-border-radius: 1em;
  border-radius: 1em;
  padding-top: 2em
}
.p-coupon .c-btn.-border {
  margin-bottom: 1.5em
}
.p-coupon__lead {
  margin: 2em 1em 1em
}
.p-term .c-frame__inner.-white, .p-attention .c-frame__inner.-white {
  background-color: rgba(255, 255, 255, 0.8)
}
.p-term h2, .p-attention h2 {
  font-weight: bold;
  text-align: center;
  margin-bottom: 1em
}
.p-contact {
  text-align: center;
  line-height: 1.85;
  position: relative
}
.p-contact h2 {
  line-height: 1.4;
  color: inherit;
  font-weight: bold;
  display: inline-block;
  background-color: #fff;
  position: absolute;
  padding: 0 0.5em;
  left: 50%;
  top: 0;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  white-space: nowrap
}
.p-contact .inner {
  border: 1px solid #ea5504;
  padding-bottom: 0.7em;
  padding-top: 2em
}
.p-contact .c-btn.-l {
  margin-top: .5em;
  margin-bottom: .5em;
  max-width: 580px
}
.disc:before {
  content: "・";
}
.f-b {
  font-weight: bold
}
.f-n {
  font-weight: normal
}
.txt_c {
  text-align: center
}

/*apps 追従*/
.apps_dl_fixed {
  width: 100%;
  margin: 0 auto;
  position: fixed;
  bottom: 0px;
  left: 0px;
  z-index: 2;
  background-color: rgba(0, 0, 0, 0.8)
}
.apps_dl {
  width: 100%;
  margin: 0 auto;
  position: fixed;
  bottom: 0px;
  left: 0px;
  z-index: 2;
  text-align: center;
  background: rgba(235, 85, 5, 0.9);
  padding: 1em;
  -webkit-box-shadow: none;
  -moz-box-shadow: none;
  box-shadow: none;
  color: #fff;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  font-size: 1.4rem
}
.apps_dl a img {
  width: 192px;
  height: auto;
  margin-top: 1em;
  margin-left: 0
}
.apps_dl a img:last-child {
  margin-right: 1em
}

/*apps 追従なし*/
.apps_nodl_fixed {
  width: 100%;
  margin: 0 auto;
  position: fixed;
  bottom: 0px;
  left: 0px;
  z-index: 2;
  background-color: rgba(0, 0, 0, 0.8)
}
.apps_nodl {
  width: 100%;
  text-align: center;
  background: rgba(235, 85, 5, 0.9);
  padding: 1em;
  -webkit-box-shadow: none;
  -moz-box-shadow: none;
  box-shadow: none;
  color: #fff;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  font-size: 1.4rem
}
.apps_nodl a img {
  width: 192px;
  height: auto;
  margin-top: 1em;
  margin-left: 0
}
.apps_nodl a img:last-child {
  margin-right: 1em
}

/* クーポン獲得追従 */
.getcoupon_dl {
  width: 100%;
  margin: 0 auto;
  position: fixed;
  bottom: 0px;
  left: 0px;
  z-index: 2;
  background-color: rgba(0, 0, 0, 0.8)
}
.getcoupon_dl {
  width: 100%;
  margin: 0 auto;
  position: fixed;
  bottom: 0px;
  left: 0px;
  z-index: 2;
  text-align: center;
  background: rgba(120, 120, 120, 0.8);
  padding: 1em;
  -webkit-box-shadow: none;
  -moz-box-shadow: none;
  box-shadow: none;
  color: #fff;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  font-size: 1.4rem
}
.getcoupon_dl a img {
  width: 320px;
  height: auto;
  margin-top: 1em;
  margin-left: 0
}

.relative {
  position: relative;
  width: 100%
}
.relative img {
  vertical-align: middle
}
.end {
  background-color: #000;
  position: relative
}
.end img {
  filter: alpha(opacity=40);
  -moz-opacity: 0.4;
  opacity: 0.4
}
.endtxt {
  display: inline-block;
  color: white;
  font-size: 3.8em;
  font-weight: bold;
  letter-spacing: 4px;
  text-align: center;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  margin: -1.6em 0 0 -50%
}
.flex {
  width: 100%;
  padding: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -moz-box;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  -moz-box-orient: horizontal;
  -moz-box-direction: normal;
  flex-direction: row;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -moz-box-pack: center;
  justify-content: center;
  margin: 0 auto;
  text-align: center
}
.janakutemo {
  line-height: 1.5em;
  margin-bottom: 0;
  text-align: center;
  width: 350px
}
.poster img {
    max-width:80%;
    border:1px solid #b1b1b1;
}
/*Swiper*/
.swiper {
	position: relative;
	width: 100%;
}
.swiper-wrapper {
}
.swiper-slide img {
	margin: auto;
}
.swiper-pagination {
	display: flex;
	justify-content: center;
	width: 100%;
	padding: 2em 1em;
}
.swiper-pagination-bullet {
	display: block;
	background: #ccc;
	width: 15px;
	height: 15px;
	border-radius: 100%;
	margin: 0 10px;
	cursor: pointer;
	transition: .2s;
}
.swiper-pagination-bullet-active {
	background: #EA5504!important;
	transition: .2s;
}
.swiper-button-prev {
	position: absolute;
	top: 50%;
	left: 20px;
	z-index: 10;
	display: block;
	cursor: pointer;
	background-size: cover;
	width: 51px;
	height: 51px;
	transition: .2s;
}
.swiper-button-next {
	position: absolute;
	top: 50%;
	right: 20px;
	z-index: 10;
	display: block;
	cursor: pointer;
	background-size: cover;
	width: 51px;
	height: 51px;
	transition: .2s;
}
.swiper-button-disabled {
	pointer-events: none;
	filter: grayscale(100%);
  opacity: 0.2;
	transition: .2s;
}

.getcoupon_cpperiod {
  line-height: 1.5em;
  margin-bottom: 0;
  text-align: center;
  width: 350px
}

.trans_coupon_swiper{
  margin-top: 10px;
  font-size: 1.9rem;
}
.trans_coupon_swiper a{
  color:#EA5504;
  font-weight:bold;
  text-decoration:none;
}
.trans_coupon_swiper a:hover{
  opacity: .6;
  text-decoration:underline;
  text-underline-offset: 8px;
}

@media (max-width: 460px) {
  others {
    font-size: 2.0rem
  }
  lh1_2 {
    line-height: 1.5
  }
  body {
    font-size: 1.6rem
  }
  .inner {
    padding: 0 4.6vw
  }
  .pc {
    display: none !important
  }
  .root {
    padding-top: ""
  }
  #footer {
    padding: 20px 0 160px
  }
  .returmtop {
    bottom: 150px
  }
  .returmtop a {
    width: 50px;
    height: 50px;
    line-height: 50px;
    font-size: 2.4rem
  }
  .c-row-sp {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex
  }
  .c-shop-step__item {
    margin-top: 2em
  }
  .c-shop-step__inner {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    width: 50%;
    margin: auto
  }
  .c-cp__title {
    width: 78.1vw;
    height: 60px
  }
  .c-cp .c-frame {
    padding: 1.7em 1em
  }
  .c-coupon-step {
    padding: 1em
  }
  .c-coupon-step__item {
    margin: 0 auto;
    padding: 3em 2em
  }
  .c-coupon-step__number {
    height: 60px;
    left: -20px;
    top: -15px;
    width: 70px
  }
  .c-coupon-step__number img {
    height: auto;
    width: 75%
  }
  .c-coupon-step__img {
    width: 80%;
    margin: 0 auto
  }
  .c-btn {
    width: -webkit-calc(100% - 1em);
    width: -moz-calc(100% - 1em);
    width: calc(100% - 1em)
  }
  .c-btn a {
    padding: 1em .5em
  }
  .c-btn.-border, .c-btn.-l {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    font-size: 1.6rem
  }
  .c-title-normal {
    margin-bottom: 25px;
    font-size: 4vw
  }
  .c-title-h2 {
    margin-bottom: 25px;
    font-size: 5vw !important
  }
  .c-title-round {
    min-width: 80%;
    height: 50px;
    line-height: 50px;
    font-size: 1.8rem
  }
  .c-title-flag {
    min-width: 80%;
    height: 85px;
    line-height: 68px;
    font-size: 1.6rem
  }
  .c-bubble {
    font-size: 5vw
  }
  .c-deco {
    width: 38px;
    height: 38px
  }
  .c-deco.-lt {
    top: -8px;
    left: -8px
  }
  .c-deco.-rt {
    top: -8px;
    right: -8px
  }
  .c-deco.-lb {
    bottom: -8px;
    left: -8px
  }
  .c-deco.-rb {
    bottom: -8px;
    right: -8px
  }
  .c-frame {
    line-height: 1.7
  }
  .c-frame:before {
    width: -webkit-calc(100% + 10px);
    width: -moz-calc(100% + 10px);
    width: calc(100% + 10px);
    height: -webkit-calc(100% + 10px);
    height: -moz-calc(100% + 10px);
    height: calc(100% + 10px)
  }
  .c-frame__inner.-l, .c-frame__inner.-m {
    padding: 0 4.6vw 2em
  }
  .c-frame__inner.-s {
    padding: 0 4.6vw 2em
  }
  .c-frame.-border {
    margin-bottom: 0
  }
  .c-term-frame {
    line-height: 1.7
  }
  .c-term-frame:before {
    width: -webkit-calc(100% + 10px);
    width: -moz-calc(100% + 10px);
    width: calc(100% + 10px);
    height: -webkit-calc(100% + 10px);
    height: -moz-calc(100% + 10px);
    height: calc(100% + 10px)
  }
  .c-term-frame h2 {
    font-size: 4.3vw
  }
  .c-term-frame__inner.-l, .c-term-frame__inner.-m {
    padding: 0 4.6vw 2em
  }
  .c-term-frame__inner.-s {
    padding: 0 4.6vw 2em
  }
  .mt2em {
    margin-top: 2em !important
  }
  .mt3em {
    margin-top: 3em !important
  }
  .p-mv .inner {
    padding: 0
  }
  .p-mv .c-note {
    padding: 0 1em
  }
  .p-coupon {
    margin: 0 0 3em
  }
  .p-term .c-btn {
    margin-top: 0.5em
  }
  .p-contact {
    font-size: 1.5rem;
    margin: 3em auto
  }
  .p-contact h2 {
    font-size: 4vw
  }

/*apps 追従*/
  .apps_dl {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    font-size: 1.4rem
  }
  .apps_dl a img {
    width: 45% !important;
    margin: 0.5em 0 0
  }
  .apps_dl a img.migi {
    margin-right: 0em
  }

/*apps 追従なし*/
  .apps_nodl {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    font-size: 1.4rem
  }
  .apps_nodl a img {
    width: 45% !important;
    margin: 0.5em 0 0
  }
  .apps_nodl a img.migi {
    margin-right: 0em
  }

/*クーポン獲得追従*/
  .getcoupon_dl {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    font-size: 1.4rem
  }
  .getcoupon_dl a img {
    width: 85% !important;
    margin: 0.5em 0 0
  }

  .endtxt {
    font-size: 2rem;
    letter-spacing: normal
  }
  .janakutemo {
    line-height: 1.5;
    margin-bottom: 0;
    width: 100%;
    padding: 0;
    text-align: bottom
  }
}
@media (min-width: 461px) {
  body {
    font-size: 1.6rem
  }
  a:hover {
    -webkit-transition: opacity 0.3s cubic-bezier(0.35, 0.3, 0.3, 0.87);
    -o-transition: opacity 0.3s cubic-bezier(0.35, 0.3, 0.3, 0.87);
    -moz-transition: opacity 0.3s cubic-bezier(0.35, 0.3, 0.3, 0.87);
    transition: opacity 0.3s cubic-bezier(0.35, 0.3, 0.3, 0.87)
  }
  a:hover:hover {
    opacity: .6
  }
  .inner {
    max-width: 750px
  }
  .inner.c-content-inner {
    padding-top: 100px;
    padding-bottom: 20px
  }
  .inner.-m {
    width: 665px
  }
  .inner.-s {
    width: 515px
  }
  .sp {
    display: none !important
  }
  .tel-link {
    cursor: default;
    pointer-events: none;
    text-decoration: none
  }
  .under-link:hover {
    text-decoration: none
  }
  .root {
    padding-top: ""
  }
  .c-row-pc {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex
  }
  .c-shop-step {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    margin: 0 -2em
  }
  .c-shop-step__item {
    width: 33.33%
  }
  .c-shop-step img {
    width: 116px
  }
  .c-cp__title {
    font-size: 1.8rem;
    width: 420px;
    height: 84px
  }
  .c-cp .c-frame {
    padding: 1.7em 2em
  }
  .c-coupon-step__item {
    padding: 3em 2em
  }
  .c-coupon-step__number {
    height: 90px;
    left: -50px;
    top: -15px;
    width: 120px
  }
  .c-coupon-step__img {
    margin: 0 auto;
    max-width: 100%;
    width: 300px
  }
  .c-btn {
    font-size: 2.4rem;
    height: 56px;
    width: 333px
  }
  .c-btn.-normal {
    font-size: 2rem
  }
  .c-btn.-l {
    font-size: 2.8rem;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    height: 60px
  }
  .c-btn.-border {
    height: 68px
  }
  .c-title-normal {
    padding: 0 1em;
    margin-bottom: 35px;
    font-size: 3.2rem
  }
  .c-title-h2 {
    margin-bottom: 25px;
    font-size: 2.8rem
  }
  .c-title-h2:before, .c-title-h2:after {
    width: 30px
  }
  .c-title-round {
    height: 47px;
    line-height: 47px;
    font-size: 3.2rem
  }
  .c-title-flag {
    height: 102px;
    line-height: 84px;
    font-size: 3rem
  }
  .c-bubble {
    font-size: 3.4rem
  }
  .c-deco {
    width: 38px;
    height: 38px
  }
  .c-deco.-lt {
    top: -8px;
    left: -8px
  }
  .c-deco.-rt {
    top: -8px;
    right: -8px
  }
  .c-deco.-lb {
    bottom: -8px;
    left: -8px
  }
  .c-deco.-rb {
    bottom: -8px;
    right: -8px
  }
  .c-frame {
    line-height: 1.8;
    font-size: 2rem
  }
  .c-frame:before {
    width: -webkit-calc(100% + 20px);
    width: -moz-calc(100% + 20px);
    width: calc(100% + 20px);
    height: -webkit-calc(100% + 20px);
    height: -moz-calc(100% + 20px);
    height: calc(100% + 20px)
  }
  .c-frame__inner {
    padding: 0 47px 50px
  }
  .c-frame__inner.-l {
    padding: 0 35px 50px
  }
  .c-frame__inner.-m {
    padding: 0 60px 50px
  }
  .c-frame__inner.-s {
    padding: 0 110px 50px
  }
  .c-frame.-border h2 {
    font-size: 2.4rem
  }
  .c-frame.-border h2:not(.-deco-none) {
    max-width: 620px
  }
  .c-frame.-border h2:not(.-deco-none) span {
    min-width: 300px
  }
  .c-term-frame {
    font-size: 2rem;
    line-height: 1.5
  }
  .c-term-frame h2 {
    margin-left: 60px;
    margin-right: 60px
  }
  .c-term-frame__inner {
    padding: 0 47px 50px
  }
  .c-term-frame__inner.-l {
    padding: 0 35px 50px
  }
  .c-term-frame__inner.-m {
    padding: 0 60px 50px
  }
  .c-term-frame__inner.-s {
    padding: 0 110px 50px
  }
  .p-coupon {
    font-size: 1.8rem;
    margin: 0 0 3em
  }
  .p-term, .p-attention {
    padding-top: 40px
  }
  .p-term h2, .p-attention h2 {
    font-size: 2.8rem
  }
  .p-term .c-btn {
    margin-top: 25px
  }
  .p-contact {
    margin: 80px auto 60px
  }
  .p-contact h2 {
    font-size: 2.2rem
  }
}
@media (max-width: 750px) {
  .inner {
    padding: 0 10px
  }
  .inner.c-content-inner {
    padding-top: 30px;
    padding-bottom: 20px
  }
  .c-shop-step__item {
    width: 100%
  }
  .c-shop-step__inner {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    width: 50%;
    margin: auto
  }
  .swiper-button-prev, .swiper-button-next {
    display: block
  }
  .c-btn {
    font-size: 3.7vw
  }
  .c-btn.-normal {
    font-size: 3.7vw
  }
  .c-btn.-border, .c-btn.-l {
    font-size: 4.3vw
  }
  .c-title-normal {
    font-size: 4.3vw
  }
  .c-title-h2 {
    font-size: 2.4rem
  }
  .c-title-round {
    font-size: 5vw
  }
  .c-title-flag {
    font-size: 4.6vw
  }
  .c-bubble {
    font-size: 5vw
  }
  .c-frame__inner {
    padding: 0 4% 2em
  }
  .c-frame__inner.-l, .c-frame__inner.-m, .c-frame__inner.-s {
    padding: 0 4% 2em
  }
  .c-frame.-border h2:not(.-deco-none) {
    max-width: 92%
  }
  .c-term-frame {
    margin-bottom: 2em
  }
  .c-term-frame h2 {
    margin-left: 4%;
    margin-right: 4%;
    font-size: 4.3vw
  }
  .c-term-frame__inner {
    padding: 0 4% 2em
  }
  .c-term-frame__inner.-l, .c-term-frame__inner.-m, .c-term-frame__inner.-s {
    padding: 0 4% 2em
  }
}
@media (max-width: 600px) {
  .swiper-button-prev {
    background-image: none
  }
  .swiper-button-prev:before {
    opacity: 1;
    content: '';
    display: block;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    width: 40px;
    height: 40px;
    border: 2px solid #eb5505;
    -moz-border-radius: 50%;
    border-radius: 50%;
    position: absolute;
    left: 0
  }
  .swiper-button-prev:after {
    content: '';
    display: block;
    width: 12px;
    height: 12px;
    border-top: 4px solid #eb5505;
    border-left: 4px solid #eb5505;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
    position: absolute;
    top: 14px;
    left: 16px;
    opacity: 10
  }
  .swiper-button-next:before {
    content: '';
    display: block;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    width: 40px;
    height: 40px;
    border: 2px solid #eb5505;
    -moz-border-radius: 50%;
    border-radius: 50%;
    position: absolute;
    right: 1px;
    opacity: 10
  }
  .swiper-button-next:after {
    content: '';
    display: block;
    width: 12px;
    height: 12px;
    border-top: 4px solid #eb5505;
    border-right: 4px solid #eb5505;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
    position: absolute;
    top: 14px;
    right: 16px
  }
}

/* 加盟店ロゴ */
.storelogo {
  max-width:550px;
  margin:0 auto;
  text-align:center;
}

/*画像の並列表示*/
.poster2_area{
 max-width:100%;
 text-align:center;
 margin-bottom:30px;
 margin-left:-25px; /* 中央ズレ調整 */
}
.poster2 {
  display: flex;
  flex-wrap: wrap;  /* 複数行で画像を並べる */
  justify-content: left; /* 横方向の中央揃え */
  align-items: flex-start;  /* 縦方向の揃えを初期値に */
}

.poster2 li {
  width: calc(100% / 2); /* 横に2つ並べる */
  padding: 0 10px; /*画像の左右に10pxの余白 */
  box-sizing: border-box; /* ボックスの幅を正確に制御 */
  display: flex; /* 画像を縦横中央揃え */
  align-items: center; /* 縦中央揃え */
  justify-content: center; /* 横中央揃え */
}

.poster2 li img {
  max-width: 100%; /* 画像のはみだしを防ぐ */
  max-height: 100%; /* 画像の高さをリストアイテムに収める */
  border:1px solid #b1b1b1;
}

/*加盟店ブランド別ロゴ＆遷移ボタン*/
.card-grid {
  width:100%;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px 30px;
  margin: 30px auto;
  justify-items: center;
}

.card {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.card-image {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
}

.card-btn {
  width: 200px;
  padding: 10px 0;
  font-size: 1.9rem;
  font-weight: bold;
  color: #fff;
  background: #e65100;
  border: none;
  border-radius: 30px;
  cursor: pointer;
  margin-bottom: 8px;
  transition: background 0.2s;
}
.card-btn:hover {
  opacity: .6;
}

/* 2段目2カラム調整 */
.card-grid > .card:nth-child(4),
.card-grid > .card:nth-child(5) {
  grid-column: span 1;
}
.card-grid > .card:nth-child(4) {
  justify-self: start;
}
.card-grid > .card:nth-child(5) {
  justify-self: start;
}

/* iPad mini 以下画面レスポンシブ */
@media (max-width: 767px) {
  .card-grid {
    grid-template-columns: 1fr 1fr;
    gap: 20px 12px;
    max-width: 98vw;
  }
  .card-image,
  .card-btn {
    width: 40vw;
    font-size: 1.5rem;
  }
  .card-btn {
    padding: 10px 0;
    border-radius: 30px;
  }
}

/* 対象店舗リスト */
.cover-store-list {
 margin:0 auto;
 padding:0 10px;
 display:block;
}
.cover-store-list ul {
 margin: 20px 0 0!important;
 text-align:left;
 display:block;
}
.cover-store li {
 display:inline-block;
 margin:0 10px 5px;
 font-weight:bold;
 font-size:90%;
 color: #e50012;
}
.cover-store li:before {
 content:" › ";
 margin-left:-8px;
 color:#999
}

/* 吹き出し付 PRバナー枠 */
    .campaign-frame {
      max-width: 750px;
      margin: 80px auto 70px;
      text-align:center;
      border: 3px solid #f15a24;
      box-sizing: border-box;
      padding: 32px 0 32px;
      position: relative;
      background: #fff;
    }
    .speech-text {
      display: flex;
      align-items: center;
      justify-content: center;
      position: relative;
      color: #f15a24;
      font-size: 1.8rem;
      font-weight: bold;
      text-align: center;
      padding: 0 20px;
      line-height: 1.5;
      margin: -60px auto 20px;
      max-width: 90%;
      background-color:#FFF;
    }
    .speech-text::before,
    .speech-text::after {
      content: "";
      background-color: #f15a24;
      height: 3px;
      width: 50px;
      border-radius: 2px;
    }
    .speech-text::before {
      transform: rotate(60deg);
      margin-right: 10px;
    }
    .speech-text::after {
      transform: rotate(-60deg);
      margin-left: 10px;
    }
    .banner-img {
      display: block;
      width: 90%;
      margin: 0 auto;
    }
    @media (max-width: 430px) {
      .campaign-frame {
        margin: 70px 10px 60px;
        padding: 24px 0 17px;
        border: 2px solid #f15a24;
      }
      .speech-text {
        font-size: 1.22rem;
        padding: 0 5px;
        margin-bottom: 12px;
      }
      .speech-text::before,
      .speech-text::after {
        width: 140px;
        height: 2px;
      }
      .speech-text::before {
      margin-right: 0px;
      }
    .speech-text::after {
      margin-left: 0px;
      }
    }