@charset "UTF-8";

html {
  line-height: 1.15;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%
}

h1 {
  font-size: 2em;
  margin: .67em 0
}

.tokuten {
  padding: 0 12px;
}

.tokuten .tokuten-title {
  margin-top: 15px;
}

.note-left {
  text-align: left;
  font-size: 10px;
  line-height: 1.6em;
  text-indent: -1.6rem;
  padding-left: 2rem;

}

.tokuten-li {
  font-size: 10px;
  line-height: 1.6em;
  text-indent: -1em;
  padding: 0 15px
}

.red_txt {
    color: #be0000;
}

.tokuten-li a,
.note-left a {
  text-decoration: underline;
}

.centerblock {
	text-align: center;
	display: block;
}

.reco-bloc__simu__notes {
    text-align: left;
    padding:  0 8px;
}

.tokuten-li a:hover,
.note-left a:hover {
  text-decoration: none;
}

.tokuten .no-indent {
  text-indent: 0rem;
  padding-left: 7px;
}

.color-red {
  color: #be0000;
}

.campaign__head2 {
  margin-top: 15px;
}

dl dl,
dl ol,
dl ul,
ol dl,
ul dl {
  margin: 0
}

ol ol,
ol ul,
ul ol,
ul ul {
  margin: 0
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible
}

main {
  display: block
}

pre {
  font-family: monospace, monospace;
  font-size: 1em
}

abbr[title] {
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted
}

b,
strong {
  font-weight: bolder
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em
}

small {
  font-size: 80%
}

svg:not(:root) {
  overflow: hidden
}

button,
input,
select {
  margin: 0
}

button {
  overflow: visible;
  text-transform: none
}

[type=button],
[type=reset],
[type=submit],
button {
  -webkit-appearance: button
}

fieldset {
  padding: .35em .75em .625em
}

input {
  overflow: visible
}

legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  white-space: normal;
}

progress {
  display: inline-block;
  vertical-align: baseline;
}

select {
  text-transform: none;
}

textarea {
  margin: 0;
  overflow: auto
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}

::-webkit-input-placeholder {
  color: inherit;
  opacity: .54
}

::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

::-moz-focus-inner {
  border-style: none;
  padding: 0
}

:-moz-focusring {
  outline: 1px dotted ButtonText
}

:-moz-ui-invalid {
  box-shadow: none
}

details {
  display: block
}

dialog {
  background-color: #fff;
  border: solid;
  color: #000;
  display: block;
  height: -moz-fit-content;
  height: -webkit-fit-content;
  height: fit-content;
  left: 0;
  margin: auto;
  padding: 1em;
  position: absolute;
  right: 0;
  width: -moz-fit-content;
  width: -webkit-fit-content;
  width: fit-content
}

dialog:not([open]) {
  display: none
}

summary {
  display: list-item
}

template {
  display: none
}

/*! destyle.css v2.0.2 | MIT License | https://github.com/nicolas-cusan/destyle.css */
*,
:after,
:before {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0
}

html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent
}

body {
  margin: 0
}

main {
  display: block;
  max-width: 100%
}

address,
blockquote,
dl,
figure,
form,
iframe,
p,
pre,
table {
  margin: 0
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
  margin: 0
}

ol,
ul {
  margin: 0;
  padding: 0;
  list-style: none
}

dt {
  font-weight: 700
}

dd {
  margin-left: 0
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit
}

pre {
  font-family: monospace, monospace;
  font-size: inherit
}

address {
  font-style: inherit
}

a {
  background-color: transparent;
  text-decoration: none;
  color: inherit
}

abbr[title] {
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted
}

b,
strong {
  font-weight: bolder
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: inherit
}

small {
  font-size: 80%
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline
}

sub {
  bottom: -.25em
}

sup {
  top: -.5em
}

embed,
iframe,
img,
object {
  vertical-align: bottom
}

button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: 0 0;
  padding: 0;
  margin: 0;
  outline: 0;
  border-radius: 0;
  text-align: inherit
}

[type=checkbox] {
  -webkit-appearance: checkbox;
  -moz-appearance: checkbox;
  appearance: checkbox
}

[type=radio] {
  -webkit-appearance: radio;
  -moz-appearance: radio;
  appearance: radio
}

button,
input {
  overflow: visible
}

button,
select {
  text-transform: none
}

[type=button],
[type=reset],
[type=submit],
button {
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none
}

[type=button][disabled],
[type=reset][disabled],
[type=submit][disabled],
button[disabled] {
  cursor: default
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
  border-style: none;
  padding: 0
}

[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring,
button:-moz-focusring {
  outline: 1px dotted ButtonText
}

select::-ms-expand {
  display: none
}

option {
  padding: 0
}

fieldset {
  margin: 0;
  padding: 0;
  min-width: 0
}

legend {
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal
}

progress {
  vertical-align: baseline
}

textarea {
  overflow: auto
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto
}

[type=search] {
  outline-offset: -2px
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit
}

label[for] {
  cursor: pointer
}

details {
  display: block
}

summary {
  display: list-item
}

[contenteditable] {
  outline: 0
}

table {
  border-collapse: collapse;
  border-spacing: 0
}

caption {
  text-align: left
}

td {
  vertical-align: top;
  padding: 0
}

th {
  vertical-align: top;
  padding: 0;
  text-align: left;
  font-weight: 700
}

[hidden],
template {
  display: none
}

.mt-0 {
  margin-top: 0 !important
}

.mt-4 {
  margin-top: 4px !important
}

.mt-8 {
  margin-top: 8px !important
}

.mt-12 {
  margin-top: 12px !important
}

.mt-16 {
  margin-top: 16px !important
}

.mt-20 {
  margin-top: 20px !important
}

.mt-24 {
  margin-top: 24px !important
}

.mt-28 {
  margin-top: 28px !important
}

.mt-32 {
  margin-top: 32px !important
}

.mt-36 {
  margin-top: 36px !important
}

.mt-40 {
  margin-top: 40px !important
}

.mt-44 {
  margin-top: 44px !important
}

.mt-48 {
  margin-top: 48px !important
}

.mt-52 {
  margin-top: 52px !important
}

.mt-56 {
  margin-top: 56px !important
}

.mt-60 {
  margin-top: 60px !important
}

.mt-64 {
  margin-top: 64px !important
}

.mt-68 {
  margin-top: 68px !important
}

.mt-72 {
  margin-top: 72px !important
}

.mt-76 {
  margin-top: 76px !important
}

.mt-80 {
  margin-top: 80px !important
}

.mt-84 {
  margin-top: 84px !important
}

.mt-88 {
  margin-top: 88px !important
}

.mt-92 {
  margin-top: 92px !important
}

.mt-96 {
  margin-top: 96px !important
}

.mt-100 {
  margin-top: 100px !important
}

.mt-104 {
  margin-top: 104px !important
}

.mt-108 {
  margin-top: 108px !important
}

.mt-112 {
  margin-top: 112px !important
}

.mt-116 {
  margin-top: 116px !important
}

.mt-120 {
  margin-top: 120px !important
}

.mt-124 {
  margin-top: 124px !important
}

.mt-128 {
  margin-top: 128px !important
}

.mt-132 {
  margin-top: 132px !important
}

.mt-136 {
  margin-top: 136px !important
}

.mt-140 {
  margin-top: 140px !important
}

.mt-144 {
  margin-top: 144px !important
}

.mt-148 {
  margin-top: 148px !important
}

.mt-152 {
  margin-top: 152px !important
}

.mt-156 {
  margin-top: 156px !important
}

.mt-160 {
  margin-top: 160px !important
}

.js-fadein {
  opacity: 0;
  -webkit-transform: translateY(50px);
  transform: translateY(50px);
  transition: .3s
}

.js-fadein.is-active {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0)
}

.align-center {
  text-align: center !important
}

html {
  -webkit-text-size-adjust: 100%;
  -webkit-print-color-adjust: exact
}

body {
  -webkit-text-size-adjust: 100%;
  -webkit-print-color-adjust: exact;
  position: relative;
  font-family: 'Noto Sans JP', "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W6", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  line-height: 1.5;
  min-width: 1000px;
  color: #222
}

body em {
  font-style: normal
}

a {
  text-decoration: none;
  color: inherit;
  transition: all .2s ease-in-out
}

a.text-link {
  text-decoration: underline
}

a.text-link:hover {
  text-decoration: none
}

img {
  max-width: 100%;
  max-height: 100%;
  height: auto
}

body * {
  position: relative
}

.js-scrollAnimation {
  opacity: 0;
  transition: opacity .3s ease, -webkit-transform .3s ease;
  transition: opacity .3s ease, transform .3s ease;
  transition: opacity .3s ease, transform .3s ease, -webkit-transform .3s ease;
  -webkit-transform: translateY(50px);
  transform: translateY(50px)
}

.js-scrollAnimation.-show {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0)
}

.header {
  background: 0 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100
}

.header__inner {
  margin: 0 auto
}

.header img {
  height: 25px
}

.main {
  overflow: hidden;
  z-index: 0
}

.main .bg-01 {
  background-image: url(../img/bg_dot01.jpg);
  background-size: 20px 20px
}

.main .bg-02 {
  background-image: url(../img/bg_dot02.jpg);
  background-size: 20px 20px
}

.main .bg-03 {
  background-image: url(../img/bg_dot03.jpg);
  background-size: 20px 20px
}

.main .bg-04 {
  background-image: url(../img/bg_dot04.jpg);
  background-size: 20px 20px
}

.label-btm,
.label-top {
  position: relative
}

.label-btm:before,
.label-top:before {
  content: '';
  width: 100%;
  height: 5px;
  background-image: url(../img/label_02.png);
  background-size: 350px 5px;
  position: absolute;
  left: 0;
  right: 0;
  margin: 0 auto;
  z-index: 2
}

.label-top:before {
  top: -2px
}

.label-btm:before {
  bottom: -2px
}

@-webkit-keyframes kv_bg {
  0% {
    -webkit-transform: rotate(0);
    transform: rotate(0)
  }

  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg)
  }
}

@keyframes kv_bg {
  0% {
    -webkit-transform: rotate(0);
    transform: rotate(0)
  }

  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg)
  }
}

.bg-cover-baige {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1
}

.bg-cover-baige:after,
.bg-cover-baige:before {
  content: '';
  background: #fefce8;
  position: absolute;
  right: 0;
  left: 0
}

.bg-cover-baige:after {
  width: 100%;
  height: 10px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%)
}

.bg-cover-baige:before {
  height: 100%;
  width: 10px;
  margin: 0 auto
}

.bg-cover-green {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1
}

.bg-cover-green:after,
.bg-cover-green:before {
  content: '';
  background: #11825b;
  position: absolute;
  right: 0;
  left: 0
}

.bg-cover-green:after {
  width: 100%;
  height: 10px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%)
}

.bg-cover-green:before {
  height: 100%;
  width: 10px;
  margin: 0 auto
}

.tgl-btn {
  bottom: -1px
}

.tgl-btn span {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%
}

.tgl-btn span img+img {
  display: none
}

.tgl-btn.is-open img:first-child {
  display: none
}

.tgl-btn.is-open img:last-child {
  display: block
}

.bg-cover {
  position: absolute;
  width: 100%;
  height: 100%;
  display: block;
  top: 0;
  left: 0;
  z-index: -1
}

.bg-cover:after,
.bg-cover:before {
  content: '';
  background: #fff;
  position: absolute;
  display: block;
  right: 0;
  left: 0;
  margin: 0 auto
}

.bg-cover:before {
  width: 100%;
  height: 10px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%)
}

.bg-cover:after {
  width: 10px;
  height: 100%
}

.icon-note,
.icon-note-01,
.icon-note-02,
.icon-note-03,
.icon-note-04,
.icon-note-05,
.icon-note-h {
  padding-left: 1.3rem
}

.icon-note-01:before,
.icon-note-02:before,
.icon-note-03:before,
.icon-note-04:before,
.icon-note-05:before,
.icon-note-h:before,
.icon-note:before {
  content: '※';
  margin-left: -1rem;
  width: 1rem;
  display: inline-block
}

.icon-note-01,
.icon-note-02,
.icon-note-03,
.icon-note-04,
.icon-note-05,
.icon-note-h {
  padding-left: 1.6rem
}

.icon-note-01:before,
.icon-note-02:before,
.icon-note-03:before,
.icon-note-04:before,
.icon-note-05:before,
.icon-note-h:before {
  margin-left: -1.3rem;
  width: 1.3rem
}

.icon-note-01:before {
  content: '※1'
}

.icon-note-02:before {
  content: '※2'
}

.icon-note-03:before {
  content: '※3'
}

.icon-note-04:before {
  content: '※4'
}

.icon-note-05:before {
  content: '※5'
}

.icon-note-dot:before {
  text-align: center;
  content: '・'
}

.icon-note-h {
  padding-left: 1rem
}

.icon-note-h:before {
  text-align: left;
  margin-left: -.8rem;
  width: .8rem;
  content: '-'
}

.orange {
  color: #ff6c00
}

.main {
  background: #f5e343
}

.btn-wt {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  border: 2px solid #3e9a34;
  color: #3e9a34;
  font-weight: 700;
  margin: 0 auto;
  box-shadow: 4px 4px 1px rgba(0, 0, 0, .1);
  transition: .3s;
  padding-bottom: 2px
}

.btn-wt:before {
  content: '';
  background-image: url(../img/arw_gr.png);
  width: 11px;
  height: 11px;
  background-size: cover;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%)
}

.label-ttl {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #06825b;
  color: #fff
}

.label-ttl_student {
	text-align: center;
}

@-webkit-keyframes diagonal-move-anim01 {
  0% {
    -webkit-transform: translate(100%, -100%);
    transform: translate(100%, -100%)
  }

  to {
    -webkit-transform: translate(-100%, 100%);
    transform: translate(-100%, 100%)
  }
}

@keyframes diagonal-move-anim01 {
  0% {
    -webkit-transform: translate(100%, -100%);
    transform: translate(100%, -100%)
  }

  to {
    -webkit-transform: translate(-100%, 100%);
    transform: translate(-100%, 100%)
  }
}

@-webkit-keyframes diagonal-move-anim02 {
  0% {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0)
  }

  to {
    -webkit-transform: translate(-200%, 200%);
    transform: translate(-200%, 200%)
  }
}

@keyframes diagonal-move-anim02 {
  0% {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0)
  }

  to {
    -webkit-transform: translate(-200%, 200%);
    transform: translate(-200%, 200%)
  }
}

.bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1
}

.lead__btnwrap {
  display: flex
}

.lead__btnwrap a {
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  font-weight: 700;
  box-shadow: 4px 4px 1px rgba(0, 0, 0, .1);
  transition: .3s
}

.lead__btnwrap a:first-child:after {
  content: '';
  background-image: url(../img/lead_icon.png);
  background-size: cover;
  width: 50px;
  height: 50px;
  position: absolute;
  top: 4px;
  left: 25px
}

.lead__btnwrap a:first-child.-offHours {
  pointer-events: none;
  background-color: #8c8c8c !important
}

.lead__btnwrap a:first-child.-offHours:after {
  background-image: url(../img/lead_icon_gr.png)
}

.lead__btnwrap a:before {
  content: '';
  background-image: url(../img/arw_wt.png);
  background-size: cover;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%)
}

.campaign {
  background: #fff;
  margin: 0 auto
}


.campaign .icon-note {
	font-size: 10px;
	padding-left: 2.3rem;
	margin-top: 4px;
}


.campaign__ttl {
  position: absolute;
  right: 0;
  left: 0;
  margin: 0 auto
}

.campaign__link {
  text-align: center;
  font-size: 10px
}

.campaign__list li {
  display: flex
}

.campaign__list li em,
.campaign__list li p {
  display: flex
}

.campaign__list li em {
  justify-content: center;
  align-items: center
}

.campaign__list li p {
  align-items: flex-start;
  justify-content: center;
  flex-direction: column;
  font-weight: 500
}

.campaign__list li em {
  height: 100%;
  z-index: 0
}

.campaign__list li em:after {
  content: '';
  width: 100%;
  height: 100%;
  position: absolute;
  background: -webkit-linear-gradient(45deg, transparent 0, #11825b 0), -webkit-linear-gradient(135deg, transparent 0, #11825b 0), -webkit-linear-gradient(225deg, transparent 0, #11825b 0), -webkit-linear-gradient(315deg, transparent 10px, #11825b 10px);
  background-position: bottom left, bottom right, top right, top left;
  background-size: 50% 50%;
  background-repeat: no-repeat;
  z-index: -1;
  top: 0;
  left: 0
}

.campaign__list li p {
  height: 100%;
  z-index: 0
}

.campaign__list li p:after {
  content: '';
  width: 100%;
  height: 100%;
  position: absolute;
  background: -webkit-linear-gradient(45deg, transparent 0, #fff 0), -webkit-linear-gradient(135deg, transparent 10px, #fff 10px), -webkit-linear-gradient(225deg, transparent 0, #fff 0), -webkit-linear-gradient(315deg, transparent 0, #fff 0);
  background-position: bottom left, bottom right, top right, top left;
  background-size: 50% 50%;
  background-repeat: no-repeat;
  z-index: -1;
  top: 0;
  left: 0
}

.campaign__list li p small {
  display: block
}

.campaign-add__step {
  margin: 0 auto;
  background: #e7fadc
}

.campaign-add__btn {
  display: block;
  justify-content: center;
  align-items: center;
  background: #06825b;
  margin: 0 auto
}

.campaign-add__btm .red {
  color: #be0000
}

.campaign-banner {
  text-align: center
}

.campaign-banner__bannerhead {
  margin: 0 auto
}

.privilege {
  background: #fef5a6
}

.privilege__boxhead {
  position: absolute;
  right: 0;
  left: 0;
  margin: 0 auto;
}


.privilege__wrap {
  margin: 0 auto;
}

.privilege__listttl {
  margin: 0 auto
}

.privilege__btm {
  text-align: center;
}

.privilege__btn {
  background: #06825b;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer
}

.reco:before {
  content: '';
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: rgba(255, 255, 255, .4)
}

.reco-top {
  background: #fff
}

.reco-top__ttl {
  margin: 0 auto
}

.reco-top__item {
  background: #fbef8c;
  display: flex;
  justify-content: center;
  align-items: center
}

.reco-top__item:before {
  content: '';
  position: absolute
}

.reco-top__cont {
  margin: 0 auto
}

.reco-bloc.reco-01 .boxwrap04 .reco-bloc__lead {
  font-weight: 500
}

.reco-bloc.reco-01 .boxwrap04 .reco-bloc__lead em {
  font-weight: 700
}

.reco-bloc.reco-02 .boxwrap02 .reco-bloc__lead {
  font-weight: 700
}
.about-vpointapp .reco-bloc__lead {
  text-align: left;
}
.reco-bloc__contents {
  text-align: center;
  margin: 40px 0;
  padding: 0 110px;
}
.about-vpointapp .ttl-img {
  width: 500px;
  text-align: center;
}
.about-vpointapp .ttl-img img {
  width: 500px;
}
.reco-bloc__contents__text {
  font-size: 16px;
  line-height: 2;
  font-weight: 500;
  text-align: left;
}
.reco-bloc__contents__text.more {
  margin-top: 30px;
}
.reco-bloc__contents__text em {
  color: #be0000;
}
.reco-bloc__contents__lead {
  color: #004831;
  font-weight: 700;
  font-size: 24px;
  display: block;
  margin-bottom: 10px;
  margin-top: 30px;
}
.about-vpointapp .reco-bloc__notewrap {
  text-align: left;
  margin: 16px 0 0;
}
.img-vpoint-save {
  margin-top: 30px;
  width: 850px;
}
.img-point-logos {
  text-align: center;
}
.img-point-logos img {
	width: 450px;
}
.reco-bloc__vpointapp {
  margin-top: 30px;
}
.reco-bloc__vpointapp_ttl {
  display: flex;
  justify-content: center;
}
.reco-bloc__vpointapp_ttl img {
  width: 75px;
  margin-right: 10px;
}
.reco-bloc__vpointapp .reco-bloc__contents__lead {
  margin: auto 0;
}
.reco-bloc__vpointapp_list{
  text-align: left;
  margin: 20px auto 0;
}
.reco-bloc__ttlnum {
  text-align: center;
  margin: 0 auto
}

.reco-bloc__ttlnum img {
  display: block;
  margin: 0 auto
}

.reco-bloc__ttl {
  margin: 0 auto
}

.reco-bloc__point {
  margin: 0 auto;
  display: flex;
  justify-content: space-between
}

.reco-bloc__boxwrap {
  margin: 0 auto
}

.reco-bloc__boxttl {
  margin: 0 auto
}

.reco-bloc__boxicon {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  margin: 0 auto 20px
}

.reco-bloc__boxhead {
  background: #004831;
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: 700;
  position: absolute;
  right: 0;
  left: 0;
  margin: 0 auto
}

.reco-bloc__boxhead:before {
  content: '';
  background-image: url(../img/arrow_01.png);
  background-size: cover;
  position: absolute;
  right: 0;
  left: 0;
  margin: 0 auto;
  bottom: -9px;
  width: 13px;
  height: 9px
}

.reco-bloc__lead small {
  display: block
}

.reco-bloc__bannerwrap {
  margin: 0 auto
}

.reco-bloc__boxrow {
  margin: 0 auto
}

.reco-bloc__boxrow em {
  text-align: center;
  display: block;
  font-weight: 700;
  color: #004831
}

.reco-bloc__simu {
  border: 2px solid #11825b;
  background: #fff;
  margin: 0 auto
}
.reco-bloc__simu__notes {
    width: fit-content;
    margin: 0 auto;
    text-align: left;
    padding:  0 8px;
}
.reco-bloc__simu.suguchan {
  background: #fefce8;
  margin: 0 auto
}

.reco-bloc__simu h3 {
  display: flex;
  background: #11825b;
  color: #fff;
  justify-content: center;
  align-items: center;
  position: absolute;
  right: 0;
  left: 0;
  margin: 0 auto;
  font-weight: 700
}

.reco-bloc__simu em {
  display: block;
  font-weight: 500
}

.reco-bloc__tgl {
  background: #06825b;
  display: flex;
  justify-content: center;
  align-items: center
}

.reco-bloc__boxcol li {
  display: flex;
  align-items: center
}

.reco-bloc__boxcol li .pct {
  display: flex;
  justify-content: center;
  align-items: center
}

.reco-bloc__boxcol li .txt em {
  color: #004831;
  font-weight: 700
}

.reco-bloc__num {
  margin: 0 auto
}

.reco-bloc__num li {
  display: flex;
  align-items: center
}

.reco-bloc__num em {
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 0
}

.reco-bloc__num em:after {
  content: '';
  width: 100%;
  height: 100%;
  position: absolute;
  background: -webkit-linear-gradient(45deg, transparent 0, #11825b 0), -webkit-linear-gradient(135deg, transparent 0, #11825b 0), -webkit-linear-gradient(225deg, transparent 0, #11825b 0), -webkit-linear-gradient(315deg, transparent 10px, #11825b 10px);
  background-position: bottom left, bottom right, top right, top left;
  background-size: 50% 50%;
  background-repeat: no-repeat;
  z-index: -1;
  top: 0;
  left: 0
}

.reco-bloc__num .txt {
  z-index: 0;
  display: flex;
  align-items: center;
  justify-content: flex-start
}

.reco-bloc__num .txt:after {
  content: '';
  width: 100%;
  height: 100%;
  position: absolute;
  background: -webkit-linear-gradient(45deg, transparent 0, #fff 0), -webkit-linear-gradient(135deg, transparent 10px, #fff 10px), -webkit-linear-gradient(225deg, transparent 0, #fff 0), -webkit-linear-gradient(315deg, transparent 0, #fff 0);
  background-position: bottom left, bottom right, top right, top left;
  background-size: 50% 50%;
  background-repeat: no-repeat;
  z-index: -1;
  top: 0;
  left: 0
}

.reco-bloc__num .txt span {
  color: #be0000
}

.reco-bloc__app {
  background: #cff6b9
}

.reco-bloc__app ul {
  margin: 0 auto;
  display: flex;
  justify-content: space-between
}

.reco-bloc__app ul li {
  background: #fff
}

.reco-bloc__app ul li em {
  text-align: center;
  display: block
}

.reco-bloc__app ul li em:before {
  content: '';
  height: 1px;
  background: #ccc;
  position: absolute;
  left: 0;
  right: 0;
  margin: 0 auto;
  bottom: 0
}

.tab__head {
  background: #fff;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  color: #004831;
  font-weight: 700
}

.tab__tab {
  display: flex;
  justify-content: center;
  align-items: flex-end
}

.tab__tab li {
  background: #fefbe8;
  color: #004831;
  transition: .3s;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700
}

.tab__tab li.is-active {
  background: #06825b;
  color: #fff
}

.tab__panel li {
  display: none
}

.tab__panel li.is-active {
  display: block
}

.tab__icon {
  color: #fff;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: 700
}

.tab__lead,
.tab__leadbtm,
.tab__leadtop {
  font-weight: 700;
  text-align: center
}

.tab__lead em,
.tab__leadbtm em,
.tab__leadtop em {
  color: #be0000
}

.tab__list li {
  display: flex
}

.tab__list li em,
.tab__list li p {
  display: flex
}

.tab__list li em {
  justify-content: center;
  align-items: center
}

.tab__list li p {
  align-items: flex-start;
  justify-content: center;
  flex-direction: column;
  font-weight: 500
}

.tab__list li em {
  height: 100%;
  z-index: 0
}

.tab__list li em:after {
  content: '';
  width: 100%;
  height: 100%;
  position: absolute;
  background: -webkit-linear-gradient(45deg, transparent 0, #11825b 0), -webkit-linear-gradient(135deg, transparent 0, #11825b 0), -webkit-linear-gradient(225deg, transparent 0, #11825b 0), -webkit-linear-gradient(315deg, transparent 10px, #11825b 10px);
  background-position: bottom left, bottom right, top right, top left;
  background-size: 50% 50%;
  background-repeat: no-repeat;
  z-index: -1;
  top: 0;
  left: 0
}

.tab__list li p {
  height: 100%;
  z-index: 0
}

.tab__list li p:after {
  content: '';
  width: 100%;
  height: 100%;
  position: absolute;
  background: -webkit-linear-gradient(45deg, transparent 0, #fff 0), -webkit-linear-gradient(135deg, transparent 10px, #fff 10px), -webkit-linear-gradient(225deg, transparent 0, #fff 0), -webkit-linear-gradient(315deg, transparent 0, #fff 0);
  background-position: bottom left, bottom right, top right, top left;
  background-size: 50% 50%;
  background-repeat: no-repeat;
  z-index: -1;
  top: 0;
  left: 0
}

.tab__list li p .icon-note,
.tab__list li p .icon-note-01,
.tab__list li p .icon-note-02,
.tab__list li p .icon-note-03,
.tab__list li p .icon-note-04,
.tab__list li p .icon-note-05,
.tab__list li p .icon-note-h {
  padding-left: 1rem
}

.tab__list li p .icon-note-01:before,
.tab__list li p .icon-note-02:before,
.tab__list li p .icon-note-03:before,
.tab__list li p .icon-note-04:before,
.tab__list li p .icon-note-05:before,
.tab__list li p .icon-note-h:before,
.tab__list li p .icon-note:before {
  margin-left: -.7rem;
  width: .7rem
}

.tab__list li p small {
  display: block;
  line-height: 1.3
}

.tab__notewrap {
  margin: 0 auto
}

.info {
  background: #fff
}

.info__label {
  background: #004831
}

.info__inner {
  margin: 0 auto
}

.info__head small {
  display: block
}

.info__head .icon-note,
.info__head .icon-note-01,
.info__head .icon-note-02,
.info__head .icon-note-03,
.info__head .icon-note-04,
.info__head .icon-note-05,
.info__head .icon-note-h {
  padding-left: 1rem
}

.info__cont dl {
  border-top: 2px solid #f5e343;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start
}

.info__cont dl dt {
  flex-shrink: 0;
  font-weight: 700
}

.info__cont dl:last-child {
  border-bottom: 2px solid #f5e343
}

.more-slide img {
  width: 100%
}

.more-slide .slick-dots {
  margin: 0 auto;
  width: auto;
  left: 0;
  right: 0
}

.more-slide .slick-dots li,
.more-slide .slick-dots li button {
  border-radius: 1px;
  width: 20px;
  height: 4px;
  content: '';
  padding: 0;
  background-color: #11825b;
  opacity: .5
}

.more-slide .slick-dots li button::before,
.more-slide .slick-dots li::before {
  content: ''
}

.more-slide .slick-dots li button.slick-active,
.more-slide .slick-dots li.slick-active {
  opacity: 1
}

.footer {
  background-color: #fff;
  padding-bottom: 58px
}

.footer>ul {
  margin: 0;
  line-height: 1.7
}

.footer small {
  font-size: 12.8px
}

.footer>p {
  font-size: 10px
}

.footer-sitemap {
  padding: 20px 0
}

.footer-sitemap li {
  font-size: 13px;
  list-style: none
}

.footer-sitemap img {
  vertical-align: middle;
  width: 14px;
  margin-left: 5px;
  position: relative;
  top: -.1em
}

.footer-sitemap a {
  text-decoration: none
}

.footer-sitemap a:hover {
  opacity: .7
}

.footer-copyright {
  text-align: center;
  background-color: #efefef;
  padding: 10px 0
}

.fixed {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 100;
  -webkit-transform: translateY(58px);
  transform: translateY(58px);
  transition: all .3s linear
}

.fixed.is-show {
  -webkit-transform: translateY(0);
  transform: translateY(0)
}

.fixed a {
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  width: 100%;
  height: 58px;
  font-weight: 700;
  background: #be0000
}

.fixed a span:before {
  content: '';
  background-image: url(../img/arrow_fixed.png);
  background-size: cover;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%)
}

.modal {
  border-radius: 10px !important;
  text-align: center
}

.modal.-offHours .note-attention {
  display: block !important
}

.modal.-offHours .lead__btnwrap a:first-child {
  pointer-events: none;
  background-color: #8c8c8c !important
}

.modal.-offHours .lead__btnwrap a:first-child:after {
  background-image: url(../img/lead_icon_gr.png);
}

.modal::before {
  pointer-events: none;
  position: absolute;
  content: '';
  width: 20px;
  height: 20px;
  top: -32px;
  right: -20px;
  background-image: url(../img/modal_close.png);
  background-size: cover
}

.modal .offHours {
  display: none
}

.modal .onHours {
  display: block
}

.modal.-offHours .offHours {
  display: block
}

.modal.-offHours .onHours {
  display: none
}

.modal .inner {
  max-width: 100%;
  padding: 40px 55px
}

.modal .point {
  padding: 0
}

.modal-ttl {
  font-size: 20px;
  font-weight: 700
}

.modal-txt {
  font-size: 12px;
  margin-top: 5px
}

.modal-box img {
  display: block;
  margin: 20px auto
}

.modal-box li,
.modal-box p {
  text-align: left
}

.modal-box p {
  font-size: 12px
}

.modal-attention {
  font-size: 16px;
  font-weight: 700
}

.modal-time {
  font-size: 24px;
  font-weight: 700;
  color: #d10000;
  margin-top: 10px
}

.modal-term {
  text-align: left;
  border: 1px solid #ddd;
  padding: 20px;
  margin-top: 20px;
  border-radius: 10px;
  max-height: 384px;
  overflow: scroll
}

.modal-term-text {
  font-size: 10px
}

.modal-term-text h4 {
  font-size: 12px;
  margin-top: 10px;
  font-weight: 700
}

.modal-term-text ul li {
  margin-top: 5px
}

.modal-term-text ul>ul {
  padding-left: 1em
}

.modal-term-text ul>ul li {
  margin-top: 0
}

.modal-term-text p {
  margin-top: 5px;
  color: #d10000;
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt"
}

#modal01 .lead__btnwrap a {
  margin: 30px auto 0
}

#modal04 .inner {
  padding: 35px 20px 40px
}

#modal03 .inner {
  width: auto
}

#modal04 h4 {
  text-align: left;
  font-weight: 700;
  margin-top: 20px
}

#modal04 h4+img {
  width: 100%;
  margin-top: 20px
}

#modal04 .modal-txt {
  margin-top: 0
}

#modal05 .note-attention,
#modal05 .note-li {
  text-align: left
}

#modal05 .note-list {
  margin-top: 20px
}

#modal05.-offHours .btn-point01 {
  background-color: #8c8c8c;
  pointer-events: none
}

#modal05.-offHours .btn-point01::before {
  background-image: url(../img/point_btn01_icon_g.png)
}

.kv .js-load01,
.kv .js-load02,
.kv .js-load03 {
  opacity: 0;
  transition: opacity .6s ease-out, -webkit-transform .5s ease-out;
  transition: opacity .6s ease-out, transform .5s ease-out;
  transition: opacity .6s ease-out, transform .5s ease-out, -webkit-transform .5s ease-out;
  -webkit-transform: translateY(30px);
  transform: translateY(30px);
  transition-delay: .1s
}

.kv .js-load02 {
  transition-delay: .15s
}

.kv .js-load03 {
  transition-delay: .22s
}

.kv.is-load .js-load01,
.kv.is-load .js-load02,
.kv.is-load .js-load03 {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0)
}

[data-script=fade] {
  opacity: 0;
  -webkit-transform: translateY(30px);
  transform: translateY(30px);
  transition: opacity .5s ease-in-out, -webkit-transform .4s ease-in-out;
  transition: opacity .5s ease-in-out, transform .4s ease-in-out;
  transition: opacity .5s ease-in-out, transform .4s ease-in-out, -webkit-transform .4s ease-in-out;
  transition-delay: .1s
}

[data-script=fade].is-fade {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0)
}

[data-script=fadebox] {
  opacity: 0;
  -webkit-transform: translateY(20px);
  transform: translateY(20px)
}

[data-script=fadebox].is-fade {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0)
}

[data-script=fadebox]:nth-child(1) {
  transition: opacity .5s ease-in-out, -webkit-transform .4s ease-in-out;
  transition: opacity .5s ease-in-out, transform .4s ease-in-out;
  transition: opacity .5s ease-in-out, transform .4s ease-in-out, -webkit-transform .4s ease-in-out;
  transition-delay: .2s
}

[data-script=fadebox]:nth-child(2) {
  transition: opacity .5s ease-in-out, -webkit-transform .4s ease-in-out;
  transition: opacity .5s ease-in-out, transform .4s ease-in-out;
  transition: opacity .5s ease-in-out, transform .4s ease-in-out, -webkit-transform .4s ease-in-out;
  transition-delay: .3s
}

[data-script=fadebox]:nth-child(3) {
  transition: opacity .5s ease-in-out, -webkit-transform .4s ease-in-out;
  transition: opacity .5s ease-in-out, transform .4s ease-in-out;
  transition: opacity .5s ease-in-out, transform .4s ease-in-out, -webkit-transform .4s ease-in-out;
  transition-delay: .4s
}

[data-script=fadebox]:nth-child(4) {
  transition: opacity .5s ease-in-out, -webkit-transform .4s ease-in-out;
  transition: opacity .5s ease-in-out, transform .4s ease-in-out;
  transition: opacity .5s ease-in-out, transform .4s ease-in-out, -webkit-transform .4s ease-in-out;
  transition-delay: .5s
}

[data-script=fadebox]:nth-child(5) {
  transition: opacity .5s ease-in-out, -webkit-transform .4s ease-in-out;
  transition: opacity .5s ease-in-out, transform .4s ease-in-out;
  transition: opacity .5s ease-in-out, transform .4s ease-in-out, -webkit-transform .4s ease-in-out;
  transition-delay: .6s
}

.note-attention {
  color: #ff6c00
}

.note-center {
  text-align: center
}

.note-attention,
.note-center,
.note-li {
  font-size: 10px;
  line-height: 1.6em;
  text-indent: -1rem;
  padding-left: 1rem;
  margin-top: 12px
}

.note-attention+li,
.note-center+li,
.note-li+li {
  margin-top: 5px
}

.note-attention a,
.note-center a,
.note-li a {
  text-decoration: underline
}

#bg {
  top: 50%;
  left: 50%;
  width: 400%;
  height: 400%;
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
  transform: translate(-50%, -50%) rotate(-45deg);
  opacity: .7;
  left: 0
}

#bg,
#bg::after,
#bg::before {
  position: absolute
}

#bg::after,
#bg::before {
  content: "";
  top: 0;
  width: 100%;
  -webkit-animation: bg 12.5s linear infinite;
  animation: bg 12.5s linear infinite;
  height: 100%;
  background: url(../img/bg.svg) left top/700px
}

#bg::after {
  left: 350px
}

@-webkit-keyframes bg {
  from {
    background-position: 0 0
  }

  to {
    background-position: -700px 0
  }
}

@keyframes bg {
  from {
    background-position: 0 0
  }

  to {
    background-position: -700px 0
  }
}

.mask {
  position: relative;
  width: 100%;
  z-index: 9
}

.cls-1 {
  fill: #06825b
}

.cls-2 {
  fill: none;
  stroke: #fff;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 6.5px
}

@media screen and (min-width:768px) {
  .spOnly {
    display: none !important
  }

  .mt-0-pc {
    margin-top: 0 !important
  }

  .mt-4-pc {
    margin-top: 4px !important
  }

  .mt-8-pc {
    margin-top: 8px !important
  }

  .mt-12-pc {
    margin-top: 12px !important
  }

  .mt-16-pc {
    margin-top: 16px !important
  }

  .mt-20-pc {
    margin-top: 20px !important
  }

  .mt-24-pc {
    margin-top: 24px !important
  }

  .mt-28-pc {
    margin-top: 28px !important
  }

  .mt-32-pc {
    margin-top: 32px !important
  }

  .mt-36-pc {
    margin-top: 36px !important
  }

  .mt-40-pc {
    margin-top: 40px !important
  }

  .mt-44-pc {
    margin-top: 44px !important
  }

  .mt-48-pc {
    margin-top: 48px !important
  }

  .mt-52-pc {
    margin-top: 52px !important
  }

  .mt-56-pc {
    margin-top: 56px !important
  }

  .mt-60-pc {
    margin-top: 60px !important
  }

  .mt-64-pc {
    margin-top: 64px !important
  }

  .mt-68-pc {
    margin-top: 68px !important
  }

  .mt-72-pc {
    margin-top: 72px !important
  }

  .mt-76-pc {
    margin-top: 76px !important
  }

  .mt-80-pc {
    margin-top: 80px !important
  }

  .mt-84-pc {
    margin-top: 84px !important
  }

  .mt-88-pc {
    margin-top: 88px !important
  }

  .mt-92-pc {
    margin-top: 92px !important
  }

  .mt-96-pc {
    margin-top: 96px !important
  }

  .mt-100-pc {
    margin-top: 100px !important
  }

  .mt-104-pc {
    margin-top: 104px !important
  }

  .mt-108-pc {
    margin-top: 108px !important
  }

  .mt-112-pc {
    margin-top: 112px !important
  }

  .mt-116-pc {
    margin-top: 116px !important
  }

  .mt-120-pc {
    margin-top: 120px !important
  }

  .mt-124-pc {
    margin-top: 124px !important
  }

  .mt-128-pc {
    margin-top: 128px !important
  }

  .mt-132-pc {
    margin-top: 132px !important
  }

  .mt-136-pc {
    margin-top: 136px !important
  }

  .mt-140-pc {
    margin-top: 140px !important
  }

  .mt-144-pc {
    margin-top: 144px !important
  }

  .mt-148-pc {
    margin-top: 148px !important
  }

  .mt-152-pc {
    margin-top: 152px !important
  }

  .mt-156-pc {
    margin-top: 156px !important
  }

  .mt-160-pc {
    margin-top: 160px !important
  }

  .pc {
    display: block !important
  }

  .sp {
    display: none !important
  }

  .header__inner {
    padding: 21px 20px 20px 100px
  }

  header {
    height: 70px
  }

  header span {
    margin: 0 24px
  }

  .inner {
    width: 1000px;
    margin: 0 auto;
    position: relative
  }

  .tgl-btn img {
    height: 24px
  }

  .btn-wt {
    width: 300px;
    height: 46px;
    border-radius: 23px;
    font-size: 16px;
    top: -4px
  }

  .btn-wt:hover {
    top: 0;
    box-shadow: none
  }

  .btn-wt:before {
    right: 24px
  }

  .label-ttl {
    height: 60px;
    width: 100%;
    font-size: 24px;
    font-weight: 700
  }

 .label-ttl.label-ttl_student {
    height: 80px;
}

  .main {
    background-image: url(../img/kv_bg.png);
    background-size: calc(1176 / 1280 * 100vw) auto;
    background-repeat: no-repeat;
    background-position: top 85px center
  }

  .kv {
    padding-top: 84px;
    margin-bottom: 60px
  }

  .kv__cont {
    width: 995px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between
  }

  .kv__cont .left {
    width: 578px;
    padding-top: 26px
  }

  .kv__cont .left .txt {
    width: 184px
  }

  .kv__cont .left .txt .write {
    width: 193px;
    position: absolute;
    top: -25px;
    right: -180px
  }

  .kv__cont .right {
    width: 406px
  }

  .kv__cont .right .icon {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap
  }

  .kv__cont .right .icon img {
    width: 200px
  }

  .kv__cont .right .icon img:nth-child(2) {
    margin-top: 40px
  }

  .kv__cont .right .icon img:nth-child(3) {
    margin-top: -33px
  }

  .kv__cont .right .icon img:nth-child(4) {
    margin-top: 5px
  }

  .kv__cont .right p {
    font-size: 10px;
    line-height: 1.6em;
    margin-top: 10px
  }

  .lead {
    margin-bottom: 100px
  }

  .lead__btnwrap {
    width: 770px;
    margin: 0 auto 15px;
    justify-content: space-between;
    max-width: 100%
  }

  .lead__btnwrap a {
    width: 370px;
    height: 56px;
    border-radius: 28px;
    top: -4px;
    font-size: 20px;
    padding-bottom: 2px
  }

  .lead__btnwrap a:hover {
    top: 0;
    box-shadow: none
  }

  .lead__btnwrap a:first-child:after {
    top: -15px;
    left: 25px
  }

  .lead__btnwrap a:before {
    right: 24px;
    width: 11px;
    height: 11px
  }

  .lead__btnwrap a:nth-child(1) {
    background: #ff6c00
  }

  .lead__btnwrap a:nth-child(2) {
    background: #333
  }

  .lead__btnwrap a:nth-child(3) {
    background: #333
  }

  .lead__txt {
    width: 775px;
    margin: 0 auto;
    font-size: 12px;
    line-height: 1.33333em
  }

  .lead__txt p+p {
    margin-top: 8px
  }

  .campaign {
    width: 1000px;
    padding: 70px 0 40px;
    box-shadow: 6px 6px 0 rgba(0, 0, 0, .1);
    margin-top: 5%;
  }

  .campaign__link {
    text-align: center;
    margin-bottom: 23px;
    font-size: 10px
  }

  .campaign__ttl {
    text-align: center;
    width: 492px;
    top: -40px;
  }

  .campaign__head,
  .campaign__lead {
    padding: 0 110px
  }

  .campaign__lead {
    font-size: 10px;
    line-height: 1.6em
  }

  .campaign__lead p+p {
    margin-top: 6px
  }

  .campaign__head {
    margin-bottom: 22px
  }

  .campaign__list {
    width: 500px;
    margin: 0 auto 23px
  }

  .campaign__list li {
    height: 50px
  }

  .campaign__list li+li {
    margin-top: 10px
  }

  .campaign__list li em {
    width: 84px
  }

  .campaign__list li em img {
    height: 11px
  }

  .campaign__list li p {
    font-size: 14px;
    line-height: 1.42857em;
    width: calc(100% - 84px);
    padding: 0 14px
  }

  .campaign__list li p small {
    font-size: 10px
  }

  .campaign-add {
    margin-top: 50px
  }

  .campaign-add__head {
    padding: 32px 110px 20px
  }

  .campaign-add__step {
    width: 780px;
    padding: 37px 0 20px
  }

  .campaign-add__btn {
    height: 36px;
    width: 780px
  }

  .campaign-add__btm {
    margin-top: 20px;
    font-size: 10px;
    line-height: 1.6em;
    padding: 0 110px
  }

  .campaign-add__btm p+p {
    margin-top: 8px
  }

  .campaign-add__btm p:last-child {
    margin-top: 11px
  }

  .campaign-banner {
    margin-top: 48px;
    margin-bottom: 80px
  }

  .campaign-banner__bannerhead {
    width: 300px;
    margin-bottom: 15px
  }

  .privilege {
    padding: 40px 0 0
  }

  .privilege-01 {
    margin-top: 46px
  }

  .privilege-01 .privilege__boxttl {
    width: 541px
  }

  .privilege-02 {
    padding-top: 42px
  }

  .privilege-02:before {
    width: 40px;
    height: 40px;
    top: -88px
  }

  .privilege-02 .privilege__boxttl {
    width: 577px;
    margin-bottom: 15px
  }

  .privilege+.privilege {
    margin-top: 116px
  }

  .privilege__boxhead {
    width: 250px;
    top: -20px
  }

  .privilege__wrap {
    width: calc(100% - 232px)
  }

  .privilege__boxttl {
    margin: 0 auto 20px
  }

  .privilege__listttl {
    width: 200px;
    margin-bottom: 11px;
    margin-top: 11px;
  }

  .privilege__listwrap {
    padding-bottom: 22px
  }

  .privilege__btm {
    font-size: 10px;
    margin-top: 8px
  }

  .privilege__btn {
    height: 36px;
    width: 100%
  }

  .privilege__btmnote {
    width: 1000px;
    margin: 20px auto 0;
    font-size: 10px
  }

  .reco-top {
    padding: 60px 0 70px;
    background-image: url(../img/reco-top_bg.png);
    background-size: calc(1081 / 1280 * 100vw) auto;
    background-repeat: no-repeat;
    background-position: top center
  }

  .reco-top__ttl {
    width: 585px;
    margin-bottom: 35px
  }

  .reco-top__cont {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 845px
  }

  .reco-top__pct {
    width: 316px
  }

  .reco-top__item {
    height: 90px;
    border-radius: 45px;
    width: 400px
  }

  .reco-top__item:before {
    top: -8px
  }

  .reco-top__item:nth-child(n+2) {
    margin-top: 28px
  }

  .reco-top__item:nth-child(n+2):before {
    left: 5px
  }

  .reco-top__item:nth-child(1):before {
    background-image: url(../img/reco-top_num01.png);
    background-size: cover;
    width: 45px;
    height: 40px;
    left: 13px
  }

  .reco-top__item:nth-child(1) img {
    width: 276px
  }

  .reco-top__item:nth-child(2):before {
    background-image: url(../img/reco-top_num02.png);
    background-size: cover;
    width: 55px;
    height: 40px
  }

  .reco-top__item:nth-child(2) img {
    width: 262px
  }

  .reco-top__item:nth-child(3):before {
    background-image: url(../img/reco-top_num03.png);
    background-size: cover;
    width: 48px;
    height: 40px
  }

  .reco-top__item:nth-child(3) img {
    width: 261px
  }

  .reco-top__item:nth-child(4):before {
    background-image: url(../img/reco-top_num04.png);
    background-size: cover;
    width: 48px;
    height: 40px
  }

  .reco-top__item:nth-child(4) img {
    width: 261px
  }

  .reco-bloc__boxwrap {
    z-index: 0
  }

  .reco-bloc__boxwrap:after {
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
    background: -webkit-linear-gradient(45deg, transparent 0, #fefce8 0), -webkit-linear-gradient(135deg, transparent 0, #fefce8 0), -webkit-linear-gradient(225deg, transparent 0, #fefce8 0), -webkit-linear-gradient(315deg, transparent 85px, #fefce8 15px);
    background-position: bottom left, bottom right, top right, top left;
    background-size: 50% 50%;
    background-repeat: no-repeat;
    z-index: -1;
    top: 0;
    left: 0
  }

  .reco-bloc__boxwrap:before {
    content: '';
    position: absolute;
    z-index: -2;
    background: -webkit-linear-gradient(45deg, transparent 0, #000 0), -webkit-linear-gradient(135deg, transparent 0, #000 0), -webkit-linear-gradient(225deg, transparent 0, #000 0), -webkit-linear-gradient(315deg, transparent 85px, #000 15px);
    background-position: bottom left, bottom right, top right, top left;
    background-size: 50% 50%;
    background-repeat: no-repeat;
    opacity: .16;
    right: -6px;
    bottom: -6px;
    width: 100%;
    height: 100%
  }

  .reco-bloc {
    padding: 60px 0 100px
  }

  .reco-bloc.reco-01 .boxwrap01 .box02 {
    background: #c6efcd
  }

  .reco-bloc.reco-01 .boxwrap01 .box04 {
    background: #cff6b9
  }

  .reco-bloc.reco-01 .boxwrap01 .box03 {
    background: #fcf3c6
  }

  .reco-bloc.reco-01 .boxwrap01 .box01 .reco-bloc__boxttl {
    width: 495px;
    margin-bottom: 30px
  }

  .reco-bloc.reco-01 .boxwrap01 .box02 {
    padding: 53px 0 40px;
    margin-top: 45px
  }

  .reco-bloc.reco-01 .boxwrap01 .box03 {
    padding: 50px 0 40px
  }

  .reco-bloc.reco-01 .boxwrap01 .box03 .reco-bloc__boxttl {
    width: 529px;
    margin-bottom: 25px
  }

  .reco-bloc.reco-01 .boxwrap01 .box03 .privilege__link {
    margin-top: 20px
  }

  .reco-bloc.reco-01 .boxwrap01 .box03 .reco-bloc__lead {
    margin-bottom: 21px
  }

  .reco-bloc.reco-01 .boxwrap01 .box04 {
    padding: 48px 0 40px
  }

  .reco-bloc.reco-01 .boxwrap01 .box04 .reco-bloc__boxttl {
    width: 540px;
    margin-bottom: 33px
  }

  .reco-bloc.reco-01 .boxwrap01 .box04 .reco-bloc__pct {
    background: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 780px;
    height: 283px;
    border-radius: 16px;
    margin: 0 auto 6px
  }

  .reco-bloc.reco-01 .boxwrap01 .box04 .reco-bloc__pct img {
    width: 580px
  }

  .reco-bloc.reco-01 .boxwrap01 .box04 .reco-bloc__pct+small {
    padding: 0 110px
  }

  .reco-bloc.reco-01 .boxwrap02 {
    padding-bottom: 40px;
  }

  .reco-bloc.reco-01 .boxwrap02 .reco-bloc__boxttl {
    width: 468px;
    margin-bottom: 39px
  }

  .reco-bloc.reco-01 .boxwrap02 .reco-bloc__boxlogo {
    width: 508px;
    margin: 0 auto 36px
  }

  .reco-bloc.reco-01 .boxwrap03 .reco-bloc__boxttl {
    margin-bottom: 30px;
    width: 560px
  }

  .reco-bloc.reco-01 .boxwrap03 .box01 {
    padding-bottom: 40px
  }

  .reco-bloc.reco-01 .boxwrap03 .box02 {
    margin-top: 48px;
    padding: 50px 0 40px
  }

  .reco-bloc.reco-01 .boxwrap04 {
    margin-top: 48px;
    padding-bottom: 40px
  }

  .reco-bloc.reco-01 .boxwrap04 .reco-bloc__boxttl {
    margin-bottom: 30px;
    width: 718px
  }

  .reco-bloc.reco-01 .boxwrap04 .reco-bloc__pct {
    width: 315px;
    margin: 0 auto 24px
  }

  .reco-bloc.reco-01 .boxwrap04 .reco-bloc__lead {
    margin-bottom: 25px;
    text-align: center
  }
  .reco-bloc.reco-01 .boxwrap04.about-vpointapp .reco-bloc__lead {
    text-align: left;
  }
  .vpointapp_text {
	text-align: center;
  }
  .reco-bloc.reco-02 .reco-bloc__ttl {
    width: 773px;
    margin: 0 auto 38px
  }

  .reco-bloc.reco-02 .boxwrap01 {
    margin-bottom: 70px
  }

  .reco-bloc.reco-02 .boxwrap01 .reco-bloc__boxttl {
    margin-bottom: 30px;
    width: 369px
  }

  .reco-bloc.reco-02 .boxwrap01 .reco-bloc__box {
    padding-bottom: 40px
  }

  .reco-bloc.reco-02 .boxwrap01 .reco-bloc__pct {
    margin: 0 auto;
    padding-top: 35px
  }

  .reco-bloc.reco-02 .boxwrap01 .reco-bloc__pct img {
    width: 755px;
    display: block;
    margin: 0 auto
  }

  .reco-bloc.reco-02 .boxwrap01 .reco-bloc__pct:before {
    content: '';
    width: 780px;
    height: 4px;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    background: #f5e343
  }

  .reco-bloc.reco-02 .boxwrap01 .reco-bloc__ttl {
    width: 773px;
    margin-bottom: 39px
  }

  .reco-bloc.reco-02 .boxwrap02 .reco-bloc__boxttl {
    width: 360px;
    margin-bottom: 28px
  }

  .reco-bloc.reco-02 .boxwrap02 .reco-bloc__lead {
    font-size: 24px;
    line-height: 1.66667em;
    text-align: center;
    margin-bottom: 40px
  }

  .reco-bloc.reco-03 .boxwrap01 {
    padding-bottom: 40px
  }

  .reco-bloc.reco-03 .boxwrap01 .reco-bloc__boxttl {
    width: 609px;
    margin: 0 auto;
    margin-bottom: 28px
  }

  .reco-bloc.reco-03 .boxwrap01 .reco-bloc__notewrap {
    padding: 0;
    width: 780px;
    font-size: 12px
  }

  .reco-bloc.reco-03 .boxwrap01 .reco-bloc__notewrap p+p {
    margin-top: 6px
  }

  .reco-bloc.reco-03 .boxwrap02 {
    padding-bottom: 40px;
    margin-top: 48px
  }

  .reco-bloc.reco-03 .boxwrap02 .reco-bloc__boxttl {
    width: 800px;
    margin: 0 auto;
    margin-bottom: 24px
  }

  .reco-bloc.reco-03 .boxwrap02 .reco-bloc__notewrap {
    padding: 0;
    width: 780px;
    font-size: 12px;
    margin-bottom: 20px
  }

  .reco-bloc__app {
    padding: 40px 0 40px
  }

  .reco-bloc__app ul {
    width: 780px
  }

  .reco-bloc__app ul li {
    width: 244px;
    height: 495px;
    padding: 20px 0 0;
    border-radius: 10px
  }

  .reco-bloc__app ul li em {
    font-size: 20px;
    line-height: 1.4em;
    padding-bottom: 10px
  }

  .reco-bloc__app ul li em img {
    height: 74px;
    display: block;
    margin: 0 auto
  }

  .reco-bloc__app ul li em:before {
    width: calc(100% - 40px)
  }

  .reco-bloc__app ul li p {
    font-size: 12px;
    line-height: 1.66667em;
    margin-top: 13px;
    padding: 0 20px
  }

  .reco-bloc__app ul li p+img {
    width: 180px;
    position: absolute;
    bottom: 0;
    right: 0;
    left: 0;
    margin: 0 auto
  }

  .reco-bloc__ttl {
    margin-bottom: 38px
  }

  .reco-bloc__lead {
    font-size: 16px;
    line-height: 2;
    padding: 0 110px
  }

  .reco-bloc__lead small {
    margin-top: 6px
  }

  .reco-bloc__lead em {
    color: #be0000
  }

  .reco-bloc__boxhead {
    font-size: 20px;
    height: 40px;
    padding: 0 33px;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    min-width: 226px;
    top: -20px
  }

  .reco-bloc__ttlnum {
    height: 115px;
    margin-bottom: 40px
  }

  .reco-bloc__point {
    width: 780px;
    margin-bottom: 70px
  }

  .reco-bloc__point.point01 li {
    width: 245px
  }

  .reco-bloc__point.point01 li:nth-child(even) {
    margin-top: 35px
  }

  .reco-bloc__point.point02 li {
    width: 244px
  }

  .reco-bloc__point.point02 li:nth-child(2) {
    margin-top: 30px
  }

  .reco-bloc__point.point02 li:nth-child(3) {
    margin-top: 51px
  }

  .reco-bloc__box small {
    font-size: 10px
  }

  .reco-bloc__boxicon {
    width: 780px;
    height: 254px;
    border-radius: 16px
  }

  .reco-bloc__boxicon img {
    width: 476px
  }

  .reco-bloc__boxwrap {
    width: 1000px;
    margin-top: 48px;
    padding-top: 50px
  }

  .reco-bloc__bannerwrap {
    width: 780px;
    margin-top: 33px
  }

  .reco-bloc__bannerwrap a {
    display: block;
    width: 728px;
    margin: 0 auto
  }

  .reco-bloc__bannerhead {
    width: 280px;
    margin: 0 auto 8px;
    display: block
  }

  .reco-bloc__boxrow {
    display: flex;
    justify-content: space-between;
    width: 780px;
    margin-bottom: 50px;
    border-top: 4px solid #f5e343;
    padding-top: 45px
  }

  .reco-bloc__boxrow li {
    width: 240px
  }

  .reco-bloc__boxrow li .pct {
    height: 100px;
    width: 166px;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto 15px
  }

  .reco-bloc__boxrow li em {
    font-size: 24px;
    line-height: 1.58333em
  }

  .reco-bloc__boxrow li p {
    font-size: 14px;
    line-height: 1.71429em;
    margin-top: 10px
  }

  .reco-bloc__iconnote {
    font-size: 10px;
    line-height: 1.6em;
    padding: 0 110px;
    margin-top: 20px
  }

  .reco-bloc__iconnote p+p {
    margin-top: 8px
  }

  .reco-bloc__box:nth-child(n+2) {
    margin-top: 60px
  }

  .reco-bloc__simu {
    width: 780px
  }

  .reco-bloc__simu h3 {
    font-size: 20px;
    width: 226px;
    height: 40px;
    border-radius: 20px;
    top: -20px
  }

  .reco-bloc__simu em {
    text-align: center;
    font-size: 24px;
    margin-bottom: 18px;
    margin-top: 40px
  }

  .reco-bloc__simupct img {
    width: 613px;
    display: block;
    margin: 0 auto;
    min-height: 158px
  }

  .reco-bloc__tgl {
    height: 36px
  }

  .reco-bloc__boxcol {
    width: 780px;
    margin: 0 auto 30px;
    border-top: 4px solid #f5e343;
    padding-top: 13px
  }

  .reco-bloc__boxcol li {
    border-bottom: 2px solid #b3d7bd
  }

  .reco-bloc__boxcol li:nth-child(1) img {
    width: 58px;
    left: -11px
  }

  .reco-bloc__boxcol li:nth-child(2) img {
    width: 111px;
    right: -4px
  }

  .reco-bloc__boxcol li:nth-child(3) img {
    width: 45px;
    left: -4px
  }

  .reco-bloc__boxcol li:nth-child(4) img {
    width: 110px;
    left: -7px
  }

  .reco-bloc__boxcol li:nth-child(5) img {
    width: 130px;
    left: -5px
  }

  .reco-bloc__boxcol .pct {
    width: 177px;
    flex-shrink: 0
  }

  .reco-bloc__boxcol .txt {
    padding: 30px 0;
    padding-right: 20px
  }

  .reco-bloc__boxcol .txt p {
    font-size: 14px;
    line-height: 1.42857em
  }

  .reco-bloc__boxcol .txt em {
    font-size: 24px;
    display: block;
    margin-bottom: 10px
  }

  .reco-bloc__boxcol .txt em small {
    font-size: 20px
  }

  .reco-bloc__num li {
    width: 700px;
    margin: 0 auto
  }

  .reco-bloc__num li+li {
    margin-top: 12px
  }

  .reco-bloc__num li .txt,
  .reco-bloc__num li em {
    height: 60px
  }

  .reco-bloc__num li em {
    width: 84px
  }

  .reco-bloc__num li em img {
    height: 36px
  }

  .reco-bloc__num li .txt {
    padding: 0 20px;
    width: calc(100% - 84px);
    font-size: 20px;
    font-weight: 500
  }

  .reco-bloc__notewrap {
    width: 700px;
    margin: 16px auto 0;
    font-size: 10px;
    line-height: 1.6em
  }

  .reco-bloc__notewrap p+p {
    margin-top: 3px
  }

  .reco-bloc.reco-01 .reco-bloc__ttl {
    width: 495px
  }

  .reco-bloc.reco-03 .reco-bloc__ttl {
    width: 835px;
    margin-bottom: 63px
  }

  .tab__tab {
    height: 47px;
    font-size: 19px;
    position: absolute;
    top: 147px;
    right: 0;
    left: 0;
    margin: 0 auto;
    border-bottom: 2px solid #06825b
  }

  .tab__tab li {
    width: 300px;
    height: 40px;
    border-radius: 10px 10px 0 0;
    box-shadow: 5px 0 1px rgba(34, 34, 34, .1)
  }

  .tab__tab li+li {
    margin-left: 20px
  }

  .tab__tab li.is-active {
    height: 47px
  }

  .tab__head {
    padding-top: 60px;
    font-size: 28px;
    height: 192px
  }

  .tab__icon {
    font-size: 21px;
    width: 283px;
    margin: 40px auto 20px;
    width: 283px
  }

  .tab__leadbtm,
  .tab__leadtop {
    font-size: 24px
  }

  .tab__leadbtm {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    margin-top: 8px
  }

  .tab__leadbtm em {
    font-size: 32px
  }

  .tab__list {
    width: 700px;
    margin: 30px auto 20px
  }

  .tab__list li {
    height: 60px
  }

  .tab__list li+li {
    margin-top: 10px
  }

  .tab__list li em {
    width: 84px
  }

  .tab__list li em img {
    height: 14px
  }

  .tab__list li p {
    font-size: 20px;
    line-height: 1.42857em;
    width: calc(100% - 84px);
    padding: 0 14px
  }

  .tab__list li p small {
    display: block;
    font-size: 10px
  }

  .tab__notewrap {
    width: 700px;
    margin: 0 auto;
    padding-bottom: 40px;
    font-size: 12px;
    line-height: 1.66667em
  }

  .info__inner {
    width: 780px
  }

  .info__label img {
    height: 25px
  }

  .info__head {
    margin-top: 50px;
    display: flex;
    justify-content: space-between
  }

  .info__head .pct {
    width: 280px;
    flex-shrink: 0;
    margin-right: 30px
  }

  .info__head .txt {
    font-size: 14px;
    line-height: 1.42857em
  }

  .info__head .txt p+p {
    margin-top: 8px
  }

  .info__head .txt small {
    margin: 8px 0
  }

  .info__cont {
    margin-top: 35px;
    margin-bottom: 20px
  }

  .info__cont dl dt {
    width: 210px;
    padding-top: 15px;
    font-size: 14px
  }

  .info__cont dl dd {
    padding: 16px 0;
    font-size: 14px;
    line-height: 1.42857em
  }

  .info__cont dl dd em {
    font-weight: 700;
    display: block;
    margin: 8px 0
  }

  .info__cont dl dd small {
    display: block;
    font-size: 10px
  }

  .info__cont dl dd p+p {
    margin-top: 8px
  }

  .info__note {
    font-size: 10px;
    line-height: 1.6em;
    margin-bottom: 30px
  }

  .info__note a {
    text-decoration: underline
  }

  .info__note p+p {
    margin-top: 8px
  }

  .info__btm {
    margin-top: 30px;
    font-size: 12px;
    line-height: 1.5em
  }

  .info__btm p+p {
    margin-top: 8px
  }

  .more {
    margin-top: 50px
  }

  .more-slide {
    width: 728px;
    margin: 19px auto 0
  }

  .footer-sitemap {
    padding: 70px 0 30px;
    display: flex;
    justify-content: center
  }

  .footer-sitemap li+li {
    border-left: 1px solid #000;
    margin-left: 20px;
    padding-left: 20px
  }

  .fixed a {
    font-size: 24px
  }

  .fixed a span:before {
    right: -27px;
    width: 11px;
    height: 11px
  }

  .modal#modal01 {
    width: 780px
  }

  .modal .btn-point01 {
    width: 400px
  }

  .modal-inner {
    display: flex;
    justify-content: space-between
  }

  .modal-box {
    width: 315px
  }

  .modal-box img {
    height: 60px
  }

  .modal#modal02 {
    width: 780px
  }

  .modal#modal02 .inner {
    padding: 40px 85px
  }

  .modal#modal02 .modal-term {
    padding: 12px 30px
  }

  .modal#modal02 .modal-term ul li {
    margin-top: 7px
  }

  #modal03,
  #modal05 {
    width: 780px
  }

  #modal04 {
    width: 550px
  }

  #modal04 .inner {
    width: 359px;
    margin: 0 auto;
    padding: 40px 0
  }

  #modal04 .btn-wt {
    width: 100%;
    margin: 20px auto 0;
    margin-top: 10px
  }

  #modal04 .btn-wt img {
    height: 17px
  }

  #modal05 .inner {
    width: 526px;
    padding: 40px 0
  }

  #modal05 .point .btnarea {
    display: block;
    width: auto;
    margin: 30px auto 0
  }

  #modal05 .point .btnarea a {
    width: 400px;
    margin: 30px auto 0
  }

  .note-attention a:hover,
  .note-center a:hover,
  .note-li a:hover {
    text-decoration: none
  }
}

@media screen and (max-width:767px) {
  .pcOnly {
    display: none !important
  }

  .pc {
    display: none !important
  }

  .sp {
    display: block !important
  }

  body {
    min-width: auto
  }

  .header__inner {
    padding: 14px 20px
  }

  header {
    height: 45px
  }

  header .header-logo .smbg-logo {
    height: 20px
  }

  header .header-logo span {
    height: 10px;
    margin: 0 8px
  }

  header .header-logo .sej-logo {
    height: 22px
  }

  .main .bg-01 {
    background-size: 10px 10px
  }

  .main .bg-02 {
    background-size: 10px 10px
  }

  .main .bg-03 {
    background-size: 10px 10px
  }

  .main .bg-04 {
    background-size: 10px 10px
  }

  .tgl-btn img {
    height: 20px
  }

  .btn-wt {
    width: calc(100% - 40px);
    height: 50px;
    border-radius: 25px;
    font-size: 16px
  }

  .btn-wt:before {
    right: 20px
  }

  .label-ttl {
    min-height: 51px;
    width: 100%;
    font-size: 16px;
    font-weight: 700;
    padding: 13px 0;
    text-align: center
  }

  .main {
    background-image: url(../img/sp/kv_bg.png);
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-position: top calc(27 / 375 * 100vw) center
  }

  .kv {
    margin-bottom: 60px
  }

  .kv__cont .top {
    width: 100%
  }

  .kv__cont .top .txt {
    width: calc(120 / 375 * 100vw);
    position: absolute;
    top: calc(98 / 375 * 100vw);
    left: calc(22 / 375 * 100vw)
  }

  .kv__cont .top .txt .write {
    position: absolute;
    top: calc(-15 / 375 * 100vw);
    right: calc(-104 / 375 * 100vw);
    width: calc(118 / 375 * 100vw)
  }

  .kv__cont .top .pct {
    width: 100%;
    padding-top: calc(141 / 375 * 100vw)
  }

  .kv__cont .btm {
    padding: 0 20px;
    margin-top: 37px
  }

  .kv__cont .btm .icon {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap
  }

  .kv__cont .btm .icon img {
    display: block;
    width: calc(165 / 335 * 100%)
  }

  .kv__cont .btm .icon img:nth-child(even) {
    right: calc(-7 / 375 * 100vw)
  }

  .kv__cont .btm .icon img:nth-child(2) {
    margin-top: 40px
  }

  .kv__cont .btm .icon img:nth-child(3) {
    margin-top: -33px
  }

  .kv__cont .btm .icon img:nth-child(4) {
    margin-top: 5px
  }

  .kv__cont .btm p {
    font-size: 10px;
    line-height: 1.6em;
    margin-top: 10px
  }

  .lead {
    margin-bottom: 55px
  }

  .lead__btnwrap {
    width: calc(100% - 40px);
    margin: 0 auto 15px;
    flex-direction: column
  }

  .lead__btnwrap a {
    width: 100%;
    height: 50px;
    border-radius: 25px;
    font-size: 18px;
    padding-bottom: 1px
  }

  @media screen and (max-width: 767px) {
    .lead__btnwrap a:first-child:after {
      top: -35px;
      left: 15px;
    }
  }

  .lead__btnwrap a+a {
    margin-top: 16px
  }

  .lead__btnwrap a:before {
    right: 24px;
    width: 11px;
    height: 11px
  }

  .lead__btnwrap a:nth-child(1) {
    background: #ff6c00
  }
  .lead__btnwrap.indexb a:nth-child(1) {
    margin-top: 20px;
    background: #ff6c00
  }

  .lead__btnwrap a:nth-child(2) {
    background: #333
  }

  .lead__btnwrap a:nth-child(3) {
    background: #333
  }

  .lead__txt {
    width: calc(100% - 40px);
    margin: 0 auto;
    font-size: 10px;
    line-height: 1.6em
  }

  .lead__txt p+p {
    margin-top: 8px
  }

  .campaign {
    width: calc(100% - 40px);
    padding: 50px 0 30px;
    box-shadow: 5px 5px 0 rgba(0, 0, 0, .1)
  }

  .campaign__ttl {
    width: calc(295 / 335 * 100%);
    margin: 0 auto;
    top: calc(-25 / 375 * 100vw)
  }

  .campaign__link {
    margin-bottom: 20px
  }

  .campaign__lead p+p {
    margin-top: 8px
  }

  .campaign__head {
    padding: 0 20px;
    margin-bottom: 20px
  }

  .campaign__lead {
    font-size: 10px;
    line-height: 1.6em;
    padding: 0 20px
  }

  .campaign__list {
    width: 100%;
    margin: 0 auto 20px;
    padding: 0 10px
  }

  .campaign__list li {
    align-items: stretch
  }

  .campaign__list li+li {
    margin-top: 8px
  }

  .campaign__list li em {
    width: 44px;
    height: auto
  }

  .campaign__list li em img {
    height: 7px
  }

  .campaign__list li p {
    font-size: 12px;
    line-height: 1.42857em;
    width: calc(100% - 44px);
    min-height: 44px;
    padding: 10px
  }

  .campaign-add {
    margin-top: 30px
  }

  .campaign-add .label-ttl {
    min-height: auto;
    padding: 4px 0
  }

  .campaign-add__link {
    height: 40px;
    border-radius: 20px
  }

  .campaign-add__head {
    padding: 17px 20px 15px
  }

  .campaign-add__step {
    width: calc(100% - 40px);
    padding: 20px 0 20px
  }

  .campaign-add__btn {
    height: 32px;
    width: calc(100% - 40px)
  }

  .campaign-add__btm {
    margin-top: 20px;
    font-size: 10px;
    line-height: 1.6em;
    padding: 0 20px
  }

  .campaign-add__btm p+p {
    margin-top: 8px
  }

  .campaign-add__btm p:last-child {
    margin-top: 15px
  }

  .campaign-banner {
    padding-top: 35px;
    margin-bottom: 50px
  }

  .campaign-banner__bannerhead {
    width: calc(215 / 375 * 100%);
    margin-bottom: 18px
  }

  .privilege {
    padding: 32px 0 0;
    width: calc(100% - 40px);
    margin: 0 auto
  }

  .privilege__link {
    height: 40px;
    border-radius: 20px
  }

  .privilege-01 .privilege__boxttl {
    padding: 0 20px
  }

  .privilege-02:before {
    width: 24px;
    height: 24px;
    top: -59px
  }

  .privilege+.privilege {
    margin-top: 80px
  }

  .privilege__boxhead {
    width: 93px;
    top: -15px
  }

  .privilege__wrap {
    width: 100%;
    margin-top: 20px
  }

  .privilege__boxttl {
    margin: 0 auto 12px;
    padding: 0 20px
  }

  .privilege__listttl {
    width: calc(157 / 295 * 100%);
    margin-bottom: 6px
  }

  .privilege__listwrap {
    padding-bottom: 20px
  }

  .privilege__btm {
    font-size: 10px;
    margin-top: 10px
  }

  .privilege__btn {
    height: 36px;
    width: 100%
  }

  .privilege__btmnote {
    width: calc(100% - 40px);
    margin: 10px auto 0;
    font-size: 10px
  }

  .reco-top {
    padding: 45px 0 60px;
    background-image: url(../img/sp/reco-top_bg.png);
    background-size: 100%;
    background-repeat: no-repeat;
    background-position: top center
  }

  .reco-top__ttl {
    width: calc(260 / 375 * 100%);
    margin-bottom: 24px
  }

  .reco-top__pct {
    width: calc(220 / 375 * 100%);
    margin: 0 auto 32px
  }

  .reco-top__item {
    width: calc(355 / 375 * 100%);
    margin-left: auto;
    margin-right: 0;
    height: 115px;
    border-radius: 58px 0 0 58px;
    justify-content: flex-start;
    padding-left: 56px;
    -webkit-transform: translateY(0) translateX(20px);
    transform: translateY(0) translateX(20px)
  }

  .reco-top__item.is-fade {
    -webkit-transform: translateY(0) translateX(0);
    transform: translateY(0) translateX(0)
  }

  .reco-top__item:before {
    top: -8px
  }

  .reco-top__item:nth-child(n+2) {
    margin-top: 22px
  }

  .reco-top__item:nth-child(n+2):before {
    left: 5px
  }

  .reco-top__item:nth-child(1):before {
    background-image: url(../img/reco-top_num01.png);
    background-size: cover;
    width: 45px;
    height: 40px;
    left: 1px
  }

  .reco-top__item:nth-child(1) img {
    width: 208px
  }

  .reco-top__item:nth-child(2):before {
    background-image: url(../img/reco-top_num02.png);
    background-size: cover;
    width: 55px;
    height: 40px;
    left: 2px
  }

  .reco-top__item:nth-child(2) img {
    width: 262px
  }

  .reco-top__item:nth-child(3):before {
    background-image: url(../img/reco-top_num03.png);
    background-size: cover;
    width: 48px;
    height: 40px;
    left: 1px
  }

  .reco-top__item:nth-child(3) img {
    width: 261px
  }

  .reco-top__item:nth-child(4):before {
    background-image: url(../img/reco-top_num04.png);
    background-size: cover;
    width: 48px;
    height: 40px;
    left: 1px
  }

  .reco-top__item:nth-child(4) img {
    width: 261px
  }

  .reco-bloc__boxwrap {
    z-index: 0
  }

  .reco-bloc__boxwrap:after {
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
    background: -webkit-linear-gradient(45deg, transparent 0, #fefce8 0), -webkit-linear-gradient(135deg, transparent 0, #fefce8 0), -webkit-linear-gradient(225deg, transparent 0, #fefce8 0), -webkit-linear-gradient(315deg, transparent 40px, #fefce8 15px);
    background-position: bottom left, bottom right, top right, top left;
    background-size: 50% 50%;
    background-repeat: no-repeat;
    z-index: -1;
    top: 0;
    left: 0
  }

  .reco-bloc__boxwrap:before {
    content: '';
    position: absolute;
    z-index: -2;
    background: -webkit-linear-gradient(45deg, transparent 0, #000 0), -webkit-linear-gradient(135deg, transparent 0, #000 0), -webkit-linear-gradient(225deg, transparent 0, #000 0), -webkit-linear-gradient(315deg, transparent 40px, #000 15px);
    background-position: bottom left, bottom right, top right, top left;
    background-size: 50% 50%;
    background-repeat: no-repeat;
    opacity: .16;
    right: -3px;
    bottom: -3px;
    width: 100%;
    height: 100%
  }

  .reco-bloc {
    padding: 50px 0
  }

  .reco-bloc .label-ttl {
    font-size: 20px;
    padding: 10px 0
  }

  .reco-bloc.reco-01 .reco-bloc__ttl {
    width: calc(262 / 375 * 100%);
    margin-bottom: 25px
  }

  .reco-bloc.reco-01 .boxwrap01 .box02 {
    background: #c6efcd
  }

  .reco-bloc.reco-01 .boxwrap01 .box04 {
    background: #cff6b9
  }

  .reco-bloc.reco-01 .boxwrap01 .box03 {
    background: #fcf3c6
  }

  .reco-bloc.reco-01 .boxwrap01 .box03 .reco-bloc__lead {
    margin-bottom: 13px
  }

  .reco-bloc.reco-01 .boxwrap01 .box01 .reco-bloc__boxttl {
    width: calc(314 / 375 * 100%);
    margin-bottom: 24px
  }

  .reco-bloc.reco-01 .boxwrap01 .box02 {
    padding: 35px 0 40px
  }

  .reco-bloc.reco-01 .boxwrap01 .box03 {
    padding: 50px 0 30px
  }

  .reco-bloc.reco-01 .boxwrap01 .box03 .reco-bloc__boxhead {
    font-size: 16px
  }

  .reco-bloc.reco-01 .boxwrap01 .box03 .reco-bloc__boxttl {
    padding: 0 20px;
    margin-bottom: 15px
  }

  .reco-bloc.reco-01 .boxwrap01 .box03 .privilege__link {
    margin-top: 20px
  }

  .reco-bloc.reco-01 .boxwrap01 .box04 {
    padding: 48px 0 30px
  }

  .reco-bloc.reco-01 .boxwrap01 .box04 .reco-bloc__boxttl {
    width: calc(276 / 335 * 100%);
    margin-bottom: 18px
  }

  .reco-bloc.reco-01 .boxwrap01 .box04 .reco-bloc__pct {
    background: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    width: calc(100% - 40px);
    padding: 20px 15px;
    border-radius: 10px;
    margin: 0 auto 15px
  }

  .reco-bloc.reco-01 .boxwrap01 .box04 .reco-bloc__pct img {
    width: 100%
  }

  .reco-bloc.reco-01 .boxwrap01 .box04 .reco-bloc__pct+small {
    width: calc(100% - 40px);
    margin: 0 auto;
    display: block;
    text-align: center
  }

  .reco-bloc.reco-01 .boxwrap02 {
    padding-bottom: 26px;
    margin-bottom: 55px
  }

  .reco-bloc.reco-01 .boxwrap02 .reco-bloc__boxttl {
    width: calc(224 / 335 * 100%);
    margin-bottom: 18px
  }

  .reco-bloc.reco-01 .boxwrap02 .reco-bloc__boxlogo {
    width: calc(293 / 335 * 100%);
    margin: 0 auto 20px
  }

  .reco-bloc.reco-01 .boxwrap03 .reco-bloc__boxttl {
    margin-bottom: 30px;
    width: calc(100% - 70px)
  }

  .reco-bloc.reco-01 .boxwrap03 .box01 {
    padding-bottom: 30px
  }

  .reco-bloc.reco-01 .boxwrap03 .box02 {
    margin-top: 48px;
    padding: 50px 0 40px
  }

  .reco-bloc.reco-01 .boxwrap04 {
    margin-top: 48px;
    padding-bottom: 30px;
    padding-top: 40px
  }

  .reco-bloc.reco-01 .boxwrap04 .reco-bloc__boxttl {
    margin-bottom: 21px;
    width: calc(252 / 335 * 100%)
  }
  .reco-bloc.reco-01 .boxwrap04 .reco-bloc__boxttl.steps {
    width: calc(252 / 335 * 100%)
  }

  .reco-bloc.reco-01 .boxwrap04 .reco-bloc__pct {
    width: calc(240 / 335 * 100%);
    margin: 0 auto 24px
  }

  .reco-bloc.reco-01 .boxwrap04 .reco-bloc__lead {
    margin-bottom: 20px
  }

  .reco-bloc.reco-02 .reco-bloc__ttl {
    width: 773px;
    width: calc(330 / 375 * 100%);
    margin: 0 auto 24px
  }

  .reco-bloc.reco-02 .boxwrap01 {
    margin-bottom: 48px
  }

  .reco-bloc.reco-02 .boxwrap01 .reco-bloc__boxttl {
    margin-bottom: 22px;
    width: calc(195 / 335 * 100%)
  }

  .reco-bloc.reco-02 .boxwrap01 .reco-bloc__box {
    padding-bottom: 30px
  }

  .reco-bloc.reco-02 .boxwrap01 .reco-bloc__pct {
    border-top: 2px solid #f5e343;
    padding-top: 20px;
    width: calc(100% - 40px);
    margin: 0 auto
  }

  .reco-bloc.reco-02 .boxwrap01 .reco-bloc__ttl {
    width: 773px;
    margin-bottom: 39px
  }

  .reco-bloc.reco-02 .boxwrap02 {
    padding-top: 40px
  }

  .reco-bloc.reco-02 .boxwrap02 .reco-bloc__boxttl {
    width: calc(218 / 335 * 100%);
    margin-bottom: 20px
  }

  .reco-bloc.reco-02 .boxwrap02 .reco-bloc__lead {
    font-size: 16px;
    line-height: 1.5625em;
    text-align: left;
    margin-bottom: 35px
  }
  .reco-bloc__contents {
    margin: 40px 0;
    padding: 0 20px;
  }
  .reco-bloc__contents__text {
    font-size: 14px;
    line-height: 1.71429em;
  }
  .reco-bloc__vpointapp_list li {
    padding-left: 1rem;
    text-indent: -1rem;
  }
  .about-vpointapp .reco-bloc__notewrap {
    margin: 10px 0 0;
    width: auto;
  }
  .reco-bloc__contents__lead {
    font-size: 18px;
    line-height: 1.22222em;
    display: block;
    font-weight: 700;
    color: #004831;
  }
  .reco-bloc__vpointapp_ttl {
    display: flex;
    justify-content: center;
  }
  .reco-bloc__vpointapp_ttl img {
    margin: 0 auto;
  }
  .reco-bloc__vpointapp_ttl .reco-bloc__contents__lead {
    margin: auto;
  }
  .img-point-logos img {
	width: 250px;
  }
  .reco-bloc.reco-03 .reco-bloc__ttl {
    width: calc(268 / 375 * 100%);
    margin-bottom: 50px
  }

  .reco-bloc.reco-03 .reco-04 .boxwrap01 {
    padding-bottom: 30px
  }

  .reco-bloc.reco-03 .boxwrap01 .reco-bloc__boxttl {
    width: calc(286 / 335 * 100%);
    margin: 0 auto;
    margin-bottom: 20px
  }

  .reco-bloc.reco-03 .boxwrap01 .reco-bloc__notewrap {
    width: 100%;
    padding: 0 20px;
    font-size: 10px;
    margin-top: 13px;
    line-height: 1.6em
  }

  .reco-bloc.reco-03 .boxwrap01 .reco-bloc__notewrap p+p {
    margin-top: 8px
  }

  .reco-bloc.reco-03 .boxwrap02 {
    padding-bottom: 40px;
    margin-top: 48px
  }

  .reco-bloc.reco-03 .boxwrap02 .reco-bloc__boxttl {
    width: calc(266 / 335 * 100%);
    margin: 0 auto;
    margin-bottom: 27px
  }

  .reco-bloc.reco-03 .boxwrap02 .reco-bloc__notewrap {
    padding: 0;
    width: 100%;
    padding: 0 20px;
    font-size: 10px;
    margin-bottom: 15px
  }

  .reco-bloc__app {
    padding: 40px 0 40px
  }

  .reco-bloc__app ul {
    padding: 0 20px;
    flex-direction: column
  }

  .reco-bloc__app ul li {
    width: 100%;
    padding: 27px 20px 0;
    border-radius: 10px
  }

  .reco-bloc__app ul li+li {
    margin-top: 24px
  }

  .reco-bloc__app ul li em {
    font-size: 16px;
    line-height: 1.75em;
    padding-bottom: 25px
  }

  .reco-bloc__app ul li em img {
    height: calc(45 / 375 * 100vw);
    width: auto
  }

  .reco-bloc__app ul li em:before {
    width: 100%
  }

  .reco-bloc__app ul li p {
    font-size: 12px;
    line-height: 1.66667em;
    margin-top: 15px
  }

  .reco-bloc__app ul li p+img {
    width: calc(200 / 255 * 100%);
    margin: 20px auto 0;
    display: block
  }

  .reco-bloc__ttl {
    margin-bottom: 38px
  }

  .reco-bloc__lead {
    font-size: 14px;
    line-height: 1.71429em;
    padding: 0 20px
  }

  .reco-bloc__lead small {
    margin-top: 10px
  }

  .reco-bloc__lead em {
    color: #be0000
  }

  .reco-bloc__boxhead {
    font-size: 14px;
    height: 28px;
    padding: 0 33px;
    padding-bottom: 2px;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    min-width: 180px;
    top: -14px
  }

  .reco-bloc__ttlnum {
    height: calc(81 / 375 * 100vw);
    margin-bottom: 24px
  }

  .reco-bloc__point {
    width: 100%;
    padding: 0 20px;
    margin-bottom: 50px
  }

  .reco-bloc__point.point01 {
    flex-wrap: wrap
  }

  .reco-bloc__point.point01 li {
    width: 47.76119%
  }

  .reco-bloc__point.point01 li:nth-child(even) {
    margin-top: 30px
  }

  .reco-bloc__point.point01 li:nth-child(3) {
    margin-top: -15px
  }

  .reco-bloc__point.point01 li:nth-child(4) {
    margin-top: 15px
  }

  .reco-bloc__point.point02 {
    flex-direction: column;
    padding: 0 40px
  }

  .reco-bloc__point.point02 li {
    width: calc(190 / 295 * 100%)
  }

  .reco-bloc__point.point02 li:nth-child(odd) {
    margin-left: 0;
    margin-right: auto
  }

  .reco-bloc__point.point02 li:nth-child(even) {
    margin-right: 0;
    margin-left: auto
  }

  .reco-bloc__point.point02 li:nth-child(n+2) {
    margin-top: 15px
  }

  .reco-bloc__box small {
    font-size: 10px
  }

  .reco-bloc__boxicon {
    width: calc(100% - 40px);
    padding: 20px 20px 11px;
    border-radius: 20px;
    margin-bottom: 20px
  }

  .reco-bloc__boxicon img {
    width: 100%
  }

  .reco-bloc__boxwrap {
    width: calc(100% - 40px);
    margin-top: 36px;
    padding-top: 45px
  }

  .reco-bloc__bannerwrap {
    width: calc(100% - 40px);
    margin-top: 25px
  }

  .reco-bloc__bannerhead {
    width: 280px;
    width: calc(217 / 300 * 100%);
    margin: 0 auto 9px;
    display: block
  }

  .reco-bloc__boxrow {
    display: block;
    margin-bottom: 40px
  }

  .reco-bloc__boxrow li {
    width: 100%;
    display: flex;
    justify-content: center;
    padding: 20px 0;
    width: calc(100% - 40px);
    margin: 0 auto
  }

  .reco-bloc__boxrow li:nth-child(1) {
    border-top: 4px solid #f5e343
  }

  .reco-bloc__boxrow li:nth-child(n+2) {
    border-top: 2px solid #b3d7bd
  }

  .reco-bloc__boxrow li .pct {
    flex-shrink: 0;
    margin: 0
  }

  .reco-bloc__boxrow li .txt {
    max-width: 287px
  }

  .reco-bloc__boxrow li:nth-child(odd) {
    flex-direction: row-reverse
  }

  .reco-bloc__boxrow li:nth-child(1) .txt {
    margin-right: 21px
  }

  .reco-bloc__boxrow li:nth-child(1) .pct {
    max-width: 86px;
    width: calc(86 / 295 * 100%)
  }

  .reco-bloc__boxrow li:nth-child(2) .txt {
    margin-left: 19px
  }

  .reco-bloc__boxrow li:nth-child(2) .pct {
    max-width: 122px;
    width: calc(122 / 295 * 100%)
  }

  .reco-bloc__boxrow li:nth-child(3) .txt {
    margin-right: 19px
  }

  .reco-bloc__boxrow li:nth-child(3) .pct {
    max-width: 122px;
    width: calc(122 / 295 * 100%)
  }

  .reco-bloc__boxrow li .pct {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 0 15px
  }

  .reco-bloc__boxrow li em {
    font-size: 18px;
    line-height: 1.22222em;
    text-align: left
  }

  .reco-bloc__boxrow li p {
    font-size: 12px;
    line-height: 1.5em;
    margin-top: 10px
  }

  .reco-bloc__iconnote {
    font-size: 10px;
    line-height: 1.6em;
    margin-top: 15px;
    padding: 0 20px
  }

  .reco-bloc__box:nth-child(n+2) {
    margin-top: 42px
  }

  .reco-bloc__simu {
    width: calc(100% - 40px);
    margin: 0 auto
  }

  .reco-bloc__simu h3 {
    font-size: 14px;
    width: 175px;
    height: 34px;
    border-radius: 17px;
    top: -17px
  }

  .reco-bloc__simu em {
    text-align: center;
    font-size: 14px;
    line-height: 1.57143em;
    margin-bottom: 16px;
    margin-top: 35px
  }

  .reco-bloc__simupct img {
    width: 100%;
    display: block;
    margin: 0 auto;
    -o-object-fit: cover;
    object-fit: cover;
  }
  .reco-bloc__simupct.suguchan img {
    width: 300px;
    display: block;
    margin: 0 auto;
    -o-object-fit: cover;
    object-fit: cover;
  }


  .reco-bloc__tgl {
    height: 33px
  }

  .reco-bloc__boxcol {
    width: calc(100% - 40px);
    margin: 0 auto 20px;
    border-top: 4px solid #f5e343
  }

  .reco-bloc__boxcol li {
    border-bottom: 2px solid #b3d7bd;
    justify-content: center
  }

  .reco-bloc__boxcol li .txt {
    max-width: 287px
  }

  .reco-bloc__boxcol li .txt em {
    font-size: 18px;
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt"
  }

  .reco-bloc__boxcol li .txt em small {
    display: block;
    font-size: 12px
  }

  .reco-bloc__boxcol li .txt p {
    font-size: 12px;
    line-height: 1.5em;
    margin-top: 7px
  }

  .reco-bloc__boxcol li:nth-child(odd) {
    flex-direction: row-reverse
  }

  .reco-bloc__boxcol li:nth-child(1) .pct {
    max-width: 74px;
    width: calc(74 / 295 * 100%);
    left: -15px
  }

  .reco-bloc__boxcol li:nth-child(1) .txt {
    margin-right: 2px
  }

  .reco-bloc__boxcol li:nth-child(1) .txt p {
    margin-right: 36px
  }

  .reco-bloc__boxcol li:nth-child(2) .pct {
    max-width: 82px;
    width: calc(82 / 295 * 100%);
    right: -6px
  }

  .reco-bloc__boxcol li:nth-child(2) .txt {
    margin-left: 34px
  }

  .reco-bloc__boxcol li:nth-child(3) .pct {
    max-width: 59px;
    width: calc(59 / 295 * 100%);
    left: -20px
  }

  .reco-bloc__boxcol li:nth-child(3) .txt {
    margin-right: 19px
  }

  .reco-bloc__boxcol li:nth-child(3) .txt p {
    margin-right: 35px
  }

  .reco-bloc__boxcol li:nth-child(4) .pct {
    max-width: 87px;
    width: calc(87 / 295 * 100%);
    right: -20px
  }

  .reco-bloc__boxcol li:nth-child(4) .txt {
    margin-left: 30px
  }

  .reco-bloc__boxcol li:nth-child(5) .pct {
    max-width: 58px;
    width: calc(58 / 295 * 100%);
    left: -20px
  }

  .reco-bloc__boxcol li:nth-child(5) .txt {
    margin-right: 40px
  }

  .reco-bloc__boxcol li:nth-child(5) .txt p {
    margin-right: 16px
  }

  .reco-bloc__boxcol .pct {
    flex-shrink: 0
  }

  .reco-bloc__boxcol .txt {
    padding: 23px 0
  }

  .reco-bloc__boxcol .txt p {
    font-size: 14px;
    line-height: 1.42857em
  }

  .reco-bloc__boxcol .txt em {
    font-size: 24px
  }

  .reco-bloc__boxcol .txt em small {
    font-size: 20px
  }

  .reco-bloc__num li {
    width: calc(100% - 40px);
    margin: 0 auto;
    align-items: stretch
  }

  .reco-bloc__num li+li {
    margin-top: 12px
  }

  .reco-bloc__num li .txt,
  .reco-bloc__num li em {
    font-weight: 500
  }

  .reco-bloc__num li em {
    width: 44px
  }

  .reco-bloc__num li em img {
    height: 26px
  }

  .reco-bloc__num li .txt {
    padding: 0 15px;
    width: calc(100% - 44px);
    font-size: 12px;
    line-height: 1.5em;
    min-height: 56px
  }

  .reco-bloc__notewrap {
    width: calc(100% - 40px);
    margin: 10px auto 0;
    font-size: 10px;
    line-height: 1.6em
  }

  .reco-bloc__notewrap p+p {
    margin-top: 4px
  }

  .tab__tab {
    height: 48px;
    font-size: 16px;
    position: absolute;
    top: 134px;
    right: 0;
    left: 0;
    margin: 0 auto;
    z-index: 0
  }

  .tab__tab:before {
    content: '';
    background: #06825b;
    position: absolute;
    bottom: 0;
    left: 0;
    height: 2px;
    width: 100%
  }

  .tab__tab li {
    max-width: 165px;
    width: 44%;
    height: 38px;
    border-radius: 5px 5px 0 0;
    box-shadow: 5px 0 1px rgba(34, 34, 34, .1);
    transition: .3s;
    z-index: -1
  }

  .tab__tab li+li {
    margin-left: 20px
  }

  .tab__tab li.is-active {
    height: 48px
  }

  .tab__head {
    padding-top: 50px;
    font-size: 20px;
    line-height: 1.6em;
    height: 180px;
    text-align: center
  }

  .tab__icon {
    font-size: 18px;
    width: 236px;
    margin: 28px auto 10px
  }

  .tab__icon em {
    font-size: 24px
  }

  .tab__leadbtm,
  .tab__leadtop {
    font-size: 14px
  }

  .tab__leadbtm {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 3px
  }

  .tab__leadbtm em {
    font-size: 18px
  }

  .tab__list {
    width: 100%;
    margin: 24px auto 15px;
    padding: 0 20px
  }

  .tab__list li {
    align-items: stretch
  }

  .tab__list li+li {
    margin-top: 10px
  }

  .tab__list li em {
    width: 44px;
    height: auto
  }

  .tab__list li em img {
    height: 7px
  }

  .tab__list li p {
    font-size: 12px;
    line-height: 1.83333em;
    width: calc(100% - 44px);
    padding: 12px 14px;
    min-height: 44px
  }

  .tab__list li p .icon-note,
  .tab__list li p .icon-note-01,
  .tab__list li p .icon-note-02,
  .tab__list li p .icon-note-03,
  .tab__list li p .icon-note-04,
  .tab__list li p .icon-note-05,
  .tab__list li p .icon-note-h {
    display: block;
    font-size: 9px;
    line-height: 1.3;
    padding-left: .7rem
  }

  .tab__notewrap {
    width: 100%;
    padding: 0 20px;
    margin: 0 auto;
    padding-bottom: 40px;
    font-size: 12px;
    line-height: 1.66667em
  }

  .info__label {
    height: 66px
  }

  .info__label img {
    height: 25px
  }

  .info__inner {
    padding: 0 20px
  }

  .info__head {
    margin-top: 40px
  }

  .info__head .pct {
    width: calc(215 / 335 * 100%);
    flex-shrink: 0;
    margin: 0 auto 30px
  }

  .info__head .txt {
    font-size: 14px;
    line-height: 1.71429em
  }

  .info__head .txt p+p {
    margin-top: 7px
  }

  .info__head .txt small {
    margin: 8px 0;
    font-size: 10px
  }

  .info__cont {
    margin-top: 20px;
    margin-bottom: 15px;
    font-size: 10px
  }

  .info__cont dl {
    border-top: 1px solid #f5e343
  }

  .info__cont dl dt {
    width: 100px;
    padding-top: 11px
  }

  .info__cont dl dd {
    padding: 11px 0
  }

  .info__cont dl dd em {
    display: block;
    font-weight: 700;
    margin: 3px 0
  }

  .info__cont dl dd small {
    display: block;
    margin-top: 4px
  }

  .info__cont dl dd p+p {
    margin-top: 8px
  }

  .info__cont dl:last-child {
    border-bottom: 1px solid #f5e343
  }

  .info__note {
    font-size: 10px;
    line-height: 1.6em;
    margin-bottom: 30px
  }

  .info__note a {
    text-decoration: underline
  }

  .info__note p+p {
    margin-top: 8px
  }

  .info__btm {
    margin-top: 30px;
    font-size: 10px;
    line-height: 1.6em
  }

  .info__btm p+p {
    margin-top: 10px
  }

  .info__link {
    width: 100%
  }

  .more {
    margin-top: 50px
  }

  .more-slide {
    width: 100%;
    margin: 40px auto 0;
    padding: 0 20px
  }

  .more .slick-dots {
    bottom: -20px
  }

  .footer-sitemap li {
    text-align: center;
    line-height: normal
  }

  .footer-sitemap li+li {
    margin-top: 5px
  }

  .footer-copyright {
    font-size: 1.1rem
  }

  .footer-copyright small {
    font-size: .8em
  }

  .fixed a {
    font-size: 18px
  }

  .fixed a span:before {
    right: -50px;
    width: 11px;
    height: 11px
  }

  .modal .lead__btnwrap {
    width: 100%;
  }

  .modal .lead__btnwrap a:first-child:after {
    left: 7px
  }

  .modal .iziModal-wrap {
    overflow-y: scroll !important;
    max-height: 100%
  }

  .modal-term-text .icon-note,
  .modal-term-text .icon-note-01,
  .modal-term-text .icon-note-02,
  .modal-term-text .icon-note-03,
  .modal-term-text .icon-note-04,
  .modal-term-text .icon-note-h {
    padding-left: 1rem
  }

  .modal {
    margin: auto 10px;
    max-height: 80vh
  }

  .modal::before {
    top: -30px;
    right: 0
  }

  .modal .inner {
    padding: 20px
  }

  .modal-attention {
    font-size: 12px
  }

  .modal-telbtn::before {
    position: absolute;
    content: '';
    width: 25px;
    height: 25px;
    background-image: url(../img/sp/modal_telicon.png);
    background-size: cover;
    top: 50%;
    left: 20px;
    margin-top: -11px
  }

  .modal-telbtn img {
    height: 22px
  }

  .modal-box {
    margin-top: 20px
  }

  .modal-box img {
    height: 50px
  }

  .modal-time {
    font-size: 16px
  }

  .modal-term {
    max-height: 300px
  }

  #modal04 .modal-txt {
    margin-top: 10px
  }

  #modal04 .btn-wt {
    margin-top: 10px
  }

  #modal04 .modal-telbtn {
    position: relative;
    color: #fff;
    background-color: #ff6c00;
    padding: 12px 10px;
    margin-top: 10px;
    border-radius: 27px;
    text-align: center;
    display: block;
    font-size: 20px;
    font-weight: 700;
    box-shadow: 5px 5px 2px 0 rgba(0, 0, 0, .1)
  }

  #modal04 .modal-telbtn::after {
    position: absolute;
    content: '';
    right: 20px;
    top: 50%;
    margin-top: -4px;
    width: 8px;
    height: 8px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg)
  }
}

@media screen and (min-width: 768px) {
  .reco-bloc__img {
    padding: 0 70px;
  }
}
@media screen and (max-width: 768px) {
  .reco-bloc__img2 {
    display: block;
    margin: 0 auto;
  }
}

@media screen and (max-width: 767px) {
  .reco-03 .boxwrap01 {
    padding-bottom: 30px;
  }
}


@media screen and (max-width: 350px) {
  .campaign-add__link {
    font-size: 12px;
  }
}

@media screen and (max-width: 350px) {
  .reco-top__item {
    padding-right: 5px;
  }
}

@media screen and (max-width: 350px) {
  .btn-wt {
    font-size: 13px;
  }
}


.notes {
  text-indent: -1em;
  padding-left: 1em;
}

.col-red {
  color: #EB4D4D;
}

.campaign-add__btm.mt-none p {
  margin-top: 0px;
}

.campaign_sbi {
  margin-top: 18%;
}

.plus p {
  text-align: center;
  margin-top: 3%;
  font-weight: bold;
  font-size: 80px;
  margin-bottom: -13%;
}

@media screen and (max-width: 768px) {
  .plus p {
    font-size: 45px;
  }
}

@media screen and (max-width: 767px) {
  .campaign__ttl {
    text-align: center;
    top: -38px;
  }
}

@media screen and (max-width: 425px) {
  .campaign__ttl {
    text-align: center;
    top: -26px;
  }
}

@media screen and (min-width: 768px) {
  .note-left {
    padding-left: 9rem;
  }
}

.campaign_title {
  margin-bottom: 35px;
}

.txt-deco {
  text-decoration: underline;
}

.campaign__lead.txt-center {
  margin: 0 auto;
}

.ma0 {
  margin: 0 auto;
}

.campaign_indent {
  text-indent: -2em;
  padding-left: 1em;
}

.paB-40 {
  padding: 0 0 26px 0;
}

@media screen and (max-width: 767px) {
  .campaign-add__head {
    text-align: center;
  }
}

.campaign__head {
  text-align: center;
}

.info_add_plus {
  margin-top: 20px;
  font-size: 20px;
}

.info_add {
  font-size: 12px;
}

.info_plus {
  text-indent: -0.8rem;
  padding-left: 1rem;
}

.info_plus2 {
  padding-left: 0.2rem;
}

.TD-underline {
  text-decoration: underline;
}

@media screen and (min-width: 768px) {
  .modal#modal06 {
    width: 780px;
  }
}

/* .privilege__listwrap .note-list {
	padding: 0 5px;
} */
.p-red {
  color: #d10000;
}

.note-margin {
  margin-bottom: 22px;
}

@media screen and (min-width: 768px) {
  .indent0 {
    text-indent: 0em;
  }
}

.special-plus {
  width: 40px;
  margin: 0 auto;
  margin-bottom: 40px;
  margin-top: 20px;
}

@media screen and (min-width: 768px) {
  .indent0 {
    text-indent: 0em;
  }
}

.ma-cp {
  margin: 0 18px 0 15px;
}

.ma-cp2 {
  margin-right: 10px;
  margin-left: 8px;
}

.ma-10 {
  margin: 10px;
}

.pa-10 {
  padding-top: 10px;
}

.privilege__boxttl {
  text-align: center;
}

.campaign__link a {
  text-decoration: underline;
}

.campaign__link a:hover {
  text-decoration: none;
}

.margin-top {
  margin-top: 20px;
}

.indent0 {
  text-indent: -1.3rem;
}


/*# sourceMappingURL=style.css.map */

.aurora_img {
  position: absolute;
  z-index: 2;
  right: 26%;
  top: 264%;
  width: 320px;
  max-width: 80%;

}

.aurora_img a {
  display: block;
}

.aurora_img-b {
  position: absolute;
  z-index: 2;
  right: -35%;
  top: -52%;
  width: 320px;
  max-width: 45%;

}

@media screen and (max-width: 767px) {
  .aurora_img {
    top: 300%;
    right: 40%;
    width: 160px;
    max-width: 100%;
  }

  .aurora_img-b {
    right: -29%;
    top: -36%;
    width: 160px;
    max-width: 45%;

  }
}

@media screen and (max-width: 600px) {
  .aurora_img {
    right: 27%;
    top: 294%;
    width: 150px;
    max-width: 100%;
  }
}

@media screen and (max-width: 425px) {
  .aurora_img {
    right: 20%;
    top: 280%;
    width: 150px;
    max-width: 100%;
  }
}

@media screen and (max-width: 375px) {
  .aurora_img {
    width: 150px;
    right: 20%;
    top: 292%;
    max-width: 100%;

  }

  .aurora_img-b {
    right: -36%;
    top: -41%;
    width: 160px;
    max-width: 42%;

  }
}

@media screen and (max-width: 320px) {
  .aurora_img {
    width: 150px;
    right: 11px;
    top: 203px;
    max-width: 100%;

  }

  .aurora_img-b {
    right: -36%;
    top: -52%;
    width: 160px;
    max-width: 45%;

  }
}

.txt .aurora_img a img:hover {
  opacity: 0.7;
}

.reco-top__pct .aurora_img-b a img:hover {
  opacity: 0.7;
}

.modal_content-a {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 1000;
  -webkit-transition: opacity 0.3s ease, visibility 0.3s ease;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

.modal_content-a.-show {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.modal-window-a {
  position: absolute;
  left: 50%;
  top: 50px;
  width: calc(100% - 20px);
  background-color: #fff;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border-radius: 50px;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  top: 10%;
}

@media screen and (max-width: 767px) {
  .modal-window-a {
    margin-top: -20px;
  }
}

@media screen and (min-width: 769px) {
  .modal-window-a {
    width: 1000px;
  }
}

.modal-window-inner-aurora {
  margin-left: auto;
  margin-right: auto;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  overflow: auto;
  display: none;
}

@media screen and (max-width: 767px) {
  .modal-window-inner-aurora {
    max-height: calc(100vh - 120px);
  }
}

.modal-window-inner-aurora.-show {
  display: block;
}

.modal-close-aurora {
  position: absolute;
  top: -35px;
  right: 0px;
  cursor: pointer;
}

@media screen and (min-width: 769px) {
  .modal-close-aurora {
    top: -40px;
    right: 0px;
  }
}

@media screen and (max-width: 767px) {
  .modal-close-aurora img {
    width: 22px;
    height: 22px;
  }
}

.modal-term-a {
  padding: 25px 10px;
  text-align: center;
}

.modal-term-a img {
  margin-top: 5%;
  width: 50%;
}

@media screen and (min-width: 768px) {
  .modal-term-a {
    padding: 60px 80px;
  }

  .modal-term-a p {
    font-size: 2.5rem;
  }
}

@media screen and (max-width: 767px) {
  .modal-term-a p {
    font-size: 1rem;
  }
}

@media screen and (min-width: 769px) {
  .modal-term-a .button a {
    width: 440px;
  }
}

.modal_content-a.-show {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  overflow: auto;
}

.modal-bg-aurora {
  position: sticky;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
}

.recom-point-cover {
  position: relative;
}

/*オーロラ券面対応_end*/

.mv-caution {
  font-size: 18px;
  font-weight: 600;
  margin-top: 30px !important;
}

@media screen and (max-width: 768px) {
  .mv-caution {
    font-size: 16px;
    margin-top: 20px !important;
  }
}

.mv-caution img {
  vertical-align: middle;
  margin-right: 10px;
  position: relative;
  top: -0.1em;
  width: 38px;
}

.mv-caution-sub {
  font-size: 12px;
  font-weight: 600;
  margin-top: 10px;
}

@media screen and (max-width: 768px) {
  .mv-caution-sub {
    font-size: 10px;
  }
}

.maT10 {
  margin-top: 10px !important;
}

.mv-caution-agreement {
  font-size: 16px;
  font-weight: 600;
}

@media screen and (max-width: 768px) {
  .mv-caution-agreement {
    font-size: 13px;
  }
}

.maT5 {
  margin-top: 5px !important;
}

.mv-caution-list li {
  font-size: 12px;
  font-weight: 600;
}

@media screen and (max-width: 768px) {
  .mv-caution-list li {
    font-size: 11px;
  }
}

@media screen and (max-width: 768px) {
  .forpc {
    display: none !important;
  }
}

@media screen and (min-width: 769px) {
  .forsp {
    display: none !important;
  }
}

.mv-break {
  margin: 20px 0;
  padding-bottom: 20px;
  position: relative;
}

@media screen and (max-width: 768px) {
  .mv-break {
    padding: 20px;
    margin-bottom: 50px;
    margin-top: -15px;
  }
}

@media screen and (min-width: 769px) {
  .mv-break {
    margin-left: auto;
    margin-right: auto;
    width: 900px;
  }
}

@media screen and (min-width: 769px) {
  .mv-break p {
    font-size: 20px;
  }
}

.head-border {
  position: relative;
  display: inline-block;
  display: flex;
  justify-content: center;
  max-height: 140px;
}

.head-border:before,
.head-border:after {
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 30%;
  height: 2px;
  background-color: #222;
  ;
}

@media screen and (max-width: 768px) {

  .head-border:before,
  .head-border:after {
    width: 25%;
  }
}

.head-border:before {
  left: 0px;
}

.head-border:after {
  right: 0px;
}

@media screen and (min-width: 769px) {
  .head-border {
    width: 900px;
  }
}

.mv-break img {
  width: 125px;
}

.under-border {
  border-bottom: solid 2px;
  margin-left: auto;
  margin-right: auto;
}

.font-weight-700 {
  font-weight: 700;
}

.mB-20 {
  margin-bottom: 20px;
}

.font-size-75 {
  font-size: 75%;
}

.txt-bold {
  font-weight: bold;
}


.usj-area {
  margin-top: 40px;
  margin-bottom: 40px;
}

.usj-box {
  width: 1000px;
  height: 100%;
  background-color: #0368D9;
  margin: 0 auto;
  padding: 30px;
  border: solid 15px #1129BC;
  background-image: linear-gradient(#cacaca7a 1px, transparent 0), linear-gradient(90deg, #cacaca7a 1px, transparent 0);
  background-size: 90px 90px;
}


@media screen and (max-width: 767px) {
  .usj-box {
    width: calc(100% - 40px);
    padding: 15px;
    border: solid 7px #1129BC;
    background-size: 60px 60px;
  }
}

.usj-title {
  text-align: center;
}

.usj-title img {
  width: 60%;
}

.usj-main-img {
  text-align: center;
}

@media screen and (min-width: 768px) {
  .usj-main {
    text-align: center;
  }

  .usj_caution {
    width: 850px;
    margin: 0 auto 20px;
  }

}

.usj-main img {
  margin-top: 5%;
  margin-bottom: 5%;
}

.usj-main p {
  color: white;
}

.content_button {
  margin-bottom: 5%;
  text-align: center;
}

.button-a {
  display: inline-block;
}

.button-a img {
  display: block;
}

.button-a:hover {
  opacity: 0.5;
  cursor: pointer;
}

.usj_caution p {
  color: white;
  font-size: 10px;
}

@media screen and (max-width: 767px) {
  .usj-title img {
    width: 90%;
  }

  .usj-main p {
    color: white;
    font-size: 14px;
  }
}

.campaign-add img {
  margin: 0 auto;
  margin-top: 26px;
}


.campaign-detail {
  text-indent: 0rem;
  padding-left: 7px;
  margin-bottom: 20px;

}

@media screen and (max-width: 767px) {
  .campaign-detail {
    padding: 0 12px;
    margin-top: -25px;
  }
}

.campaign-detail li {
  font-size: 10px;
  margin: 0 auto;
  padding: 0 12px;

}

@media screen and (min-width: 768px) {
  .campaign-detail li {
    width: calc(100% - 235px);
  }
  .campaign_content.campaign_step {
    padding: 0 20px 26px;
  }
  .icon-note.icon-note_sbi {
    font-size: 10px;
    margin-top: 0;
    padding-left: 1.2rem;
  }
}

.campaign_content {
  padding-bottom: 26px;
}

.campaign_content img {
  margin: 0 auto;
}

.icon-note_sbi:first-child {
	margin-top: 4px;
}
@media screen and (max-width: 767px) {
  .note-list_campaign {
    padding: 0 20px;
  }
  .campaign_content img {
    width: 90%;
  }
  .icon-note.icon-note_sbi {
    padding: 0 30px;
  }
}

.tokuten-content {
  line-height: 1.6em;
  text-indent: 0em;
}

.tokuten-content span {
  text-decoration: underline;
}

.entry_period {
  margin-bottom: 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .entry_period {
    margin-top: -5px;
    font-size: 10px;
  }
}

@media screen and (max-width: 425px) {
  .entry_period {
    margin-top: -2px;
  }
}

@media screen and (max-width: 767px) {
  .campaign-banner_add img {
    width: 90%;
  }
}

.tokuten_kakaku {
  padding: 0 12px;
}

.tokuten_kakaku .no-indent {
  text-indent: 0rem;
  padding-left: 7px;

}

@media screen and (max-width: 767px) {
  .tokuten_kakaku .no-indent {
    text-indent: 0rem;
    padding-left: 7px;

  }

}

.reco-bloc__ttl_04 {
  width: 731px;
}

@media screen and (max-width: 767px) {
  .reco-bloc__ttl04 reco-bloc_num04 {
    width: calc(200 / 430 * 100%);
  }
}

.img_center {
  text-align: center;
}

.tokuten-touch {
  margin-top: -12px;
  padding: 0 12px;
  padding-bottom: 10px;
}

.campaign_content_kakaku {
  width: 95%;
  margin: 0 auto;
  padding-bottom: 20px;
}

.indent {
  text-indent: -1em;
  padding-left: 1em;
}

.fs-10 {
  font-size: 10px;
}

.lead__btnwrap a:first-child:after {
  top: -16px;
  left: 15px;
}

.ta-left {
  text-align: left;
}

.js-sokujitext {
  display: none;
}

.js-sokujitextdblock {
  display: block;
}

.js-sokujitextnone {
  display: none;
}

.nyukai {
  width: auto;
}

.nyukai img {
  vertical-align: middle;
  width: 14px;
  margin-left: 5px;
  position: relative;
  top: -.1em
}

.mt-10 {
  margin-top: 10px;
}

.text1 {
  margin-bottom: 20px;
}


.campaign-top {
  padding-top: 30px;
  margin-top: 0px;
}

.text_01 {
  font-size: 14px;

}

@media screen and (max-width: 767px) {
  .text_01 {
    font-size: 12px;
    text-indent: -1em;
    padding-left: 1em;
  }
}

.text_02 {
  font-size: 14px;
  text-indent: -1em;
  padding-left: 1em;
  margin: 0px 199px;
}

.text_02 a {
  text-decoration: underline;
}

@media screen and (max-width: 767px) {
  .text_02 {
    font-size: 12px;
    margin: auto;
  }
}

.lead__btnwrap.atokara__btn {
  justify-content: center;
}

.lead__btnwrap.atokara__btn a {
  background: #333;
}

.lead__btnwrap.atokara__btn a:first-child:after {
  background-image: none;
}

.p-campaign__countdown {
  width: 243px;
  margin-bottom: 20px;
}

@media screen and (min-width: 768px) {
  .p-campaign__countdown {
    width: 423px;
  }
}

.suguchan-area {
  margin-bottom: 60px;
}

.suguchan-img {
  text-align: center;
}

.suguchan-img img {
  width: 620px;
}


/* suguchann step1~3 */
.suguchan_title{
	padding: 50px;
}
.suguchan_title_sp{
	padding: 10px;

}
.p-about__inner {
    margin: 0 auto;
    max-width: 1080px;
    padding-inline: min(2.85714286vw, 40px);
    width: 100%;
}
.p-about .p-about__item+.p-about__item {
    margin-top: 138px;
}
.p-about__item.suguchan {
    margin-top: 90px;
}
@media (max-width: 767px) {
    .p-about .p-about__item+.p-about__item {
        margin-top: 93px;
    }
}

@media (min-width: 768px) {
.p-about__item {
    margin-top: 120px;
}
}
@media (max-width: 767px) {
.p-about__item {
    margin-top: 80px;
}
}
.p-about__item:first-child {
    padding: 85px 30px 50px 50px;
}
@media (max-width: 767px) {
    .p-about__item:first-child {
        padding: 60px 27px 40px 30px;
    }
}
.p-about__item:nth-child(2) {
    padding: 69px 50px 50px 59px;
}
@media (max-width: 767px) {
    .p-about__item:nth-child(2) {
        padding:60px 27px 40px 30px
    }
}
.p-about__item:nth-child(3) {
    padding: 54px 41px 47px 50px;
}
@media (max-width: 767px) {
    .p-about__item:nth-child(3) {
        padding:60px 27px 38px 30px
    }
}

@media (max-width: 767px) {
.suguchan_img{
	width: 300px;
}
.p-about__item:first-child .p-about__item-img {
    max-width: 200px;
    margin: 0 auto;
}


.p-about__item:nth-child(2) .p-about__item-img {
    max-width: 191px;
    margin: 0 auto;
}

.p-about__item:nth-child(3) .p-about__item-img {
    max-width: 200px;
    margin: 0 auto;
}
}
@media (min-width: 768px) {
.p-about__item:first-child .p-about__item-img {
    width: 250px;
    margin: 0 auto;
}
.p-about__item:nth-child(2) .p-about__item-img {
    width: 230px;
    margin: 0 auto;
}
.p-about__item:nth-child(3) .p-about__item-img {
    width: 270px;
    margin: 0 auto;
}
}

.p-about__item {
  background-color: #FFFFFF;
  border-radius: 20px;
  box-shadow: 10px 10px 0px 0px rgba(87, 196, 205, 1);
  counter-increment: countNum;
  position: relative;
}
@media (max-width: 767px)  {
.p-about__item {
    box-shadow: 6px 6px 0px 0px rgba(87, 196, 205, 1);
  }
}
.p-about__item:nth-child(1) .p-about__item-inner,
.p-about__item:nth-child(3) .p-about__item-inner {
    flex-direction: row-reverse;
}

.p-about__item-title {
  text-align: center;
  position: absolute;
  top: -77px;
  left: 50%;
  transform: translateX(-50%);
}

 @media (max-width: 767px)  {
 .p-about__item-title {
   top: -57px;
 }
}

.p-about__item-title span {
  display: block;
  font-weight: 800;
}

.p-about__item-title span:nth-child(1) {
  color: #108761;
  font-size: 20px;
  line-height: 1.35;
}
@media(max-width: 767px)  {
.p-about__item-title span:nth-child(1) {
    font-size: 16px;
    line-height: 1.25;
  }
}

.p-about__item-title span:nth-child(2) {
  background-color: #108761;
  border-radius: 50%;
  color: #FFFFFF;
  font-size: 48px;
  line-height: 1;
  width: 80px;
  height: 80px;
  margin-top: 10px;

  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 767px)  {
.p-about__item-title span:nth-child(2) {
    font-size: 36px;
    line-height: 1.9;
    width: 60px;
    height: 60px;
    margin-top: 5px;
  }
}

.p-about__item-title span:nth-child(2)::before {
  content: counter(countNum);
}
@media (min-width: 768px) {
.p-about__item-inner {
    display: flex;
}
.p-about__item-img {
    margin-inline: auto;
}
.p-about__item-content {
    margin-top: 30px;
  }
}
@media (max-width: 767px) {
    .p-about__item-content {
        margin-top: 30px;
    }
}

.p-about__item-content-text {
  font-size: 16px;
  line-height: 1.75;
  margin-top: 23px;
}

@media (max-width: 767px) {
.p-about__item-content-text {
    font-size: 14px;
    line-height: 1.71428571;
    margin-top: 20px;
  }
}

.p-about__item-content-note {
  margin-top: 18px;
  padding-left: 17px;
  text-indent: -17px;
}
.p-about__item-content-note::before {
	content: "※"
}
@media (max-width: 767px) {
.p-about__item-content-note {
    font-size: 12px;
    line-height: 1.5;
    margin-top: 13px;
    padding-left: 14px;
    text-indent: -14px;
  }
}
.p-about__item-content-note.points {
  margin: 10px 20px 60px 20px;
  padding-left: 30px;
  text-indent: -17px;
  text-align: left;
}
.p-about__item-content-note.points::before {
	content: "※"
}
@media (max-width: 767px) {
  .p-about__item-content-note.points {
  margin: 10px 0px 30px 0px;
  padding-left: 20px;
  text-indent: -13px;
  text-align: left;
}
}

.p-about__item-content-link {
  color: #108761;
  display: inline-block;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.5;
  margin-top: 30px;
}

@media (max-width: 767px) {
  .p-about__item-content-link {
    font-size: 14px;
    line-height: 1.42857143;
    margin-top: 20px;
  }
}

.p-about__item-content-link span {

  padding-right: 16px;
}
.p-about__item:first-child .p-about__item-content-title {
    max-width: 559px;
}
.p-about__item:nth-child(2) .p-about__item-content-title {
    max-width: 482px;
}
.p-about__item:nth-child(3) .p-about__item-content-title {
    max-width: 300px;
}
@media (max-width: 767px) {
    .p-about__item:first-child .p-about__item-content-title {
        max-width: 285px;
    }
    .p-about__item:nth-child(2) .p-about__item-content-title {
        max-width: 296px;
    }
        .p-about__item:nth-child(3) .p-about__item-content-title {
        max-width: 242px;
    }
}

@media (min-width: 768px) {
.p-about__item:first-child .p-about__item-inner {
  gap: min(2.14285714vw, 30px);
}
.p-about__item:nth-child(2) .p-about__item-inner {
   gap: min(2.71428571vw, 66px);
}
.p-about__item:first-child .p-about__item-content {
   width: 68.8636364%;
}
.p-about__item:nth-child(2) .p-about__item-content {
    margin-left: auto;
    padding-top: 21px;
    width: 59.6%;
}
.p-about__item:nth-child(3) .p-about__item-content {
     padding-top: 27px;
     width: 64.0909091%;
}
.p-about__item:nth-child(3) .p-about__item-inner {
    gap: min(2.14285714vw, 30px);
}
}

.nl-inner {
  padding: 15px 55px;
}

.preparation .preparation-list {
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap;
  padding: 0 20px;
}

.preparation .preparation-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 290px;
  text-align: center;
  margin-top: 15px;
}

.preparation h5 {
  font-size: 16px;
  margin-top: 20px;
  font-weight: 700;
}

.preparation-title {
  font-size: 12px;
  font-weight: 700;
}

.preparation-item img {
  margin: 0 0 10px;
  width: 115px;
}

.preparation-text {
  font-size: 10px;
  margin-top: 10px;
}

.nl-modal-term {
  max-height: 250px;
}

@media screen and (max-width: 767px) {
  .nl-modal-term {
    max-height: 200px;
  }

  .nl-inner {
    padding: 20px;
  }

  .preparation .preparation-list {
    padding: 0;
  }

  .preparation .preparation-item {
    flex-direction: row;
    align-items: normal;
    flex-wrap: wrap;
    width: 100%;
    text-align: left;
  }

  .preparation-item img {
    max-width: 100%;
    text-align: center;
  }

  .preparation-unit {
    flex: 1;
    padding: 0 10px;
  }
}

.student_camp_box{
  width: 1000px;
  margin: 0 auto;
}
.student_campaign{
  width: 100%;
  z-index: 10;
}

.togglebox__head span {
	font-size: 48px;
}
.togglebox__head p {
	font-size: 20px;
	margin-top: 10px;
}

.student_open {
    position: absolute;
    right: 15px;
    top: calc(50% - 11px);
    width: 30px;
    height: 30px;
}
.student_open::before, .student_open::after {
    position: absolute;
    z-index: 2;
    top: calc(50% - 3px);
    left: 0;
    content: "";
    display: block;
    width: 100%;
    height: 3px;
    background-color: #fff;
}
.student_open::after {
    transform: rotate(90deg);
}
.student_campaign.show .student_open:after {
    transform: rotate(0deg);
}

.student-title{
  background: #fff;
  margin: 0 auto;
  display: block;
  width: 100%;
  padding: 22px 40px;
  border-radius: 40px;
  background: #0bbb84;
  cursor: pointer;
  text-align: center;
  padding: 50px;
  color: #fff;
  font-size: 32px;
  font-weight: 700;
  box-shadow: 4px 4px 1px rgba(0, 0, 0, .1);
}
.student_camp_info{
  display: none;
  text-align: center;
  background-color: #fefce8;
  padding: 70px 70px 50px;
  top: -40px;
}

.p-mv--icon-01 {
	position: absolute;
	right: 13%;
    top: 18%;
    width: 15%;
    transform: rotate(12deg);
}

.p-mv--icon-02 {
	position: absolute;
    left: 15%;
    top: 15%;
    width: 10%;
    transform: rotate(-10deg);
}

.student_info_box {
	background-color: #fff;
	text-align: left;
	margin-top: 40px;
	padding: 40px 30px;
}

.student_info_point {
	font-weight: 700;
	font-size: 32px;
}
.student_info_point span {
	color: #a11818;
	font-size: 48px;
}

.student_info_title {
	font-size: 32px;
	margin-bottom: 20px;
	color: #004831;
	font-weight: 700;
}
.student-point-box {
    background-color: #FAE572;
    padding: 16px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    box-sizing: content-box;
}

.yellow-bg {
	background-color: #FAE572;
}
.yellow-txt {
	color: #CEBD5D;
	border-color: #D6CA5D;
}
.green-bg {
	background-color: #78E8AD;
}

.green-txt {
	color: #63A783;
    border-color: #63A783
}
.blue-bg {
	background-color: #B2D9FF;
}
.blue-txt {
	color: #6E8398;
    border-color: #6E8398 !important;
}

.white-box {
    height: 100%;
    background-color: #ffffff;
    border-radius: 10px;
    padding: 0px 0px 20px 0px;
    margin: 13px 0px 0px 0px;
    text-align: center;
}

.point-student {
    width: 130px;
    font-size: 16px;
    line-height: 28px;
    font-weight: bold;
    border-bottom: solid 3px;
    padding: 0px 0px 1px 0px;
    display: inline-block;
    position: relative;
    margin: 16px 0 16px;
}

.point-student::before {
    content: "";
    width: 13px;
    height: 13px;
    border-top: solid 3px;
    border-right: solid 3px;
    position: absolute;
    background-color: #ffffff;
    top: 30px;
    left: 50%;
    transform: translate(-50%, -46%) rotate(135deg);
    -webkit-transform: translate(-50%, -46%) rotate(135deg);
}

.point-student_title {
	color: #000000;
    font-weight: bold;
    font-size: 16px;
    text-align: center;
}
.max-point-student {
    color: #000000;
    font-weight: bold;
}

.max-point {
	font-size: 32px;
}

.point-service {
	padding: 10px 0 20px;
}

.mt-student {
	margin-top: 48px;
}

.student_caution {
	text-align: left;
	font-size: 14px;
}

.student_linepay {
	width: 80px;
	margin: 0 auto;
}

.student_linepay img {
	width: 100%;
	margin-top: 10px;
}

.caution_second {
    padding-left: 1rem;
}

.caution_first {
	text-indent: -1rem;
	padding-left: 1rem;
}

.student_caution a {
	text-decoration: underline;
}

@media screen and (min-width: 768px) {
	.student_camp_info:before {
        content: '';
        position: absolute;
        z-index: -2;
        background: -webkit-linear-gradient(45deg, transparent 0, #000 0), -webkit-linear-gradient(135deg, transparent 0, #000 0), -webkit-linear-gradient(225deg, transparent 0, #000 0), -webkit-linear-gradient(315deg, transparent 85px, #000 15px);
        background-position: bottom left, bottom right, top right, top left;
        background-size: 50% 50%;
        background-repeat: no-repeat;
        opacity: .16;
        right: -6px;
        bottom: -6px;
        width: 100%;
        height: 100%;
    }
	.point-service {
	    display: flex;
	}
	.student-point-box {
	    display: flex;
	}
	.student-point-box {
	    width: 300px;
	    flex-direction: column;
	}
	.br-sp {
	    display: none;
	}
}
.student_caution p {
    font-size: 14px;
}
@media screen and (max-width: 767px) {
	.text_center {
        text-align: center;
	}
	.togglebox__head {
	    font-size: 20px;
	}
	.togglebox__head span {
	    font-size: 24px;
    }
	.student_camp_box {
	    width: 100%;
	    padding: 20px;
    }
    .student_camp_info {
        padding: 30px 20px 30px;
        top: -28px;
     }
     .student-title {
     font-size: 24px;
     padding: 20px;
     }
     .student_info_title {
         font-size: 22px;
         margin-top: 20px;
     }
     .student_info_box {
	     padding: 20px;
     }
     .student_info_box p {
         margin-top: 10px;
         font-size: 12px;
     }
     .student_info_point {
         font-size: 14px;
         text-align: center;
     }
     .student_info_point span {
         font-size: 28px;
     }
     .student_caution {
         font-size: 12px;
     }
     .student_caution p {
         font-size: 12px;
     }
     .togglebox__head p {
	     font-size: 14px;
     }
     .student_open {
         right: 10%;
         width: 20px;
     }
     .p-mv--icon-01 {
         display: none;
     }
     .p-mv--icon-02 {
         left: 5%;
         top: 5%;
         width: 20%;
     }
     .br-sp {
         display: block;
     }
     .point-student {
         width: 100px;
     }
}

.vpoint_integration_clickabe_img {
  position: absolute;
  z-index: 2;
  right: -8%;
  top: 58%;
  width: 320px;
  max-width: 40%;

}

@media screen and (max-width: 767px) {
  .vpoint_integration_clickabe_img {
    right: 0%;
    top: 90%;
    width: 210px;
    max-width: 45%;

  }
}

@media screen and (max-width: 375px) {
  .vpoint_integration_clickabe_img {
    right: 0%;
    top: 90%;
    width: 160px;
    max-width: 45%;

  }
}
.vpoint_integration_clickabe_img a img:hover {
  opacity: 0.7;
}

.tokuten-list{
   margin-top: 4px;
}

@media screen and (min-width: 768px) {
.p-about__item_maT{
  margin-top: 65px;
}
}
@media screen and (max-width: 767px) {
.p-about__item_maT{
  margin-top: 75px;
}
}
@media screen and (min-width: 768px) {
  .reco-bloc__simupct {
    padding: 0 22px 17px
  }
}
  @media screen and (max-width: 767px) {
    .reco-bloc__simupct {
    padding: 0 15px 15px
  }
}


.text-center{
  text-align: center;
  margin-top: 26px;
}

.font-bold{
  font-weight: bold;
}

.col_Black {
color: #222;
}

.slash {
    position: relative;
    display: inline-block;
    padding: 0 30px;
    margin-bottom: 10px;
}
@media screen and (max-width: 767px){
.slash {
    padding: 0 15px;
    margin-bottom: 10px;
	font-size: 15px;
}
}

.slash:before {
    position: absolute;
    left: 0;
    top: 0;
    content: "";
    width: 2px;
    height: 100%;
    background: #222;
    border-radius: 3px;
    transform: rotate(-25deg);
}

.slash:after {
    position: absolute;
    content: "";
    right: 0;
    top: 0;
    width: 2px;
    height: 100%;
    background: #222;
    border-radius: 3px;
    transform: rotate(25deg);
}

