/* Slider */
.slick-slider
{
    position: relative;

    display: block;
    box-sizing: border-box;

    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;

    -webkit-touch-callout: none;
    -khtml-user-select: none;
    -ms-touch-action: pan-y;
        touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}

.slick-list
{
    position: relative;

    display: block;
    overflow: hidden;

    margin: 0;
    padding: 0;
}
.slick-list:focus
{
    outline: none;
}
.slick-list.dragging
{
    cursor: pointer;
    cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list
{
    -webkit-transform: translate3d(0, 0, 0);
       -moz-transform: translate3d(0, 0, 0);
        -ms-transform: translate3d(0, 0, 0);
         -o-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
}

.slick-track
{
    position: relative;
    top: 0;
    left: 0;

    display: block;
    margin-left: auto;
    margin-right: auto;
}
.slick-track:before,
.slick-track:after
{
    display: table;

    content: '';
}
.slick-track:after
{
    clear: both;
}
.slick-loading .slick-track
{
    visibility: hidden;
}

.slick-slide
{
    display: none;
    float: left;

    height: 100%;
    min-height: 1px;
}
[dir='rtl'] .slick-slide
{
    float: right;
}
.slick-slide img
{
    display: block;
}
.slick-slide.slick-loading img
{
    display: none;
}
.slick-slide.dragging img
{
    pointer-events: none;
}
.slick-initialized .slick-slide
{
    display: block;
}
.slick-loading .slick-slide
{
    visibility: hidden;
}
.slick-vertical .slick-slide
{
    display: block;

    height: auto;

    border: 1px solid transparent;
}
.slick-arrow.slick-hidden {
    display: none;
}
/* Slider */
.slick-loading .slick-list
{

}

/* Arrows */
.slick-prev,
.slick-next
{
    font-size: 0;
    line-height: 0;

    position: absolute;
    top: 50%;

    display: block;

    width: 20px;
    height: 20px;
    padding: 0;
    -webkit-transform: translate(0, -50%);
    -ms-transform: translate(0, -50%);
    transform: translate(0, -50%);

    cursor: pointer;

    color: transparent;
    border: none;
    outline: none;
    background: transparent;
}
.slick-prev:hover,
.slick-prev:focus,
.slick-next:hover,
.slick-next:focus
{
    color: transparent;
    outline: none;
    background: transparent;
}
.slick-prev:hover:before,
.slick-prev:focus:before,
.slick-next:hover:before,
.slick-next:focus:before
{
    opacity: 1;
}
.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before
{
    opacity: .25;
}

.slick-prev:before,
.slick-next:before
{
    font-family: 'slick';
    font-size: 20px;
    line-height: 1;

    opacity: .75;
    color: white;

    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.slick-prev
{
    left: -25px;
}
[dir='rtl'] .slick-prev
{
    right: -25px;
    left: auto;
}
.slick-prev:before
{
    content: '竊�';
}
[dir='rtl'] .slick-prev:before
{
    content: '竊�';
}

.slick-next
{
    right: -25px;
}
[dir='rtl'] .slick-next
{
    right: auto;
    left: -25px;
}
.slick-next:before
{
    content: '竊�';
}
[dir='rtl'] .slick-next:before
{
    content: '竊�';
}

/* Dots */
.slick-dotted.slick-slider
{
}

.slick-dots
{
    position: absolute;
    bottom: -25px;

    display: block;

    width: 100%;
    padding: 0;
    margin: 0;

    list-style: none;

    text-align: center;
}
.slick-dots li
{
    position: relative;

    display: inline-block;

    width: 20px;
    height: 20px;
    margin: 0 5px;
    padding: 0;

    cursor: pointer;
}
.slick-dots li button
{
    font-size: 0;
    line-height: 0;

    display: block;

    width: 20px;
    height: 20px;
    padding: 5px;

    cursor: pointer;

    color: transparent;
    border: 0;
    outline: none;
    background: transparent;
}
.slick-dots li button:hover,
.slick-dots li button:focus
{
    outline: none;
}
.slick-dots li button:hover:before,
.slick-dots li button:focus:before
{
    opacity: 1;
}
.slick-dots li button:before
{
    font-family: 'slick';
    font-size: 6px;
    line-height: 20px;

    position: absolute;
    top: 0;
    left: 0;

    width: 20px;
    height: 20px;

    content: '窶｢';
    text-align: center;

    opacity: .25;
    color: black;

    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.slick-dots li.slick-active button:before
{
    opacity: .75;
    color: black;
}


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: 12px;
  line-height: 1.6em;
  text-indent: -1.6rem;
  padding-left: 1.5rem;
}

.tokuten-li {
  font-size: 12px;
  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)
}

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

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

.label-btm:before,
.label-top:before {
  content: '';
  width: 100%;
  height: 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
}

.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
}

.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;
  box-shadow: 7px 5px 7px #3e9a34bf;
}

.btn-wt:before {
  content: '';
  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: #ff4949;
  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-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:before {
  content: '';
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%)
}

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


.campaign .icon-note {
	font-size: 12px;
	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: #fff;
  border-radius: 20px;
}

.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-around
}

.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: '';
  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: #ff2020
}

.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 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;
}

.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: '';
  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::before {
  pointer-events: none;
  position: absolute;
  content: '';
  width: 20px;
  height: 20px;
  top: -32px;
  right: -20px;
}

.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: 12px
}

.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
}

.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;
  margin: 3em 0;
}

[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: .25s;
  margin: 3em 0;
}

[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: .3s;
  margin: 3em 0;
}

[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: .35s;
  margin: 3em 0;
}

[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: .4s;
  margin: 3em 0;
}

[data-script=fadebox]:nth-child(6) {
  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: .45s;
  margin: 3em 0;
}

[data-script=fadebox]:nth-child(7) {
  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;
  margin: 3em 0;
}

[data-script=fadebox]:nth-child(8) {
  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: .55s;
  margin: 3em 0;
}

[data-script=fadebox]:nth-child(9) {
  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;
  margin: 3em 0;
}

[data-script=fadebox]:nth-child(10) {
  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: .65s;
  margin: 3em 0;
}

[data-script=fadebox]:nth-child(11) {
  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: .7s;
  margin: 3em 0;
}

[data-script=fadebox]:nth-child(12) {
  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: .75s;
  margin: 3em 0;
}

.note-attention {
  color: #ff6c00
}

.note-center {
  text-align: center
}

.note-attention,
.note-center,
.note-li {
  font-size: 12px;
  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%;
}

#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
  }

  .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 !important;
  }

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

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

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

  .kv {
    padding-top: 150px;
    background-color: #ff4949;
    background-image: linear-gradient(rgba(210, 210, 210, 0.4) 1px, transparent 1px), linear-gradient(to right, rgba(210, 210, 210, 0.4) 1px, transparent 1px);
    background-size: 45px 45px;
    background-position: -14px 14px;
  }

  .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: 12px;
    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_content_kakaku .campaign__head {
    padding: 0 80px;
    margin-top: 20px;
  }

  .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;
  }

  .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: 120px;
    border-radius: 45px;
    width: 400px;
    font-size: 1.3em;
  }

  .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
  }

  .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: 60%;
    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: 30%;
    margin-bottom: 1%;
  }

  .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: 820px;
    margin-bottom: 50px;
    border-top: 4px solid #f5e343;
    padding-top: 45px
  }

  .reco-bloc__boxrow li {
    width: 270px
  }

  .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: 12px;
    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: 12px;
    line-height: 1.6em
  }

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

  .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: 60px 0;
    font-size: 28px;
  }

  .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: 12px
  }

  .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;
	font-size: 12px;
  }

  .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: 12px
  }

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

  .info__note {
    font-size: 12px;
    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: 30px 0;
    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
  }

  .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
  }

  .kv {
    padding-top: 100px;
    background-color: #ff4949;
    background-image: linear-gradient(rgba(210, 210, 210, 0.4) 1px, transparent 1px), linear-gradient(to right, rgba(210, 210, 210, 0.4) 1px, transparent 1px);
    background-size: 30px 30px;
    background-position: -14px 14px;
    padding-bottom: 5px;
  }

  .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: 12px;
    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: 12px;
    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_content_kakaku .campaign__head {
        padding: 0;
    }

  .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: 15px 0 10px;
  }

  .reco-top__ttl {
    width: 95%;
    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-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: 12px;
    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: 12px;
    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 {
    padding: 0 10px
  }

  .reco-bloc__point.point02 li {
    width: 45%;
  }

  .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__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: 110px;
    width: calc(110 / 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: 12px;
    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: 12px;
    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: fit-content;
    height: auto;
    padding: 0 10px;
  }

  .tab__list li em img {
    height: 7px
  }

  .tab__list li p {
    font-size: 1.2em;
    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: 12px;
    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: 12px
  }

  .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 small {
	font-size: 10px;
  }

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

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

  .info__note {
    font-size: 12px;
    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.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-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;
	padding: 0 150px;
  }
}

.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;
}

.note-indent{
	text-indent: -0.9rem;
}

/*# 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: 12px;
  }
}

.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: 12px;
  }
}

@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: 12px;
}

@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: 12px;
    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: 12px;
  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;
		justify-content: center;
	}
	.student-point-box {
	    display: flex;
	}
	.student-point-box {
	    width: 50%;
	    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);
}

.seven_table {
    text-align: center;
    max-width: 100%;
    border: 2px solid #111111;
    margin: 16px 110px 0;
    padding: 16px 24px;
}

@media screen and (max-width: 767px) {
.seven_table {
    margin: 0 20px;
    padding: 12px 16px;
}
}

.seven_table .seven_title {
    margin: 10px 0;
}

.seven_table .reco-bloc__iconnote {
    padding: 0;
    margin-top: 0;
}

.seven_table .reco-bloc__lead {
    padding: 0;
    font-size: 14px;
    margin: 10px 0;
}

@media screen and (min-width: 768px) {
  .seven_notesTable {
    display: flex;
    justify-content: center;
    align-items: center;
    width: auto;
    gap: 8px;
  }
}

.seven_notesTable .notesTable {
    display: flex;
    text-align: left;
}

.seven_notesTable p {
    line-height: 1.8;
    text-align: left;
}

.seven_title {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.8;
}

.seven_table img {
    width: 300px;
}
@media screen and (min-width: 768px) {
.reco-bloc__txt{
    margin: 0 auto;
    width: 780px;
    font-size: 14px;
    padding-top: 5px;
}
.reco-bloc__txt:before {
    width: 1.7rem;
}
}
@media screen and (max-width: 767px) {
.reco-bloc__txt{
    width: calc(100% - 40px);
    margin: 0 auto;
    font-size: 12px;
    padding-top: 5px;
}
}

.fs-12{
font-size: 12px;
}

.c-goldfree__link {
  position: absolute;
  margin-left: 43.5%;
  width: 170px;
  top: 500px;
  z-index: 10;
}
.c-goldfree__link p {
  font-size: 15px;
  font-weight: bold;
  display: flex;
  justify-content: center;
  align-items: center;
}
.c-goldfree__link span{
	display: block;
	font-size: 10px;
	text-align: center;
}
.c-goldfree__link p:before,
.c-goldfree__link p:after {
  content: "";
  display: block;
  margin: 0 15px;
  width: 0.1vw;
  height: 15px;
  background-color: #000000;
}
.c-goldfree__link p:before {
  transform: rotate(-30deg);
}
.c-goldfree__link p:after {
  transform: rotate(30deg);
}
@media screen and (max-width: 1000px) {
  .c-goldfree__link {
    right: 43%;
    top: 78%;
  }
}

@media screen and (max-width: 767px) {
  .c-goldfree__link {
    right: 0;
    width: 30vw;
    top: 105vw;
  }
  .c-goldfree__link p {
    font-size: 3vw;
  }
  .c-goldfree__link p:before,
  .c-goldfree__link p:after {
    width: 1.5px;
    height: 2.7vw;
  }
  .c-goldfree__link span{
    font-size: 2vw;
  }
}
a{
  cursor: pointer;
  }
.c-goldfree__link a:hover {
    opacity: 0.5;
    }

    body {
        font-weight: bold;
    }
    ul.reco-top__lsit {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        justify-content: space-between;
    }
    .reco-top__item.is-fade {
        padding: 0 7% 0 8%;
        position: relative;
    }
    .reco-top__item span {
        position: absolute;
        top: -25%;
        left: 0;
        font-size: 2.5em;
        color: #ff2020;
    }
    .kauru_osusume {
        font-size: 2em;
        text-align: center;
        font-weight: 500;
    }
    .kasen_div {
        position: relative;
        border-bottom: 3px solid #ff2020;
        width: fit-content;
        padding: 0 3px;
        margin: 0 auto .5em;
    }
    .kasen_div:before {
        position: absolute;
        bottom: -14px;
        left: 4em;
        width: 0;
        height: 0;
        content: '';
        border-width: 14px 12px 0 12px;
        border-style: solid;
        border-color: #ff2020 transparent transparent transparent;
    }
    .kasen_div:after {
        position: absolute;
        bottom: -10px;
        left: 4em;
        width: 0;
        height: 0;
        content: '';
        border-width: 14px 12px 0 12px;
        border-style: solid;
        border-color: #f9f9f9 transparent transparent transparent;
    }
    .kauru_osusume span {
        font-size: 1.5em;
        margin-right: 5px;
        color: #000;
    }
    .point_title {
      font-size: 2.5em;
      text-align: center;
    }
    .reco-bloc__point {
      flex-wrap: wrap;
    }
    .point_title .point_title1 {
      color: #ff2020;
      font-size: 1.1em;
    }
    .point02_item1, .point02_item2, .point02_item3 {
        background-color: #fff;
        padding: 10% 5%;
        border-radius: 15px 3px 15px 3px;
        position: relative;
    }
    .point02_item1 img, .point02_item2 img, .point02_item3 img {
        width: 75%;
        display: block;
        margin: 0 auto 1em;
        border-bottom: 2px solid;
        padding-bottom: 1em;
    }
    .campaign_area {
        text-align: center;
        font-size: 1.7em;
    }
    span.campaign_title {
      display: block;
      font-size: 1.2em;
    }
    .campaign_speed {
        margin: 10px;
    }
    .campaign_price_area {
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .campaign_price_title {
        margin: 15px auto;
        font-size: 1.2em;
    }
    .campaign_price1 {
        text-decoration: line-through;
        color: #595959;
        font-size: 1.2em;
    }
    .campaign_price2 {
      color: #f00;
      font-size: 2em;
    }
    .triangle {
      background: #f00;
      height: calc(tan(50deg) * 35px / 1);
      width: 30px;
      clip-path: polygon(0 0, 100% 50%, 0 100%);
      margin: 0 20px;
    }
    .accordion {
        max-width: 700px;
        margin: 20px auto;
    }
    .accordion-item {
        margin-bottom: 15px;
        border-radius: 4px;
    }
    .accordion-header {
        background-color: #fff;
        padding: 15px 50px 15px 25px;
        cursor: pointer;
        position: relative;
        display: flex;
        justify-content: space-between;
        align-items: center;
        border: none;
        width: 100%;
        text-align: left;
        font-size: 1.2em;
    }
    .accordion-content {
        max-height: 0;
        overflow: hidden;
        transition: max-height 0.3s ease-out;
        background-color: white;
    }
    .accordion-content-inner {
        padding: 15px;
        border-top: 1px solid;
      }
    .accordion-icon {
        width: 10px;
        height: 10px;
        border-right: 2px solid #666;
        border-bottom: 2px solid #666;
        transform: rotate(45deg);
        transition: transform 0.3s ease;
    }
    .accordion-header.active .accordion-icon {
        transform: rotate(-135deg);
    }
    .tab {
      margin-top: 50px;
    }
    .tab.tab2 {
      padding-bottom: 50px;
    }
    .cv_flex {
        margin-top: 5em;
    }
    .cv_flex .reco-bloc__link.btn-wt {
        margin: 0;
        font-size: 2em;
        width: 340px;
        height: 60px;
        border-radius: 63px;
    }
    .cv_flex .reco-bloc__link.btn-wt.mail {
      border: 2px solid #ff870e;
      color: #ff870e;
      box-shadow: 7px 5px 7px #ff870ec4;
    }
    .cv_flex div {
        margin: 0 3em;
    }
    .underline-before {
        background: linear-gradient(#ff870e, #ff870e) 0 100%/0 4px no-repeat;
        transition: background 2s;
        text-decoration: none;
    }
    .underline-before2 {
        background: linear-gradient(#ff870e, #ff870e) 0 100%/0 4px no-repeat;
        transition: background 2s;
        text-decoration: none;
    }
    .underline-before3 {
        background: linear-gradient(#ff870e, #ff870e) 0 100%/0 4px no-repeat;
        transition: background 2s;
        text-decoration: none;
    }
    .underline-after {
        background-size: 100% 2px;
    }
    .underline-after2 {
        background-size: 100% 2px;
    }
    .underline-after3 {
        background-size: 100% 2px;
    }
    .campaign_t1 {
      width: fit-content;
      font-size: 2em;
      margin: 0 auto;
    }
    .reco-bloc__boxwrap.boxwrap01.campaign123 {
        padding: 30px 0;
    }
    .point02 .speed_pp {
      box-shadow: 5px 3px 3px #bfbfbf;
      border: 2px solid #bfbfbf;
      border-radius: 3px;
    }
    .app_item_flex li img {
        display: block;
        margin: 0 auto;
    }
    .app_item_flex li {
      text-align: center;
    }
    .app_span {
        text-align: center;
        font-size: 1.5em;
    }
    .footer {
        padding-bottom: 8em;
    }
    .footer_tracking .cv_flex {
        margin: 0;
    }
    .footer_tracking {
        position: fixed;
        bottom: 0;
        background-color: #fff;
        width: 100%;
        border-top: 3px solid #fffb11;
        padding: 2em 0 1.5em;
      transform: translateY(100%);
      transition: transform 0.3s ease;
      z-index: 1000;
    }
    .footer_tracking.visible {
      transform: translateY(0);
    }
    .rate_num {
        font-size: 4em;
      color: red;
    }
    .reco-bloc__point.point02 li {
      box-shadow: 7px 5px 7px #ad23235c;
      border: 1px solid #ad232324;
    }
    .reco-bloc__point.point02.point03 li {
      box-shadow: 7px 5px 7px #7979795c;
      border: 1px solid #55555524;
    }
    .popular_title {
        font-size: 2em;
        color: #ff2020;
    }
    .popular_title_span2 {
        font-size: 1.5em;
        margin-left: 10px;
    }
    .header {
        display: flex;
        align-items: center;
        position: absolute;
        top: 10px;
        z-index: 1;
        right: 0;
        left: 0;
        margin: 0 auto;
        width: 75%;
        background-color: #fff;
        border-radius: 25px;
      padding: 5px 0;
      box-shadow: 0 0 5px 3px #ffffff9c;
    }
    .header ul {
        display: flex;
      width: 50%;
      justify-content: center;
    }
    .reco.etc_area {
      width: 60%;
      margin: 200px auto 50px;
      border-radius: 50px;
      padding: 3% 5%;
    }
    .reco.etc_area h2 {
        font-size: 2em;
        text-align: center;
        margin-bottom: 1em;
    }
    .reco.etc_area h3 {
      font-size: 1.5em;
      margin: 1em auto;
      color: #c00841;
      font-weight: bold;
    }
    .reco.etc_area table {
        margin: 1em auto;
    }
    .reco.etc_area table th, .reco.etc_area table td {
        border: 1px solid;
        padding: 1em;
    }
    .main.main2 {
      background-color: #ffd0d0;
    }
    .reco.etc_area.etc_area2 {
      width: 60%;
      margin: 10em auto 2em;
      background-color: #fff;
      padding: 25px;
      border-radius: 15px;
    }
    .reco.etc_area dl {
        display: flex;
        justify-content: space-around;
        align-items: center;
      margin-bottom: 2em;
    }
    .reco.etc_area dt {
      width: 30%;
      text-align: left;
    }
    .reco.etc_area dd {
      width: 65%;
    }
    #appetc {
        display: none;
        margin-top: 1em;
    }
    .reco.etc_area dd.no-wrap {
        display: flex;
    }
    .reco.etc_area dd.no-wrap .radio_box1 {
        margin-right: 2em;
    }
    .reco.etc_area input, .reco.etc_area select, .reco.etc_area textarea {
        border: 1px solid #c6c6c6;
        padding: 10px;
    }
    .reco.etc_area textarea {
      height: 5em;
    }
    .form_submit {
      text-align: center;
    }
    .reco.etc_area .form_submit input {
        border: 2px solid #fffb11;
        color: #fffb11;
        box-shadow: 7px 5px 7px #fffb118c;
        padding: 10px 50px;
    }
    #day1, #day2, #day3 {
        margin-right: .5em;
        width: 20%;
    }
    .item12 {
      width: 15%;
      margin: 0 10px;
    }
    .bankette {
        display: block;
        margin-top: 10px;
    }
    .header__inner {
      margin: 0 auto;
      width: 35%;
    }
    .header ul li {
      width: 20%;
      text-align: center;
    }
    html {
      scroll-behavior: smooth;
    }
    .real_time_speed.is-fade {
        margin: 5em auto;
    }
    .reco-bloc__boxwrap.boxwrap01.real_time_speed.is-fade {
        padding-bottom: 50px;
    }
    .real_time_speed.is-fade span {
        display: block;
        text-align: center;
    }
    .real_time_title {
        font-size: 2em;
    }
    .real_time_text {
        font-size: 1.5em;
        margin: 10px 0;
    }
    .real_time_speed.is-fade span.real_time_text span {
        display: inline-block;
        color: red;
        font-size: 1.5em;
        margin-left: 5px;
    }
    .header ul li a {
      border-bottom: 2px solid #fffb11;
      padding: 0 3px;
    }
    .kv__cont {
      position: relative;
    }
    .top_parts {
      position: absolute;
    }
    
    
    .kv__cont img {
      object-fit: cover;
    }
    .top_parts {
      opacity: 0;
      transform: translateY(20px);
      animation: fadeInUp 0.8s ease-out forwards;
    }
    @keyframes fadeInUp {
      from {
        opacity: 0;
        transform: translateY(20px);
      }
      to {
        opacity: 1;
        transform: translateY(0);
      }
    }
    .top_parts1:nth-of-type(2) {
      animation-delay: 0.5s;
    }
    .top_parts1:nth-of-type(3) {
      animation-delay: 0.7s;
    }
    .top_parts1:nth-of-type(4) {
      animation-delay: 0.9s;
    }
    .top_parts1:nth-of-type(5) {
      animation-delay: 1.1s;
    }
    
    
    
    
    
    
    
    .display {
      display: inline-block;
      box-sizing: border-box;
      position: relative;
      width: 60px;
      height: 100px;
      border: solid 4px #202020;
      background-color: #202020;
      overflow: hidden;
    }
    .display::before {
      content: "";
      position: absolute;
      top: 50%;
      left: 50%;
      width: 28px;
      height: 28px;
      -webkit-transform: translate(-50%, -50%) rotate(45deg);
      -moz-transform: translate(-50%, -50%) rotate(45deg);
      -ms-transform: translate(-50%, -50%) rotate(45deg);
      transform: translate(-50%, -50%) rotate(45deg);
    }
    .display::after {
      content: "";
      position: absolute;
      top: 50%;
      left: 50%;
      width: 30px;
      height: 12px;
      border-top: solid 30px #202020;
      border-bottom: solid 30px #202020;
      padding: 5px;
      -webkit-transform: translate(-50%, -50%);
      -moz-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%);
    }
    .d0::before {
      background-color: #ffffff29;
      box-shadow: -30px -30px #fffb11,
                    0px -30px #fffb11,
                  -30px   0px #fffb11,
                    0px  30px #fffb11,
                   30px   0px #fffb11,
                   30px  30px #fffb11;
    }
    .d1::before {
      background-color: #ffffff29;
      box-shadow: -30px -30px #ffffff29,
                    0px -30px #fffb11,
                  -30px   0px #ffffff29,
                    0px  30px #ffffff29,
                   30px   0px #fffb11,
                   30px  30px #ffffff29;
    }
    .d2::before {
      background-color: #fffb11;
      box-shadow: -30px -30px #fffb11,
                    0px -30px #fffb11,
                  -30px   0px #ffffff29,
                    0px  30px #fffb11,
                   30px   0px #ffffff29,
                   30px  30px #fffb11;
    }
    .d3::before {
      background-color: #fffb11;
      box-shadow: -30px -30px #fffb11,
                    0px -30px #fffb11,
                  -30px   0px #ffffff29,
                    0px  30px #ffffff29,
                   30px   0px #fffb11,
                   30px  30px #fffb11;
    }
    .d4::before {
      background-color: #fffb11;
      box-shadow: -30px -30px #ffffff29,
                    0px -30px #fffb11,
                  -30px   0px #fffb11,
                    0px  30px #ffffff29,
                   30px   0px #fffb11,
                   30px  30px #ffffff29;
    }
    .d5::before {
      background-color: #fffb11;
      box-shadow: -30px -30px #fffb11,
                    0px -30px #ffffff29,
                  -30px   0px #fffb11,
                    0px  30px #ffffff29,
                   30px   0px #fffb11,
                   30px  30px #fffb11;
    }
    .d6::before {
      background-color: #fffb11;
      box-shadow: -30px -30px #fffb11,
                    0px -30px #ffffff29,
                  -30px   0px #fffb11,
                    0px  30px #fffb11,
                   30px   0px #fffb11,
                   30px  30px #fffb11;
    }
    .d7::before {
      background-color: #ffffff29;
      box-shadow: -30px -30px #fffb11,
                    0px -30px #fffb11,
                  -30px   0px #fffb11,
                    0px  30px #ffffff29,
                   30px   0px #fffb11,
                   30px  30px #ffffff29;
    }
    .d8::before {
      background-color: #fffb11;
      box-shadow: -30px -30px #fffb11,
                    0px -30px #fffb11,
                  -30px   0px #fffb11,
                    0px  30px #fffb11,
                   30px   0px #fffb11,
                   30px  30px #fffb11;
    }
    .d9::before {
      background-color: #fffb11;
      box-shadow: -30px -30px #fffb11,
                    0px -30px #fffb11,
                  -30px   0px #fffb11,
                    0px  30px #ffffff29,
                   30px   0px #fffb11,
                   30px  30px #fffb11;
    }
    .time_box_num {
      margin: 2em 10px;
      text-align: center;
    }
    .time_text1.time_text1234 {
      display: inline-block !important;
    }
    .soku1day {
        font-size: 2.5em;
        display: inline-block;
        color: fffb11;
        background-color: #ffe300;
        padding: 0 10px;
        border-radius: 5px;
    }
    .time_box_num1 {
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .time_box_num1 .time_text1 {
        font-size: 2.5em;
    }
    .time_box_num1 .time_text2 {
        font-size: 3em;
    }
    .time_box_date {
        font-size: 1.5em;
        text-align: center;
        margin-top: 1em;
    }
    .time_text1 {
        font-size: 2.5em;
    }
    .time_text1 {
        font-size: 2.5em;
        margin: 0 10px;
    }
    
    .time_box_num {
      margin: 2em 10px;
      text-align: center;
    }
    .time_text1.time_text1234 {
      display: inline-block !important;
    }
    .soku1day {
        font-size: 2.5em;
        display: inline-block;
        color: fffb11;
        background-color: #ffe300;
        padding: 0 10px;
        border-radius: 5px;
      color: #000;
    }
    .time_box_num1 {
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .time_box_num1 .time_text1 {
        font-size: 2.5em;
    }
    .time_box_num1 .time_text2 {
        font-size: 3em;
    }
    .time_box_date {
        font-size: 1.5em;
        text-align: center;
        margin-top: 1em;
    }
    .time_text1 {
        font-size: 2.5em;
    }
    .time_text1 {
        font-size: 2.5em;
        margin: 0 10px;
    }
    
    .rate_time {
      border: 2px solid #fd5871;
      background: #fd5871;
      border-radius: 7px;
      color: white;
      margin-top: 3%;
      margin-left: 2%;
      margin-right: 2%;
      position: relative;
      overflow: hidden;
      height: 2.8em;
    }
    .rate_time p {
      font-size: 1.5em;
      justify-content: center;
    }
    .ratetime_first {
      display: flex;
    }
    .ratetime_second {
      display: flex;
    }
    .rate_numimg1 {
      width: 40%;
      align-content: end;
    }
    .rate_numimg2 {
      width: 40%;
      align-content: end;
    }
    .ratenum_sub {
      align-content: center;
      width: 30%;
    }
    
    
    /* スライド用親要素に必要 */
    .rate_num {
      position: relative;
      overflow: hidden;
      height: 3em;
      margin-bottom: 3%;
      margin-left: 8%;
      margin-right: 8%;
      margin-top: 2%;
    }
    
    .rate_time p,
    .ratetime_first,
    .ratetime_second {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      transition: transform 0.6s ease, opacity 0.6s ease;
      display: flex; /* ← これは保持！ */
    }
    
    /* 表示中 */
    .slide-show {
      transform: translateY(0%);
      opacity: 1;
      z-index: 2;
      pointer-events: auto;
    }
    
    /* 上に控えてる（次にスライドしてくる） */
    .slide-next-up {
      transform: translateY(-100%);
      opacity: 1;
      z-index: 1;
      pointer-events: none;
    }
    
    /* 下に消える（表示終了） */
    .slide-hide {
      transform: translateY(100%);
      opacity: 0;
      z-index: 0;
      pointer-events: none;
    }
    
    /* 上に戻す（透明で、見えない） */
    .slide-reset {
      transform: translateY(-100%);
      opacity: 0;
      z-index: 0;
      pointer-events: none;
    }
    .fadebox {
      margin-top: 2%;
    }
    
    @media screen and (min-width:670px) {
    .ip_only {
      display: none !important;
    }
    .campaign_item {
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .time_box_num {
        display: flex;
        justify-content: center;
        align-items: end;
    }
    .cv_flex {
        display: flex;
        justify-content: center;
    }
    }
    
    @media screen and (max-width:670px) {
    .pc_only {
      display: none !important;
    }
      .reco.etc_area {
      width: 90% !important;
      margin: 10em auto 2em;
    }
    .reco.etc_area h2 {
      font-size: 1.5em;
    }
    .reco.etc_area h3 {
      font-size: 1.2em;
    }
    .kv__cont {
      text-align: center;
    }
    .top_parts.top_parts1 {
      top: 0;
      left: 0;
    }
    header {
        position: absolute;
        top: 15px;
        width: 90%;
        z-index: 1000;
        right: 0;
        left: 0;
        margin: 0 auto;
        background-color: #fff;
        border-radius: 25px;
        padding: 5px 0;
        box-shadow: 0 0 5px 3px #ffffff9c;
    }
    .header-inner img {
        width: 65%;
    }
    .header-inner {
      display: flex;
      justify-content: space-between;
      align-items: center;
      height: 60px;
      padding: 0 20px;
    }
    .site-logo {
      font-size: 24px;
      font-weight: bold;
    }
    .hamburger {
      display: block;
      width: 30px;
      height: 24px;
      position: relative;
      cursor: pointer;
      z-index: 1001;
    }
    .hamburger span {
      display: block;
      width: 100%;
      height: 2px;
      background-color: #333;
      position: absolute;
      transition: all 0.3s;
    }
    .hamburger span:nth-child(1) {
      top: 0;
    }
    .hamburger span:nth-child(2) {
      top: 11px;
    }
    .hamburger span:nth-child(3) {
      bottom: 0;
    }
    .hamburger.active span:nth-child(1) {
      transform: translateY(11px) rotate(45deg);
    }
    .hamburger.active span:nth-child(2) {
      opacity: 0;
    }
    .hamburger.active span:nth-child(3) {
      transform: translateY(-11px) rotate(-45deg);
    }
    .nav {
      position: fixed;
      top: 0;
      right: -300px;
      width: 300px;
      height: 100vh;
      background-color: #333;
      padding-top: 120px;
      transition: all 0.3s;
      z-index: 999;
      overflow-y: auto;
    }
    .nav.active {
      right: 0;
    }
    .nav-list {
      list-style: none;
    }
    .nav-item {
      border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    }
    .nav-link {
      display: block;
      padding: 15px 20px;
      color: #fff;
      text-decoration: none;
      transition: all 0.3s;
    }
    .nav-link:hover {
      background-color: #444;
    }
    .overlay {
      position: fixed;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-color: rgba(0, 0, 0, 0.5);
      visibility: hidden;
      opacity: 0;
      transition: all 0.3s;
      z-index: 998;
    }
    .overlay.active {
      visibility: visible;
      opacity: 1;
    }
    .content {
      margin-top: 80px;
      padding: 20px;
    }
    .content h1 {
      margin-bottom: 20px;
    }
    .content p {
      line-height: 1.6;
      margin-bottom: 20px;
    }
    .tab {
      margin-top: 25px;
    }
    .campaign_t1.ip_only {
        font-size: 6vw;
    }
    .campaign_item img {
      display: block;
      margin: 0 auto;
    }
    .real_time_title, .time_text1 {
        font-size: 8vw;
    }
    .time_box_num_ff {
        display: flex;
        align-items: baseline;
        justify-content: center;
      margin-top: 2em;
    }
    .cv_flex .reco-bloc__link.btn-wt {
      margin: 0 auto;
    }
    .cv_flex div {
      margin: 3em 0em;
    }
    .reco-top__item.is-fade {
      font-size: 5vw;
    }
    .reco-top__item span {
      top: -40%;
      left: 5%;
    }
    .reco-bloc__point.point02 li {
      margin: 1em 0 !important;
      padding: 10px;
    }
    .reco-top__lsit [data-script=fadebox] {
      margin: 1em auto;
    }
    .tab .tab__list li em span {
        font-size: 2em;
        background-color: #ff4949;
        padding: 5px 10px;
        border-radius: 30px 0 0 0;
      color: #fff;
    }
    .footer_tracking.visible .cv_flex div {
      margin: 1em 0em;
    }
    .tab tab2 .reco-bloc__ttl .img_center span {
        font-size: 7vw;
    }
    .reco.etc_area input, .reco.etc_area select, .reco.etc_area textarea {
      width: 100%;
    }
    .rate_num {
      height: 1.5em;
      margin-bottom: 0%;
      margin-left: 5%;
      margin-right: 5%;
      margin-top: 3%;
    }
    .app_item {
      font-size: 3.7vw;
    }

    body {
      font-size: 1.4rem;
      margin-top: 0% !important;
    }
}

.access123 {
  width: 200px;
}

.num_btn {
  border: 1px solid #c6c6c6;
  margin-top: 1%;
  padding: 0.5% 2%;
}

.button__wrapper {
  text-align: center;
}

.ssn_btn445 {
  width: 30%;
  background: #bf0841;
  color: white;
  border-radius: 10px;
}