@charset "UTF-8";
html {
  font-family: sans-serif;
  -moz-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  margin-top: 0 !important;
}

body {
  margin: 0;
  padding: 0;
}

div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, dialog, figure, footer, header, hgroup, menu, nav, section, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  font-weight: inherit;
}

article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
  display: block;
}

ul, ol {
  list-style-type: none;
}

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

td, th {
  padding: 0;
}

img {
  max-width: 100%;
  vertical-align: bottom;
  border: 0;
  width: 100%;
  height: auto;
}

i {
  display: block;
}

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

a:hover, a:active {
  text-decoration: none;
  outline: 0;
}

a:before, a:after {
  text-decoration: none;
}

b, strong {
  font-weight: bold;
}

em {
  font-style: normal;
}

button, input, optgroup, select, textarea {
  color: inherit;
  font: inherit;
  margin: 0;
}

button {
  padding: 0;
  background-color: transparent;
  border: none;
  color: inherit;
  overflow: visible;
  text-transform: none;
}

button:focus {
  outline: none;
}

select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  text-transform: none;
}

input[type=date] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

button {
  -webkit-appearance: button;
  cursor: pointer;
}

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

button[disabled], input[disabled] {
  cursor: default;
}

button::-moz-focus-inner {
  padding: 0;
  border: 0;
}

input {
  line-height: normal;
  vertical-align: middle;
}

input::-moz-focus-inner {
  padding: 0;
  border: 0;
}

input[type=checkbox], input[type=radio] {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0;
}

select {
  vertical-align: middle;
}

textarea {
  overflow: auto;
}

optgroup {
  font-weight: bold;
}

body {
  min-width: 1000px;
  background-color: #fff;
}

.wrapper {
  position: relative;
  font-family: "ヒラギノ角ゴ Pro W9", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 14px;
  line-height: 1.35;
}

.wrapper * {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  background-repeat: no-repeat;
}

.wrapper a {
  position: relative;
}

.wrapper a:hover, .wrapper a:active, .wrapper a:focus {
  text-decoration: none;
}

.pc-only {
  display: block;
}

.sp-only {
  display: none;
}

.inner {
  max-width: 1000px;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .inner {
    max-width: 100%;
  }
}
@media screen and (max-width: 767px) {
  body {
    min-width: 320px;
  }
  .pc-only {
    display: none;
  }
  .sp-only {
    display: block;
  }
}
.link-over {
  opacity: 1;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
}

.link-over:hover {
  opacity: 0.8;
}

body {
  padding-top: 114px;
}

@media screen and (max-width: 767px) {
  body {
    padding-top: 118px;
  }
}
.bg-loading-popup {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  width: 100vw;
  height: 100vh;
  background-color: #fff;
  display: none;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}

.bg-loading-popup .bg-popup {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 80px;
}

.bg-loading-popup.js-active {
  display: block;
}

.loading-blink {
  -webkit-animation: blink 1s ease-in-out infinite alternate;
  animation: blink 1s ease-in-out infinite alternate;
}

@-webkit-keyframes blink {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes blink {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.cashback-popup {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  width: 100vw;
  height: 100vh;
  background-color: rgba(30, 47, 67, 0.6);
  display: none;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}

.cashback-popup .banner {
  width: 320px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  background-image: url(../img/popup-back-img.png);
  background-size: cover;
  background-repeat: no-repeat;
  padding: 30px 0 20px;
}

@media screen and (max-width: 767px) {
  .cashback-popup .banner {
    width: 280px;
    padding: 20px 0;
  }
}
.cashback-popup .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 20px 16px 0;
}

@media screen and (max-width: 767px) {
  .cashback-popup .btn {
    padding: 20px 6px 0;
  }
}
.cashback-popup .btn a {
  display: block;
  margin: 0 4px;
}

.cashback-popup .cashback-popup-close {
  width: 24px;
  position: absolute;
  top: -10px;
  right: -12px;
  cursor: pointer;
}

.cashback-popup.js-active {
  display: block;
}

body.fixed {
  overflow: hidden;
}

.header {
  background-color: #1e2f43;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
}

.header .inner {
  padding: 8px 10px;
}

@media screen and (max-width: 767px) {
  .header .inner {
    padding: 0 10px;
  }
}
.header .box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.header .box .logo {
  width: 90px;
  display: block;
  position: relative;
  margin-top: -8px;
  margin-bottom: -28px;
  background-color: #fff;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .header .box .logo {
    width: 80px;
    margin-top: -22px;
  }
}
.header .box .logo a {
  display: block;
  padding: 6px 0;
}

@media screen and (max-width: 767px) {
  .header .box .logo a {
    padding: 2px 0;
  }
}
.header .box .logo img {
  width: 50px;
}

@media screen and (max-width: 767px) {
  .header .box .logo img {
    width: 70px;
  }
}
.header .box .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
  justify-content: space-around;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.header .box .list li {
  text-align: center;
  margin: 0 20px;
  position: relative;
}

.header .box .list li .sub-menu {
  position: absolute;
  left: -20px;
  top: 40px;
  width: 190px;
  background-color: #fff;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
  visibility: hidden;
  opacity: 0;
  border-radius: 4px;
  padding: 6px 0;
  z-index: 1;
}

.header .box .list li .sub-menu li {
  margin: 0 8px;
  text-align: left;
}

.header .box .list li .sub-menu li:last-child a {
  border-bottom: none;
}

.header .box .list li .sub-menu a {
  display: block;
  padding: 10px 0 10px 16px;
  color: #1e2f43;
  font-weight: 600;
  border-bottom: 1px dashed #eee;
  position: relative;
}

.header .box .list li .sub-menu a:before {
  content: "▶︎";
  font-size: 10px;
  position: absolute;
  top: 50%;
  left: 1%;
  -webkit-transform: translateY(-50%) translateX(0%);
  -ms-transform: translateY(-50%) translateX(0%);
  transform: translateY(-50%) translateX(0%);
  line-height: 1;
}

.header .box .list li:hover .sub-menu {
  top: 50px;
  visibility: visible;
  opacity: 1;
}

.header .box .list a {
  color: #fff;
  font-size: 12px;
}

.header .box .list a small {
  color: #2a98d2;
  font-weight: 900;
  display: block;
  font-size: 10px;
  letter-spacing: 1px;
  margin-top: 6px;
}

@media screen and (max-width: 767px) {
  .header .box .btn {
    margin-left: auto;
  }
}
.header .box .btn a {
  display: inline-block;
  background-color: #ff373c;
  padding: 14px 20px;
  color: #fff;
  border-radius: 30px;
  position: relative;
  overflow: hidden;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .header .box .btn a {
    padding: 16px 12px 16px 42px;
    border-radius: 0px;
    font-size: 12px;
    background-image: url(../img/top-btn-icon1-img.svg);
    background-size: 26px;
    background-position: 8px 50%;
    font-weight: 900;
    letter-spacing: 1px;
    display: block;
    position: relative;
    overflow: hidden;
  }
}
.header .box .btn .light {
  height: 100%;
  width: 20px;
  position: absolute;
  top: -180px;
  left: 0;
  background-color: #fff;
  opacity: 0;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  -webkit-animation: light 5s ease-in-out infinite;
  animation: light 5s ease-in-out infinite;
}

.header .news {
  background-color: #f4f4f4;
  text-align: center;
}

.header .news .inner {
  padding: 0 10px !important;
}

.header .news .txt {
  padding: 8px 0;
}

@media screen and (max-width: 767px) {
  .header .news .txt {
    padding: 12px 0 6px;
  }
}
.header .news a {
  font-size: 14px;
  color: #47b2ea;
  font-weight: 700;
}

@-webkit-keyframes light {
  0% {
    -webkit-transform: scale(0) rotate(45deg);
    transform: scale(0) rotate(45deg);
    opacity: 0;
  }
  80% {
    -webkit-transform: scale(0) rotate(45deg);
    transform: scale(0) rotate(45deg);
    opacity: 0.5;
  }
  81% {
    -webkit-transform: scale(4) rotate(45deg);
    transform: scale(4) rotate(45deg);
    opacity: 1;
  }
  100% {
    -webkit-transform: scale(50) rotate(45deg);
    transform: scale(50) rotate(45deg);
    opacity: 0;
  }
}
@keyframes light {
  0% {
    -webkit-transform: scale(0) rotate(45deg);
    transform: scale(0) rotate(45deg);
    opacity: 0;
  }
  80% {
    -webkit-transform: scale(0) rotate(45deg);
    transform: scale(0) rotate(45deg);
    opacity: 0.5;
  }
  81% {
    -webkit-transform: scale(4) rotate(45deg);
    transform: scale(4) rotate(45deg);
    opacity: 1;
  }
  100% {
    -webkit-transform: scale(50) rotate(45deg);
    transform: scale(50) rotate(45deg);
    opacity: 0;
  }
}
@media screen and (max-width: 767px) {
  .header .nav-wrap.open {
    display: block;
  }
  .header .nav-wrap.close {
    display: none;
  }
  .header .nav-button {
    display: block;
    cursor: pointer;
  }
  .header .nav-wrap {
    position: fixed;
    left: 0;
    top: 0;
    display: none;
    z-index: 10;
    background-color: rgba(30, 47, 67, 0.9);
    width: 100%;
    height: 100vh;
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
  }
  .header .nav-wrap .nav {
    height: 100%;
    position: relative;
    overflow-x: hidden;
    overflow-y: scroll;
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
    padding: 64px 0 10px;
    -webkit-overflow-scrolling: touch;
  }
  .header .nav-wrap li {
    display: block;
  }
  .header .nav-wrap li a {
    color: #fff;
    font-size: 14px;
    display: block;
    text-align: center;
    padding: 14px;
    letter-spacing: 1px;
    border-bottom: 1px solid #fff;
  }
  .header .nav-wrap li a small {
    display: block;
    font-size: 10px;
    margin-top: 2px;
  }
  .header .nav-wrap li span.sp-toggle-nemu {
    color: #fff;
    font-size: 14px;
    display: block;
    text-align: center;
    padding: 14px;
    letter-spacing: 1px;
    border-bottom: 1px solid #fff;
    position: relative;
  }
  .header .nav-wrap li span.sp-toggle-nemu small {
    display: block;
    font-size: 10px;
    margin-top: 2px;
  }
  .header .nav-wrap li span.sp-toggle-nemu span {
    width: 16px;
    height: 1px;
    background-color: #fff;
    display: block;
    position: absolute;
    right: 20px;
    top: 50%;
    -webkit-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    transform: rotate(90deg);
    -webkit-transition: all 0.6s;
    transition: all 0.6s;
  }
  .header .nav-wrap li span.sp-toggle-nemu span:after {
    content: "";
    width: 14px;
    height: 1px;
    background-color: #fff;
    display: block;
    position: absolute;
    right: 1px;
    top: 48%;
    -webkit-transform: rotate(-90deg);
    -ms-transform: rotate(-90deg);
    transform: rotate(-90deg);
  }
  .header .nav-wrap li span.sp-toggle-nemu.active span {
    -webkit-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  .header .nav-wrap li span.sp-toggle-nemu.active span:after {
    -webkit-transform: rotate(180deg);
    -ms-transform: rotate(180deg);
    transform: rotate(180deg);
  }
  .header .nav-wrap li .sub-menu {
    display: none;
  }
  .header .nav-button, .header .nav-button span {
    display: inline-block;
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
  }
  .header .nav-button {
    z-index: 20;
    position: relative;
    width: 54px;
    height: 60px;
  }
  .header .nav-button small {
    color: #fff;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 1px;
    position: absolute;
    bottom: 7px;
    right: 0;
    left: 14px;
    margin: 0 auto;
    text-align: center;
  }
  .header .nav-button span {
    position: absolute;
    left: 10px;
    right: 0;
    margin: 0 auto;
    width: 20px;
    height: 2px;
    background-color: #fff;
    border-radius: 4px;
  }
  .header .nav-button span:nth-of-type(1) {
    top: 20px;
  }
  .header .nav-button span:nth-of-type(2) {
    top: 27px;
  }
  .header .nav-button span:nth-of-type(3) {
    top: 34px;
  }
  .header .nav-button.active span:nth-of-type(1) {
    -webkit-transform: translateY(8px) rotate(-45deg);
    -ms-transform: translateY(8px) rotate(-45deg);
    transform: translateY(8px) rotate(-45deg);
  }
  .header .nav-button.active span:nth-of-type(2) {
    opacity: 0;
  }
  .header .nav-button.active span:nth-of-type(3) {
    -webkit-transform: translateY(-6px) rotate(45deg);
    -ms-transform: translateY(-6px) rotate(45deg);
    transform: translateY(-6px) rotate(45deg);
  }
  .header .nav-button.active small {
    opacity: 0.4;
  }
}
@media screen and (max-width: 767px) {
  .header .nav-drawer {
    z-index: 20;
    position: relative;
    width: 54px;
    height: 60px;
  }
  .header .nav-drawer .nav-unshown {
    display: none;
  }
  .header .nav-drawer #nav-open {
    margin: 20px 0 0 18px;
    display: inline-block;
    width: 28px;
    height: 22px;
    vertical-align: middle;
    cursor: pointer;
    -webkit-transition: ease 0.5s;
    transition: ease 0.5s;
    position: absolute;
  }
  .header .nav-drawer .navbar-toggle-icon {
    position: relative;
    display: block;
    height: 2px;
    width: 28px;
    background: #ffffff;
    -webkit-transition: ease 0.5s;
    transition: ease 0.5s;
  }
  .header .nav-drawer .navbar-toggle-icon:nth-child(1) {
    top: 0;
  }
  .header .nav-drawer .navbar-toggle-icon:nth-child(2) {
    margin: 7px 0;
  }
  .header .nav-drawer .navbar-toggle-icon:nth-child(3) {
    top: 0;
  }
  .header .nav-drawer #nav-close {
    display: none;
    position: fixed;
    z-index: 99;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: black;
    opacity: 0;
    -webkit-transition: ease 0.5s;
    transition: ease 0.5s;
  }
  .header .nav-drawer #nav-content {
    overflow: auto;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 9999;
    width: 210px;
    height: 100%;
    background: #ffffff;
    -webkit-transition: ease 0.5s;
    transition: ease 0.5s;
    -webkit-transform: translateX(100%);
    -ms-transform: translateX(100%);
    transform: translateX(100%);
  }
  .header .nav-drawer #nav-input:checked ~ #nav-close {
    display: block;
    opacity: 0.7;
  }
  .header .nav-drawer #nav-input:checked ~ #nav-content {
    position: fixed;
    -webkit-transform: translateX(calc(100% - 210px));
    -ms-transform: translateX(calc(100% - 210px));
    transform: translateX(calc(100% - 210px));
    -webkit-box-shadow: 6px 0 25px rgba(0, 0, 0, 0.15);
    box-shadow: 6px 0 25px rgba(0, 0, 0, 0.15);
  }
  .header .nav-drawer #nav-input:checked ~ #nav-open {
    right: 210px;
  }
  .header .nav-drawer #nav-input:checked ~ #nav-open .navbar-toggle-icon {
    z-index: 100;
  }
  .header .nav-drawer #nav-input:checked ~ #nav-open .navbar-toggle-icon:nth-child(1) {
    top: 8.6px;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
  }
  .header .nav-drawer #nav-input:checked ~ #nav-open .navbar-toggle-icon:nth-child(2) {
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    opacity: 0;
  }
  .header .nav-drawer #nav-input:checked ~ #nav-open .navbar-toggle-icon:nth-child(3) {
    top: -8.6px;
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }
  .header .nav-drawer .nav-content .nav-drawer-header {
    text-align: center;
    padding: 16px 0;
  }
  .header .nav-drawer .nav-content .nav-drawer-header img {
    width: 30px;
  }
  .header .nav-drawer .nav-content .menu-box .menu-ttl {
    background-color: #f0f0f0;
    padding: 6px 10px;
    color: #0e233b;
    font-size: 10px;
    font-weight: 600;
  }
  .header .nav-drawer .nav-content .menu-box .list {
    display: block;
  }
  .header .nav-drawer .nav-content .menu-box .list li {
    margin: 0;
    border-bottom: 1px solid #0e233b;
    text-align: left;
    background-size: 20px;
    background-position: 10px 50%;
  }
  .header .nav-drawer .nav-content .menu-box .list li.toggle-menu-box {
    border-bottom: none;
    position: relative;
    color: #0e233b;
    font-weight: 600;
    padding: 14px 40px;
    font-size: 12px;
    cursor: pointer;
  }
  .header .nav-drawer .nav-content .menu-box .list li.toggle-menu-box .line {
    display: inline-block;
    position: absolute;
    background-color: #0e233b;
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
  }
  .header .nav-drawer .nav-content .menu-box .list li.toggle-menu-box .line.line1 {
    top: 50%;
    right: 12px;
    width: 12px;
    height: 2px;
  }
  .header .nav-drawer .nav-content .menu-box .list li.toggle-menu-box .line.line2 {
    width: 2px;
    height: 12px;
    right: 17px;
    top: 17px;
  }
  .header .nav-drawer .nav-content .menu-box .list li.toggle-menu-box.active .line.line2 {
    -webkit-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    transform: rotate(90deg);
  }
  .header .nav-drawer .nav-content .menu-box .list a {
    display: block;
    color: #0e233b;
    font-weight: 600;
    padding: 14px 14px 14px 40px;
  }
  .header .nav-drawer .nav-content .menu-box .contact-btn {
    margin: 14px 10px 0;
    padding-bottom: 20px;
  }
  .header .nav-drawer .nav-content .menu-box .contact-btn a {
    display: block;
    background-color: #ff373c;
    color: #fff;
    text-align: center;
    font-size: 12px;
    font-weight: 600;
    padding: 16px 10px 16px 30px;
    border-radius: 6px;
    background-size: 22px;
    background-position: 8px 50%;
  }
  .header .nav-drawer .nav-content .menu-box .sub-drawer-menu {
    display: none;
  }
  .header .nav-drawer .nav-content .menu-box .sub-drawer-menu li {
    border-bottom: 1px solid #fff;
  }
  .header .nav-drawer .nav-content .menu-box .sub-drawer-menu li:last-child {
    border-bottom: none;
  }
  .header .nav-drawer .nav-content .menu-box .sub-drawer-menu li a {
    display: block;
    font-size: 10px;
    background-color: #0e233b;
    color: #fff;
    font-weight: 600;
    padding: 8px 0 8px 50px;
  }
}
.footer {
  background-color: #1e2f43;
  padding-bottom: 86px;
}

.footer .inner {
  padding: 20px 10px;
}

@media screen and (max-width: 767px) {
  .footer .inner {
    padding: 10px 0;
  }
}
.footer .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

@media screen and (max-width: 767px) {
  .footer .list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.footer .list .text-link li {
  margin: 16px 0;
}

@media screen and (max-width: 767px) {
  .footer .list .text-link li {
    margin: 0;
  }
}
.footer .list .text-link li a {
  color: #fff;
}

@media screen and (max-width: 767px) {
  .footer .list .text-link li a {
    display: block;
    text-align: center;
    padding: 14px 10px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.6);
    letter-spacing: 1px;
  }
}
.footer .list .icon-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 120px;
}

@media screen and (max-width: 767px) {
  .footer .list .icon-link {
    margin-top: 20px;
    width: 100%;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}
.footer .list .icon-link li {
  width: 40px;
  margin: 6px 10px;
}

@media screen and (max-width: 767px) {
  .footer .list .icon-link li {
    width: 32px;
    margin: 0 6px;
  }
}
.footer .list .text-link.min {
  -ms-flex-preferred-size: 16%;
  flex-basis: 16%;
}

@media screen and (max-width: 767px) {
  .footer .list .text-link.min {
    -ms-flex-preferred-size: auto;
    flex-basis: auto;
    width: 100%;
  }
}
.footer .list .text-link.max {
  -ms-flex-preferred-size: 20%;
  flex-basis: 20%;
}

@media screen and (max-width: 767px) {
  .footer .list .text-link.max {
    -ms-flex-preferred-size: auto;
    flex-basis: auto;
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .footer .list .sp-shop-link {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .footer .list .sp-shop-link .shop-name {
    text-align: center;
    padding: 14px 10px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.6);
    letter-spacing: 1px;
    color: #fff;
    position: relative;
    cursor: pointer;
  }
}
@media screen and (max-width: 767px) {
  .footer .list .sp-shop-link .shop-name span {
    width: 16px;
    height: 1px;
    background-color: #fff;
    display: block;
    position: absolute;
    right: 20px;
    top: 50%;
    -webkit-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    transform: rotate(90deg);
    -webkit-transition: all 0.6s;
    transition: all 0.6s;
  }
}
@media screen and (max-width: 767px) {
  .footer .list .sp-shop-link .shop-name span:after {
    content: "";
    width: 14px;
    height: 1px;
    background-color: #fff;
    display: block;
    position: absolute;
    right: 1px;
    top: 48%;
    -webkit-transform: rotate(-90deg);
    -ms-transform: rotate(-90deg);
    transform: rotate(-90deg);
  }
}
@media screen and (max-width: 767px) {
  .footer .list .sp-shop-link .shop-name.active span {
    -webkit-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    transform: rotate(0deg);
  }
}
@media screen and (max-width: 767px) {
  .footer .list .sp-shop-link .shop-name.active span:after {
    -webkit-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    transform: rotate(0deg);
    opacity: 0;
  }
}
@media screen and (max-width: 767px) {
  .footer .list .sp-shop-link .text-link {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .footer .list .sp-shop-link .text-link a {
    background-color: rgba(255, 255, 255, 0.04);
  }
}
.footer .logo {
  text-align: center;
  padding: 20px 0 10px;
}

.footer .logo img {
  width: 90px;
  background-color: #fff;
  padding: 4px 14px;
}

@media screen and (max-width: 767px) {
  .footer .logo img {
    width: 80px;
  }
}
.footer .gym-name {
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .footer .gym-name {
    font-size: 10px;
    letter-spacing: 0;
  }
}
.footer .copyright {
  border-top: 1px solid #566372;
  text-align: center;
  padding: 8px 0;
  color: rgba(255, 255, 255, 0.6);
  font-size: 12px;
  font-weight: 400;
}

@media screen and (max-width: 767px) {
  .footer .copyright {
    font-size: 10px;
    letter-spacing: 1px;
  }
}
@media screen and (max-width: 767px) {
  .top .fv {
    background-color: #fff;
  }
}
.top .fv .inner {
  max-width: 100%;
}

.top .fv .slick-prev.slick-arrow, .top .fv .slick-next.slick-arrow {
  display: none !important;
}

.top .fv .slick-list.draggable {
  height: 100%;
}

.top .fv .fv-slider {
  position: relative;
}

@media screen and (max-width: 767px) {
  .top .fv .fv-slider {
    padding-bottom: 0;
    height: auto;
  }
}
@media screen and (max-width: 767px) {
  .top .fv .fv-slider .slider {
    margin: 0 2px;
    border-right: 1px solid #eee;
    border-left: 1px solid #eee;
  }
}
.top .fv .fv-slider .slide-dots {
  text-align: center;
  position: absolute;
  right: 0;
  left: 0;
  margin: 0 auto;
  bottom: 10px;
  width: 100%;
}

@media screen and (max-width: 767px) {
  .top .fv .fv-slider .slide-dots {
    bottom: 4px;
  }
}
.top .fv .fv-slider .slide-dots li {
  display: inline-block;
  margin: 0 8px;
  position: relative;
}

.top .fv .fv-slider .slide-dots li button {
  position: relative;
  text-indent: -9999px;
}

.top .fv .fv-slider .slide-dots li button:before {
  content: "";
  text-indent: 0px;
  position: absolute;
  top: 5px;
  left: -4px;
  width: 8px;
  height: 8px;
  border-radius: 100%;
  background-color: #e6e6e6;
}

.top .fv .fv-slider .slide-dots li.slick-active button:before {
  background-color: #1f2f43;
}

.top .btn-area.top-area {
  background-color: #1e2f43;
}

.top .btn-area.top-area .inner {
  padding: 26px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .top .btn-area.top-area .inner {
    padding: 20px 10px;
    max-width: 500px;
  }
}
.top .btn-area.top-area .campaign {
  margin-top: 10px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .top .btn-area.top-area .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
  }
}
.top .btn-area.top-area .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 767px) {
  .top .btn-area.top-area .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.top .btn-area.top-area .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .top .btn-area.top-area .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.top .btn-area.top-area .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .top .btn-area.top-area .campaign .img span {
    font-size: 12px;
  }
}
.top .btn-area.top-area .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .top .btn-area.top-area .campaign .img span b {
    font-size: 10px;
  }
}
.top .btn-area.top-area .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .top .btn-area.top-area .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.top .btn-area.top-area .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .top .btn-area.top-area .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.top .btn-area.top-area .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.top .btn-area.top-area .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .top .btn-area.top-area .campaign .txt .cost {
    font-size: 16px;
  }
}
.top .btn-area.top-area .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .top .btn-area.top-area .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.top .btn-area.top-area .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .top .btn-area.top-area .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.top .btn-area.top-area .attention {
  margin-top: 10px;
}

.top .btn-area.top-area .attention p {
  color: #fff;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.top .btn-area.top-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-top: 24px;
  text-align: center;
}

.top .btn-area.top-area .btn .left, .top .btn-area.top-area .btn .right {
  width: 49%;
}

.top .btn-area.top-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .top .btn-area.top-area .btn .left a {
    background-image: url(../img/top-btn-icon1-img.svg);
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
  }
}
.top .btn-area.top-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .top .btn-area.top-area .btn .left a span {
    font-size: 14px;
  }
}
.top .btn-area.top-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .top .btn-area.top-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.top .btn-area.top-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .top .btn-area.top-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.top .btn-area.top-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .top .btn-area.top-area .btn .right a span {
    font-size: 14px;
  }
}
.top .banner {
  background-color: #fff;
}

.top .banner .inner {
  padding: 16px 10px;
}

@media screen and (max-width: 767px) {
  .top .banner .inner {
    padding: 20px 10px 10px;
  }
}
.top .banner .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.top .banner .list li {
  width: 49%;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .top .banner .list li {
    margin: 0 0 10px 0;
  }
}
.top .before-after .list {
  overflow: hidden;
}

.top .before-after .list .ttl {
  text-align: center;
  padding: 20px 0;
}

.top .before-after .list .ttl span {
  background-color: #fdfc37;
  display: inline-block;
  padding: 8px 40px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .top .before-after .list .ttl span {
    padding: 8px 20px;
  }
}
.top .before-after .list .ttl span:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -6px;
  border: 6px solid transparent;
  border-top: 10px solid #fdfc37;
}

.top .before-after .list .ttl h2 {
  font-size: 32px;
  font-weight: 900;
  letter-spacing: 3px;
  padding-top: 10px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .top .before-after .list .ttl h2 {
    font-size: 22px;
    letter-spacing: 1px;
  }
}
.top .before-after .list .img {
  position: relative;
  background-color: #f4f4f4;
  padding-top: 30px;
}

@media screen and (max-width: 767px) {
  .top .before-after .list .img {
    padding-top: 20px;
  }
}
.top .before-after .list .img:before {
  content: "";
  width: 60%;
  height: 150%;
  background-color: #2ca8e8;
  position: absolute;
  top: -20%;
  right: -10%;
  -webkit-transform: rotate(16deg);
  -ms-transform: rotate(16deg);
  transform: rotate(16deg);
}

.top .before-after .list .img .inner {
  padding: 0 10px 0 160px;
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .top .before-after .list .img .inner {
    padding: 0 10px;
  }
}
.top .before-after .list .img .inner img {
  display: block;
  margin-bottom: -70px;
}

@media screen and (max-width: 767px) {
  .top .before-after .list .img .inner img {
    margin-bottom: -20px;
  }
}
.top .before-after .list .number {
  background-color: #1e2f43;
  position: relative;
}

.top .before-after .list .number .inner {
  padding: 100px 10px 60px;
}

@media screen and (max-width: 767px) {
  .top .before-after .list .number .inner {
    padding: 30px 10px 20px;
  }
}
.top .before-after .list .number .inner .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
  justify-content: space-around;
}

.top .before-after .list .number .inner .list li {
  width: 32%;
  text-align: center;
  border: 1px solid #fff;
  padding: 20px 0;
  color: #fff;
  font-size: 18px;
}

@media screen and (max-width: 767px) {
  .top .before-after .list .number .inner .list li {
    padding: 10px 0;
    font-size: 12px;
  }
}
.top .before-after .list .number .inner .list li span {
  color: #fdfc37;
  display: inline-block;
  margin: 0 2px;
}

@media screen and (max-width: 767px) {
  .top .before-after .list .number .inner .list li span {
    margin: 4px 2px 0;
  }
}
.top .before-after .list .number .inner .list li b {
  font-family: Century Gothic;
  font-size: 28px;
  display: inline-block;
  vertical-align: baseline;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .top .before-after .list .number .inner .list li b {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    font-size: 18px;
  }
}
.top .before-after .list .number .inner .attention {
  margin: 10px 0 0 5px;
  color: #fff;
  font-size: 40%;
}

@media screen and (max-width: 767px) {
  .top .before-after .list .number .inner .attention {
    margin: 10px 0 0 0;
  }
}
.top .before-after .list.list2 .number .inner {
  padding: 100px 10px 40px;
}

@media screen and (max-width: 767px) {
  .top .before-after .list.list2 .number .inner {
    padding: 30px 10px 20px;
  }
}
.top .before-after .list.list2 .btn {
  text-align: center;
  margin-top: 40px;
}

@media screen and (max-width: 767px) {
  .top .before-after .list.list2 .btn {
    margin-top: 20px;
  }
}
.top .before-after .list.list2 .btn a {
  background-color: #fff;
  display: inline-block;
  font-weight: 900;
  padding: 14px 60px;
  border-radius: 30px;
  color: #1e2f43;
}

.top .bodymake {
  position: relative;
  overflow: hidden;
  background-position: center bottom;
  background-repeat: repeat;
  background-size: cover;
  background-image: url(../img/top-bodymake-back-img.jpg);
}

.top .bodymake .inner {
  padding: 60px;
  max-width: 800px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .top .bodymake .inner {
    padding: 40px 10px;
    max-width: 500px;
  }
}
.top .bodymake .headline {
  display: inline-block;
  border: 1px solid #fff;
  padding: 6px 60px;
  color: #fff;
  font-size: 22px;
  font-weight: 900;
  letter-spacing: 2px;
  background-color: rgba(30, 47, 67, 0.6);
}

@media screen and (max-width: 767px) {
  .top .bodymake .headline {
    padding: 6px 40px;
    font-size: 18px;
    letter-spacing: 1px;
  }
}
.top .bodymake .headline span {
  color: #fdfc37;
}

.top .bodymake .headline b {
  font-family: Century Gothic;
  font-size: 28px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .top .bodymake .headline b {
    font-size: 22px;
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.top .bodymake .ttl {
  margin: 20px 0;
}

.top .bodymake .ttl span {
  display: block;
  color: #fff;
  font-weight: 900;
  font-size: 20px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .top .bodymake .ttl span {
    font-size: 18px;
  }
}
.top .bodymake .ttl strong {
  font-family: YuGothic, "Yu Gothic";
  display: block;
  margin: 20px 0;
  font-size: 50px;
  letter-spacing: 4px;
  color: rgba(30, 47, 67, 0.6);
  -webkit-text-stroke: 2px #fff;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

@media screen and (max-width: 767px) {
  .top .bodymake .ttl strong {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    font-size: 36px;
    letter-spacing: 1px;
    -webkit-text-stroke: 1px #fff;
  }
}
.top .bodymake .ttl small {
  letter-spacing: 1px;
  display: inline-block;
  color: #fff;
  font-weight: 900;
  font-size: 12px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .top .bodymake .ttl small {
    font-size: 10px;
  }
}
.top .bodymake .ttl small:after {
  content: "";
  width: 50px;
  height: 1px;
  background-color: #fff;
  position: absolute;
  top: 50%;
  right: -70px;
  opacity: 0.6;
}

@media screen and (max-width: 767px) {
  .top .bodymake .ttl small:after {
    width: 40px;
    right: -50px;
  }
}
.top .bodymake .ttl small:before {
  content: "";
  width: 50px;
  height: 1px;
  background-color: #fff;
  position: absolute;
  top: 50%;
  left: -70px;
  opacity: 0.6;
}

@media screen and (max-width: 767px) {
  .top .bodymake .ttl small:before {
    width: 40px;
    left: -50px;
  }
}
.top .bodymake .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 30px 0;
}

.top .bodymake .list li {
  background-color: rgba(44, 168, 232, 0.7);
  width: 150px;
  height: 150px;
  position: relative;
  border-radius: 100%;
  color: #fff;
  font-weight: 900;
  font-size: 16px;
  line-height: 1.4;
  letter-spacing: 2px;
  margin: 0 10px;
}

@media screen and (max-width: 767px) {
  .top .bodymake .list li {
    width: 110px;
    height: 110px;
    font-size: 14px;
    letter-spacing: 1px;
    margin: 0 6px;
  }
}
.top .bodymake .list li span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
}

.top .bodymake .btn a {
  background-color: #fff;
  display: inline-block;
  font-weight: 900;
  padding: 14px 60px;
  border-radius: 30px;
  color: #1e2f43;
}

@media screen and (max-width: 767px) {
  .top .bodymake .btn a {
    padding: 14px 30px;
  }
}
.top .rule {
  background-color: #fafafa;
}

.top .rule .inner {
  padding: 60px 10px;
}

@media screen and (max-width: 767px) {
  .top .rule .inner {
    padding: 40px 10px;
  }
}
.top .rule h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 60px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .top .rule h2 {
    font-size: 20px;
    margin-bottom: 40px;
  }
}
.top .rule h2 span {
  font-family: Century Gothic;
  font-size: 32px;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .top .rule h2 span {
    font-size: 26px;
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.top .rule .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .top .rule .list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.top .rule .list li {
  width: 32%;
  border: 2px solid #2ca8e8;
  border-radius: 4px;
  background-color: #fff;
  padding: 10px;
}

@media screen and (max-width: 767px) {
  .top .rule .list li {
    width: 100%;
    margin-bottom: 40px;
    position: relative;
  }
}
@media screen and (max-width: 767px) {
  .top .rule .list li:last-child {
    margin-bottom: 0;
  }
}
.top .rule .list .point {
  display: block;
  width: 80px;
  height: 80px;
  background-color: #2ca8e8;
  border-radius: 100%;
  position: relative;
  margin: -50px auto 0;
}

@media screen and (max-width: 767px) {
  .top .rule .list .point {
    margin: 0;
    position: absolute;
    top: -12px;
    left: 14px;
    width: 70px;
    height: 70px;
  }
}
.top .rule .list .point:before {
  content: "";
  width: 20px;
  height: 20px;
  top: -16px;
  right: -36px;
  left: 0;
  margin: 0 auto;
  position: absolute;
  background-image: url(../img/top-date-icon-img.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

@media screen and (max-width: 767px) {
  .top .rule .list .point:before {
    right: -22px;
  }
}
.top .rule .list .date {
  color: #fff;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  font-weight: 900;
  font-size: 24px;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .top .rule .list .date {
    font-size: 20px;
  }
}
.top .rule .list .date small {
  display: block;
  line-height: 1;
  font-size: 12px;
}

@media screen and (max-width: 767px) {
  .top .rule .list .date small {
    margin-top: 2px;
  }
}
.top .rule .list h3 {
  margin: 10px 0;
  text-align: center;
  font-weight: 900;
  color: #2ca8e8;
  line-height: 1.6;
}

.top .rule .list h3 strong {
  display: block;
  font-size: 20px;
  letter-spacing: 2px;
}

.top .rule .list p {
  font-weight: 900;
  line-height: 1.5;
  font-size: 12px;
}

.top .stylist {
  background-color: #fff;
}

.top .stylist .inner {
  padding: 60px 10px;
}

@media screen and (max-width: 767px) {
  .top .stylist .inner {
    padding: 40px 10px;
  }
}
.top .stylist h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 60px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .top .stylist h2 {
    font-size: 20px;
    margin-bottom: 20px;
  }
}
.top .stylist h2 small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  display: block;
  font-size: 12px;
  margin-top: 10px;
}

@media screen and (max-width: 767px) {
  .top .stylist h2 small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.top .stylist .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
  justify-content: space-around;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 60px 0;
}

@media screen and (max-width: 767px) {
  .top .stylist .list {
    margin: 20px auto;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    max-width: 500px;
  }
}
.top .stylist .list li {
  width: 32%;
  margin: 0 0 10px 0;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: left top;
  text-align: right;
}

@media screen and (max-width: 767px) {
  .top .stylist .list li {
    width: 48%;
    background-position: -16px 50%;
  }
}
.top .stylist .list li a {
  display: block;
  position: relative;
  color: #fff;
}

.top .stylist .list .txt {
  width: 80%;
  text-align: left;
  display: inline-block;
  position: relative;
  padding: 32px 10px 20px 50px;
  background: -webkit-gradient(linear, right top, left top, color-stop(80%, #1e2f43), color-stop(86%, #1e2f43), color-stop(96%, rgba(30, 47, 67, 0.1)), to(rgba(30, 47, 67, 0)));
  background: linear-gradient(-90deg, #1e2f43 80%, #1e2f43 86%, rgba(30, 47, 67, 0.1) 96%, rgba(30, 47, 67, 0) 100%);
}

@media screen and (max-width: 767px) {
  .top .stylist .list .txt {
    width: 72%;
    padding: 32px 10px 20px 22px;
    background: -webkit-gradient(linear, right top, left top, color-stop(80%, #1e2f43), color-stop(88%, #1e2f43), color-stop(98%, rgba(30, 47, 67, 0.1)), to(rgba(30, 47, 67, 0)));
    background: linear-gradient(-90deg, #1e2f43 80%, #1e2f43 88%, rgba(30, 47, 67, 0.1) 98%, rgba(30, 47, 67, 0) 100%);
  }
}
.top .stylist .list .txt .shop {
  background-color: #2ca8e8;
  display: inline-block;
  font-size: 12px;
  padding: 2px 10px;
  position: absolute;
  top: 10px;
  right: 0;
}

@media screen and (max-width: 767px) {
  .top .stylist .list .txt .shop {
    font-size: 10px;
    padding: 2px 8px;
    top: 8px;
  }
}
.top .stylist .list .txt .name {
  font-size: 14px;
  font-size: 20px;
  font-weight: 900;
  font-style: italic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .top .stylist .list .txt .name {
    letter-spacing: 0;
    word-break: break-all;
    font-size: 14px;
  }
}
.top .stylist .list .txt small {
  font-size: 10px;
  letter-spacing: 1px;
}

.top .stylist .btn {
  text-align: center;
}

.top .stylist .btn a {
  display: inline-block;
  font-weight: 900;
  padding: 18px 40px;
  border-radius: 30px;
  color: #1e2f43;
  border: 2px solid #1e2f43;
}

@media screen and (max-width: 767px) {
  .top .stylist .btn a {
    padding: 16px 30px;
  }
}
.top .stylist.new-stylist .list li a {
  background-color: #f4f4f4;
  overflow: hidden;
}

.top .stylist.new-stylist .list .txt {
  width: 58%;
  padding: 32px 10px 20px 40px;
  background: #1e2f43;
  padding: 32px 10px 20px 20px;
}

@media screen and (max-width: 767px) {
  .top .stylist.new-stylist .list .txt {
    padding: 32px 4px 20px 6px;
  }
}
.top .stylist.new-stylist .list .txt:before {
  content: "";
  width: 30px;
  height: 100%;
  background-color: #1e2f43;
  position: absolute;
  left: -12px;
  top: 0;
  -webkit-transform: skewX(-10deg);
  -ms-transform: skewX(-10deg);
  transform: skewX(-10deg);
}

.top .stylist.new-stylist .list .txt .name {
  position: relative;
}

@media screen and (max-width: 767px) {
  .top .stylist.new-stylist .list .txt .name {
    font-size: 12px;
  }
}
.top .stylist.new-stylist .list .txt small {
  position: relative;
}

.top .stylist.new-stylist .list .img {
  width: 30%;
  position: absolute;
  bottom: 0;
  left: 5%;
}

@media screen and (max-width: 767px) {
  .top .stylist.new-stylist .list .img {
    width: 40%;
    left: 2%;
    max-width: 78px;
  }
}
.top .shop {
  background-color: #f4f4f4;
}

.top .shop .inner {
  padding: 60px 10px;
}

@media screen and (max-width: 767px) {
  .top .shop .inner {
    padding: 40px 10px;
  }
}
.top .shop h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 60px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .top .shop h2 {
    font-size: 20px;
    margin-bottom: 20px;
  }
}
.top .shop h2 small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  display: block;
  font-size: 12px;
  margin-top: 10px;
}

@media screen and (max-width: 767px) {
  .top .shop h2 small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.top .shop .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

@media screen and (max-width: 767px) {
  .top .shop .list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.top .shop .list li {
  width: 48%;
  margin-bottom: 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .top .shop .list li {
    width: 100%;
    margin-bottom: 30px;
  }
}
@media screen and (max-width: 767px) {
  .top .shop .list li:last-child {
    margin-bottom: 0;
  }
}
.top .shop .list .img {
  width: 40%;
  height: 140px;
  overflow: hidden;
  position: relative;
}

.top .shop .list .img img {
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  position: relative;
  height: 100%;
}

@media screen and (max-width: 767px) {
  .top .shop .list .img img {
    height: 130px;
  }
}
.top .shop .list .img .no-img {
  position: relative;
  height: 100%;
  background-color: #1e2f43;
}

.top .shop .list .img .no-img span {
  color: #fff;
  font-weight: 900;
  font-size: 16px;
  font-family: Century Gothic;
  display: block;
  text-align: center;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  padding: 0 10px;
}

.top .shop .list .txt {
  width: 56%;
}

.top .shop .list .txt .access {
  font-weight: 900;
  font-size: 12px;
  line-height: 1.5;
}

.top .shop .list .txt .name {
  margin: 10px 0;
}

.top .shop .list .txt .name a {
  font-weight: 900;
  color: #2ca8e8;
}

.top .shop .list .txt .detail {
  margin: 10px 0;
}

.top .shop .list .txt .detail p {
  margin-bottom: 2px;
  font-size: 12px;
  font-weight: 900;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.top .shop .list .txt .detail p span {
  display: inline-block;
  background-color: #1e2f43;
  color: #fff;
  padding: 2px 6px;
  font-weight: 400;
  width: 60px;
  text-align: center;
  margin-right: 4px;
}

.top .shop .list .txt .detail p b {
  display: inline-block;
  width: 190px;
}

.top .shop .list .txt .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-top: 20px;
}

@media screen and (max-width: 767px) {
  .top .shop .list .txt .btn {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    margin-top: 10px;
  }
}
.top .shop .list .txt .btn .left, .top .shop .list .txt .btn .right {
  width: 49%;
  border: 2px solid #1e2f43;
  border-radius: 30px;
  overflow: hidden;
}

.top .shop .list .txt .btn .left a, .top .shop .list .txt .btn .right a {
  display: block;
  background-color: #fff;
  color: #1e2f43;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .top .shop .list .txt .btn .left a, .top .shop .list .txt .btn .right a {
    font-size: 12px;
  }
}
.top .shop .list .txt .btn .right {
  text-align: center;
}

.top .shop .list .txt .btn .right a {
  padding: 8px 0;
}

.top .shop .list .txt .btn .left a {
  background-image: url(../img/top-btn-icon3-img.png);
  background-size: 18px;
  background-position: 10px 50%;
  background-repeat: no-repeat;
  padding: 8px 0 8px 34px;
}

@media screen and (max-width: 767px) {
  .top .shop .list .txt .btn .left a {
    background-size: 14px;
    background-position: 8px 50%;
    padding: 8px 0 8px 26px;
  }
}
.top .shop .box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .top .shop .box {
    display: block;
    position: relative;
  }
}
.top .shop .box .img {
  width: 45%;
  padding: 0 20px 0 0;
}

@media screen and (max-width: 767px) {
  .top .shop .box .img {
    padding: 0;
    width: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translateY(-50%) translateX(-50%);
    -ms-transform: translateY(-50%) translateX(-50%);
    transform: translateY(-50%) translateX(-50%);
  }
}
.top .shop .box .box-list {
  width: 55%;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .top .shop .box .box-list {
    width: 100%;
    position: relative;
    z-index: 1;
  }
}
.top .shop .box .box-list h1 {
  font-size: 16px;
  display: inline-block;
  position: relative;
  margin-bottom: 20px;
}

@media screen and (max-width: 767px) {
  .top .shop .box .box-list h1 {
    font-size: 14px;
  }
}
.top .shop .box .box-list h1:before {
  content: "";
  width: 1px;
  height: 26px;
  background-color: #a89859;
  position: absolute;
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg);
  left: -12px;
}

.top .shop .box .box-list h1:after {
  content: "";
  width: 1px;
  height: 26px;
  background-color: #a89859;
  position: absolute;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  right: -12px;
}

.top .shop .box .box-list .area {
  text-align: left;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 10px;
}

.top .shop .box .box-list .area:last-child {
  margin-bottom: 0;
}

.top .shop .box .box-list .area .area-name {
  width: 14%;
}

@media screen and (max-width: 767px) {
  .top .shop .box .box-list .area .area-name {
    width: 16%;
  }
}
.top .shop .box .box-list .area .area-name span {
  font-size: 16px;
  margin-top: 2px;
  display: inline-block;
}

@media screen and (max-width: 767px) {
  .top .shop .box .box-list .area .area-name span {
    font-size: 14px;
    margin-top: 6px;
  }
}
.top .shop .box .box-list .area .shop-name {
  width: 86%;
  padding: 0 6px;
}

@media screen and (max-width: 767px) {
  .top .shop .box .box-list .area .shop-name {
    width: 84%;
  }
}
.top .shop .box .box-list .area .shop-name span {
  display: inline-block;
  margin: 2px 0;
}

.top .shop .box .box-list .area .shop-name a {
  display: block;
  border: 1px solid #a89859;
  border-radius: 4px;
  background-color: #fff;
  color: #a89859;
  font-size: 12px;
  padding: 4px 8px;
}

@media screen and (max-width: 767px) {
  .top .shop .box .box-list .area .shop-name a {
    padding: 4px 6px;
  }
}
.top .shop .shop-btn {
  text-align: center;
  margin-top: 40px;
}

.top .shop .shop-btn a {
  display: inline-block;
  color: #1e2f43;
  font-weight: 600;
  border: 2px solid #1e2f43;
  padding: 16px 40px;
  border-radius: 30px;
}

@media screen and (max-width: 767px) {
  .top .shop .shop-btn a {
    padding: 14px 40px;
  }
}
.top .price {
  background-color: #fff;
}

.top .price .inner {
  padding: 60px 10px;
}

@media screen and (max-width: 767px) {
  .top .price .inner {
    padding: 40px 0;
  }
}
.top .price h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 60px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .top .price h2 {
    font-size: 20px;
    margin-bottom: 20px;
    padding: 0 10px;
  }
}
.top .price h2 small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  display: block;
  font-size: 12px;
  margin-top: 10px;
}

@media screen and (max-width: 767px) {
  .top .price h2 small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.top .price .tab-area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  cursor: pointer;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}

.top .price .tab-area .tab {
  width: 24.6%;
  text-align: center;
  color: white;
  border-radius: 6px 6px 0 0;
  background-color: #1e2f43;
}

@media screen and (max-width: 767px) {
  .top .price .tab-area .tab {
    width: 23.3333333333%;
  }
}
.top .price .tab-area .tab.other {
  padding: 10px 0;
}

.top .price .tab-area .tab.other .name {
  font-weight: 900;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .top .price .tab-area .tab.other .name {
    font-size: 12px;
  }
}
.top .price .tab-area .tab.other .name small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  display: block;
  font-size: 10px;
  margin-top: 2px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .top .price .tab-area .tab.other .name small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    letter-spacing: 0;
  }
}
.top .price .tab-area .tab.special {
  padding: 10px 10px 10px 30px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .top .price .tab-area .tab.special {
    padding: 10px 2px;
  }
}
.top .price .tab-area .tab.special .point {
  background-color: #fff268;
  display: block;
  width: 50px;
  height: 50px;
  border-radius: 100%;
  color: #000;
  font-weight: 900;
  position: absolute;
  top: -10px;
  left: 10px;
}

@media screen and (max-width: 767px) {
  .top .price .tab-area .tab.special .point {
    width: 40px;
    height: 40px;
    top: -30px;
    left: 4px;
  }
}
.top .price .tab-area .tab.special .point span {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  font-size: 12px;
}

@media screen and (max-width: 767px) {
  .top .price .tab-area .tab.special .point span {
    font-size: 10px;
  }
}
.top .price .tab-area .tab.special .point span b {
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  .top .price .tab-area .tab.special .point span b {
    font-size: 10px;
  }
}
.top .price .tab-area .tab.special .name {
  font-weight: 900;
  font-size: 16px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .top .price .tab-area .tab.special .name {
    font-size: 12px;
    letter-spacing: 0;
  }
}
.top .price .tab-area .tab.special .name small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #fff268;
  display: block;
  font-size: 10px;
  margin-top: 2px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .top .price .tab-area .tab.special .name small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    letter-spacing: 0;
  }
}
.top .price .tab-area .tab.active {
  background-color: #ff373c;
  padding: 16px 10px 16px 10px;
}

@media screen and (max-width: 767px) {
  .top .price .tab-area .tab.active {
    padding: 12px 2px 12px 2px;
    width: 29%;
  }
}
.top .price .tab-area .tab.active .name {
  font-size: 18px;
}

@media screen and (max-width: 767px) {
  .top .price .tab-area .tab.active .name {
    font-size: 12px;
  }
}
.top .price .tab-area .tab.active.special {
  padding: 16px 10px 16px 30px;
}

@media screen and (max-width: 767px) {
  .top .price .tab-area .tab.active.special {
    padding: 12px 2px 12px 2px;
    width: 29%;
  }
}
.top .price .content-area .content {
  display: none;
  background-color: #f4f4f4;
  padding: 20px 40px 30px 40px;
}

@media screen and (max-width: 767px) {
  .top .price .content-area .content {
    padding: 20px;
  }
}
.top .price .content-area .content .name {
  text-align: center;
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 1px;
  line-height: 1.6;
  margin: 10px 0 20px 0;
}

@media screen and (max-width: 767px) {
  .top .price .content-area .content .name {
    font-size: 14px;
    letter-spacing: 0;
    margin: 0 0 20px 0;
  }
}
.top .price .content-area .content .table {
  width: 100%;
  margin: 20px 0 10px;
  font-weight: 900;
}

.top .price .content-area .content .table th {
  background-color: #f4fbfe;
  color: #2ca8e8;
  padding: 14px 0;
  letter-spacing: 1px;
  width: 40%;
  border-bottom: 2px solid #f4f4f4;
}

@media screen and (max-width: 767px) {
  .top .price .content-area .content .table th {
    padding: 10px 0;
    width: 30%;
    font-size: 12px;
  }
}
.top .price .content-area .content .table td {
  font-family: Century Gothic;
  background-color: #fff;
  width: 60%;
  text-align: center;
  padding: 20px 10px;
  border-bottom: 2px solid #f4f4f4;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .top .price .content-area .content .table td {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    width: 70%;
    padding: 14px 10px;
    font-size: 14px;
  }
}
.top .price .content-area .content .table td .font-small {
  font-size: 12px;
  display: inline-block;
  position: relative;
  top: -1px;
}

.top .price .content-area .content .table td .border {
  text-decoration: line-through;
}

.top .price .content-area .content .table td .border .font-small {
  font-size: 12px;
  display: inline-block;
  text-decoration: line-through;
  position: relative;
  top: -1px;
}

.top .price .content-area .content .table td .color {
  color: #ff373c;
}

.top .price .content-area .content .table td .color .font-small {
  font-size: 12px;
  display: inline-block;
  position: relative;
  top: -1px;
}

.top .price .content-area .content .attention p {
  font-weight: 900;
  font-size: 12px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .top .price .content-area .content .attention p {
    font-size: 10px;
  }
}
.top .price .content-area .content.show {
  display: block;
}

.top .price .shop-notice {
  margin: 40px 0 0;
}

@media screen and (max-width: 767px) {
  .top .price .shop-notice {
    padding: 0 10px;
    margin: 20px 0 0;
  }
}
.top .price .shop-notice h2 {
  color: #1e2f43;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: 2px;
  padding-bottom: 10px;
  margin: 20px 0;
  position: relative;
  background-repeat: repeat-x;
  text-align: left;
}

@media screen and (max-width: 767px) {
  .top .price .shop-notice h2 {
    font-size: 18px;
  }
}
.top .price .shop-notice h2:after {
  content: "";
  width: 100%;
  height: 4px;
  bottom: 0;
  left: 0;
  position: absolute;
  background-image: url(../img/page-h2-img.png);
  background-size: contain;
  background-position: 0 100%;
}

@media screen and (max-width: 767px) {
  .top .price .shop-notice h2:after {
    background-size: auto;
  }
}
.top .price .shop-notice .txt {
  background-color: #f4fbfe;
  padding: 20px;
  color: #1e2f43;
}

.top .price .shop-notice .txt p {
  line-height: 1.9;
}

.top .price .shop-notice .txt b {
  display: inline-block;
}

.top .price .shop-notice .txt b span {
  width: 10px;
  height: 10px;
  display: inline-block;
  background-color: #1e2f43;
  margin-right: 6px;
}

.top .news {
  background-color: #f4f4f4;
}

.top .news .inner {
  padding: 60px 10px;
}

@media screen and (max-width: 767px) {
  .top .news .inner {
    padding: 40px 10px;
  }
}
.top .news h2 {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  font-size: 28px;
  letter-spacing: 1px;
  margin-bottom: 40px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .top .news h2 {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    font-size: 22px;
    margin-bottom: 20px;
  }
}
.top .news .list {
  max-width: 460px;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .top .news .list {
    max-width: 400px;
  }
}
.top .news .dl-box {
  margin-bottom: 20px;
  position: relative;
  font-weight: 900;
  font-size: 12px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.top .news .dl-box dt {
  font-family: Century Gothic;
  width: 20%;
  padding-right: 10px;
  color: #2ca8e8;
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  .top .news .dl-box dt {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    width: 30%;
    font-size: 12px;
  }
}
.top .news .dl-box dd {
  width: 80%;
}

@media screen and (max-width: 767px) {
  .top .news .dl-box dd {
    width: 70%;
  }
}
.top .news .dl-box dd a {
  color: #000;
}

.top .news .btn {
  text-align: center;
  margin-top: 60px;
}

@media screen and (max-width: 767px) {
  .top .news .btn {
    margin-top: 40px;
  }
}
.top .news .btn a {
  display: inline-block;
  font-weight: 900;
  padding: 18px 60px;
  border-radius: 30px;
  color: #1e2f43;
  border: 2px solid #1e2f43;
}

@media screen and (max-width: 767px) {
  .top .news .btn a {
    padding: 16px 40px;
  }
}
.top .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.top .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .top .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.top .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .top .btn-area.bottom-area .btn {
    margin-top: 0;
  }
}
.top .btn-area.bottom-area .btn .left, .top .btn-area.bottom-area .btn .right {
  width: 49%;
}

.top .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .top .btn-area.bottom-area .btn .left a {
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
    background-image: url(../img/top-btn-icon1-img.svg);
  }
}
.top .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .top .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
}
.top .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .top .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.top .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .top .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 40px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.top .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .top .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}
.breadcrumbs-list {
  background-color: #f4f4f4;
}

.breadcrumbs-list .inner {
  padding: 6px 10px;
  color: #a9a9a9;
  font-weight: 900;
  font-size: 10px;
}

.breadcrumbs-list span.img {
  width: 14px;
  display: inline-block;
  margin-right: 6px;
}

.breadcrumbs-list a {
  color: #a9a9a9;
  font-weight: 900;
  font-size: 10px;
}

.contact-page .fv .inner {
  padding: 0 10px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .contact-page .fv .inner {
    padding: 0;
    max-width: 500px;
  }
}
.contact-page .fv .fv-banner {
  background-color: #00dcea;
  padding: 10px;
  text-align: center;
}

.contact-page .fv .fv-banner img {
  width: 300px;
}

.contact-page .fv .notice-txt {
  position: relative;
  margin-top: 40px;
  border: 2px solid #cd8392;
  padding: 10px;
  font-size: 12px;
  line-height: 1.6;
  background-color: #fff0f1;
  font-weight: 600;
}

@media screen and (max-width: 767px) {
  .contact-page .fv .notice-txt {
    width: 95%;
    margin: 30px auto 10px;
    font-size: 10px;
  }
}
.contact-page .fv .notice-txt span {
  display: inline-block;
  width: 20px;
  height: 20px;
  position: absolute;
  top: -14px;
  left: 12px;
  border-radius: 50%;
  background-color: #ff0023;
}

.contact-page .fv .notice-txt span img {
  width: 12px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
}

.contact-page .btn-area.top-area .inner {
  padding: 26px 10px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .inner {
    padding: 0;
    max-width: 500px;
  }
}
.contact-page .btn-area.top-area .campaign {
  margin-top: 10px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
  }
}
.contact-page .btn-area.top-area .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.contact-page .btn-area.top-area .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.contact-page .btn-area.top-area .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .campaign .img span {
    font-size: 12px;
  }
}
.contact-page .btn-area.top-area .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .campaign .img span b {
    font-size: 10px;
  }
}
.contact-page .btn-area.top-area .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.contact-page .btn-area.top-area .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.contact-page .btn-area.top-area .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.contact-page .btn-area.top-area .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .campaign .txt .cost {
    font-size: 16px;
  }
}
.contact-page .btn-area.top-area .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.contact-page .btn-area.top-area .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.contact-page .btn-area.top-area .attention {
  margin-top: 10px;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .attention {
    padding: 0 10px;
  }
}
.contact-page .btn-area.top-area .attention p {
  color: #1e2f43;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.contact-page .form-area .inner {
  max-width: 800px;
  padding: 40px 100px 80px 40px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .contact-page .form-area .inner {
    max-width: 500px;
    padding: 0 0 40px;
  }
}
.contact-page .form-area .box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

@media screen and (max-width: 767px) {
  .contact-page .form-area .box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
    margin-bottom: 0;
  }
}
.contact-page .form-area .box .half {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0 0 20px 0;
}

@media screen and (max-width: 767px) {
  .contact-page .form-area .box .half {
    width: 100%;
    margin-bottom: 10px;
  }
}
.contact-page .form-area .box .all {
  width: 100%;
}

.contact-page .form-area .box .ttl {
  font-weight: 900;
  color: #1e2f43;
  padding: 14px 10px 8px 10px;
  position: relative;
  width: 30%;
  text-align: center;
  text-indent: -20px;
}

@media screen and (max-width: 767px) {
  .contact-page .form-area .box .ttl {
    font-size: 12px;
    padding: 10px 20px 0 10px;
    width: 36%;
    text-indent: 0;
  }
}
.contact-page .form-area .box .ttl .req {
  display: inline-block;
  background-color: #ff363c;
  padding: 6px;
  color: #fff;
  line-height: 1;
  font-size: 10px;
  margin-left: 4px;
  position: absolute;
  right: 12px;
  text-indent: 0;
  border-radius: 4px;
}

@media screen and (max-width: 767px) {
  .contact-page .form-area .box .ttl .req {
    font-size: 10px;
    padding: 4px;
    right: 0;
    top: 10px;
  }
}
.contact-page .form-area .box .ttl .not-req {
  display: inline-block;
  background-color: #1e2f43;
  padding: 6px;
  color: #fff;
  line-height: 1;
  font-size: 10px;
  margin-left: 4px;
  position: absolute;
  right: 12px;
  text-indent: 0;
  border-radius: 4px;
}

@media screen and (max-width: 767px) {
  .contact-page .form-area .box .ttl .not-req {
    font-size: 10px;
    padding: 4px;
    right: 0;
  }
}
.contact-page .form-area .box .input-area {
  width: 70%;
  position: relative;
}

@media screen and (max-width: 767px) {
  .contact-page .form-area .box .input-area {
    padding: 0 10px;
    width: 64%;
  }
}
.contact-page .form-area .box .input-area input[type=text], .contact-page .form-area .box .input-area input[type=tel], .contact-page .form-area .box .input-area input[type=email], .contact-page .form-area .box .input-area input[type=date] {
  width: 100%;
  height: 50px;
  padding: 10px;
  border-radius: 4px;
  color: #1e2f43;
  border: 2px solid #ddd;
}

.contact-page .form-area .box .input-area input[type=text]::-webkit-input-placeholder, .contact-page .form-area .box .input-area input[type=tel]::-webkit-input-placeholder, .contact-page .form-area .box .input-area input[type=email]::-webkit-input-placeholder, .contact-page .form-area .box .input-area input[type=date]::-webkit-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.contact-page .form-area .box .input-area input[type=text]:-ms-input-placeholder, .contact-page .form-area .box .input-area input[type=tel]:-ms-input-placeholder, .contact-page .form-area .box .input-area input[type=email]:-ms-input-placeholder, .contact-page .form-area .box .input-area input[type=date]:-ms-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.contact-page .form-area .box .input-area input[type=text]::-ms-input-placeholder, .contact-page .form-area .box .input-area input[type=tel]::-ms-input-placeholder, .contact-page .form-area .box .input-area input[type=email]::-ms-input-placeholder, .contact-page .form-area .box .input-area input[type=date]::-ms-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.contact-page .form-area .box .input-area input[type=text]::placeholder, .contact-page .form-area .box .input-area input[type=tel]::placeholder, .contact-page .form-area .box .input-area input[type=email]::placeholder, .contact-page .form-area .box .input-area input[type=date]::placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .contact-page .form-area .box .input-area input[type=text], .contact-page .form-area .box .input-area input[type=tel], .contact-page .form-area .box .input-area input[type=email], .contact-page .form-area .box .input-area input[type=date] {
    height: 45px;
  }
}
.contact-page .form-area .box .input-area input[type=radio] {
  margin: 0 6px;
  vertical-align: text-bottom;
}

.contact-page .form-area .box .input-area select {
  width: 70%;
  height: 50px;
  padding: 10px;
  border-radius: 4px;
  color: #a9a9a9;
  border: 2px solid #ddd;
}

@media screen and (max-width: 767px) {
  .contact-page .form-area .box .input-area select {
    height: 45px;
    width: 100%;
  }
}
.contact-page .form-area .box .input-area textarea {
  width: 100%;
  height: 160px;
  padding: 10px;
  border-radius: 4px;
  font-weight: 900;
  color: #1e2f43;
  border: 2px solid #ddd;
}

.contact-page .form-area .box .input-area textarea::-webkit-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.contact-page .form-area .box .input-area textarea:-ms-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.contact-page .form-area .box .input-area textarea::-ms-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.contact-page .form-area .box .input-area textarea::placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.contact-page .form-area .box .input-area select.req {
  border: 2px solid #ddd;
  font-weight: 900;
  background-color: #ffe9e8;
}

.contact-page .form-area .box .input-area input.req[type=text], .contact-page .form-area .box .input-area input.req[type=tel], .contact-page .form-area .box .input-area input.req[type=email], .contact-page .form-area .box .input-area input.req[type=date] {
  border: 2px solid #ddd;
  font-weight: 900;
  background-color: #ffe9e8;
}

.contact-page .form-area .box .input-area.radio {
  padding-top: 14px;
}

@media screen and (max-width: 767px) {
  .contact-page .form-area .box .input-area.radio {
    padding-top: 10px;
  }
}
.contact-page .form-area .box .attention {
  width: 100%;
  margin-top: 10px;
  color: #1e2f43;
  font-weight: 900;
  font-size: 12px;
}

@media screen and (max-width: 767px) {
  .contact-page .form-area .box .attention {
    padding: 0 10px;
  }
}
.contact-page .form-area .box .select-point.all {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 12px;
  position: absolute;
  top: 18px;
  line-height: 1;
  right: 34%;
  display: block;
}

@media screen and (max-width: 767px) {
  .contact-page .form-area .box .select-point.all {
    font-size: 10px;
    right: 10%;
  }
}
.contact-page .form-area .btn {
  text-align: center;
  margin-top: 40px;
}

.contact-page .form-area .btn input[type=submit] {
  background-color: #ff363c;
  color: #fff;
  font-weight: 900;
  padding: 20px 60px;
  display: inline-block;
  border-radius: 6px;
  background-image: url(../img/contact-btn-icon1.png);
  background-size: 22px;
  background-position: 94% 50%;
  background-repeat: no-repeat;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
}

.contact-page .form-area .fix-btn-wrap {
  width: 180px;
  position: absolute;
  top: 0;
  right: -90px;
}

.contact-page .form-area .fix-btn-wrap .line {
  border-radius: 4px;
  margin-bottom: 10px;
  overflow: hidden;
}

.contact-page .form-area .fix-btn-wrap .line a {
  display: block;
  background-color: #00b900;
  text-align: center;
  padding: 12px 10px;
  color: #fff;
  font-weight: 900;
  font-size: 12px;
  letter-spacing: 1px;
  background-image: url(../img/line-icon-img.png), url(../img/icon1-img.png);
  background-size: 18px, 10px;
  background-position: 14px 50%, 90% 53%;
}

.contact-page .form-area .fix-btn-wrap .action-btn {
  border-radius: 4px;
  overflow: hidden;
  background-color: #ff363c;
  text-align: center;
}

.contact-page .form-area .fix-btn-wrap .action-btn .count {
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  line-height: 1.5;
  padding: 8px 10px;
}

.contact-page .form-area .fix-btn-wrap .action-btn .count .yellow {
  color: #fff610;
}

.contact-page .form-area .fix-btn-wrap .action-btn .count strong {
  letter-spacing: 1px;
  margin-top: 2px;
  display: inline-block;
}

.contact-page .form-area .fix-btn-wrap .action-btn .count .remaining {
  display: inline-block;
  margin: 0 4px;
  color: #fff610;
  font-size: 14px;
  -webkit-animation: flash 2s linear infinite;
  animation: flash 2s linear infinite;
}

.contact-page .form-area .fix-btn-wrap .action-btn .complete-btn {
  display: none;
}

.contact-page .form-area .fix-btn-wrap .action-btn .complete-btn button {
  display: block;
  padding: 20px 28px 20px 6px;
  font-size: 12px;
  color: #fff;
  font-weight: 900;
  position: relative;
  background-image: url(../img/icon1-img.png);
  background-size: 10px;
  background-position: 90% 53%;
  width: 100%;
}

@media screen and (max-width: 767px) {
  .contact-page .top-line {
    padding: 14px 10px;
    max-width: 500px;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .contact-page .top-line .line {
    border-radius: 4px;
    margin-bottom: 10px;
    overflow: hidden;
  }
}
@media screen and (max-width: 767px) {
  .contact-page .top-line .line a {
    display: block;
    background-color: #00b900;
    text-align: center;
    padding: 20px 10px;
    color: #fff;
    font-weight: 900;
    font-size: 16px;
    letter-spacing: 1px;
    background-image: url(../img/line-icon-img.png), url(../img/icon1-img.png);
    background-size: 32px, 10px;
    background-position: 14px 50%, 90% 53%;
  }
}
@media screen and (max-width: 767px) {
  .contact-page .action-btn {
    position: fixed;
    width: 100%;
    bottom: 0;
    left: 0;
    background-color: #ff363c;
    z-index: 1;
  }
}
@media screen and (max-width: 767px) {
  .contact-page .action-btn .count {
    text-align: center;
    padding: 20px;
    font-size: 16px;
    font-weight: 900;
    letter-spacing: 1px;
    color: #fff;
  }
}
@media screen and (max-width: 767px) {
  .contact-page .action-btn .count .yellow {
    color: #fff610;
  }
}
@media screen and (max-width: 767px) {
  .contact-page .action-btn .count .remaining {
    color: #fff610;
    display: inline-block;
    margin: 0 2px;
    -webkit-animation: flash 2s linear infinite;
    animation: flash 2s linear infinite;
  }
}
@media screen and (max-width: 767px) {
  .contact-page .action-btn .complete-btn {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .contact-page .action-btn .complete-btn button {
    display: block;
    text-align: center;
    width: 100%;
    padding: 20px;
    color: #fff;
    font-weight: 900;
    background-image: url(../img/icon1-img.png);
    background-size: 10px;
    background-position: 90% 53%;
  }
}
@-webkit-keyframes flash {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes flash {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.contact-page .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.contact-page .btn-area.bottom-area .inner {
  padding: 10px;
}

.contact-page .btn-area.bottom-area .btn {
  text-align: center;
}

.contact-page .btn-area.bottom-area .btn a {
  background-color: #5fe536;
  display: inline-block;
  padding: 18px 80px;
  color: #fff;
  font-weight: 900;
  letter-spacing: 1px;
  border-radius: 4px;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.bottom-area .btn a {
    padding: 18px 60px;
  }
}
.company-contact .fv {
  background-image: url(../img/company-contact-fv-back-img.png);
  background-size: cover;
  background-position: center top;
}

.company-contact .fv .inner {
  padding: 80px 0;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .company-contact .fv .inner {
    padding: 60px 10px;
  }
}
.company-contact .fv h1 {
  color: #1e2f43;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .company-contact .fv h1 {
    font-size: 22px;
  }
}
.company-contact .form-area .inner {
  max-width: 800px;
  padding: 40px 100px 80px 40px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .company-contact .form-area .inner {
    max-width: 500px;
    padding: 0 0 40px;
  }
}
.company-contact .form-area .box {
  margin: 0 0 20px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

@media screen and (max-width: 767px) {
  .company-contact .form-area .box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
    margin-bottom: 0;
  }
}
.company-contact .form-area .box .half {
  width: 48%;
}

@media screen and (max-width: 767px) {
  .company-contact .form-area .box .half {
    width: 100%;
    margin-bottom: 20px;
  }
}
.company-contact .form-area .box .all {
  width: 100%;
}

.company-contact .form-area .box .ttl {
  margin-bottom: 10px;
  font-weight: 900;
  color: #1e2f43;
  padding: 8px 10px 8px 16px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .company-contact .form-area .box .ttl {
    background-color: #1e2f43;
    color: #fff;
    margin-bottom: 20px;
  }
}
.company-contact .form-area .box .ttl:before {
  content: "";
  width: 8px;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background-color: #1e2f43;
  border-radius: 4px;
}

@media screen and (max-width: 767px) {
  .company-contact .form-area .box .ttl:before {
    content: none;
  }
}
.company-contact .form-area .box .ttl .req {
  display: inline-block;
  background-color: #ff363c;
  padding: 6px 12px;
  color: #fff;
  line-height: 1;
  font-size: 10px;
  -webkit-box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
  box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
  margin-left: 4px;
}

@media screen and (max-width: 767px) {
  .company-contact .form-area .box .ttl .req {
    font-size: 12px;
  }
}
.company-contact .form-area .box .ttl .not-req {
  display: inline-block;
  background-color: #1e2f43;
  padding: 6px 12px;
  color: #fff;
  line-height: 1;
  font-size: 10px;
  -webkit-box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
  box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
  margin-left: 4px;
}

@media screen and (max-width: 767px) {
  .company-contact .form-area .box .ttl .not-req {
    font-size: 12px;
  }
}
@media screen and (max-width: 767px) {
  .company-contact .form-area .box .ttl.not {
    background-color: #d6e9ff;
    color: #1e2f43;
  }
}
.company-contact .form-area .box .input-area {
  position: relative;
}

@media screen and (max-width: 767px) {
  .company-contact .form-area .box .input-area {
    padding: 0 10px;
  }
}
.company-contact .form-area .box .input-area input[type=text], .company-contact .form-area .box .input-area input[type=tel], .company-contact .form-area .box .input-area input[type=email], .company-contact .form-area .box .input-area input[type=date] {
  width: 100%;
  height: 50px;
  padding: 10px;
  border-radius: 4px;
  color: #1e2f43;
  border: 2px solid #1e2f43;
  -webkit-box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
  box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
}

.company-contact .form-area .box .input-area input[type=text]::-webkit-input-placeholder, .company-contact .form-area .box .input-area input[type=tel]::-webkit-input-placeholder, .company-contact .form-area .box .input-area input[type=email]::-webkit-input-placeholder, .company-contact .form-area .box .input-area input[type=date]::-webkit-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.company-contact .form-area .box .input-area input[type=text]:-ms-input-placeholder, .company-contact .form-area .box .input-area input[type=tel]:-ms-input-placeholder, .company-contact .form-area .box .input-area input[type=email]:-ms-input-placeholder, .company-contact .form-area .box .input-area input[type=date]:-ms-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.company-contact .form-area .box .input-area input[type=text]::-ms-input-placeholder, .company-contact .form-area .box .input-area input[type=tel]::-ms-input-placeholder, .company-contact .form-area .box .input-area input[type=email]::-ms-input-placeholder, .company-contact .form-area .box .input-area input[type=date]::-ms-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.company-contact .form-area .box .input-area input[type=text]::placeholder, .company-contact .form-area .box .input-area input[type=tel]::placeholder, .company-contact .form-area .box .input-area input[type=email]::placeholder, .company-contact .form-area .box .input-area input[type=date]::placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .company-contact .form-area .box .input-area input[type=text], .company-contact .form-area .box .input-area input[type=tel], .company-contact .form-area .box .input-area input[type=email], .company-contact .form-area .box .input-area input[type=date] {
    height: 45px;
    border: 2px solid #d6e9ff;
  }
}
.company-contact .form-area .box .input-area select {
  width: 70%;
  height: 50px;
  padding: 10px;
  border-radius: 4px;
  color: #a9a9a9;
  border: 2px solid #1e2f43;
  -webkit-box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
  box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
}

@media screen and (max-width: 767px) {
  .company-contact .form-area .box .input-area select {
    height: 45px;
    border: 2px solid #d6e9ff;
  }
}
.company-contact .form-area .box .input-area textarea {
  width: 100%;
  height: 160px;
  padding: 10px;
  border-radius: 4px;
  font-weight: 900;
  color: #1e2f43;
  border: 2px solid #1e2f43;
  -webkit-box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
  box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
}

.company-contact .form-area .box .input-area textarea::-webkit-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.company-contact .form-area .box .input-area textarea:-ms-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.company-contact .form-area .box .input-area textarea::-ms-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.company-contact .form-area .box .input-area textarea::placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .company-contact .form-area .box .input-area textarea {
    border: 2px solid #d6e9ff;
  }
}
.company-contact .form-area .box .input-area select.req {
  border: 2px solid #ff363c;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .company-contact .form-area .box .input-area select.req {
    border: 2px solid #1e2f43;
  }
}
.company-contact .form-area .box .input-area input.req[type=text], .company-contact .form-area .box .input-area input.req[type=tel], .company-contact .form-area .box .input-area input.req[type=email], .company-contact .form-area .box .input-area input.req[type=date] {
  font-weight: 900;
  border: 2px solid #ff363c;
}

@media screen and (max-width: 767px) {
  .company-contact .form-area .box .input-area input.req[type=text], .company-contact .form-area .box .input-area input.req[type=tel], .company-contact .form-area .box .input-area input.req[type=email], .company-contact .form-area .box .input-area input.req[type=date] {
    border: 2px solid #1e2f43;
  }
}
.company-contact .form-area .box .attention {
  width: 100%;
  margin-top: 10px;
  color: #1e2f43;
  font-weight: 900;
  font-size: 12px;
}

@media screen and (max-width: 767px) {
  .company-contact .form-area .box .attention {
    padding: 0 10px;
  }
}
.company-contact .form-area .box .select-point.all {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 12px;
  position: absolute;
  top: 18px;
  line-height: 1;
  right: 34%;
  display: block;
}

.company-contact .form-area .btn {
  text-align: center;
  margin-top: 40px;
}

.company-contact .form-area .btn input[type=submit] {
  background-color: #ff363c;
  color: #fff;
  font-weight: 900;
  padding: 20px 60px;
  display: inline-block;
  border-radius: 6px;
  background-image: url(../img/contact-btn-icon1.png);
  background-size: 22px;
  background-position: 94% 50%;
  background-repeat: no-repeat;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
}

.company-contact .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.company-contact .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .company-contact .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.company-contact .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .company-contact .btn-area.bottom-area .btn {
    margin-top: 0;
  }
}
.company-contact .btn-area.bottom-area .btn .left, .company-contact .btn-area.bottom-area .btn .right {
  width: 49%;
}

.company-contact .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .company-contact .btn-area.bottom-area .btn .left a {
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
    background-image: url(../img/top-btn-icon1-img.svg);
  }
}
.company-contact .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .company-contact .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
}
.company-contact .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .company-contact .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.company-contact .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .company-contact .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.company-contact .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .company-contact .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}
.course-page .fv {
  background-color: #00aaef;
  position: relative;
}

.course-page .fv .inner {
  max-width: 660px;
  padding: 60px 100px;
  background-image: url(../img/price-fv-left-img.png), url(../img/price-fv-right-img.png);
  background-size: 68px, 70px;
  background-position: 0% 50%, 100% 50%;
}

@media screen and (max-width: 767px) {
  .course-page .fv .inner {
    padding: 60px 10px 30px;
    position: relative;
    background-image: url(../img/price-fv-right-img.png);
    background-size: 60px;
    background-position: 98% 100%;
    max-width: 500px;
  }
}
@media screen and (max-width: 767px) {
  .course-page .fv .txt {
    position: relative;
    z-index: 1;
    margin-bottom: 40px;
  }
}
.course-page .fv .headline {
  text-align: center;
}

@media screen and (max-width: 767px) {
  .course-page .fv .headline {
    text-align: left;
    padding-left: 44px;
  }
}
.course-page .fv .headline span {
  color: #fff;
  font-weight: 900;
  border-bottom: 2px solid #fff;
  display: inline-block;
  margin-bottom: 20px;
  padding-bottom: 4px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .course-page .fv .headline span {
    font-size: 16px;
  }
}
.course-page .fv h1 {
  color: #fff;
  font-weight: 900;
  letter-spacing: 2px;
  font-size: 32px;
  line-height: 1.2;
  font-style: italic;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .course-page .fv h1 {
    font-size: 26px;
    letter-spacing: 0;
    text-align: left;
  }
}
.course-page .fv h1 span {
  font-size: 44px;
}

@media screen and (max-width: 767px) {
  .course-page .fv h1 span {
    font-size: 40px;
  }
}
.course-page .fv .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
  justify-content: space-around;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .course-page .fv .list {
    display: none;
    margin: 20px 0;
  }
}
.course-page .fv .list li {
  width: 48%;
  font-weight: 900;
  font-style: italic;
  padding: 4px;
  background-color: #fff;
  text-align: center;
  border-radius: 4px;
  font-size: 16px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .course-page .fv .list li {
    font-size: 14px;
  }
}
.course-page .fv .campaign {
  margin-top: 20px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 10px 20px;
}

@media screen and (max-width: 767px) {
  .course-page .fv .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
    position: relative;
    z-index: 1;
  }
}
.course-page .fv .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0;
}

@media screen and (max-width: 767px) {
  .course-page .fv .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.course-page .fv .campaign .img {
  background-color: #2ca8e8;
  width: 90px;
  height: 90px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .course-page .fv .campaign .img {
    width: 80px;
    height: 80px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.course-page .fv .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
  font-size: 12px;
}

@media screen and (max-width: 767px) {
  .course-page .fv .campaign .img span {
    font-size: 10px;
  }
}
.course-page .fv .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 10px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .course-page .fv .campaign .img span b {
    font-size: 10px;
  }
}
.course-page .fv .campaign .txt {
  margin: 0 10px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .course-page .fv .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.course-page .fv .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 20px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
  font-size: 12px;
}

@media screen and (max-width: 767px) {
  .course-page .fv .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.course-page .fv .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.course-page .fv .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 16px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .course-page .fv .campaign .txt .cost {
    font-size: 14px;
  }
}
.course-page .fv .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .course-page .fv .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.course-page .fv .campaign .txt .cost span b {
  font-size: 36px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .course-page .fv .campaign .txt .cost span b {
    font-size: 24px;
  }
}
.course-page .fv .attention {
  margin-top: 10px;
}

.course-page .fv .attention p {
  color: #fff;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.course-page .price .headline {
  margin: 40px 0;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .course-page .price .headline {
    padding: 0 10px;
  }
}
.course-page .price .headline strong {
  font-weight: 400;
  font-size: 20px;
  line-height: 1.6;
}

.course-page .price .headline p {
  margin-top: 10px;
}

.course-page .price .inner {
  padding: 0 10px 10px;
}

.course-page .price .box {
  margin: 40px 0;
}

@media screen and (max-width: 767px) {
  .course-page .price .box:last-child {
    margin-bottom: 0;
  }
}
.course-page .price .box .member {
  background-color: #1e2f43;
  position: relative;
  border-radius: 6px 6px 0 0;
  color: #fff;
  padding: 14px 40px;
  font-size: 16px;
  letter-spacing: 1px;
}

.course-page .price .box .member.first {
  background-color: #ff363c;
  padding: 14px 70px;
}

.course-page .price .box .member.first .point {
  background-color: #fff268;
  display: block;
  width: 46px;
  height: 46px;
  border-radius: 100%;
  color: #000;
  font-weight: 900;
  position: absolute;
  top: -10px;
  left: 10px;
  letter-spacing: 0;
}

.course-page .price .box .member.first .point:after {
  content: "";
  position: absolute;
  bottom: 0;
  right: -2px;
  margin-top: -4px;
  border: 4px solid transparent;
  border-left: 8px solid #fff268;
  z-index: 0;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}

.course-page .price .box .member.first .point span {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  font-size: 12px;
  text-align: center;
}

.course-page .price .box .content-area {
  background-color: #f4f4f4;
  padding: 20px 40px 30px 40px;
}

@media screen and (max-width: 767px) {
  .course-page .price .box .content-area {
    padding: 20px;
  }
}
.course-page .price .box .content-area .name {
  text-align: center;
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 1px;
  line-height: 1.6;
  margin: 10px 0 20px 0;
}

@media screen and (max-width: 767px) {
  .course-page .price .box .content-area .name {
    font-size: 14px;
    letter-spacing: 0;
    margin: 0 0 20px 0;
  }
}
.course-page .price .box .content-area .table {
  width: 100%;
  margin: 20px 0 10px;
  font-weight: 900;
}

.course-page .price .box .content-area .table th {
  background-color: #f4fbfe;
  color: #2ca8e8;
  padding: 14px 0;
  letter-spacing: 1px;
  width: 40%;
  border-bottom: 2px solid #f4f4f4;
}

@media screen and (max-width: 767px) {
  .course-page .price .box .content-area .table th {
    padding: 10px 0;
    width: 30%;
    font-size: 12px;
  }
}
.course-page .price .box .content-area .table td {
  font-family: Century Gothic;
  background-color: #fff;
  width: 60%;
  text-align: center;
  padding: 20px 10px;
  border-bottom: 2px solid #f4f4f4;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .course-page .price .box .content-area .table td {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    width: 70%;
    padding: 14px 10px;
    font-size: 14px;
  }
}
.course-page .price .box .content-area .table td .font-small {
  font-size: 12px;
  display: inline-block;
  position: relative;
  top: -1px;
}

.course-page .price .box .content-area .table td .border {
  text-decoration: line-through;
}

.course-page .price .box .content-area .table td .border .font-small {
  font-size: 12px;
  display: inline-block;
  text-decoration: line-through;
  position: relative;
  top: -1px;
}

.course-page .price .box .content-area .table td .color {
  color: #ff373c;
}

.course-page .price .box .content-area .table td .color .font-small {
  font-size: 12px;
  display: inline-block;
  position: relative;
  top: -1px;
}

.course-page .price .box .content-area .attention p {
  font-weight: 900;
  font-size: 12px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .course-page .price .box .content-area .attention p {
    font-size: 10px;
  }
}
.course-page .price .notice {
  margin: 40px 0;
}

.course-page .price .notice h2 {
  color: #1e2f43;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: 2px;
  padding-bottom: 10px;
  margin: 20px 0;
  position: relative;
  background-repeat: repeat-x;
}

@media screen and (max-width: 767px) {
  .course-page .price .notice h2 {
    font-size: 20px;
  }
}
.course-page .price .notice h2:after {
  content: "";
  width: 100%;
  height: 4px;
  bottom: 0;
  left: 0;
  position: absolute;
  background-image: url(../img/page-h2-img.png);
  background-size: contain;
  background-position: 0 100%;
}

@media screen and (max-width: 767px) {
  .course-page .price .notice h2:after {
    background-size: auto;
  }
}
.course-page .price .notice .txt {
  background-color: #f4fbfe;
  padding: 20px;
  color: #1e2f43;
  margin-bottom: 30px;
}

.course-page .price .notice .txt p {
  line-height: 1.9;
}

.course-page .price .notice .txt b {
  display: inline-block;
}

.course-page .price .notice .txt b span {
  width: 10px;
  height: 10px;
  display: inline-block;
  background-color: #1e2f43;
  margin-right: 6px;
}

.course-page .split {
  background-color: #fd2a15;
}

.course-page .split .inner {
  padding: 60px 10px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .course-page .split .inner {
    padding: 40px 10px;
  }
}
.course-page .split h2 {
  text-align: center;
  font-size: 26px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 20px;
  color: #fff;
}

@media screen and (max-width: 767px) {
  .course-page .split h2 {
    font-size: 20px;
  }
}
.course-page .split .white {
  background-color: #fff;
  padding: 12px;
  border-radius: 10px;
  width: 500px;
  margin: 20px auto;
}

@media screen and (max-width: 767px) {
  .course-page .split .white {
    width: 100%;
  }
}
.course-page .split .white p {
  color: #2ca7e9;
  font-weight: 900;
  line-height: 1.5;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .course-page .split .white p {
    font-size: 14px;
  }
}
.course-page .split .white span {
  font-size: 24px;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .course-page .split .white span {
    font-size: 22px;
  }
}
.course-page .split .list {
  margin: 10px auto;
  width: 400px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
  justify-content: space-around;
}

@media screen and (max-width: 767px) {
  .course-page .split .list {
    width: 100%;
  }
}
.course-page .split .list li {
  width: 50%;
  text-align: left;
  color: #fff;
  font-weight: 900;
  font-size: 16px;
  padding-left: 30px;
  background-image: url(../img/what-split-list-img.png);
  background-size: 18px;
  background-position: 0 50%;
}

@media screen and (max-width: 767px) {
  .course-page .split .list li {
    width: 40%;
  }
}
.course-page .split strong {
  display: inline-block;
  color: #fff;
  font-size: 22px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .course-page .split strong {
    font-size: 20px;
  }
}
.course-page .split .box {
  width: 400px;
  margin: 20px auto 0;
  border: 2px solid #fff;
  padding: 12px;
  border-radius: 10px;
  position: relative;
  color: #fff;
  font-weight: 900;
  font-size: 12px;
  line-height: 1.5;
}

@media screen and (max-width: 767px) {
  .course-page .split .box {
    width: 100%;
    padding: 16px;
  }
}
.course-page .split .box:before {
  content: "";
  position: absolute;
  top: -20px;
  left: 50%;
  margin-left: -8px;
  border: 8px solid transparent;
  border-bottom: 10px solid #fff;
}

.course-page .split .box span {
  display: block;
  font-size: 18px;
  margin-bottom: 8px;
  line-height: 1;
}

.course-page .refund {
  background-color: #1e2f43;
}

.course-page .refund .inner {
  padding: 60px 10px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .course-page .refund .inner {
    padding: 40px 10px;
  }
}
.course-page .refund h2 {
  text-align: center;
  font-size: 26px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 20px;
  color: #fff;
}

@media screen and (max-width: 767px) {
  .course-page .refund h2 {
    font-size: 20px;
  }
}
.course-page .refund h2 span {
  color: #fff610;
  font-size: 32px;
}

@media screen and (max-width: 767px) {
  .course-page .refund h2 span {
    font-size: 26px;
  }
}
.course-page .refund .txt {
  color: #fff;
  line-height: 1.75;
  font-weight: 900;
  font-size: 12px;
  margin-bottom: 20px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .course-page .refund .txt {
    text-align: left;
  }
}
.course-page .refund .box {
  width: 400px;
  margin: 40px auto 0;
  border: 2px solid #fff;
  padding: 12px;
  border-radius: 10px;
  position: relative;
  color: #fff;
  font-weight: 900;
  font-size: 16px;
  line-height: 1.5;
}

@media screen and (max-width: 767px) {
  .course-page .refund .box {
    width: 100%;
    padding: 16px;
  }
}
.course-page .refund .box span {
  color: #fff610;
}

.course-page .refund .box strong {
  font-size: 24px;
  line-height: 1;
  display: inline-block;
  margin-left: 2px;
}

.course-page .refund .box:before {
  content: "";
  position: absolute;
  top: -20px;
  left: 50%;
  margin-left: -8px;
  border: 8px solid transparent;
  border-bottom: 10px solid #fff;
}

.course-page .refund .attention {
  width: 550px;
  margin: 40px auto 0;
  text-align: left;
}

@media screen and (max-width: 767px) {
  .course-page .refund .attention {
    width: 100%;
    padding: 0 0 0 10px;
  }
}
.course-page .refund .attention p {
  color: #fff;
  font-weight: 900;
  font-size: 10px;
  margin: 4px 0;
  letter-spacing: 1px;
  text-indent: -10px;
}

.course-page .banner.bottom .inner {
  padding: 16px 10px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .course-page .banner.bottom .inner {
    padding: 20px 10px 10px;
    max-width: 500px;
  }
}
.course-page .banner.bottom h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  padding: 40px 0;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .course-page .banner.bottom h2 {
    font-size: 20px;
    padding: 40px 0 20px;
  }
}
.course-page .banner.bottom .campaign {
  margin-top: 10px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .course-page .banner.bottom .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
    margin-bottom: 10px;
  }
}
.course-page .banner.bottom .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .course-page .banner.bottom .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.course-page .banner.bottom .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .course-page .banner.bottom .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.course-page .banner.bottom .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .course-page .banner.bottom .campaign .img span {
    font-size: 12px;
  }
}
.course-page .banner.bottom .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .course-page .banner.bottom .campaign .img span b {
    font-size: 10px;
  }
}
.course-page .banner.bottom .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .course-page .banner.bottom .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.course-page .banner.bottom .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .course-page .banner.bottom .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.course-page .banner.bottom .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.course-page .banner.bottom .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .course-page .banner.bottom .campaign .txt .cost {
    font-size: 16px;
  }
}
.course-page .banner.bottom .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .course-page .banner.bottom .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.course-page .banner.bottom .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .course-page .banner.bottom .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.course-page .banner.bottom .attention {
  margin: 10px 0;
}

.course-page .banner.bottom .attention p {
  color: #1e2f43;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.course-page .banner.bottom .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.course-page .banner.bottom .list li {
  width: 49%;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .course-page .banner.bottom .list li {
    margin: 0 0 10px 0;
  }
}
.course-page .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.course-page .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .course-page .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.course-page .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .course-page .btn-area.bottom-area .btn {
    margin-top: 0;
  }
}
.course-page .btn-area.bottom-area .btn .left, .course-page .btn-area.bottom-area .btn .right {
  width: 49%;
}

.course-page .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .course-page .btn-area.bottom-area .btn .left a {
    background-image: url(../img/top-btn-icon1-img.svg);
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
  }
}
.course-page .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .course-page .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
}
.course-page .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .course-page .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.course-page .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .course-page .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.course-page .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .course-page .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}
.trainer-page .fv {
  background-image: url(../img/trainer-fv-back-img.png);
  background-size: cover;
  background-position: center;
}

.trainer-page .fv .inner {
  padding: 70px 100px 114px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .trainer-page .fv .inner {
    padding: 60px 10px 100px;
    position: relative;
  }
}
.trainer-page .fv .headline {
  text-align: center;
}

.trainer-page .fv .headline span {
  color: #1e2f43;
  font-weight: 900;
  border-bottom: 2px solid #1e2f43;
  display: inline-block;
  margin-bottom: 30px;
  padding-bottom: 4px;
  letter-spacing: 1px;
}

.trainer-page .fv h1 {
  text-align: center;
  color: #1e2f43;
  font-weight: 500;
  font-size: 32px;
  letter-spacing: 4px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .trainer-page .fv h1 {
    font-size: 28px;
  }
}
.trainer-page .fv h1 span {
  display: block;
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  .trainer-page .fv h1 span {
    letter-spacing: 2px;
  }
}
.trainer-page .fv h1 img {
  width: 300px;
}

@media screen and (max-width: 767px) {
  .trainer-page .fv h1 img {
    width: 240px;
  }
}
.trainer-page .fv p {
  text-align: center;
  margin-top: 20px;
  font-size: 12px;
  line-height: 1.6;
}

.trainer-page .fv .arrow {
  display: block;
  margin: 0 auto;
  width: 24px;
  height: 24px;
  position: absolute;
  right: 0;
  left: 0;
  bottom: 22px;
  border-radius: 100%;
  border: 1px solid #1e2f43;
}

.trainer-page .fv .arrow img {
  -webkit-animation: blink-slide 1.4s ease-in-out infinite;
  animation: blink-slide 1.4s ease-in-out infinite;
}

.trainer-page .fv .arrow .top {
  width: 1px;
  height: 36px;
  background-color: #1e2f43;
  position: absolute;
  top: -36px;
  right: 0;
  left: 0;
  margin: 0 auto;
  display: block;
}

.trainer-page .fv .arrow .bottom {
  width: 1px;
  height: 22px;
  background-color: #1e2f43;
  position: absolute;
  bottom: -22px;
  right: 0;
  left: 0;
  margin: 0 auto;
  display: block;
}

@-webkit-keyframes blink-slide {
  0% {
    opacity: 0;
    margin-bottom: 0;
  }
  40% {
    opacity: 1;
    margin-bottom: 0;
  }
  100% {
    opacity: 0;
    margin-bottom: -12px;
  }
}
@keyframes blink-slide {
  0% {
    opacity: 0;
    margin-bottom: 0;
  }
  40% {
    opacity: 1;
    margin-bottom: 0;
  }
  100% {
    opacity: 0;
    margin-bottom: -12px;
  }
}
.trainer-page .stylist .inner {
  padding: 40px 10px;
}

.trainer-page .stylist .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

@media screen and (max-width: 767px) {
  .trainer-page .stylist .list {
    margin: 0 auto;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    max-width: 500px;
  }
}
.trainer-page .stylist .list li {
  width: 32.3333333%;
  margin: 0 0.5% 10px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: left top;
  text-align: right;
}

@media screen and (max-width: 767px) {
  .trainer-page .stylist .list li {
    width: 48%;
    background-position: -16px 50%;
  }
}
.trainer-page .stylist .list li a {
  display: block;
  position: relative;
  color: #fff;
}

.trainer-page .stylist .list .txt {
  width: 80%;
  text-align: left;
  display: inline-block;
  position: relative;
  padding: 32px 10px 20px 50px;
  background: -webkit-gradient(linear, right top, left top, color-stop(80%, #1e2f43), color-stop(86%, #1e2f43), color-stop(96%, rgba(30, 47, 67, 0.1)), to(rgba(30, 47, 67, 0)));
  background: linear-gradient(-90deg, #1e2f43 80%, #1e2f43 86%, rgba(30, 47, 67, 0.1) 96%, rgba(30, 47, 67, 0) 100%);
}

@media screen and (max-width: 767px) {
  .trainer-page .stylist .list .txt {
    width: 72%;
    padding: 32px 10px 20px 22px;
    background: -webkit-gradient(linear, right top, left top, color-stop(80%, #1e2f43), color-stop(88%, #1e2f43), color-stop(98%, rgba(30, 47, 67, 0.1)), to(rgba(30, 47, 67, 0)));
    background: linear-gradient(-90deg, #1e2f43 80%, #1e2f43 88%, rgba(30, 47, 67, 0.1) 98%, rgba(30, 47, 67, 0) 100%);
  }
}
.trainer-page .stylist .list .txt .shop {
  background-color: #2ca8e8;
  display: inline-block;
  font-size: 12px;
  padding: 2px 10px;
  position: absolute;
  top: 10px;
  right: 0;
}

@media screen and (max-width: 767px) {
  .trainer-page .stylist .list .txt .shop {
    font-size: 10px;
    padding: 2px 8px;
    top: 8px;
  }
}
.trainer-page .stylist .list .txt .name {
  font-size: 14px;
  font-size: 20px;
  font-weight: 900;
  font-style: italic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .trainer-page .stylist .list .txt .name {
    letter-spacing: 0;
    word-break: break-all;
    font-size: 14px;
  }
}
.trainer-page .stylist .list .txt small {
  font-size: 10px;
  letter-spacing: 1px;
}

.trainer-page .stylist.new-stylist .list li a {
  background-color: #f4f4f4;
  overflow: hidden;
}

.trainer-page .stylist.new-stylist .list .txt {
  width: 58%;
  padding: 32px 10px 20px 40px;
  background: #1e2f43;
  padding: 32px 10px 20px 20px;
}

@media screen and (max-width: 767px) {
  .trainer-page .stylist.new-stylist .list .txt {
    padding: 32px 4px 20px 6px;
  }
}
.trainer-page .stylist.new-stylist .list .txt:before {
  content: "";
  width: 30px;
  height: 100%;
  background-color: #1e2f43;
  position: absolute;
  left: -12px;
  top: 0;
  -webkit-transform: skewX(-10deg);
  -ms-transform: skewX(-10deg);
  transform: skewX(-10deg);
}

.trainer-page .stylist.new-stylist .list .txt .name {
  position: relative;
}

@media screen and (max-width: 767px) {
  .trainer-page .stylist.new-stylist .list .txt .name {
    font-size: 12px;
  }
}
.trainer-page .stylist.new-stylist .list .txt small {
  position: relative;
}

.trainer-page .stylist.new-stylist .list .img {
  width: 30%;
  position: absolute;
  bottom: 0;
  left: 5%;
}

@media screen and (max-width: 767px) {
  .trainer-page .stylist.new-stylist .list .img {
    width: 40%;
    left: 2%;
    max-width: 78px;
  }
}
.trainer-page .banner.bottom .inner {
  padding: 16px 10px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .trainer-page .banner.bottom .inner {
    padding: 20px 10px 10px;
    max-width: 500px;
  }
}
.trainer-page .banner.bottom h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  padding: 40px 0;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .trainer-page .banner.bottom h2 {
    font-size: 20px;
    padding: 40px 0 20px;
  }
}
.trainer-page .banner.bottom .campaign {
  margin-top: 10px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .trainer-page .banner.bottom .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
    margin-bottom: 10px;
  }
}
.trainer-page .banner.bottom .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .trainer-page .banner.bottom .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.trainer-page .banner.bottom .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .trainer-page .banner.bottom .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.trainer-page .banner.bottom .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .trainer-page .banner.bottom .campaign .img span {
    font-size: 12px;
  }
}
.trainer-page .banner.bottom .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .trainer-page .banner.bottom .campaign .img span b {
    font-size: 10px;
  }
}
.trainer-page .banner.bottom .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .trainer-page .banner.bottom .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.trainer-page .banner.bottom .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .trainer-page .banner.bottom .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.trainer-page .banner.bottom .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.trainer-page .banner.bottom .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .trainer-page .banner.bottom .campaign .txt .cost {
    font-size: 16px;
  }
}
.trainer-page .banner.bottom .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .trainer-page .banner.bottom .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.trainer-page .banner.bottom .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .trainer-page .banner.bottom .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.trainer-page .banner.bottom .attention {
  margin: 10px 0;
}

.trainer-page .banner.bottom .attention p {
  color: #1e2f43;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.trainer-page .banner.bottom .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.trainer-page .banner.bottom .list li {
  width: 49%;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .trainer-page .banner.bottom .list li {
    margin: 0 0 10px 0;
  }
}
.trainer-page .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.trainer-page .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .trainer-page .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.trainer-page .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .trainer-page .btn-area.bottom-area .btn {
    margin-top: 0;
  }
}
.trainer-page .btn-area.bottom-area .btn .left, .trainer-page .btn-area.bottom-area .btn .right {
  width: 49%;
}

.trainer-page .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .trainer-page .btn-area.bottom-area .btn .left a {
    background-image: url(../img/top-btn-icon1-img.svg);
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
  }
}
.trainer-page .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .trainer-page .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
}
.trainer-page .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .trainer-page .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.trainer-page .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .trainer-page .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.trainer-page .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .trainer-page .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}
.shop-page .fv {
  background-color: #f2f2f2;
}

.shop-page .fv .inner {
  padding: 36px 10px;
}

@media screen and (max-width: 767px) {
  .shop-page .fv .inner {
    padding: 80px 10px;
    overflow: hidden;
  }
}
.shop-page .fv .box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .shop-page .fv .box {
    display: block;
    position: relative;
  }
}
.shop-page .fv .box .img {
  width: 40%;
  padding: 0 20px 0 0;
}

@media screen and (max-width: 767px) {
  .shop-page .fv .box .img {
    padding: 0;
    width: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translateY(-50%) translateX(-50%);
    -ms-transform: translateY(-50%) translateX(-50%);
    transform: translateY(-50%) translateX(-50%);
  }
}
.shop-page .fv .box .list {
  width: 50%;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .shop-page .fv .box .list {
    width: 100%;
    position: relative;
    z-index: 1;
  }
}
.shop-page .fv .box .list h1 {
  font-size: 16px;
  display: inline-block;
  position: relative;
  margin-bottom: 20px;
}

@media screen and (max-width: 767px) {
  .shop-page .fv .box .list h1 {
    font-size: 14px;
  }
}
.shop-page .fv .box .list h1:before {
  content: "";
  width: 1px;
  height: 26px;
  background-color: #a89859;
  position: absolute;
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg);
  left: -12px;
}

.shop-page .fv .box .list h1:after {
  content: "";
  width: 1px;
  height: 26px;
  background-color: #a89859;
  position: absolute;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  right: -12px;
}

.shop-page .fv .box .list .area {
  text-align: left;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 10px;
}

.shop-page .fv .box .list .area:last-child {
  margin-bottom: 0;
}

.shop-page .fv .box .list .area .area-name {
  width: 12%;
}

.shop-page .fv .box .list .area .area-name span {
  font-size: 16px;
  margin-top: 2px;
  display: inline-block;
}

@media screen and (max-width: 767px) {
  .shop-page .fv .box .list .area .area-name span {
    font-size: 14px;
    margin-top: 6px;
  }
}
.shop-page .fv .box .list .area .shop-name {
  width: 88%;
  padding: 0 6px;
}

.shop-page .fv .box .list .area .shop-name span {
  display: inline-block;
  margin: 2px 0;
}

.shop-page .fv .box .list .area .shop-name a {
  display: block;
  border: 1px solid #a89859;
  border-radius: 4px;
  background-color: #fff;
  color: #a89859;
  font-size: 12px;
  padding: 4px 8px;
}

@media screen and (max-width: 767px) {
  .shop-page .fv .box .list .area .shop-name a {
    padding: 4px 6px;
  }
}
.shop-page .main-contents {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 60px 10px;
}

@media screen and (max-width: 767px) {
  .shop-page .main-contents {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
    padding: 40px 10px;
  }
}
.shop-page .main-contents .left {
  width: 70%;
  padding-right: 20px;
}

@media screen and (max-width: 767px) {
  .shop-page .main-contents .left {
    width: 100%;
    padding-right: 0;
  }
}
.shop-page .main-contents .right {
  width: 30%;
}

@media screen and (max-width: 767px) {
  .shop-page .main-contents .right {
    width: 100%;
    margin-top: 30px;
  }
}
.shop-page .shop .area-name {
  margin-bottom: 30px;
  border-bottom: 2px solid #1e2f43;
  color: #1e2f43;
  font-size: 20px;
  padding-bottom: 10px;
  padding-left: 40px;
  background-image: url(../img/shop-area-icon-img.png);
  background-size: 26px;
  background-position: 6px 2px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .shop-page .shop .area-name {
    font-size: 18px;
    background-size: 22px;
  }
}
.shop-page .shop .list {
  margin-bottom: 30px;
}

.shop-page .shop .list:last-child {
  margin-bottom: 0;
}

.shop-page .shop .list li {
  width: 100%;
  margin-bottom: 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .shop-page .shop .list li {
    width: 100%;
    margin-bottom: 30px;
  }
}
@media screen and (max-width: 767px) {
  .shop-page .shop .list li:last-child {
    margin-bottom: 0;
  }
}
.shop-page .shop .list .img {
  width: 36%;
}

.shop-page .shop .list .img .no-img {
  position: relative;
  height: 100%;
  background-color: #1e2f43;
}

.shop-page .shop .list .img .no-img span {
  color: #fff;
  font-weight: 900;
  font-size: 16px;
  font-family: Century Gothic;
  display: block;
  text-align: center;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  padding: 0 10px;
}

.shop-page .shop .list .txt {
  width: 64%;
  padding: 0 10px;
}

@media screen and (max-width: 767px) {
  .shop-page .shop .list .txt {
    padding: 0 0 0 10px;
  }
}
.shop-page .shop .list .txt .access {
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .shop-page .shop .list .txt .access {
    font-size: 12px;
  }
}
.shop-page .shop .list .txt .name {
  margin: 10px 0;
}

.shop-page .shop .list .txt .name a {
  font-weight: 900;
  color: #2ca8e8;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .shop-page .shop .list .txt .name a {
    font-size: 14px;
  }
}
.shop-page .shop .list .txt .detail {
  margin: 10px 0;
}

.shop-page .shop .list .txt .detail p {
  margin-bottom: 2px;
  font-size: 12px;
  font-weight: 900;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.shop-page .shop .list .txt .detail p span {
  display: inline-block;
  background-color: #1e2f43;
  color: #fff;
  padding: 2px 6px;
  font-weight: 400;
  width: 60px;
  text-align: center;
  margin-right: 4px;
}

.shop-page .shop .list .txt .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 20px;
}

@media screen and (max-width: 767px) {
  .shop-page .shop .list .txt .btn {
    margin-top: 10px;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
}
.shop-page .shop .list .txt .btn .left, .shop-page .shop .list .txt .btn .right {
  width: 28%;
  border: 2px solid #1e2f43;
  border-radius: 30px;
  overflow: hidden;
  padding-right: 0;
  margin: 0 4px;
}

@media screen and (max-width: 767px) {
  .shop-page .shop .list .txt .btn .left, .shop-page .shop .list .txt .btn .right {
    width: 49%;
    margin: 0;
  }
}
.shop-page .shop .list .txt .btn .left a, .shop-page .shop .list .txt .btn .right a {
  display: block;
  background-color: #fff;
  color: #1e2f43;
  font-weight: 900;
  font-size: 12px;
}

.shop-page .shop .list .txt .btn .right {
  text-align: center;
}

.shop-page .shop .list .txt .btn .right a {
  padding: 4px 0;
}

@media screen and (max-width: 767px) {
  .shop-page .shop .list .txt .btn .right a {
    padding: 6px 0;
  }
}
.shop-page .shop .list .txt .btn .left a {
  background-image: url(../img/top-btn-icon3-img.png);
  background-size: 12px;
  background-position: 10px 50%;
  background-repeat: no-repeat;
  padding: 4px 0 4px 30px;
}

@media screen and (max-width: 767px) {
  .shop-page .shop .list .txt .btn .left a {
    padding: 6px 0 6px 30px;
  }
}
@media screen and (max-width: 767px) {
  .shop-page .sidebar .banner {
    text-align: center;
  }
  .shop-page .sidebar .banner img {
    max-width: 300px;
  }
}
.shop-page .sidebar .shop-link {
  margin-top: 20px;
}

.shop-page .sidebar .shop-link .ttl {
  background-color: #1e2f43;
  color: #fff;
  text-align: center;
  padding: 10px;
  border-radius: 4px 4px 0 0;
}

.shop-page .sidebar .shop-link .list {
  background-color: #f2f2f2;
}

.shop-page .sidebar .shop-link .list li {
  padding: 0 10px;
}

.shop-page .sidebar .shop-link .list li a {
  display: block;
  border-bottom: dashed 1px #c3c3c3;
  padding: 14px 30px 14px 10px;
  font-size: 12px;
  color: #231d41;
  position: relative;
}

.shop-page .sidebar .shop-link .list li a:after {
  content: ">";
  position: absolute;
  top: 50%;
  right: 12px;
  font-size: 16px;
  line-height: 1;
  color: #c3c3c3;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
}

.shop-page .sidebar .shop-link .list li:last-child a {
  border-bottom: none;
}

.shop-page .banner.bottom .inner {
  padding: 16px 10px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .shop-page .banner.bottom .inner {
    padding: 20px 10px 10px;
    max-width: 500px;
  }
}
.shop-page .banner.bottom h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  padding: 40px 0;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .shop-page .banner.bottom h2 {
    font-size: 20px;
    padding: 40px 0 20px;
  }
}
.shop-page .banner.bottom .campaign {
  margin-top: 10px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .shop-page .banner.bottom .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
    margin-bottom: 10px;
  }
}
.shop-page .banner.bottom .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .shop-page .banner.bottom .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.shop-page .banner.bottom .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .shop-page .banner.bottom .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.shop-page .banner.bottom .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .shop-page .banner.bottom .campaign .img span {
    font-size: 12px;
  }
}
.shop-page .banner.bottom .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .shop-page .banner.bottom .campaign .img span b {
    font-size: 10px;
  }
}
.shop-page .banner.bottom .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .shop-page .banner.bottom .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.shop-page .banner.bottom .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .shop-page .banner.bottom .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.shop-page .banner.bottom .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.shop-page .banner.bottom .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .shop-page .banner.bottom .campaign .txt .cost {
    font-size: 16px;
  }
}
.shop-page .banner.bottom .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .shop-page .banner.bottom .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.shop-page .banner.bottom .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .shop-page .banner.bottom .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.shop-page .banner.bottom .attention {
  margin: 10px 0;
}

.shop-page .banner.bottom .attention p {
  color: #1e2f43;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.shop-page .banner.bottom .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.shop-page .banner.bottom .list li {
  width: 49%;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .shop-page .banner.bottom .list li {
    margin: 0 0 10px 0;
  }
}
.shop-page .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.shop-page .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .shop-page .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.shop-page .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .shop-page .btn-area.bottom-area .btn {
    margin-top: 0;
  }
}
.shop-page .btn-area.bottom-area .btn .left, .shop-page .btn-area.bottom-area .btn .right {
  width: 49%;
}

.shop-page .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .shop-page .btn-area.bottom-area .btn .left a {
    background-image: url(../img/top-btn-icon1-img.svg);
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
  }
}
.shop-page .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .shop-page .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
}
.shop-page .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .shop-page .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.shop-page .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .shop-page .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.shop-page .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .shop-page .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}
.what-page .fv .inner {
  background-image: url(../img/what-fv-pc-img.png);
  background-size: 68%;
  background-position: center bottom;
  padding: 172px 10px 40px;
}

@media screen and (max-width: 767px) {
  .what-page .fv .inner {
    padding: 200px 10px 20px;
    background-image: url(../img/what-fv-sp-img.png);
  }
}
.what-page .fv .inner h1 {
  font-size: 36px;
  color: #fff;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .what-page .fv .inner h1 {
    font-size: 24px;
  }
}
.what-page .fv .inner h1 span {
  display: inline-block;
  background-color: #1e2f43;
  padding: 0 4px;
  margin: 4px 0;
}

@media screen and (max-width: 767px) {
  .what-page .fv .inner h1 span {
    margin: 2px 0;
  }
}
.what-page .section1 {
  background-color: #00aaef;
  position: relative;
  overflow: hidden;
}

.what-page .section1 .inner {
  padding: 40px 10px;
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .what-page .section1 .inner {
    padding: 40px 10px;
    max-width: 500px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.what-page .section1 .txt {
  color: #fff;
  width: 60%;
  padding: 20px 10px 20px 0;
}

@media screen and (max-width: 767px) {
  .what-page .section1 .txt {
    width: 100%;
    padding: 0;
    margin-bottom: 20px;
  }
}
.what-page .section1 .txt p {
  line-height: 1.6;
  font-weight: 900;
  margin-bottom: 10px;
}

.what-page .section1 .img {
  width: 36%;
}

@media screen and (max-width: 767px) {
  .what-page .section1 .img {
    width: 80%;
    margin: 0 auto;
  }
}
.what-page .section1 h2 {
  margin-bottom: 20px;
  font-size: 24px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .what-page .section1 h2 {
    font-size: 20px;
  }
}
.what-page .section2 {
  position: relative;
  overflow: hidden;
}

.what-page .section2 .inner {
  padding: 60px 10px;
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-flow: row-reverse;
  flex-flow: row-reverse;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .what-page .section2 .inner {
    padding: 40px 10px;
    max-width: 500px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.what-page .section2 .txt {
  color: #00aaef;
  width: 60%;
  padding: 20px 0 20px 10px;
}

@media screen and (max-width: 767px) {
  .what-page .section2 .txt {
    width: 100%;
    padding: 0;
    margin-bottom: 20px;
  }
}
.what-page .section2 .txt p {
  line-height: 1.6;
  font-weight: 900;
  margin-bottom: 10px;
}

.what-page .section2 .img {
  width: 36%;
}

@media screen and (max-width: 767px) {
  .what-page .section2 .img {
    width: 80%;
    margin: 0 auto;
  }
}
.what-page .section2 h2 {
  margin-bottom: 20px;
  font-size: 24px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .what-page .section2 h2 {
    font-size: 20px;
  }
}
.what-page .section3 {
  background-color: #fd2a15;
  position: relative;
  overflow: hidden;
}

.what-page .section3:before {
  content: "";
  width: 460px;
  height: 100%;
  position: absolute;
  background-image: url(../img/what-section3-img.jpg);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  top: 0;
  right: 0;
}

@media screen and (max-width: 767px) {
  .what-page .section3:before {
    background-size: cover;
    width: 100%;
    max-width: 500px;
    height: 260px;
    top: auto;
    right: 0;
    left: 0;
    bottom: 10px;
    margin: 0 auto;
  }
}
.what-page .section3 .inner {
  padding: 60px 10px;
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .what-page .section3 .inner {
    padding: 40px 10px 280px;
    max-width: 500px;
  }
}
.what-page .section3 .txt {
  color: #fff;
  width: 60%;
}

@media screen and (max-width: 767px) {
  .what-page .section3 .txt {
    width: 100%;
  }
}
.what-page .section3 .txt p {
  line-height: 1.6;
  font-weight: 900;
  margin-bottom: 10px;
}

.what-page .section3 h2 {
  margin-bottom: 20px;
  font-size: 24px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .what-page .section3 h2 {
    font-size: 20px;
  }
}
.what-page .rule {
  background-color: #fafafa;
}

.what-page .rule .inner {
  padding: 60px 10px;
}

@media screen and (max-width: 767px) {
  .what-page .rule .inner {
    padding: 40px 10px;
  }
}
.what-page .rule h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 60px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .what-page .rule h2 {
    font-size: 20px;
    margin-bottom: 40px;
  }
}
.what-page .rule h2 span {
  font-family: Century Gothic;
  font-size: 32px;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .what-page .rule h2 span {
    font-size: 26px;
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.what-page .rule .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .what-page .rule .list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.what-page .rule .list li {
  width: 32%;
  border: 2px solid #2ca8e8;
  border-radius: 4px;
  background-color: #fff;
  padding: 10px;
}

@media screen and (max-width: 767px) {
  .what-page .rule .list li {
    width: 100%;
    margin-bottom: 40px;
    position: relative;
  }
}
@media screen and (max-width: 767px) {
  .what-page .rule .list li:last-child {
    margin-bottom: 0;
  }
}
.what-page .rule .list .point {
  display: block;
  width: 80px;
  height: 80px;
  background-color: #2ca8e8;
  border-radius: 100%;
  position: relative;
  margin: -50px auto 0;
}

@media screen and (max-width: 767px) {
  .what-page .rule .list .point {
    margin: 0;
    position: absolute;
    top: -12px;
    left: 14px;
    width: 70px;
    height: 70px;
  }
}
.what-page .rule .list .point:before {
  content: "";
  width: 20px;
  height: 20px;
  top: -16px;
  right: -36px;
  left: 0;
  margin: 0 auto;
  position: absolute;
  background-image: url(../img/top-date-icon-img.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

@media screen and (max-width: 767px) {
  .what-page .rule .list .point:before {
    right: -22px;
  }
}
.what-page .rule .list .date {
  color: #fff;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  font-weight: 900;
  font-size: 24px;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .what-page .rule .list .date {
    font-size: 20px;
  }
}
.what-page .rule .list .date small {
  display: block;
  line-height: 1;
  font-size: 12px;
}

@media screen and (max-width: 767px) {
  .what-page .rule .list .date small {
    margin-top: 2px;
  }
}
.what-page .rule .list h3 {
  margin: 10px 0;
  text-align: center;
  font-weight: 900;
  color: #2ca8e8;
  line-height: 1.6;
}

.what-page .rule .list h3 strong {
  display: block;
  font-size: 20px;
  letter-spacing: 2px;
}

.what-page .rule .list p {
  font-weight: 900;
  line-height: 1.5;
  font-size: 12px;
}

.what-page .split {
  background-color: #fd2a15;
}

.what-page .split .inner {
  padding: 60px 10px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .what-page .split .inner {
    padding: 40px 10px;
  }
}
.what-page .split h2 {
  text-align: center;
  font-size: 26px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 20px;
  color: #fff;
}

@media screen and (max-width: 767px) {
  .what-page .split h2 {
    font-size: 20px;
  }
}
.what-page .split .white {
  background-color: #fff;
  padding: 12px;
  border-radius: 10px;
  width: 500px;
  margin: 20px auto;
}

@media screen and (max-width: 767px) {
  .what-page .split .white {
    width: 100%;
  }
}
.what-page .split .white p {
  color: #2ca7e9;
  font-weight: 900;
  line-height: 1.5;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .what-page .split .white p {
    font-size: 14px;
  }
}
.what-page .split .white span {
  font-size: 24px;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .what-page .split .white span {
    font-size: 22px;
  }
}
.what-page .split .list {
  margin: 10px auto;
  width: 400px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
  justify-content: space-around;
}

@media screen and (max-width: 767px) {
  .what-page .split .list {
    width: 100%;
  }
}
.what-page .split .list li {
  width: 50%;
  text-align: left;
  color: #fff;
  font-weight: 900;
  font-size: 16px;
  padding-left: 30px;
  background-image: url(../img/what-split-list-img.png);
  background-size: 18px;
  background-position: 0 50%;
}

@media screen and (max-width: 767px) {
  .what-page .split .list li {
    width: 40%;
  }
}
.what-page .split strong {
  display: inline-block;
  color: #fff;
  font-size: 22px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .what-page .split strong {
    font-size: 20px;
  }
}
.what-page .split .box {
  width: 400px;
  margin: 20px auto 0;
  border: 2px solid #fff;
  padding: 12px;
  border-radius: 10px;
  position: relative;
  color: #fff;
  font-weight: 900;
  font-size: 12px;
  line-height: 1.5;
}

@media screen and (max-width: 767px) {
  .what-page .split .box {
    width: 100%;
    padding: 16px;
  }
}
.what-page .split .box:before {
  content: "";
  position: absolute;
  top: -20px;
  left: 50%;
  margin-left: -8px;
  border: 8px solid transparent;
  border-bottom: 10px solid #fff;
}

.what-page .split .box span {
  display: block;
  font-size: 18px;
  margin-bottom: 8px;
  line-height: 1;
}

.what-page .refund {
  background-color: #1e2f43;
}

.what-page .refund .inner {
  padding: 60px 10px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .what-page .refund .inner {
    padding: 40px 10px;
  }
}
.what-page .refund h2 {
  text-align: center;
  font-size: 26px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 20px;
  color: #fff;
}

@media screen and (max-width: 767px) {
  .what-page .refund h2 {
    font-size: 20px;
  }
}
.what-page .refund h2 span {
  color: #fff610;
  font-size: 32px;
}

@media screen and (max-width: 767px) {
  .what-page .refund h2 span {
    font-size: 26px;
  }
}
.what-page .refund .txt {
  color: #fff;
  line-height: 1.75;
  font-weight: 900;
  font-size: 12px;
  margin-bottom: 20px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .what-page .refund .txt {
    text-align: left;
  }
}
.what-page .refund .box {
  width: 400px;
  margin: 40px auto 0;
  border: 2px solid #fff;
  padding: 12px;
  border-radius: 10px;
  position: relative;
  color: #fff;
  font-weight: 900;
  font-size: 16px;
  line-height: 1.5;
}

@media screen and (max-width: 767px) {
  .what-page .refund .box {
    width: 100%;
    padding: 16px;
  }
}
.what-page .refund .box span {
  color: #fff610;
}

.what-page .refund .box strong {
  font-size: 24px;
  line-height: 1;
  display: inline-block;
  margin-left: 2px;
}

.what-page .refund .box:before {
  content: "";
  position: absolute;
  top: -20px;
  left: 50%;
  margin-left: -8px;
  border: 8px solid transparent;
  border-bottom: 10px solid #fff;
}

.what-page .refund .attention {
  width: 550px;
  margin: 40px auto 0;
  text-align: left;
}

@media screen and (max-width: 767px) {
  .what-page .refund .attention {
    width: 100%;
    padding: 0 0 0 10px;
  }
}
.what-page .refund .attention p {
  color: #fff;
  font-weight: 900;
  font-size: 10px;
  margin: 4px 0;
  letter-spacing: 1px;
  text-indent: -10px;
}

.what-page .banner .inner {
  padding: 16px 10px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .what-page .banner .inner {
    padding: 20px 10px 10px;
    max-width: 500px;
  }
}
.what-page .banner h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  padding: 40px 0;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .what-page .banner h2 {
    font-size: 20px;
    padding: 40px 0 20px;
  }
}
.what-page .banner .campaign {
  margin-top: 10px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .what-page .banner .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
    margin-bottom: 10px;
  }
}
.what-page .banner .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .what-page .banner .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.what-page .banner .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .what-page .banner .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.what-page .banner .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .what-page .banner .campaign .img span {
    font-size: 12px;
  }
}
.what-page .banner .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .what-page .banner .campaign .img span b {
    font-size: 10px;
  }
}
.what-page .banner .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .what-page .banner .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.what-page .banner .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .what-page .banner .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.what-page .banner .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.what-page .banner .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .what-page .banner .campaign .txt .cost {
    font-size: 16px;
  }
}
.what-page .banner .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .what-page .banner .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.what-page .banner .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .what-page .banner .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.what-page .banner .attention {
  margin-top: 10px;
}

.what-page .banner .attention p {
  color: #1e2f43;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.what-page .banner .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.what-page .banner .list li {
  width: 49%;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .what-page .banner .list li {
    margin: 0 0 10px 0;
  }
}
.what-page .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.what-page .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .what-page .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.what-page .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .what-page .btn-area.bottom-area .btn {
    margin-top: 0;
  }
}
.what-page .btn-area.bottom-area .btn .left, .what-page .btn-area.bottom-area .btn .right {
  width: 49%;
}

.what-page .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .what-page .btn-area.bottom-area .btn .left a {
    background-image: url(../img/top-btn-icon1-img.svg);
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
  }
}
.what-page .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .what-page .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
}
.what-page .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .what-page .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.what-page .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .what-page .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.what-page .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .what-page .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}
.method-page .fv {
  position: relative;
  overflow: hidden;
}

.method-page .fv:before {
  content: "";
  width: 50%;
  height: 100%;
  background-color: #00aaef;
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
}

@media screen and (max-width: 767px) {
  .method-page .fv:before {
    width: 100%;
  }
}
.method-page .fv .inner {
  padding: 20px 10px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .method-page .fv .inner {
    padding: 40px 10px 20px;
  }
}
.method-page .fv .pc-only img {
  width: 766px;
}

.method-page .problem {
  position: relative;
  overflow: hidden;
}

.method-page .problem .inner {
  padding: 60px 10px;
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .method-page .problem .inner {
    padding: 40px 10px;
    max-width: 500px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.method-page .problem .txt {
  width: 60%;
  padding: 20px 10px 20px 0;
}

@media screen and (max-width: 767px) {
  .method-page .problem .txt {
    width: 100%;
    padding: 0;
    margin-bottom: 20px;
  }
}
.method-page .problem .txt p {
  line-height: 1.6;
  font-weight: 900;
  margin-bottom: 10px;
}

.method-page .problem .img {
  width: 34%;
}

@media screen and (max-width: 767px) {
  .method-page .problem .img {
    width: 80%;
    margin: 0 auto;
  }
}
.method-page .problem h2 {
  margin-bottom: 20px;
  font-size: 24px;
  font-weight: 900;
  color: #1e2f43;
}

@media screen and (max-width: 767px) {
  .method-page .problem h2 {
    font-size: 20px;
  }
}
.method-page .problem .list li {
  color: #1e2f43;
  padding: 4px 0 2px 30px;
  font-weight: 900;
  margin: 8px 0;
  background-size: 20px;
  background-repeat: no-repeat;
  background-position: 0 50%;
}

.method-page .problem .list li:nth-child(odd) {
  background-image: url(../img/list-blue-icon-img.png);
}

.method-page .problem .list li:nth-child(even) {
  background-image: url(../img/list-red-icon-img.png);
}

.method-page .way {
  background-color: #00aaef;
}

.method-page .way .inner {
  padding: 40px 10px;
}

@media screen and (max-width: 767px) {
  .method-page .way .inner {
    max-width: 500px;
  }
}
.method-page .way h2 {
  margin-bottom: 60px;
  font-size: 24px;
  font-weight: 900;
  color: #fff;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .method-page .way h2 {
    font-size: 20px;
    margin-bottom: 40px;
  }
}
.method-page .way .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .method-page .way .list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.method-page .way .list li {
  width: 32%;
  border-radius: 6px;
  border: 2px solid #1e2f43;
  background-color: #fff;
  padding: 10px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .method-page .way .list li {
    width: 100%;
    margin-bottom: 40px;
    padding: 20px 10px;
  }
}
@media screen and (max-width: 767px) {
  .method-page .way .list li:last-child {
    margin-bottom: 0;
  }
}
.method-page .way .list li .img {
  text-align: center;
  padding: 0 60px;
}

.method-page .way .list li .img img {
  margin-top: -60px;
}

@media screen and (max-width: 767px) {
  .method-page .way .list li .img img {
    margin-top: -40px;
  }
}
.method-page .way .list li .txt h3 {
  font-size: 18px;
  text-align: center;
  margin: 10px 0;
  color: #1e2f43;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .method-page .way .list li .txt h3 {
    font-size: 16px;
  }
}
.method-page .way .list li .txt p {
  color: #1e2f43;
  font-size: 12px;
  line-height: 1.6;
}

.method-page .way .list li .number {
  background-color: #1e2f43;
  display: block;
  border-radius: 100%;
  width: 34px;
  color: #fff;
  font-weight: 900;
  text-align: center;
  padding: 8px 0;
  position: absolute;
  top: 10px;
  left: 10px;
}

.method-page .way .list li .number:before {
  content: "";
  background-image: url(../img/method-way-number-img.png);
  background-size: contain;
  background-repeat: no-repeat;
  width: 10px;
  height: 10px;
  position: absolute;
  top: -8px;
  right: -12px;
  left: 0;
  margin: 0 auto;
}

.method-page .way .list .list1 img {
  width: 170px;
}

.method-page .way .list .list2 img {
  width: 134px;
}

.method-page .way .list .list3 img {
  width: 116px;
}

.method-page .section1 {
  position: relative;
  overflow: hidden;
}

.method-page .section1:before {
  content: "";
  width: 480px;
  height: 100%;
  position: absolute;
  background-image: url(../img/method-section1-img.png);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  top: 0;
  left: 0;
}

@media screen and (max-width: 767px) {
  .method-page .section1:before {
    background-size: cover;
    width: 100%;
    max-width: 500px;
    height: 260px;
    top: auto;
    right: 0;
    left: 0;
    bottom: 10px;
    margin: 0 auto;
  }
}
.method-page .section1 .inner {
  padding: 80px 10px;
  position: relative;
  z-index: 1;
  text-align: right;
}

@media screen and (max-width: 767px) {
  .method-page .section1 .inner {
    padding: 40px 10px 280px;
    max-width: 500px;
  }
}
.method-page .section1 .txt {
  color: #00aaef;
  width: 60%;
  text-align: left;
  display: inline-block;
}

@media screen and (max-width: 767px) {
  .method-page .section1 .txt {
    width: 100%;
  }
}
.method-page .section1 .txt p {
  line-height: 1.6;
  font-weight: 900;
  margin-bottom: 10px;
}

.method-page .section1 h2 {
  margin-bottom: 20px;
  font-size: 24px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .method-page .section1 h2 {
    font-size: 20px;
  }
}
.method-page .section2 {
  background-color: #fd2a15;
  position: relative;
  overflow: hidden;
}

.method-page .section2:before {
  content: "";
  width: 460px;
  height: 100%;
  position: absolute;
  background-image: url(../img/what-section3-img.jpg);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  top: 0;
  right: 0;
}

@media screen and (max-width: 767px) {
  .method-page .section2:before {
    background-size: cover;
    width: 100%;
    max-width: 500px;
    height: 260px;
    top: auto;
    right: 0;
    left: 0;
    bottom: 10px;
    margin: 0 auto;
  }
}
.method-page .section2 .inner {
  padding: 60px 10px;
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .method-page .section2 .inner {
    padding: 40px 10px 280px;
    max-width: 500px;
  }
}
.method-page .section2 .txt {
  color: #fff;
  width: 60%;
}

@media screen and (max-width: 767px) {
  .method-page .section2 .txt {
    width: 100%;
  }
}
.method-page .section2 .txt p {
  line-height: 1.6;
  font-weight: 900;
  margin-bottom: 10px;
}

.method-page .section2 h2 {
  margin-bottom: 20px;
  font-size: 24px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .method-page .section2 h2 {
    font-size: 20px;
  }
}
.method-page .banner .inner {
  padding: 16px 10px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .method-page .banner .inner {
    padding: 20px 10px 10px;
    max-width: 500px;
  }
}
.method-page .banner h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  padding: 40px 0;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .method-page .banner h2 {
    font-size: 20px;
    padding: 40px 0 20px;
  }
}
.method-page .banner .campaign {
  margin-top: 10px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .method-page .banner .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
    margin-bottom: 10px;
  }
}
.method-page .banner .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .method-page .banner .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.method-page .banner .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .method-page .banner .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.method-page .banner .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .method-page .banner .campaign .img span {
    font-size: 12px;
  }
}
.method-page .banner .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .method-page .banner .campaign .img span b {
    font-size: 10px;
  }
}
.method-page .banner .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .method-page .banner .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.method-page .banner .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .method-page .banner .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.method-page .banner .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.method-page .banner .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .method-page .banner .campaign .txt .cost {
    font-size: 16px;
  }
}
.method-page .banner .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .method-page .banner .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.method-page .banner .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .method-page .banner .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.method-page .banner .attention {
  margin-top: 10px;
}

.method-page .banner .attention p {
  color: #1e2f43;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.method-page .banner .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.method-page .banner .list li {
  width: 49%;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .method-page .banner .list li {
    margin: 0 0 10px 0;
  }
}
.method-page .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.method-page .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .method-page .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.method-page .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .method-page .btn-area.bottom-area .btn {
    margin-top: 0;
  }
}
.method-page .btn-area.bottom-area .btn .left, .method-page .btn-area.bottom-area .btn .right {
  width: 49%;
}

.method-page .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .method-page .btn-area.bottom-area .btn .left a {
    background-image: url(../img/top-btn-icon1-img.svg);
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
  }
}
.method-page .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .method-page .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
}
.method-page .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .method-page .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.method-page .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .method-page .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.method-page .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .method-page .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}
.safety-page .fv {
  background: linear-gradient(110deg, #fd2a15 26%, #00aaef 66%);
}

.safety-page .fv .inner {
  padding: 135px 10px;
}

@media screen and (max-width: 767px) {
  .safety-page .fv .inner {
    padding: 85px 10px;
  }
}
.safety-page .fv .img {
  text-align: center;
}

.safety-page .fv .img img {
  width: 50px;
}

.safety-page .fv .ttl {
  text-align: center;
  padding-top: 20px;
}

.safety-page .fv .ttl h1 {
  display: inline-block;
  position: relative;
  color: #fff;
  font-weight: 900;
  font-size: 18px;
}

.safety-page .fv .ttl h1 small {
  font-size: 10px;
  position: absolute;
  display: block;
  bottom: -14px;
  left: 24px;
}

.safety-page .know {
  position: relative;
  overflow: hidden;
}

.safety-page .know:before {
  content: "";
  width: 50%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background-color: #fd2a15;
}

.safety-page .know:after {
  content: "";
  width: 50%;
  height: 100%;
  position: absolute;
  right: 0;
  top: 0;
  background-color: #00aaef;
}

.safety-page .know .inner {
  background-color: #fff;
  position: relative;
  z-index: 1;
  padding: 40px;
}

@media screen and (max-width: 767px) {
  .safety-page .know .inner {
    padding: 20px;
    width: 90%;
  }
}
.safety-page .know h2 {
  margin-bottom: 40px;
}

@media screen and (max-width: 767px) {
  .safety-page .know h2 {
    margin-bottom: 20px;
  }
}
.safety-page .know h2 span {
  display: inline-block;
  background-color: #1e2f43;
  color: #fff;
  font-size: 20px;
  font-weight: 900;
  padding: 0 4px;
  margin: 2px 0;
}

@media screen and (max-width: 767px) {
  .safety-page .know h2 span {
    font-size: 18px;
  }
}
.safety-page .know .list {
  margin: 0 40px;
}

@media screen and (max-width: 767px) {
  .safety-page .know .list {
    margin: 0;
  }
}
.safety-page .know .list li {
  color: #1e2f43;
  letter-spacing: 1px;
  margin-bottom: 8px;
  padding: 6px 0 6px 30px;
  background-size: 18px;
  background-position: 4px 50%;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .safety-page .know .list li {
    background-size: 16px;
  }
}
.safety-page .know .list li:nth-child(even) {
  background-image: url(../img/list-blue-icon-img.png);
}

.safety-page .know .list li:nth-child(odd) {
  background-image: url(../img/list-red-icon-img.png);
}

.safety-page .power {
  position: relative;
  overflow: hidden;
}

.safety-page .power .inner {
  padding: 86px 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .safety-page .power .inner {
    padding: 60px 10px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-flow: column-reverse;
    flex-flow: column-reverse;
    max-width: 500px;
  }
}
.safety-page .power .img {
  width: 40%;
  text-align: center;
  position: relative;
}

@media screen and (max-width: 767px) {
  .safety-page .power .img {
    margin-top: 20px;
  }
}
.safety-page .power .img img {
  width: 50px;
  display: block;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.safety-page .power .img span.left {
  background-color: #e4a939;
  height: 1px;
  width: 100vw;
  position: absolute;
  margin: 0 auto;
  right: 50%;
  top: 14px;
}

.safety-page .power .img span.right {
  background-color: #e4a939;
  height: 1px;
  width: 100vw;
  position: absolute;
  margin: 0 auto;
  left: 54%;
  top: 32px;
}

@media screen and (max-width: 767px) {
  .safety-page .power .img span.right {
    left: 60%;
  }
}
.safety-page .power .txt {
  width: 40%;
}

@media screen and (max-width: 767px) {
  .safety-page .power .txt {
    width: 100%;
  }
}
.safety-page .power .txt h2 {
  margin-bottom: 20px;
}

.safety-page .power .txt h2 span {
  display: inline-block;
  background-color: #1e2f43;
  color: #fff;
  font-size: 20px;
  font-weight: 900;
  padding: 0 4px;
  margin: 2px 0;
}

@media screen and (max-width: 767px) {
  .safety-page .power .txt h2 span {
    font-size: 18px;
  }
}
.safety-page .power .txt p {
  line-height: 1.75;
  font-weight: 900;
  color: #1e2f43;
}

.safety-page .section {
  position: relative;
  overflow: hidden;
}

.safety-page .section1 {
  background-color: #1e2f43;
  color: #fff;
}

.safety-page .section1 .inner {
  padding: 80px 10px;
  background-image: url(../img/safety-section1-img.png);
  background-size: 760px;
  background-position: 90% 20px;
}

@media screen and (max-width: 767px) {
  .safety-page .section1 .inner {
    padding: 60px 10px;
    max-width: 500px;
    background-size: 360px;
  }
}
.safety-page .section1 h2 {
  font-size: 20px;
  font-weight: 900;
  margin-bottom: 20px;
}

@media screen and (max-width: 767px) {
  .safety-page .section1 h2 {
    font-size: 18px;
  }
}
.safety-page .section1 strong {
  display: inline-block;
  margin-bottom: 20px;
  font-size: 20px;
  font-weight: 500;
}

@media screen and (max-width: 767px) {
  .safety-page .section1 strong {
    font-size: 18px;
  }
}
.safety-page .section1 p {
  line-height: 1.75;
  margin: 0 10px;
}

.safety-page .section1 .cover-slide {
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-color: #1e2f43;
  top: 0;
  left: 0;
  -webkit-transform: translateX(0);
  -ms-transform: translateX(0);
  transform: translateX(0);
  -webkit-transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1) 0.6s;
  transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1) 0.6s;
}

.safety-page .section2 {
  background-color: #fd2a15;
  color: #fff;
}

.safety-page .section2 .inner {
  padding: 104px 10px;
  background-image: url(../img/safety-section2-img.png);
  background-size: 500px;
  background-position: 46% 60px;
}

@media screen and (max-width: 767px) {
  .safety-page .section2 .inner {
    padding: 84px 10px;
    background-size: 240px;
    background-position: 32% 60px;
  }
}
.safety-page .section2 h2 {
  font-size: 20px;
  font-weight: 900;
  margin-bottom: 20px;
}

@media screen and (max-width: 767px) {
  .safety-page .section2 h2 {
    font-size: 18px;
  }
}
.safety-page .section2 strong {
  display: inline-block;
  margin-bottom: 20px;
  font-size: 20px;
  font-weight: 500;
}

@media screen and (max-width: 767px) {
  .safety-page .section2 strong {
    font-size: 18px;
  }
}
.safety-page .section2 p {
  line-height: 1.75;
  margin: 0 10px;
}

.safety-page .section2 .cover-slide {
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-color: #fd2a15;
  top: 0;
  left: 0;
  -webkit-transform: translateX(0);
  -ms-transform: translateX(0);
  transform: translateX(0);
  -webkit-transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1) 1.6s;
  transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1) 1.6s;
}

.safety-page .section3 {
  background-color: #f7f7f7;
  color: #1e2f43;
}

.safety-page .section3 .inner {
  padding: 92px 10px;
  background-image: url(../img/safety-section3-img.png);
  background-size: 400px;
  background-position: 40% 60px;
}

@media screen and (max-width: 767px) {
  .safety-page .section3 .inner {
    padding: 72px 10px;
    background-size: 180px;
    background-position: 30% 60px;
  }
}
.safety-page .section3 h2 {
  font-size: 20px;
  font-weight: 900;
  margin-bottom: 20px;
}

@media screen and (max-width: 767px) {
  .safety-page .section3 h2 {
    font-size: 18px;
  }
}
.safety-page .section3 strong {
  display: inline-block;
  margin-bottom: 20px;
  font-size: 20px;
  font-weight: 500;
}

@media screen and (max-width: 767px) {
  .safety-page .section3 strong {
    font-size: 18px;
  }
}
.safety-page .section3 p {
  line-height: 1.75;
  margin: 0 10px;
}

.safety-page .section3 .cover-slide {
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-color: #f7f7f7;
  top: 0;
  left: 0;
  -webkit-transform: translateX(0);
  -ms-transform: translateX(0);
  transform: translateX(0);
  -webkit-transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1) 1.6s;
  transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1) 1.6s;
}

.safety-page .section4 {
  background-color: #00aaef;
  color: #fff;
}

.safety-page .section4 .inner {
  padding: 104px 10px;
  background-image: url(../img/safety-section4-img.png);
  background-size: 400px;
  background-position: 40% 60px;
}

@media screen and (max-width: 767px) {
  .safety-page .section4 .inner {
    padding: 80px 10px;
    background-size: 170px;
    background-position: 34% 60px;
  }
}
.safety-page .section4 h2 {
  font-size: 20px;
  font-weight: 900;
  margin-bottom: 20px;
}

.safety-page .section4 strong {
  display: inline-block;
  margin-bottom: 20px;
  font-size: 20px;
  font-weight: 500;
}

.safety-page .section4 p {
  line-height: 1.75;
  margin: 0 10px;
}

.safety-page .section4 .cover-slide {
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  background-color: #00aaef;
  top: 0;
  left: 0;
  -webkit-transform: translateX(0);
  -ms-transform: translateX(0);
  transform: translateX(0);
  -webkit-transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1) 1.6s;
  transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1) 1.6s;
}

.safety-page .banner .inner {
  padding: 40px 10px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .safety-page .banner .inner {
    padding: 20px 10px 10px;
    max-width: 500px;
  }
}
.safety-page .banner h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  padding: 40px 0 0;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .safety-page .banner h2 {
    font-size: 20px;
    padding: 40px 0 20px;
  }
}
.safety-page .banner .campaign {
  margin-top: 10px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .safety-page .banner .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
    margin-bottom: 10px;
  }
}
.safety-page .banner .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .safety-page .banner .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.safety-page .banner .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .safety-page .banner .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.safety-page .banner .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .safety-page .banner .campaign .img span {
    font-size: 12px;
  }
}
.safety-page .banner .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .safety-page .banner .campaign .img span b {
    font-size: 10px;
  }
}
.safety-page .banner .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .safety-page .banner .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.safety-page .banner .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .safety-page .banner .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.safety-page .banner .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.safety-page .banner .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .safety-page .banner .campaign .txt .cost {
    font-size: 16px;
  }
}
.safety-page .banner .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .safety-page .banner .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.safety-page .banner .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .safety-page .banner .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.safety-page .banner .attention {
  margin-top: 10px;
}

.safety-page .banner .attention p {
  color: #1e2f43;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.safety-page .banner .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.safety-page .banner .list li {
  width: 49%;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .safety-page .banner .list li {
    margin: 0 0 10px 0;
  }
}
.safety-page .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.safety-page .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .safety-page .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.safety-page .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .safety-page .btn-area.bottom-area .btn {
    margin-top: 0;
  }
}
.safety-page .btn-area.bottom-area .btn .left, .safety-page .btn-area.bottom-area .btn .right {
  width: 49%;
}

.safety-page .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .safety-page .btn-area.bottom-area .btn .left a {
    background-image: url(../img/top-btn-icon1-img.svg);
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
  }
}
.safety-page .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .safety-page .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
}
.safety-page .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .safety-page .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.safety-page .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .safety-page .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.safety-page .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .safety-page .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}
.ba-page .fv {
  position: relative;
  overflow: hidden;
  background-color: #da412c;
}

.ba-page .fv:before {
  content: "";
  width: 50%;
  height: 100%;
  background-color: #00aaef;
  position: absolute;
  left: 0;
  top: 0;
}

.ba-page .fv .inner {
  padding: 32px 10px;
  text-align: center;
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .ba-page .fv .inner {
    padding: 30px 10px 50px;
  }
}
.ba-page .fv .pc-only img {
  width: 766px;
}

.ba-page .fv .txt {
  position: absolute;
  top: 62%;
  left: 50%;
  -webkit-transform: translateY(0%) translateX(-50%);
  -ms-transform: translateY(0%) translateX(-50%);
  transform: translateY(0%) translateX(-50%);
  color: #fff;
  line-height: 1.75;
  font-size: 12px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .ba-page .fv .txt {
    top: 66%;
    width: 100%;
  }
}
.ba-page .before-after .list {
  overflow: hidden;
}

.ba-page .before-after .list .ttl {
  text-align: center;
  padding: 20px 0;
}

.ba-page .before-after .list .ttl span {
  background-color: #fdfc37;
  display: inline-block;
  padding: 8px 40px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .ba-page .before-after .list .ttl span {
    padding: 8px 20px;
  }
}
.ba-page .before-after .list .ttl span:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -6px;
  border: 6px solid transparent;
  border-top: 10px solid #fdfc37;
}

.ba-page .before-after .list .ttl h2 {
  font-size: 32px;
  font-weight: 900;
  letter-spacing: 3px;
  padding-top: 10px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .ba-page .before-after .list .ttl h2 {
    font-size: 22px;
    letter-spacing: 1px;
  }
}
.ba-page .before-after .list .img {
  position: relative;
  background-color: #f4f4f4;
  padding-top: 30px;
}

@media screen and (max-width: 767px) {
  .ba-page .before-after .list .img {
    padding-top: 20px;
  }
}
.ba-page .before-after .list .img:before {
  content: "";
  width: 60%;
  height: 150%;
  background-color: #2ca8e8;
  position: absolute;
  top: -20%;
  right: -10%;
  -webkit-transform: rotate(16deg);
  -ms-transform: rotate(16deg);
  transform: rotate(16deg);
}

.ba-page .before-after .list .img .inner {
  padding: 0 10px 0 160px;
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .ba-page .before-after .list .img .inner {
    padding: 0 10px;
  }
}
.ba-page .before-after .list .img .inner img {
  display: block;
  margin-bottom: -70px;
}

@media screen and (max-width: 767px) {
  .ba-page .before-after .list .img .inner img {
    margin-bottom: -20px;
  }
}
.ba-page .before-after .list .number {
  background-color: #1e2f43;
  position: relative;
}

.ba-page .before-after .list .number .inner {
  padding: 100px 10px 60px;
}

@media screen and (max-width: 767px) {
  .ba-page .before-after .list .number .inner {
    padding: 30px 10px 20px;
  }
}
.ba-page .before-after .list .number .inner .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
  justify-content: space-around;
}

.ba-page .before-after .list .number .inner .list li {
  width: 32%;
  text-align: center;
  border: 1px solid #fff;
  padding: 20px 0;
  color: #fff;
  font-size: 18px;
}

@media screen and (max-width: 767px) {
  .ba-page .before-after .list .number .inner .list li {
    padding: 10px 0;
    font-size: 12px;
  }
}
.ba-page .before-after .list .number .inner .list li span {
  color: #fdfc37;
  display: inline-block;
  margin: 0 2px;
}

@media screen and (max-width: 767px) {
  .ba-page .before-after .list .number .inner .list li span {
    margin: 4px 2px 0;
  }
}
.ba-page .before-after .list .number .inner .list li b {
  font-family: Century Gothic;
  font-size: 28px;
  display: inline-block;
  vertical-align: baseline;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .ba-page .before-after .list .number .inner .list li b {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    font-size: 18px;
  }
}
.ba-page .before-after .list .number .inner .attention {
  margin: 10px 0 0 5px;
  color: #fff;
  font-size: 40%;
}

@media screen and (max-width: 767px) {
  .ba-page .before-after .list .number .inner .attention {
    margin: 10px 0 0 0;
  }
}
.ba-page .before-after .list.list2 .number .inner {
  padding: 100px 10px 40px;
}

@media screen and (max-width: 767px) {
  .ba-page .before-after .list.list2 .number .inner {
    padding: 30px 10px 20px;
  }
}
.ba-page .before-after .list.list2 .btn {
  text-align: center;
  margin-top: 40px;
}

@media screen and (max-width: 767px) {
  .ba-page .before-after .list.list2 .btn {
    margin-top: 20px;
  }
}
.ba-page .before-after .list.list2 .btn a {
  background-color: #fff;
  display: inline-block;
  font-weight: 900;
  padding: 14px 60px;
  border-radius: 30px;
  color: #1e2f43;
}

.ba-page .banner .inner {
  padding: 16px 10px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .ba-page .banner .inner {
    padding: 20px 10px 10px;
    max-width: 500px;
  }
}
.ba-page .banner h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  padding: 40px 0;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .ba-page .banner h2 {
    font-size: 20px;
    padding: 40px 0 20px;
  }
}
.ba-page .banner .campaign {
  margin-top: 10px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .ba-page .banner .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
    margin-bottom: 10px;
  }
}
.ba-page .banner .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .ba-page .banner .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.ba-page .banner .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .ba-page .banner .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.ba-page .banner .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .ba-page .banner .campaign .img span {
    font-size: 12px;
  }
}
.ba-page .banner .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .ba-page .banner .campaign .img span b {
    font-size: 10px;
  }
}
.ba-page .banner .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .ba-page .banner .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.ba-page .banner .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .ba-page .banner .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.ba-page .banner .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.ba-page .banner .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .ba-page .banner .campaign .txt .cost {
    font-size: 16px;
  }
}
.ba-page .banner .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .ba-page .banner .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.ba-page .banner .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .ba-page .banner .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.ba-page .banner .attention {
  margin: 10px 0;
}

.ba-page .banner .attention p {
  color: #1e2f43;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.ba-page .banner .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.ba-page .banner .list li {
  width: 49%;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .ba-page .banner .list li {
    margin: 0 0 10px 0;
  }
}
.ba-page .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.ba-page .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .ba-page .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.ba-page .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .ba-page .btn-area.bottom-area .btn {
    margin-top: 0;
  }
}
.ba-page .btn-area.bottom-area .btn .left, .ba-page .btn-area.bottom-area .btn .right {
  width: 49%;
}

.ba-page .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .ba-page .btn-area.bottom-area .btn .left a {
    background-image: url(../img/top-btn-icon1-img.svg);
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
  }
}
.ba-page .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .ba-page .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
}
.ba-page .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .ba-page .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.ba-page .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .ba-page .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.ba-page .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .ba-page .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}
.recruit-page .fv .inner {
  padding: 23px 10px;
  background-image: url(../img/recruit-fv1-img.png), url(../img/recruit-fv2-img.png);
  background-size: 164px, 164px;
  background-position: 4% 46%, 96% 46%;
}

@media screen and (max-width: 767px) {
  .recruit-page .fv .inner {
    padding: 42px 10px;
    background-size: 128px, 122px;
    background-position: -16% 32%, 110% 29%;
  }
}
.recruit-page .fv .txt {
  text-align: center;
}

.recruit-page .fv .txt .sub {
  color: #0063e0;
  font-size: 16px;
}

.recruit-page .fv .txt h1 {
  margin: 22px 0;
  color: #0063e0;
  font-weight: 800;
  font-size: 42px;
  line-height: 1.3;
  letter-spacing: 1px;
  font-family: "Hiragino Sans", "Meiryo", "MS Pgothic", helvetica, arial, sans-serif;
}

@media screen and (max-width: 767px) {
  .recruit-page .fv .txt h1 {
    font-size: 36px;
    line-height: 1.2;
  }
}
.recruit-page .fv .txt .list {
  width: 260px;
  margin: 0 auto;
  text-align: left;
}

@media screen and (max-width: 767px) {
  .recruit-page .fv .txt .list {
    width: 230px;
  }
}
.recruit-page .fv .txt .list li {
  margin: 10px 0;
  color: #0063e0;
  font-weight: 900;
  font-size: 18px;
  position: relative;
  padding-left: 24px;
}

@media screen and (max-width: 767px) {
  .recruit-page .fv .txt .list li {
    font-size: 16px;
  }
}
.recruit-page .fv .txt .list li:before {
  content: "";
  width: 12px;
  height: 12px;
  background-color: #0063e0;
  position: absolute;
  border-radius: 100%;
  border: 3px solid #eeeeee;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%) translateX(0%);
  -ms-transform: translateY(-50%) translateX(0%);
  transform: translateY(-50%) translateX(0%);
}

.recruit-page .fv .txt .list li span {
  font-size: 14px;
  display: inline-block;
  margin-left: 4px;
}

.recruit-page .fv .txt .btn {
  margin-top: 20px;
}

.recruit-page .fv .txt .btn a {
  display: inline-block;
  background-color: #0063e0;
  color: #fff;
  font-size: 22px;
  padding: 10px 70px;
  border-radius: 4px;
  background-image: url(../img/recruit-btn-img.png);
  background-size: 34px;
  background-position: 94% 50%;
}

@media screen and (max-width: 767px) {
  .recruit-page .fv .txt .btn a {
    font-size: 18px;
    padding: 14px 58px 14px 28px;
  }
}
.recruit-page .person .inner {
  padding: 60px 200px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .recruit-page .person .inner {
    padding: 40px 40px 40px 10px;
  }
}
.recruit-page .person h2 {
  color: #0063e0;
  font-size: 24px;
  margin-bottom: 30px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .recruit-page .person h2 {
    font-size: 22px;
  }
}
.recruit-page .person .box {
  margin-bottom: 30px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .recruit-page .person .box {
    min-height: 250px;
  }
}
.recruit-page .person .box:before {
  content: "";
  width: 6px;
  height: 200px;
  background-color: #eeeeee;
  position: absolute;
  right: -19%;
  top: 26px;
}

@media screen and (max-width: 767px) {
  .recruit-page .person .box:before {
    right: -24px;
    height: 280px;
  }
}
.recruit-page .person .box:nth-of-type(2):before {
  height: 210px;
}

@media screen and (max-width: 767px) {
  .recruit-page .person .box:nth-of-type(2):before {
    height: 280px;
  }
}
.recruit-page .person .box:last-child:before {
  content: none;
}

.recruit-page .person .box h3 {
  background-color: #0063e0;
  color: #fff;
  font-size: 20px;
  padding: 10px;
  font-weight: 900;
  position: relative;
  margin-bottom: 20px;
}

@media screen and (max-width: 767px) {
  .recruit-page .person .box h3 {
    font-size: 16px;
    padding: 10px 10px 10px 50px;
  }
}
.recruit-page .person .box h3:before {
  content: "";
  width: 100%;
  height: 100%;
  background-color: #0063e0;
  position: absolute;
  left: -180px;
  top: 0;
  z-index: -1;
}

@media screen and (max-width: 767px) {
  .recruit-page .person .box h3:before {
    content: none;
  }
}
.recruit-page .person .box h3:after {
  position: absolute;
  content: "";
  left: -182px;
  top: -2px;
  border: none;
  border-left: solid 40px white;
  border-bottom: solid 52px transparent;
}

@media screen and (max-width: 767px) {
  .recruit-page .person .box h3:after {
    left: -4px;
  }
}
.recruit-page .person .box h3 span.icon {
  width: 22px;
  height: 22px;
  background-image: url(../img/recruit-list-img.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: 50%;
  display: inline-block;
  line-height: 1;
  vertical-align: sub;
  margin-left: -42px;
  margin-right: 20px;
}

@media screen and (max-width: 767px) {
  .recruit-page .person .box h3 span.icon {
    margin-left: -20px;
    margin-right: 6px;
  }
}
.recruit-page .person .box p {
  color: #0063e0;
  font-weight: 900;
  padding: 0 10px;
  line-height: 1.75;
  letter-spacing: 1px;
}

.recruit-page .person .box .circle {
  width: 20px;
  height: 20px;
  display: block;
  border-radius: 100%;
  background-color: #aed0fc;
  position: absolute;
  top: 14px;
  right: -20%;
}

@media screen and (max-width: 767px) {
  .recruit-page .person .box .circle {
    top: 16px;
    right: -31px;
  }
}
.recruit-page .person .box .circle.active {
  background-color: #0063e0;
  -webkit-animation: blink-circle 1s ease-in-out infinite none;
  animation: blink-circle 1s ease-in-out infinite none;
}

@-webkit-keyframes blink-circle {
  0% {
    -webkit-box-shadow: 0 0 0 0 rgba(0, 99, 224, 0.6);
    box-shadow: 0 0 0 0 rgba(0, 99, 224, 0.6);
  }
  100% {
    -webkit-box-shadow: 0 0 0 6px rgba(0, 99, 224, 0.3);
    box-shadow: 0 0 0 6px rgba(0, 99, 224, 0.3);
  }
}
@keyframes blink-circle {
  0% {
    -webkit-box-shadow: 0 0 0 0 rgba(0, 99, 224, 0.6);
    box-shadow: 0 0 0 0 rgba(0, 99, 224, 0.6);
  }
  100% {
    -webkit-box-shadow: 0 0 0 6px rgba(0, 99, 224, 0.3);
    box-shadow: 0 0 0 6px rgba(0, 99, 224, 0.3);
  }
}
.recruit-page .ess {
  background-color: #1471e6;
}

.recruit-page .ess .inner {
  padding: 60px 10px;
}

@media screen and (max-width: 767px) {
  .recruit-page .ess .inner {
    padding: 40px 10px;
  }
}
.recruit-page .ess h2 {
  text-align: center;
  color: #fff;
  font-size: 20px;
  margin-bottom: 40px;
}

.recruit-page .ess .table {
  width: 100%;
  color: #fff;
  border-collapse: separate;
  border-spacing: 10px 6px;
}

.recruit-page .ess .table th {
  width: 30%;
  padding: 10px;
  border-bottom: 2px solid #fff;
}

.recruit-page .ess .table td {
  padding: 10px 20px;
  border-bottom: 2px solid #fff;
}

.recruit-page .ess .btn {
  text-align: center;
  margin-top: 60px;
}

@media screen and (max-width: 767px) {
  .recruit-page .ess .btn {
    margin-top: 40px;
  }
}
.recruit-page .ess .btn a {
  display: inline-block;
  background-color: #fff;
  color: #0063e0;
  font-size: 22px;
  padding: 10px 70px;
  border-radius: 4px;
  background-image: url(../img/recruit-btn2-img.png);
  background-size: 34px;
  background-position: 94% 50%;
}

@media screen and (max-width: 767px) {
  .recruit-page .ess .btn a {
    font-size: 18px;
    padding: 14px 58px 14px 28px;
  }
}
.recruit-page .form .inner {
  padding: 60px 10px;
}

@media screen and (max-width: 767px) {
  .recruit-page .form .inner {
    padding: 40px 10px;
  }
}
.recruit-page .form .banner {
  text-align: center;
  margin-bottom: 60px;
}

@media screen and (max-width: 767px) {
  .recruit-page .form .banner {
    margin-bottom: 40px;
  }
}
.recruit-page .form .banner img {
  width: 600px;
}

@media screen and (max-width: 767px) {
  .recruit-page .form .banner img {
    max-width: 500px;
    width: 100%;
  }
}
.recruit-page .form .form-area .box {
  margin: 0 0 20px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

@media screen and (max-width: 767px) {
  .recruit-page .form .form-area .box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
    margin-bottom: 0;
  }
}
.recruit-page .form .form-area .box .half {
  width: 48%;
}

@media screen and (max-width: 767px) {
  .recruit-page .form .form-area .box .half {
    width: 100%;
    margin-bottom: 20px;
  }
}
.recruit-page .form .form-area .box .all {
  width: 100%;
}

.recruit-page .form .form-area .box .ttl {
  margin-bottom: 10px;
  font-weight: 900;
  color: #1e2f43;
  padding: 8px 10px 8px 16px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .recruit-page .form .form-area .box .ttl {
    background-color: #1e2f43;
    color: #fff;
    margin-bottom: 20px;
    padding-left: 68px;
  }
}
.recruit-page .form .form-area .box .ttl:before {
  content: "";
  width: 8px;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background-color: #1e2f43;
  border-radius: 4px;
}

@media screen and (max-width: 767px) {
  .recruit-page .form .form-area .box .ttl:before {
    content: none;
  }
}
.recruit-page .form .form-area .box .ttl .req {
  display: inline-block;
  background-color: #ff363c;
  padding: 6px 12px;
  color: #fff;
  line-height: 1;
  font-size: 10px;
  -webkit-box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
  box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
  margin-left: 4px;
}

@media screen and (max-width: 767px) {
  .recruit-page .form .form-area .box .ttl .req {
    font-size: 12px;
    position: absolute;
    top: 50%;
    left: 6px;
    -webkit-transform: translateY(-50%) translateX(0%);
    -ms-transform: translateY(-50%) translateX(0%);
    transform: translateY(-50%) translateX(0%);
  }
}
.recruit-page .form .form-area .box .ttl .not-req {
  display: inline-block;
  background-color: #1e2f43;
  padding: 6px 12px;
  color: #fff;
  line-height: 1;
  font-size: 10px;
  -webkit-box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
  box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
  margin-left: 4px;
}

@media screen and (max-width: 767px) {
  .recruit-page .form .form-area .box .ttl .not-req {
    font-size: 12px;
    background-color: #1471e6;
    position: absolute;
    top: 50%;
    left: 6px;
    -webkit-transform: translateY(-50%) translateX(0%);
    -ms-transform: translateY(-50%) translateX(0%);
    transform: translateY(-50%) translateX(0%);
  }
}
@media screen and (max-width: 767px) {
  .recruit-page .form .form-area .box .ttl.not {
    background-color: #d6e9ff;
    color: #1e2f43;
  }
}
.recruit-page .form .form-area .box .input-area {
  position: relative;
}

@media screen and (max-width: 767px) {
  .recruit-page .form .form-area .box .input-area {
    padding: 0 10px;
  }
}
.recruit-page .form .form-area .box .input-area input[type=text], .recruit-page .form .form-area .box .input-area input[type=tel], .recruit-page .form .form-area .box .input-area input[type=email], .recruit-page .form .form-area .box .input-area input[type=date] {
  width: 100%;
  height: 50px;
  padding: 10px;
  border-radius: 4px;
  color: #1e2f43;
  border: 2px solid #1e2f43;
  -webkit-box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
  box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
}

.recruit-page .form .form-area .box .input-area input[type=text]::-webkit-input-placeholder, .recruit-page .form .form-area .box .input-area input[type=tel]::-webkit-input-placeholder, .recruit-page .form .form-area .box .input-area input[type=email]::-webkit-input-placeholder, .recruit-page .form .form-area .box .input-area input[type=date]::-webkit-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.recruit-page .form .form-area .box .input-area input[type=text]:-ms-input-placeholder, .recruit-page .form .form-area .box .input-area input[type=tel]:-ms-input-placeholder, .recruit-page .form .form-area .box .input-area input[type=email]:-ms-input-placeholder, .recruit-page .form .form-area .box .input-area input[type=date]:-ms-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.recruit-page .form .form-area .box .input-area input[type=text]::-ms-input-placeholder, .recruit-page .form .form-area .box .input-area input[type=tel]::-ms-input-placeholder, .recruit-page .form .form-area .box .input-area input[type=email]::-ms-input-placeholder, .recruit-page .form .form-area .box .input-area input[type=date]::-ms-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.recruit-page .form .form-area .box .input-area input[type=text]::placeholder, .recruit-page .form .form-area .box .input-area input[type=tel]::placeholder, .recruit-page .form .form-area .box .input-area input[type=email]::placeholder, .recruit-page .form .form-area .box .input-area input[type=date]::placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .recruit-page .form .form-area .box .input-area input[type=text], .recruit-page .form .form-area .box .input-area input[type=tel], .recruit-page .form .form-area .box .input-area input[type=email], .recruit-page .form .form-area .box .input-area input[type=date] {
    height: 45px;
    border: 2px solid #d6e9ff;
  }
}
.recruit-page .form .form-area .box .input-area select {
  width: 70%;
  height: 50px;
  padding: 10px;
  border-radius: 4px;
  color: #1e2f43;
  border: 2px solid #1e2f43;
  -webkit-box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
  box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
}

@media screen and (max-width: 767px) {
  .recruit-page .form .form-area .box .input-area select {
    height: 45px;
    border: 2px solid #d6e9ff;
  }
}
.recruit-page .form .form-area .box .input-area textarea {
  width: 100%;
  height: 160px;
  padding: 10px;
  border-radius: 4px;
  font-weight: 900;
  color: #1e2f43;
  border: 2px solid #1e2f43;
  -webkit-box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
  box-shadow: 0 1px 5px 1px rgba(0, 0, 0, 0.2);
}

.recruit-page .form .form-area .box .input-area textarea::-webkit-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.recruit-page .form .form-area .box .input-area textarea:-ms-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.recruit-page .form .form-area .box .input-area textarea::-ms-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.recruit-page .form .form-area .box .input-area textarea::placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .recruit-page .form .form-area .box .input-area textarea {
    border: 2px solid #d6e9ff;
  }
}
.recruit-page .form .form-area .box .input-area select.req {
  border: 2px solid #ff363c;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .recruit-page .form .form-area .box .input-area select.req {
    border: 2px solid #1e2f43;
  }
}
.recruit-page .form .form-area .box .input-area input.req[type=text], .recruit-page .form .form-area .box .input-area input.req[type=tel], .recruit-page .form .form-area .box .input-area input.req[type=email], .recruit-page .form .form-area .box .input-area input.req[type=date] {
  font-weight: 900;
  border: 2px solid #ff363c;
}

@media screen and (max-width: 767px) {
  .recruit-page .form .form-area .box .input-area input.req[type=text], .recruit-page .form .form-area .box .input-area input.req[type=tel], .recruit-page .form .form-area .box .input-area input.req[type=email], .recruit-page .form .form-area .box .input-area input.req[type=date] {
    border: 2px solid #1e2f43;
  }
}
.recruit-page .form .form-area .box .input-area textarea.req {
  font-weight: 900;
  border: 2px solid #ff363c;
}

.recruit-page .form .form-area .box .attention {
  width: 100%;
  margin-top: 10px;
  color: #1e2f43;
  font-weight: 900;
  font-size: 12px;
}

@media screen and (max-width: 767px) {
  .recruit-page .form .form-area .box .attention {
    padding: 0 10px;
  }
}
.recruit-page .form .form-area .box .select-point.all {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 12px;
  position: absolute;
  top: 18px;
  line-height: 1;
  right: 34%;
  display: block;
}

.recruit-page .form .form-area .btn {
  text-align: center;
  margin-top: 40px;
}

.recruit-page .form .form-area .btn input[type=submit] {
  background-color: #ff363c;
  color: #fff;
  font-weight: 900;
  padding: 20px 60px;
  display: inline-block;
  border-radius: 6px;
  background-image: url(../img/contact-btn-icon1.png);
  background-size: 22px;
  background-position: 94% 50%;
  background-repeat: no-repeat;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
}

.recruit-page .form .form-area .btn .attention {
  width: 100%;
  margin-top: 20px;
  color: #1e2f43;
  font-weight: 900;
  font-size: 12px;
}

.faq-page .fv {
  background-size: cover;
  background-position: center top;
}

.faq-page .fv .inner {
  padding: 80px 0;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .faq-page .fv .inner {
    padding: 60px 10px;
  }
}
.faq-page .fv h1 {
  color: #1e2f43;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .faq-page .fv h1 {
    font-size: 22px;
  }
}
.faq-page .faq-wrap .inner {
  padding: 40px 10px;
}

.faq-page .faq-wrap .list li {
  margin-bottom: 10px;
  position: relative;
  border: 1px solid #f4f4f4;
  border-radius: 6px;
  overflow: hidden;
}

.faq-page .faq-wrap .list .ttl {
  padding: 20px 20px 20px 40px;
  color: #1e2f43;
  font-size: 16px;
  font-weight: 900;
  cursor: pointer;
}

@media screen and (max-width: 767px) {
  .faq-page .faq-wrap .list .ttl {
    padding: 20px 10px 20px 40px;
    font-size: 14px;
  }
}
.faq-page .faq-wrap .list .ttl .icon {
  display: inline-block;
  margin-left: -22px;
  margin-right: 6px;
  color: #2a98d2;
}

.faq-page .faq-wrap .list .txt {
  padding: 0 20px 20px 40px;
  letter-spacing: 1px;
  line-height: 1.75;
  display: none;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .faq-page .faq-wrap .list .txt {
    padding: 0 10px 20px 40px;
    font-size: 12px;
  }
}
.faq-page .faq-wrap .list .txt .icon {
  display: inline-block;
  margin-left: -20px;
  margin-right: -3px;
  color: #ff373c;
}

.faq-page .banner.bottom .inner {
  padding: 16px 10px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .faq-page .banner.bottom .inner {
    padding: 20px 10px 10px;
    max-width: 500px;
  }
}
.faq-page .banner.bottom h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  padding: 40px 0;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .faq-page .banner.bottom h2 {
    font-size: 20px;
    padding: 40px 0 20px;
  }
}
.faq-page .banner.bottom .campaign {
  margin-top: 10px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .faq-page .banner.bottom .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
    margin-bottom: 10px;
  }
}
.faq-page .banner.bottom .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .faq-page .banner.bottom .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.faq-page .banner.bottom .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .faq-page .banner.bottom .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.faq-page .banner.bottom .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .faq-page .banner.bottom .campaign .img span {
    font-size: 12px;
  }
}
.faq-page .banner.bottom .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .faq-page .banner.bottom .campaign .img span b {
    font-size: 10px;
  }
}
.faq-page .banner.bottom .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .faq-page .banner.bottom .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.faq-page .banner.bottom .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .faq-page .banner.bottom .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.faq-page .banner.bottom .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.faq-page .banner.bottom .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .faq-page .banner.bottom .campaign .txt .cost {
    font-size: 16px;
  }
}
.faq-page .banner.bottom .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .faq-page .banner.bottom .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.faq-page .banner.bottom .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .faq-page .banner.bottom .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.faq-page .banner.bottom .attention {
  margin: 10px 0;
}

.faq-page .banner.bottom .attention p {
  color: #1e2f43;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.faq-page .banner.bottom .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.faq-page .banner.bottom .list li {
  width: 49%;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .faq-page .banner.bottom .list li {
    margin: 0 0 10px 0;
  }
}
.faq-page .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.faq-page .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .faq-page .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.faq-page .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .faq-page .btn-area.bottom-area .btn {
    margin-top: 0;
  }
}
.faq-page .btn-area.bottom-area .btn .left, .faq-page .btn-area.bottom-area .btn .right {
  width: 49%;
}

.faq-page .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .faq-page .btn-area.bottom-area .btn .left a {
    background-image: url(../img/top-btn-icon1-img.svg);
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
  }
}
.faq-page .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .faq-page .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
}
.faq-page .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .faq-page .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.faq-page .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .faq-page .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.faq-page .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .faq-page .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}
.change-course-page .fv {
  position: relative;
}

.change-course-page .fv .inner {
  max-width: 660px;
  padding: 18px 100px 7px;
}

@media screen and (max-width: 767px) {
  .change-course-page .fv .inner {
    padding: 40px 10px 20px;
    position: relative;
  }
}
@media screen and (max-width: 767px) {
  .change-course-page .fv .txt {
    position: relative;
    z-index: 1;
    margin-bottom: 40px;
  }
}
.change-course-page .fv .headline {
  text-align: center;
}

@media screen and (max-width: 767px) {
  .change-course-page .fv .headline {
    text-align: left;
    padding-left: 44px;
  }
}
.change-course-page .fv .headline span {
  color: #fff;
  font-weight: 900;
  border-bottom: 2px solid #fff;
  display: inline-block;
  margin-bottom: 20px;
  padding-bottom: 4px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .change-course-page .fv .headline span {
    font-size: 16px;
  }
}
.change-course-page .fv h1 {
  color: #fff;
  font-weight: 900;
  letter-spacing: 2px;
  font-size: 32px;
  line-height: 1.2;
  font-style: italic;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .change-course-page .fv h1 {
    font-size: 26px;
    letter-spacing: 0;
    text-align: left;
  }
}
.change-course-page .fv h1 span {
  font-size: 44px;
}

@media screen and (max-width: 767px) {
  .change-course-page .fv h1 span {
    font-size: 40px;
  }
}
.change-course-page .price {
  background-color: #fefc36;
}

.change-course-page .price .headline {
  margin: 40px 0;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .headline {
    padding: 0 10px;
  }
}
.change-course-page .price .headline strong {
  font-weight: 400;
  font-size: 20px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .headline strong {
    font-size: 18px;
  }
}
.change-course-page .price .headline p {
  margin-top: 10px;
}

.change-course-page .price .tab-area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  cursor: pointer;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  margin-top: 40px;
}

.change-course-page .price .tab-area .tab {
  width: 24.6%;
  text-align: center;
  color: white;
  border-radius: 6px 6px 0 0;
  background-color: #1e2f43;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .tab-area .tab {
    width: 23.3333333333%;
  }
}
.change-course-page .price .tab-area .tab.other {
  padding: 10px 0;
}

.change-course-page .price .tab-area .tab.other .name {
  font-weight: 900;
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .tab-area .tab.other .name {
    font-size: 12px;
  }
}
.change-course-page .price .tab-area .tab.other .name small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  display: block;
  font-size: 10px;
  margin-top: 2px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .tab-area .tab.other .name small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    letter-spacing: 0;
  }
}
.change-course-page .price .tab-area .tab.special {
  padding: 10px 10px 10px 30px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .tab-area .tab.special {
    padding: 10px 2px;
  }
}
.change-course-page .price .tab-area .tab.special .point {
  background-color: #fff268;
  display: block;
  width: 44px;
  height: 44px;
  border-radius: 100%;
  color: #000;
  font-weight: 900;
  position: absolute;
  top: -10px;
  left: -6px;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .tab-area .tab.special .point {
    width: 40px;
    height: 40px;
    top: -30px;
    left: 4px;
  }
}
.change-course-page .price .tab-area .tab.special .point span {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  font-size: 12px;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .tab-area .tab.special .point span {
    font-size: 10px;
  }
}
.change-course-page .price .tab-area .tab.special .point span b {
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .tab-area .tab.special .point span b {
    font-size: 10px;
  }
}
.change-course-page .price .tab-area .tab.special .name {
  font-weight: 900;
  font-size: 14px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .tab-area .tab.special .name {
    font-size: 12px;
    letter-spacing: 0;
  }
}
.change-course-page .price .tab-area .tab.special .name small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #fff268;
  display: block;
  font-size: 10px;
  margin-top: 2px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .tab-area .tab.special .name small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    letter-spacing: 0;
  }
}
.change-course-page .price .tab-area .tab.active {
  background-color: #ff373c;
  padding: 12px 10px 12px 10px;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .tab-area .tab.active {
    padding: 12px 2px 12px 2px;
    width: 29%;
  }
}
.change-course-page .price .tab-area .tab.active .name {
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .tab-area .tab.active .name {
    font-size: 12px;
  }
}
.change-course-page .price .tab-area .tab.active.special {
  padding: 12px 10px 12px 20px;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .tab-area .tab.active.special {
    padding: 12px 2px 12px 2px;
    width: 29%;
  }
}
.change-course-page .price .content-area .content {
  display: none;
}

.change-course-page .price .content-area .content.show {
  display: block;
}

.change-course-page .price .inner {
  padding: 0 10px 10px;
}

.change-course-page .price .box {
  margin: 0 0 40px 0;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .box:last-child {
    margin-bottom: 0;
  }
}
.change-course-page .price .box .member {
  background-color: #1e2f43;
  position: relative;
  border-radius: 6px 6px 0 0;
  color: #fff;
  padding: 14px 40px;
  font-size: 16px;
  letter-spacing: 1px;
}

.change-course-page .price .box .member.first {
  background-color: #ff363c;
  padding: 14px 70px;
}

.change-course-page .price .box .member.first .point {
  background-color: #fff268;
  display: block;
  width: 46px;
  height: 46px;
  border-radius: 100%;
  color: #000;
  font-weight: 900;
  position: absolute;
  top: -10px;
  left: 10px;
  letter-spacing: 0;
}

.change-course-page .price .box .member.first .point:after {
  content: "";
  position: absolute;
  bottom: 0;
  right: -2px;
  margin-top: -4px;
  border: 4px solid transparent;
  border-left: 8px solid #fff268;
  z-index: 0;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}

.change-course-page .price .box .member.first .point span {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  font-size: 12px;
  text-align: center;
}

.change-course-page .price .box .content-area {
  background-color: #fff;
  padding: 20px 40px 30px 40px;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .box .content-area {
    padding: 20px;
  }
}
.change-course-page .price .box .content-area .name {
  text-align: center;
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 1px;
  line-height: 1.6;
  margin: 10px 0 20px 0;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .box .content-area .name {
    font-size: 14px;
    letter-spacing: 0;
    margin: 0 0 20px 0;
  }
}
.change-course-page .price .box .content-area .table {
  width: 100%;
  margin: 20px 0 10px;
  font-weight: 900;
}

.change-course-page .price .box .content-area .table th {
  background-color: #f4fbfe;
  color: #2ca8e8;
  padding: 14px 0;
  letter-spacing: 1px;
  width: 40%;
  border-bottom: 2px solid #f4f4f4;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .box .content-area .table th {
    padding: 10px 0;
    width: 30%;
    font-size: 12px;
  }
}
.change-course-page .price .box .content-area .table td {
  font-family: Century Gothic;
  background-color: #fff;
  width: 60%;
  text-align: center;
  padding: 20px 10px;
  border-bottom: 2px solid #f4f4f4;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .box .content-area .table td {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    width: 70%;
    padding: 14px 10px;
    font-size: 14px;
  }
}
.change-course-page .price .box .content-area .table td .border {
  text-decoration: line-through;
}

.change-course-page .price .box .content-area .table td .color {
  color: #ff373c;
}

.change-course-page .price .box .content-area .attention p {
  font-weight: 900;
  font-size: 12px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .box .content-area .attention p {
    font-size: 10px;
  }
}
.change-course-page .price .notice {
  margin: 40px 0;
}

.change-course-page .price .notice h2 {
  color: #1e2f43;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: 2px;
  padding-bottom: 10px;
  margin: 20px 0;
  position: relative;
  background-repeat: repeat-x;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .notice h2 {
    font-size: 20px;
  }
}
.change-course-page .price .notice h2:after {
  content: "";
  width: 100%;
  height: 4px;
  bottom: 0;
  left: 0;
  position: absolute;
  background-image: url(../img/page-h2-img.png);
  background-size: contain;
  background-position: 0 100%;
}

@media screen and (max-width: 767px) {
  .change-course-page .price .notice h2:after {
    background-size: auto;
  }
}
.change-course-page .price .notice .txt {
  background-color: #f4fbfe;
  padding: 20px;
  color: #1e2f43;
  margin-bottom: 30px;
}

.change-course-page .price .notice .txt p {
  line-height: 1.9;
}

.change-course-page .price .notice .txt b {
  display: inline-block;
}

.change-course-page .price .notice .txt b span {
  width: 10px;
  height: 10px;
  display: inline-block;
  background-color: #1e2f43;
  margin-right: 6px;
}

.change-course-page .price .news {
  padding-top: 40px;
}

.change-course-page .price .news .ttl {
  text-align: center;
  font-size: 20px;
  margin-bottom: 14px;
}

.change-course-page .price .news .txt {
  text-align: center;
  font-size: 12px;
  line-height: 1.5;
}

.change-course-page .reason {
  background-color: #f3fbfe;
}

.change-course-page .reason .inner {
  padding: 0 10px 10px;
}

.change-course-page .reason h2 {
  text-align: center;
  font-size: 20px;
  margin-bottom: 40px;
  padding-top: 40px;
}

@media screen and (max-width: 767px) {
  .change-course-page .reason h2 {
    padding-top: 20px;
    font-size: 18px;
  }
}
.change-course-page .reason .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.change-course-page .reason .list .box {
  width: 48%;
  margin-bottom: 40px;
}

@media screen and (max-width: 767px) {
  .change-course-page .reason .list .box {
    width: 100%;
  }
}
.change-course-page .reason .list .box .ttl {
  background-color: #ff002e;
  text-align: center;
  color: #fff;
  padding: 10px 0;
  border-radius: 10px 10px 0 0;
  margin-bottom: 2px;
}

.change-course-page .reason .list .box .txt {
  border: 2px solid #1e2f43;
  background-color: #fff;
  padding: 10px;
  border-radius: 0 0 10px 10px;
}

.change-course-page .reason .list .box .txt .img {
  text-align: center;
  margin-bottom: 10px;
}

.change-course-page .reason .list .box .txt p {
  color: #1e2f43;
  line-height: 1.75;
  font-size: 12px;
}

.change-course-page .reason .list .box1 .img img {
  width: 50px;
}

.change-course-page .reason .list .box2 .img img {
  width: 60px;
}

.change-course-page .reason .list .box3 .img img {
  width: 68px;
}

.change-course-page .reason .list .box4 .img img {
  width: 66px;
}

.change-course-page .compare {
  background-color: #f3fbfe;
}

.change-course-page .compare .inner {
  padding: 0 10px 40px;
}

.change-course-page .compare h2 {
  text-align: center;
  font-size: 20px;
  margin-bottom: 40px;
}

@media screen and (max-width: 767px) {
  .change-course-page .compare h2 {
    font-size: 18px;
  }
}
.change-course-page .compare .table .ttl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-pack: distribute;
  justify-content: space-around;
}

.change-course-page .compare .table .ttl .name {
  width: 40%;
  text-align: center;
  color: #fff;
  padding: 14px;
  position: relative;
  border-radius: 4px;
  margin-bottom: 40px;
}

@media screen and (max-width: 767px) {
  .change-course-page .compare .table .ttl .name {
    width: 48%;
    padding: 14px 6px;
    margin-bottom: 20px;
  }
}
.change-course-page .compare .table .ttl .name.blue {
  background-color: #1e2f43;
}

.change-course-page .compare .table .ttl .name.blue:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -6px;
  border: 6px solid transparent;
  border-top: 10px solid #1e2f43;
}

.change-course-page .compare .table .ttl .name.red {
  background-color: #e10f0f;
}

.change-course-page .compare .table .ttl .name.red:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -6px;
  border: 6px solid transparent;
  border-top: 10px solid #e10f0f;
}

.change-course-page .compare .table .list {
  position: relative;
  background-color: #f2f2f2;
  padding: 0 14px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .change-course-page .compare .table .list {
    padding-top: 20px;
  }
}
.change-course-page .compare .table .list:before {
  content: "";
  width: 50%;
  right: 0;
  top: 0;
  height: 100%;
  background-color: #e10f0f;
  position: absolute;
  z-index: -1;
}

.change-course-page .compare .table .list:last-child .left, .change-course-page .compare .table .list:last-child .right {
  border-bottom: none;
}

.change-course-page .compare .table .list .left, .change-course-page .compare .table .list .right {
  width: 50%;
  border-bottom: dashed 1px #1e2f43;
  text-align: center;
  padding: 16px 0;
  min-height: 90px;
}

@media screen and (max-width: 767px) {
  .change-course-page .compare .table .list .left, .change-course-page .compare .table .list .right {
    padding: 16px 0;
  }
}
.change-course-page .compare .table .list .left strong, .change-course-page .compare .table .list .right strong {
  display: block;
  margin-top: 10px;
}

.change-course-page .compare .table .list .left strong span, .change-course-page .compare .table .list .right strong span {
  font-size: 18px;
}

@media screen and (max-width: 767px) {
  .change-course-page .compare .table .list .left strong span, .change-course-page .compare .table .list .right strong span {
    font-size: 16px;
  }
}
.change-course-page .compare .table .list .left {
  color: #1e2f43;
  position: relative;
}

@media screen and (max-width: 767px) {
  .change-course-page .compare .table .list .left {
    padding-right: 10px;
  }
}
.change-course-page .compare .table .list .right {
  color: #fff;
  position: relative;
}

@media screen and (max-width: 767px) {
  .change-course-page .compare .table .list .right {
    padding-left: 10px;
  }
}
.change-course-page .compare .table .list .point {
  border: 1px solid #1e2f43;
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 4px 20px;
  background-color: #fff;
  border-radius: 30px;
  position: absolute;
  top: 12px;
  right: 0;
  left: 0;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .change-course-page .compare .table .list .point {
    font-size: 12px;
    top: 6px;
    padding: 2px 0px;
    text-align: center;
    width: 140px;
  }
}
.change-course-page .compare .table .list .float-txt {
  display: block;
  position: absolute;
  bottom: 14px;
  right: 0;
  left: 0;
  margin: 0 auto;
  text-align: center;
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 2px;
}

@media screen and (max-width: 767px) {
  .change-course-page .compare .table .list .float-txt {
    font-size: 16px;
    bottom: 30px;
  }
}
.change-course-page .compare .table .list .float-txt span {
  color: #fff;
}

.change-course-page .compare .table .list .float-txt.txt01 {
  text-indent: -18px;
}

@media screen and (max-width: 767px) {
  .change-course-page .compare .table .list .float-txt.txt01 {
    text-indent: -14px;
  }
}
.change-course-page .compare .table .list .float-txt.txt02 {
  text-indent: 2px;
}

@media screen and (max-width: 767px) {
  .change-course-page .compare .table .list .float-txt.txt02 {
    text-indent: 1px;
  }
}
.change-course-page .banner.bottom .inner {
  padding: 16px 10px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .change-course-page .banner.bottom .inner {
    padding: 20px 10px 10px;
    max-width: 500px;
  }
}
.change-course-page .banner.bottom h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  padding: 40px 0;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .change-course-page .banner.bottom h2 {
    font-size: 20px;
    padding: 40px 0 20px;
  }
}
.change-course-page .banner.bottom .campaign {
  margin-top: 10px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .change-course-page .banner.bottom .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
    margin-bottom: 10px;
  }
}
.change-course-page .banner.bottom .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .change-course-page .banner.bottom .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.change-course-page .banner.bottom .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .change-course-page .banner.bottom .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.change-course-page .banner.bottom .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .change-course-page .banner.bottom .campaign .img span {
    font-size: 12px;
  }
}
.change-course-page .banner.bottom .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .change-course-page .banner.bottom .campaign .img span b {
    font-size: 10px;
  }
}
.change-course-page .banner.bottom .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .change-course-page .banner.bottom .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.change-course-page .banner.bottom .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .change-course-page .banner.bottom .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.change-course-page .banner.bottom .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.change-course-page .banner.bottom .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .change-course-page .banner.bottom .campaign .txt .cost {
    font-size: 16px;
  }
}
.change-course-page .banner.bottom .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .change-course-page .banner.bottom .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.change-course-page .banner.bottom .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .change-course-page .banner.bottom .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.change-course-page .banner.bottom .attention {
  margin: 10px 0;
}

.change-course-page .banner.bottom .attention p {
  color: #1e2f43;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.change-course-page .banner.bottom .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.change-course-page .banner.bottom .list li {
  width: 49%;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .change-course-page .banner.bottom .list li {
    margin: 0 0 10px 0;
  }
}
.change-course-page .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.change-course-page .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .change-course-page .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.change-course-page .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .change-course-page .btn-area.bottom-area .btn {
    margin-top: 0;
  }
}
.change-course-page .btn-area.bottom-area .btn .left, .change-course-page .btn-area.bottom-area .btn .right {
  width: 49%;
}

.change-course-page .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .change-course-page .btn-area.bottom-area .btn .left a {
    background-image: url(../img/top-btn-icon1-img.svg);
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
  }
}
.change-course-page .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .change-course-page .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
}
.change-course-page .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .change-course-page .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.change-course-page .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .change-course-page .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.change-course-page .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .change-course-page .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}
.news-page .fv {
  background-size: cover;
  background-position: center top;
}

.news-page .fv .inner {
  padding: 80px 0;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .news-page .fv .inner {
    padding: 60px 10px;
  }
}
.news-page .fv h1 {
  color: #1e2f43;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .news-page .fv h1 {
    font-size: 22px;
  }
}
.news-page .news {
  background-color: #f4f4f4;
}

.news-page .news .inner {
  padding: 60px 10px;
}

@media screen and (max-width: 767px) {
  .news-page .news .inner {
    padding: 40px 10px;
  }
}
.news-page .news .list {
  max-width: 460px;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .news-page .news .list {
    max-width: 400px;
  }
}
.news-page .news .dl-box {
  margin-bottom: 20px;
  position: relative;
  font-weight: 900;
  font-size: 12px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.news-page .news .dl-box dt {
  font-family: Century Gothic;
  width: 20%;
  padding-right: 10px;
  color: #2ca8e8;
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  .news-page .news .dl-box dt {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    width: 30%;
    font-size: 12px;
  }
}
.news-page .news .dl-box dd {
  width: 80%;
}

@media screen and (max-width: 767px) {
  .news-page .news .dl-box dd {
    width: 70%;
  }
}
.news-page .news .dl-box dd a {
  color: #000;
}

.news-page .banner.bottom .inner {
  padding: 16px 10px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .news-page .banner.bottom .inner {
    padding: 20px 10px 10px;
    max-width: 500px;
  }
}
.news-page .banner.bottom h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  padding: 40px 0;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .news-page .banner.bottom h2 {
    font-size: 20px;
    padding: 40px 0 20px;
  }
}
.news-page .banner.bottom .campaign {
  margin-top: 10px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .news-page .banner.bottom .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
    margin-bottom: 10px;
  }
}
.news-page .banner.bottom .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .news-page .banner.bottom .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.news-page .banner.bottom .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .news-page .banner.bottom .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.news-page .banner.bottom .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .news-page .banner.bottom .campaign .img span {
    font-size: 12px;
  }
}
.news-page .banner.bottom .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .news-page .banner.bottom .campaign .img span b {
    font-size: 10px;
  }
}
.news-page .banner.bottom .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .news-page .banner.bottom .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.news-page .banner.bottom .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .news-page .banner.bottom .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.news-page .banner.bottom .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.news-page .banner.bottom .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .news-page .banner.bottom .campaign .txt .cost {
    font-size: 16px;
  }
}
.news-page .banner.bottom .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .news-page .banner.bottom .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.news-page .banner.bottom .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .news-page .banner.bottom .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.news-page .banner.bottom .attention {
  margin: 10px 0;
}

.news-page .banner.bottom .attention p {
  color: #1e2f43;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.news-page .banner.bottom .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.news-page .banner.bottom .list li {
  width: 49%;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .news-page .banner.bottom .list li {
    margin: 0 0 10px 0;
  }
}
.news-page .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.news-page .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .news-page .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.news-page .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .news-page .btn-area.bottom-area .btn {
    margin-top: 0;
  }
}
.news-page .btn-area.bottom-area .btn .left, .news-page .btn-area.bottom-area .btn .right {
  width: 49%;
}

.news-page .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .news-page .btn-area.bottom-area .btn .left a {
    background-image: url(../img/top-btn-icon1-img.svg);
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
  }
}
.news-page .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .news-page .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
}
.news-page .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .news-page .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.news-page .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .news-page .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.news-page .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .news-page .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}
.page-temp .fv {
  background-size: cover;
  background-position: center top;
}

.page-temp .fv .inner {
  padding: 80px 0;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .page-temp .fv .inner {
    padding: 60px 10px;
  }
}
.page-temp .fv h1 {
  color: #1e2f43;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .page-temp .fv h1 {
    font-size: 22px;
  }
}
.page-temp .page-box .inner {
  padding: 40px 10px;
}

.page-temp .page-box h1 {
  color: #1e2f43;
  font-size: 22px;
  font-weight: 900;
  letter-spacing: 1px;
  text-align: center;
  margin-bottom: 20px;
}

@media screen and (max-width: 767px) {
  .page-temp .page-box h1 {
    font-size: 20px;
  }
}
.page-temp .page-box h2 {
  color: #1e2f43;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: 2px;
  padding-bottom: 10px;
  margin-bottom: 20px;
  position: relative;
  background-repeat: repeat-x;
}

@media screen and (max-width: 767px) {
  .page-temp .page-box h2 {
    font-size: 20px;
  }
}
.page-temp .page-box h2:after {
  content: "";
  width: 100%;
  height: 4px;
  bottom: 0;
  left: 0;
  position: absolute;
  background-image: url(../img/page-h2-img.png);
  background-size: contain;
  background-position: 0 100%;
}

@media screen and (max-width: 767px) {
  .page-temp .page-box h2:after {
    background-size: auto;
  }
}
.page-temp .page-box h3 {
  color: #1e2f43;
  font-size: 18px;
  letter-spacing: 1px;
  margin-bottom: 8px;
  padding: 6px 0 6px 30px;
  background-size: 18px;
  background-position: 4px 50%;
  font-weight: 900;
  background-image: url(../img/list-blue-icon-img.png);
}

@media screen and (max-width: 767px) {
  .page-temp .page-box h3 {
    font-size: 16px;
    background-size: 16px;
  }
}
.page-temp .page-box h3:nth-of-type(even) {
  background-image: url(../img/list-red-icon-img.png);
}

.page-temp .page-box h4 {
  color: #1e2f43;
  font-size: 18px;
  letter-spacing: 1px;
  margin-bottom: 8px;
  padding: 6px 0 6px 30px;
  font-weight: 900;
  position: relative;
}

@media screen and (max-width: 767px) {
  .page-temp .page-box h4 {
    font-size: 16px;
  }
}
.page-temp .page-box h4:before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 100%;
  border: 4px solid #1e2f43;
  position: absolute;
  top: 50%;
  left: 4px;
  -webkit-transform: translateY(-50%) translateX(0%);
  -ms-transform: translateY(-50%) translateX(0%);
  transform: translateY(-50%) translateX(0%);
}

@media screen and (max-width: 767px) {
  .page-temp .page-box h4:before {
    width: 8px;
    height: 8px;
  }
}
.page-temp .page-box p {
  margin: 0 0 20px;
  line-height: 1.75;
  letter-spacing: 1px;
  color: #1e2f43;
  font-weight: 900;
}

.page-temp .page-box ul {
  margin-bottom: 20px;
}

.page-temp .page-box ul li {
  line-height: 1.75;
}

.page-temp .page-box table {
  width: 100%;
  margin: 20px 0;
  font-weight: 900;
}

.page-temp .page-box table th {
  background-color: #f4fbfe;
  color: #2ca8e8;
  padding: 14px 0;
  letter-spacing: 1px;
  width: 40%;
  border-bottom: 2px solid #f4f4f4;
}

@media screen and (max-width: 767px) {
  .page-temp .page-box table th {
    padding: 10px;
    width: 30%;
    font-size: 12px;
  }
}
.page-temp .page-box table td {
  font-family: Century Gothic;
  background-color: #fff;
  width: 60%;
  text-align: center;
  padding: 20px 10px;
  border-bottom: 2px solid #f4f4f4;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .page-temp .page-box table td {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    width: 70%;
    padding: 14px 10px;
    font-size: 12px;
  }
}
.page-temp .page-box table td .border {
  text-decoration: line-through;
}

.page-temp .page-box table td .color {
  color: #ff373c;
}

.page-temp .page-box .thanks-txt .headline {
  color: #2d2b3d;
  text-align: center;
  line-height: 1.5;
  font-weight: 600;
  font-size: 30px;
  margin: 0 0 20px 0;
}

@media screen and (max-width: 767px) {
  .page-temp .page-box .thanks-txt .headline {
    font-size: 20px;
  }
}
.page-temp .page-box .thanks-txt .red {
  color: #ed1313;
  font-size: 18px;
  margin: 40px 0;
}

@media screen and (max-width: 767px) {
  .page-temp .page-box .thanks-txt .red {
    font-size: 16px;
  }
}
.page-temp .page-box .thanks-txt .red span {
  font-size: 28px;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .page-temp .page-box .thanks-txt .red span {
    font-size: 24px;
  }
}
.page-temp .page-box .text-box {
  text-align: center;
}

.page-temp .page-box .text-box .marker {
  background: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(0%, #f8eb84));
  background: linear-gradient(transparent 0%, #f8eb84 0%);
}

.page-temp .page-box .text-box b {
  display: inline-block;
  margin: 0 -2px;
  position: relative;
  color: #ff2f39;
  font-size: 16px;
  padding-top: 6px;
}

.page-temp .page-box .text-box b:before {
  content: "";
  width: 4px;
  height: 4px;
  display: block;
  background-color: #1e2f43;
  border-radius: 50%;
  right: 0;
  left: 0;
  position: absolute;
  margin: 0 auto;
  top: 5px;
}

.page-temp .page-box .border-box {
  width: 780px;
  margin: 40px auto 0;
  position: relative;
  border: 2px solid #00aee2;
  padding: 20px;
  text-align: center;
  line-height: 1.75;
  background-color: #f0fafe;
  color: #2d2b3d;
  font-weight: 600;
}

@media screen and (max-width: 767px) {
  .page-temp .page-box .border-box {
    width: 100%;
    padding: 20px 10px;
    font-size: 12px;
  }
}
.page-temp .page-box .border-box:before {
  content: "";
  position: absolute;
  top: -24px;
  left: 50%;
  margin-left: -8px;
  border: 8px solid transparent;
  border-bottom: 15px solid #00aee2;
}

.page-temp .page-box .border-box b {
  font-size: 16px;
}

.page-temp .page-box .border-box .marker {
  font-size: 16px;
  background: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(0%, #f8eb84));
  background: linear-gradient(transparent 0%, #f8eb84 0%);
  color: #2d2b3d;
  font-weight: 600;
}

.page-temp .page-box .border-box strong {
  display: inline-block;
  color: #ff2f39;
  font-size: 20px;
  letter-spacing: 1px;
  margin-bottom: 4px;
}

@media screen and (max-width: 767px) {
  .page-temp .page-box .border-box strong {
    font-size: 18px;
  }
}
.page-temp .page-box .border-box .btn {
  text-align: center;
  margin-top: 10px;
}

.page-temp .page-box .border-box .btn a {
  display: inline-block;
  background-color: #43e145;
  color: #fff;
  letter-spacing: 1px;
  font-size: 12px;
  padding: 12px 40px;
  border-radius: 6px;
  border-bottom: 4px solid #2ab230;
  cursor: pointer;
}

.page-temp .banner.bottom .inner {
  padding: 16px 10px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .page-temp .banner.bottom .inner {
    padding: 20px 10px 10px;
    max-width: 500px;
  }
}
.page-temp .banner.bottom h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  padding: 40px 0;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .page-temp .banner.bottom h2 {
    font-size: 20px;
    padding: 40px 0 20px;
  }
}
.page-temp .banner.bottom .campaign {
  margin-top: 10px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .page-temp .banner.bottom .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
    margin-bottom: 10px;
  }
}
.page-temp .banner.bottom .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .page-temp .banner.bottom .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.page-temp .banner.bottom .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .page-temp .banner.bottom .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.page-temp .banner.bottom .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .page-temp .banner.bottom .campaign .img span {
    font-size: 12px;
  }
}
.page-temp .banner.bottom .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .page-temp .banner.bottom .campaign .img span b {
    font-size: 10px;
  }
}
.page-temp .banner.bottom .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .page-temp .banner.bottom .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.page-temp .banner.bottom .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .page-temp .banner.bottom .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.page-temp .banner.bottom .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.page-temp .banner.bottom .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .page-temp .banner.bottom .campaign .txt .cost {
    font-size: 16px;
  }
}
.page-temp .banner.bottom .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .page-temp .banner.bottom .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.page-temp .banner.bottom .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .page-temp .banner.bottom .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.page-temp .banner.bottom .attention {
  margin: 10px 0;
}

.page-temp .banner.bottom .attention p {
  color: #1e2f43;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.page-temp .banner.bottom .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.page-temp .banner.bottom .list li {
  width: 49%;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .page-temp .banner.bottom .list li {
    margin: 0 0 10px 0;
  }
}
.page-temp .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.page-temp .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .page-temp .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.page-temp .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .page-temp .btn-area.bottom-area .btn {
    margin-top: 0;
  }
}
.page-temp .btn-area.bottom-area .btn .left, .page-temp .btn-area.bottom-area .btn .right {
  width: 49%;
}

.page-temp .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .page-temp .btn-area.bottom-area .btn .left a {
    background-image: url(../img/top-btn-icon1-img.svg);
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
  }
}
.page-temp .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .page-temp .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
}
.page-temp .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .page-temp .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.page-temp .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .page-temp .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.page-temp .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .page-temp .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}
.page-temp.page-404 .fv .inner {
  padding: 80px 0 0;
}

@media screen and (max-width: 767px) {
  .page-temp.page-404 .fv .inner {
    padding: 40px 0 0;
  }
}
.page-temp.page-404 .fv h1 {
  font-family: "Hiragino Sans", "Meiryo", "MS Pgothic", helvetica, arial, sans-serif;
  font-size: 60px;
  font-weight: 700;
  letter-spacing: 4px;
  line-height: 1;
  position: relative;
}

@media screen and (max-width: 767px) {
  .page-temp.page-404 .fv h1 {
    font-size: 44px;
  }
}
.page-temp.page-404 .fv h1:after {
  content: "";
  width: 24px;
  height: 22px;
  background-image: url(../img/404-ttl-img.png);
  position: absolute;
  top: -18px;
  background-position: center;
  right: 0;
  left: 16px;
  margin: 0 auto;
  background-size: cover;
}

.page-temp.page-404 .page-box .inner {
  text-align: center;
  padding: 40px 10px 120px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .page-temp.page-404 .page-box .inner {
    padding: 40px 10px 80px;
  }
}
.page-temp.page-404 .page-box strong {
  font-family: "Hiragino Sans", "Meiryo", "MS Pgothic", helvetica, arial, sans-serif;
  display: block;
  font-size: 18px;
  font-weight: 700;
  margin: 0 0 20px;
  line-height: 1.75;
  letter-spacing: 1px;
  color: #1e2f43;
  position: relative;
  z-index: 1;
}

.page-temp.page-404 .page-box p {
  position: relative;
  z-index: 1;
}

.page-temp.page-404 .page-box .serch-form {
  position: relative;
  z-index: 1;
  margin: 30px auto 0;
  width: 420px;
}

@media screen and (max-width: 767px) {
  .page-temp.page-404 .page-box .serch-form {
    width: 100%;
  }
}
.page-temp.page-404 .page-box .serch-form form {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.page-temp.page-404 .page-box .serch-form form input {
  width: 100%;
  border: 1px solid #1e2f43;
  padding: 6px 10px;
}

.page-temp.page-404 .page-box .serch-form form button {
  width: 34px;
  background-color: #1e2f43;
  padding: 6px 4px;
  border-radius: 0 4px 4px 0;
}

.page-temp.page-404 .page-box .serch-form form button img {
  width: 20px;
}

.page-temp.page-404 .page-box .btn {
  margin-top: 40px;
  position: relative;
  z-index: 1;
}

.page-temp.page-404 .page-box .btn a {
  background-color: #ff373c;
  padding: 14px 60px;
  color: #fff;
  border-radius: 30px;
  display: inline-block;
  font-weight: 900;
}

.page-temp.page-404 .page-box .cover {
  width: 100vw;
  height: 100%;
  position: absolute;
  background-image: url(../img/404-back-img.png);
  background-size: contain;
  background-position: top left;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  bottom: 0;
  border-bottom: 24px solid #00aaef;
}

@media screen and (max-width: 767px) {
  .page-temp.page-404 .page-box .cover {
    background-position: bottom left;
  }
}
.search-page .fv {
  background-size: cover;
  background-position: center top;
}

.search-page .fv .inner {
  padding: 80px 0;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .search-page .fv .inner {
    padding: 60px 10px;
  }
}
.search-page .fv h1 {
  color: #1e2f43;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .search-page .fv h1 {
    font-size: 22px;
  }
}
.search-page .page-box .inner {
  padding: 60px 10px;
}

@media screen and (max-width: 767px) {
  .search-page .page-box .inner {
    padding: 40px 10px;
  }
}
.search-page .page-box .list li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 20px;
}

@media screen and (max-width: 767px) {
  .search-page .page-box .list li {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.search-page .page-box .list .img {
  width: 30%;
}

@media screen and (max-width: 767px) {
  .search-page .page-box .list .img {
    width: 100%;
  }
}
.search-page .page-box .list .img .no-img {
  min-height: 200px;
  position: relative;
  background-color: #1e2f43;
}

.search-page .page-box .list .img .no-img span {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  display: block;
  width: 100%;
  text-align: center;
  color: #fff;
  font-weight: 900;
  font-size: 16px;
  font-family: Century Gothic;
  padding: 0 10px;
}

.search-page .page-box .list .txt {
  width: 70%;
  padding: 20px;
}

@media screen and (max-width: 767px) {
  .search-page .page-box .list .txt {
    width: 100%;
    padding: 20px 10px;
  }
}
.search-page .page-box .list .txt h2 {
  font-size: 18px;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .search-page .page-box .list .txt h2 {
    font-size: 16px;
  }
}
.search-page .page-box .list .txt h2 a {
  color: #47b2ea;
}

.search-page .page-box .list .txt p {
  letter-spacing: 1px;
  line-height: 1.75;
}

@media screen and (max-width: 767px) {
  .search-page .page-box .list .txt p {
    font-size: 12px;
  }
}
.search-page .page-box p.error-message {
  color: #1e2f43;
  font-weight: 900;
  text-align: center;
}

.search-page .banner.bottom .inner {
  padding: 16px 10px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .search-page .banner.bottom .inner {
    padding: 20px 10px 10px;
    max-width: 500px;
  }
}
.search-page .banner.bottom h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  padding: 40px 0;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .search-page .banner.bottom h2 {
    font-size: 20px;
    padding: 40px 0 20px;
  }
}
.search-page .banner.bottom .campaign {
  margin-top: 10px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .search-page .banner.bottom .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
    margin-bottom: 10px;
  }
}
.search-page .banner.bottom .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .search-page .banner.bottom .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.search-page .banner.bottom .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .search-page .banner.bottom .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.search-page .banner.bottom .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .search-page .banner.bottom .campaign .img span {
    font-size: 12px;
  }
}
.search-page .banner.bottom .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .search-page .banner.bottom .campaign .img span b {
    font-size: 10px;
  }
}
.search-page .banner.bottom .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .search-page .banner.bottom .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.search-page .banner.bottom .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .search-page .banner.bottom .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.search-page .banner.bottom .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.search-page .banner.bottom .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .search-page .banner.bottom .campaign .txt .cost {
    font-size: 16px;
  }
}
.search-page .banner.bottom .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .search-page .banner.bottom .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.search-page .banner.bottom .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .search-page .banner.bottom .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.search-page .banner.bottom .attention {
  margin: 10px 0;
}

.search-page .banner.bottom .attention p {
  color: #1e2f43;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.search-page .banner.bottom .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.search-page .banner.bottom .list li {
  width: 49%;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .search-page .banner.bottom .list li {
    margin: 0 0 10px 0;
  }
}
.search-page .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.search-page .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .search-page .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.search-page .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .search-page .btn-area.bottom-area .btn {
    margin-top: 0;
  }
}
.search-page .btn-area.bottom-area .btn .left, .search-page .btn-area.bottom-area .btn .right {
  width: 49%;
}

.search-page .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .search-page .btn-area.bottom-area .btn .left a {
    background-image: url(../img/top-btn-icon1-img.svg);
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
  }
}
.search-page .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .search-page .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
}
.search-page .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .search-page .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.search-page .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .search-page .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.search-page .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .search-page .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}
.single-shop-page .shop-fv .slick-prev.slick-arrow, .single-shop-page .shop-fv .slick-next.slick-arrow {
  display: none !important;
}

.single-shop-page .shop-fv .slick-list.draggable {
  height: 100%;
}

.single-shop-page .shop-fv .fv-slider {
  position: relative;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-fv .fv-slider {
    padding-bottom: 0;
    height: auto;
  }
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-fv .fv-slider .slider {
    margin: 0 2px;
    border-right: 1px solid #eee;
    border-left: 1px solid #eee;
  }
}
.single-shop-page .shop-fv .fv-slider .slide-dots {
  text-align: center;
  position: absolute;
  right: 0;
  left: 0;
  margin: 0 auto;
  bottom: 10px;
  width: 100%;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-fv .fv-slider .slide-dots {
    bottom: 4px;
  }
}
.single-shop-page .shop-fv .fv-slider .slide-dots li {
  display: inline-block;
  margin: 0 8px;
  position: relative;
}

.single-shop-page .shop-fv .fv-slider .slide-dots li button {
  position: relative;
  text-indent: -9999px;
}

.single-shop-page .shop-fv .fv-slider .slide-dots li button:before {
  content: "";
  text-indent: 0px;
  position: absolute;
  top: 5px;
  left: -4px;
  width: 8px;
  height: 8px;
  border-radius: 100%;
  background-color: #e6e6e6;
}

.single-shop-page .shop-fv .fv-slider .slide-dots li.slick-active button:before {
  background-color: #1f2f43;
}

.single-shop-page .shop-fv .inner .img:nth-of-type(n+2) {
  display: none;
}

.single-shop-page .shop-container {
  padding: 60px 0;
  color: #221e3f;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container {
    padding: 20px 0;
  }
}
.single-shop-page .shop-container .inner-wrap {
  max-width: 1000px;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .inner-wrap {
    max-width: 100%;
    padding: 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.single-shop-page .shop-container .shop-main {
  width: 700px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-main {
    width: 100%;
  }
}
.single-shop-page .shop-container .shop-main .page-ttl {
  margin: 0 0 10px 0;
  line-height: 1;
  background-color: #221e3f;
  color: #fff;
  font-size: 18px;
  padding: 14px;
  letter-spacing: 1px;
}

.single-shop-page .shop-container .shop-sidebar {
  width: 300px;
  padding-left: 20px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-sidebar {
    width: 100%;
    padding-left: 0;
  }
}
.single-shop-page .shop-container .main-img-conrainer {
  position: relative;
}

.single-shop-page .shop-container .main-img-conrainer .shop-slider {
  opacity: 0;
}

.single-shop-page .shop-container .main-img-conrainer .shop-slider img {
  opacity: 0;
}

.single-shop-page .shop-container .main-img-conrainer .shop-slider .slick-slide img {
  opacity: 1;
}

.single-shop-page .shop-container .main-img-conrainer .slick-initialized {
  opacity: 1;
}

.single-shop-page .shop-container .slick-initialized .slick-slide {
  padding: 0;
  display: block;
}

.single-shop-page .shop-container .slick-slide img {
  width: 100%;
}

.single-shop-page .shop-container .shop-slider-thumb .slick-track {
  -webkit-transform: unset !important;
  -ms-transform: unset !important;
  transform: unset !important;
}

.single-shop-page .shop-container .shop-slider-thumb .slick-slide {
  padding: 4px 2px;
  min-height: 57px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-slider-thumb .slick-slide {
    min-height: 32px;
  }
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .main-img-wrap {
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .shop-scroll .main-shop {
  margin-bottom: 20px;
}

.single-shop-page .shop-container .shop-scroll .main-shop .txt {
  margin-top: 16px;
}

.single-shop-page .shop-container .shop-scroll .main-shop p {
  font-size: 12px;
  margin-top: 6px;
  line-height: 1.6;
}

.single-shop-page .shop-container .shop-scroll .sub-shop {
  overflow: hidden;
}

.single-shop-page .shop-container .shop-scroll .sub-shop .scroll {
  overflow: scroll;
  -webkit-overflow-scrolling: touch;
}

.single-shop-page .shop-container .shop-scroll .sub-shop .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

.single-shop-page .shop-container .shop-scroll .sub-shop .list li {
  width: 200px;
  margin-right: 10px;
}

.single-shop-page .shop-container .shop-scroll .sub-shop .list li:last-child {
  margin-right: 0;
}

.single-shop-page .shop-container .shop-scroll .sub-shop .list .txt {
  margin-top: 10px;
}

.single-shop-page .shop-container .shop-scroll .sub-shop .list p {
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.5;
}

.single-shop-page .shop-container .main-img-txt {
  position: relative;
  z-index: 9;
  width: 100%;
  margin: 10px 0 0;
  background-color: #fff;
  border-radius: 4px;
  padding: 10px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  line-height: 1.4;
  color: #221e3f;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .main-img-txt {
    position: relative;
    bottom: auto;
    margin-top: 10px;
    width: 100%;
  }
}
.single-shop-page .shop-container .main-img-txt p {
  margin: 10px 0;
  font-size: 12px;
}

.single-shop-page .shop-container .cashback {
  margin: 40px 0 20px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .cashback {
    margin: 0 0 20px;
  }
}
.single-shop-page .shop-container .cashback .campaign {
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .cashback .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
    margin-bottom: 10px;
  }
}
.single-shop-page .shop-container .cashback .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .cashback .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.single-shop-page .shop-container .cashback .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .cashback .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.single-shop-page .shop-container .cashback .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .cashback .campaign .img span {
    font-size: 12px;
  }
}
.single-shop-page .shop-container .cashback .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .cashback .campaign .img span b {
    font-size: 10px;
  }
}
.single-shop-page .shop-container .cashback .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .cashback .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.single-shop-page .shop-container .cashback .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .cashback .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.single-shop-page .shop-container .cashback .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.single-shop-page .shop-container .cashback .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .cashback .campaign .txt .cost {
    font-size: 16px;
  }
}
.single-shop-page .shop-container .cashback .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .cashback .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.single-shop-page .shop-container .cashback .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .cashback .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.single-shop-page .shop-container .cashback .attention {
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .cashback .attention {
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .cashback .attention p {
  color: #1e2f43;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.single-shop-page .shop-container .shop-btn-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-pack: distribute;
  justify-content: space-around;
  margin: 20px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-btn-wrap {
    margin: 10px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.single-shop-page .shop-container .contact-btn {
  width: 48%;
  margin: 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .contact-btn {
    width: 80%;
    margin: 4px 0;
  }
}
.single-shop-page .shop-container .contact-btn a {
  display: block;
  background-color: #221e3f;
  color: #fff;
  font-size: 14px;
  border-radius: 4px;
  font-weight: 600;
  padding: 16px 0;
  text-align: center;
  border-bottom: 6px solid #05050a;
}

.single-shop-page .shop-container .contact-btn a:after {
  content: "▶︎";
  margin-left: 6px;
  margin-right: -6px;
}

.single-shop-page .shop-container .line-btn {
  width: 48%;
  margin: 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .line-btn {
    width: 80%;
    margin: 4px 0;
  }
}
.single-shop-page .shop-container .line-btn a {
  text-align: center;
  display: block;
  background-color: #00c800;
  color: #fff;
  font-size: 14px;
  border-radius: 4px;
  font-weight: 600;
  padding: 16px 0;
  border-bottom: 6px solid #02a501;
}

.single-shop-page .shop-container .line-btn a:after {
  content: "▶︎";
  margin-left: 6px;
  margin-right: -6px;
}

.single-shop-page .shop-container .line-btn span {
  margin-right: 8px;
  margin-left: -8px;
}

.single-shop-page .shop-container .line-btn span img {
  width: 26px;
  display: inline-block;
  vertical-align: middle;
}

.single-shop-page .shop-container .shop-covid {
  margin: 40px 0;
  background-color: #f2fbfe;
  padding: 20px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-covid {
    padding: 10px 0;
  }
}
.single-shop-page .shop-container .shop-covid .ttl strong {
  background-color: #221e3f;
  color: #fff;
  font-size: 16px;
  display: inline-block;
  padding: 4px 10px;
  border-radius: 4px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-covid .ttl strong {
    font-size: 14px;
    padding: 4px 6px;
  }
}
.single-shop-page .shop-container .shop-covid .txt p {
  margin: 10px 0;
  font-weight: 600;
  color: #221e3f;
  font-size: 12px;
  letter-spacing: 1px;
  line-height: 1.75;
}

.single-shop-page .shop-container .shop-covid .scroll {
  overflow-x: scroll;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-covid .scroll {
    overflow-x: hidden;
  }
}
.single-shop-page .shop-container .shop-covid .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 20px 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-covid .list {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}
.single-shop-page .shop-container .shop-covid .list .img {
  width: 280px;
  margin: 0 1%;
  position: relative;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-covid .list .img {
    width: 48%;
    margin: 0 1% 1%;
  }
}
.single-shop-page .shop-container .shop-covid .list .img .bottom {
  position: absolute;
  bottom: 0;
  width: 100%;
  left: 0;
  right: 0;
  color: #fff;
  font-size: 10px;
  padding: 6px 6px 6px 40px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-covid .list .img .bottom {
    position: relative;
  }
}
.single-shop-page .shop-container .shop-covid .list .img .bottom span {
  display: inline-block;
  width: 26px;
  height: 26px;
  border-radius: 100%;
  position: absolute;
  top: 50%;
  left: 2%;
  -webkit-transform: translateY(-50%) translateX(0%);
  -ms-transform: translateY(-50%) translateX(0%);
  transform: translateY(-50%) translateX(0%);
}

.single-shop-page .shop-container .shop-covid .list .img.img1 .bottom {
  background-color: #07b5b4;
}

.single-shop-page .shop-container .shop-covid .list .img.img2 .bottom {
  background-color: #e79a2e;
}

.single-shop-page .shop-container .shop-covid .list .img.img3 .bottom {
  background-color: #13a3d8;
}

.single-shop-page .shop-container .shop-covid .list .img.img4 .bottom {
  background-color: #dc485e;
}

.single-shop-page .shop-container .shop-covid .link a {
  color: #2a98d2;
  font-weight: 600;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-covid .link a {
    font-size: 12px;
  }
}
.single-shop-page .shop-container .shop-info {
  margin: 40px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-info {
    margin: 20px 0;
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .shop-info h2 {
  margin: 0;
  font-size: 18px;
  padding: 14px 0;
  border-left: 6px solid #221e3f;
  line-height: 1;
  padding-left: 16px;
  color: #221e3f;
}

.single-shop-page .shop-container .map-img {
  margin: 10px 0;
}

.single-shop-page .shop-container .map-img iframe {
  width: 100%;
  height: 350px;
  -webkit-filter: grayscale(100%);
  filter: grayscale(100%);
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .map-img iframe {
    height: 250px;
  }
}
.single-shop-page .shop-container .shop-table table {
  width: 100%;
  border-collapse: collapse;
}

.single-shop-page .shop-container .shop-table th {
  color: #221e3f;
  padding: 14px;
  width: 26%;
  line-height: 1;
  background-color: #f6f6f6;
  font-size: 12px;
  text-align: left;
  border-bottom: 1px dashed #c3c3c3;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-table th {
    padding: 12px;
    width: 30%;
  }
}
.single-shop-page .shop-container .shop-table th:last-child th {
  border-bottom: none;
}

.single-shop-page .shop-container .shop-table td {
  color: #221e3f;
  font-size: 12px;
  padding: 12px 18px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-table td {
    padding: 10px 12px;
  }
}
.single-shop-page .shop-container .shop-table .shop-btn {
  display: inline-block;
  background-color: #221e3f;
  color: #fff;
  font-size: 10px;
  line-height: 1;
  padding: 8px 28px;
  border-radius: 4px;
  margin-left: 20px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-table .shop-btn {
    margin-top: 10px;
    margin-left: 10px;
  }
}
.single-shop-page .shop-container .trainer {
  margin: 40px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .trainer {
    margin: 20px 0;
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .trainer h2 {
  margin: 0;
  font-size: 18px;
  padding: 14px 0;
  border-left: 6px solid #221e3f;
  line-height: 1;
  padding-left: 16px;
  color: #221e3f;
}

.single-shop-page .shop-container .trainer-info {
  margin: 20px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 20px 10px;
  background-color: #f6f6f6;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .trainer-info {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.single-shop-page .shop-container .trainer-info .img {
  width: 150px;
  height: 150px;
  overflow: hidden;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .trainer-info .img {
    margin: 0 auto;
  }
}
.single-shop-page .shop-container .trainer-info .img img {
  border-radius: 100%;
}

.single-shop-page .shop-container .trainer-info .txt {
  width: 510px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .trainer-info .txt {
    width: 100%;
    margin-top: 20px;
  }
}
.single-shop-page .shop-container .trainer-info .txt .name {
  color: #221e3f;
  font-size: 18px;
  border-bottom: none;
  line-height: 1.4;
  padding-bottom: 0;
  margin: 0 0 10px 0;
}

.single-shop-page .shop-container .trainer-info .detail {
  margin: 14px 0;
}

.single-shop-page .shop-container .trainer-info .detail span {
  background-color: #221e3f;
  color: #fff;
  font-size: 14px;
  padding: 8px 14px;
  line-height: 1;
  display: inline-block;
  border-radius: 4px;
  position: relative;
}

.single-shop-page .shop-container .trainer-info .detail span:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 6px solid #221e3f;
}

.single-shop-page .shop-container .trainer-info .detail p {
  margin: 10px 0;
  color: #221e3f;
  font-size: 12px;
}

.single-shop-page .shop-container .trainer.new-box .trainer-info {
  background-color: #a7f5ff;
  padding: 30px 20px;
  -webkit-box-align: initial;
  -ms-flex-align: initial;
  align-items: initial;
  min-height: 200px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .trainer.new-box .trainer-info {
    padding: 10px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-flow: row;
    flex-flow: row;
    -webkit-box-align: initial;
    -ms-flex-align: initial;
    align-items: initial;
    min-height: 210px;
  }
}
.single-shop-page .shop-container .trainer.new-box .trainer-info .img {
  position: relative;
  min-height: 200px;
  height: auto;
  margin-bottom: -30px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .trainer.new-box .trainer-info .img {
    margin-bottom: -10px;
    position: relative;
    height: auto;
  }
}
.single-shop-page .shop-container .trainer.new-box .trainer-info .img img {
  border-radius: 0;
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
  margin: 0 auto;
  -o-object-fit: contain;
  object-fit: contain;
  width: 100%;
  height: 100%;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .trainer.new-box .trainer-info .img img {
    border-radius: 0;
    position: absolute;
    bottom: 0;
    right: 0;
    left: 0;
    margin: 0 auto;
    width: 100%;
    height: auto;
  }
}
.single-shop-page .shop-container .trainer.new-box .trainer-info .txt {
  width: 500px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .trainer.new-box .trainer-info .txt {
    width: 100%;
    margin-top: 10px;
  }
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .trainer.new-box .trainer-info .txt .name {
    font-size: 16px;
  }
}
.single-shop-page .shop-container .trainer.new-box .trainer-info .txt .name a {
  color: #221e3f;
  display: inline-block;
  border-bottom: 1px solid #221e3f;
}

.single-shop-page .shop-container .trainer.new-box .trainer-info .txt .name span {
  font-size: 12px;
  vertical-align: unset;
  display: inline-block;
  margin-left: 14px;
}

.single-shop-page .shop-container .trainer.new-box .trainer-info .detail span {
  border-radius: 20px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .trainer.new-box .trainer-info .detail span {
    font-size: 12px;
    padding: 6px 8px;
  }
}
.single-shop-page .shop-container .trainer.new-box .trainer-info .detail p {
  line-height: 1.75;
  margin: 14px 0;
}

.single-shop-page .shop-container .gallery {
  margin: 40px 0;
  background-image: url(../img/shop-gallery-back.jpg);
  background-size: cover;
  background-position: center;
}

.single-shop-page .shop-container .gallery .inner {
  padding: 30px;
  background-image: url(../img/shop-gallery-img1.png), url(../img/shop-gallery-img2.png);
  background-size: 150px, 128px;
  background-repeat: no-repeat;
  background-position: 4% 0%, 96% 0%;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .gallery .inner {
    padding: 30px 30px 50px;
    background-size: 120px, 100px;
    background-position: 2% 100%, 96% 100%;
  }
}
.single-shop-page .shop-container .gallery p {
  font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", sans-serif;
  margin: 0 0 20px 0;
  text-align: center;
  color: #221e3f;
  font-weight: 800;
  line-height: 1.3;
  font-size: 28px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .gallery p {
    margin: 0 0 60px 0;
    font-size: 24px;
  }
}
.single-shop-page .shop-container .gallery a {
  display: block;
  background-color: #221e3f;
  color: #fff;
  text-align: center;
  font-weight: 600;
  padding: 10px 0;
  font-size: 12px;
  border-radius: 30px;
  width: 40%;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .gallery a {
    padding: 12px 0;
    width: 80%;
  }
}
.single-shop-page .shop-container .voice {
  margin: 40px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .voice {
    margin: 20px 0;
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .voice h2 {
  margin: 0;
  font-size: 18px;
  padding: 14px 0;
  border-left: 6px solid #221e3f;
  line-height: 1;
  padding-left: 16px;
  color: #221e3f;
}

.single-shop-page .shop-container .voice .list {
  margin: 20px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 0 10px;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .voice .list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.single-shop-page .shop-container .voice .list .img {
  width: 150px;
  height: 150px;
  overflow: hidden;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .voice .list .img {
    margin: 0 auto;
  }
}
.single-shop-page .shop-container .voice .list .img img {
  border-radius: 100%;
}

.single-shop-page .shop-container .voice .list .txt {
  width: 510px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .voice .list .txt {
    width: 100%;
    margin-top: 20px;
  }
}
.single-shop-page .shop-container .voice .list .name {
  color: #221e3f;
  font-size: 18px;
  border-bottom: none;
  line-height: 1.4;
  padding-bottom: 0;
  margin: 0 0 10px 0;
}

.single-shop-page .shop-container .voice .list .name span {
  margin: 0 12px 0 0;
  font-size: 14px;
  border: none;
  padding: 0;
  display: inline-block;
  color: #221e3f;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .voice .list .name span {
    margin: 0 8px 0 0;
    font-size: 12px;
  }
}
.single-shop-page .shop-container .voice .list .detail {
  margin: 14px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .voice .list .detail {
    margin: 12px 0;
  }
}
.single-shop-page .shop-container .voice .list .question {
  background-color: #221e3f;
  color: #fff;
  font-size: 14px;
  padding: 10px 14px;
  line-height: 1;
  display: inline-block;
  border-radius: 4px;
  position: relative;
  margin: 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .voice .list .question {
    line-height: 1.4;
  }
}
.single-shop-page .shop-container .voice .list .answer {
  margin: 10px 0;
  font-size: 12px;
  line-height: 1.5;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .voice .list .answer {
    margin: 12px 0;
  }
}
.single-shop-page .shop-container .voice .voice-active {
  background-color: #f4f4f4;
  padding: 14px 10px;
  font-size: 16px;
  cursor: pointer;
  margin-bottom: 20px;
  position: relative;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  letter-spacing: 1px;
}

.single-shop-page .shop-container .voice .voice-active:after {
  content: ">";
  font-weight: 600;
  position: absolute;
  top: 50%;
  right: 10px;
  -webkit-transform: translateY(-50%) translateX(0%);
  -ms-transform: translateY(-50%) translateX(0%);
  transform: translateY(-50%) translateX(0%);
  line-height: 1;
  color: #c3c3c3;
}

.single-shop-page .shop-container .voice .voice-active.active:after {
  -webkit-transform: translateY(-50%) translateX(0%) rotate(90deg);
  -ms-transform: translateY(-50%) translateX(0%) rotate(90deg);
  transform: translateY(-50%) translateX(0%) rotate(90deg);
}

.single-shop-page .shop-container .voice .voice-hidden {
  display: none;
}

.single-shop-page .shop-container .shop-sidebar .banner {
  padding: 0;
  margin-bottom: 10px;
}

.single-shop-page .shop-container .shop-sidebar .shop-sidebar-ttl {
  margin: 0;
  background-color: #221e3f;
  color: #fff;
  font-size: 12px;
  text-align: center;
  padding: 10px 0;
  border-radius: 2px 2px 0 0;
}

.single-shop-page .shop-container .shop-sidebar .shop-sidebar-list {
  background-color: #f6f6f6;
  padding: 0 10px;
}

.single-shop-page .shop-container .shop-sidebar .shop-sidebar-list a {
  position: relative;
  display: block;
  color: #221e3f;
  font-size: 12px;
  padding: 12px 50px 12px 10px;
  border-bottom: 1px dashed #c3c3c3;
  line-height: 1.4;
}

.single-shop-page .shop-container .shop-sidebar .shop-sidebar-list a:after {
  content: ">";
  color: #c3c3c3;
  position: absolute;
  right: 20px;
  top: 32%;
  font-size: 16px;
  line-height: 1;
}

.single-shop-page .shop-container .shop-sidebar .shop-sidebar-list li:last-child a {
  border-bottom: none;
}

.single-shop-page .shop-container .access-block-wrap {
  margin: 40px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .access-block-wrap {
    margin: 20px 0;
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .access-block-wrap h2 {
  margin: 0;
  font-size: 18px;
  padding: 14px 0;
  border-left: 6px solid #221e3f;
  line-height: 1;
  padding-left: 16px;
  color: #221e3f;
}

.single-shop-page .shop-container .access-block-wrap .access-block {
  margin: 20px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.single-shop-page .shop-container .access-block-wrap .access-img {
  width: 26%;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .access-block-wrap .access-img {
    width: 35%;
  }
}
.single-shop-page .shop-container .access-block-wrap .access-container {
  width: 74%;
  padding-left: 20px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .access-block-wrap .access-container {
    width: 65%;
    padding-left: 10px;
  }
}
.single-shop-page .shop-container .access-block-wrap .access-container .access-head {
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 1px;
}

.single-shop-page .shop-container .access-block-wrap .access-container .access-head b {
  font-weight: 600;
  display: inline-block;
  margin-bottom: 6px;
  font-size: 14px;
}

.single-shop-page .shop-container .access-block-wrap .access-active {
  background-color: #f4f4f4;
  padding: 14px 10px;
  font-size: 16px;
  cursor: pointer;
  margin-bottom: 20px;
  position: relative;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  letter-spacing: 1px;
}

.single-shop-page .shop-container .access-block-wrap .access-active:after {
  content: ">";
  font-weight: 600;
  position: absolute;
  top: 50%;
  right: 10px;
  -webkit-transform: translateY(-50%) translateX(0%);
  -ms-transform: translateY(-50%) translateX(0%);
  transform: translateY(-50%) translateX(0%);
  line-height: 1;
  color: #c3c3c3;
}

.single-shop-page .shop-container .access-block-wrap .access-active.active:after {
  -webkit-transform: translateY(-50%) translateX(0%) rotate(90deg);
  -ms-transform: translateY(-50%) translateX(0%) rotate(90deg);
  transform: translateY(-50%) translateX(0%) rotate(90deg);
}

.single-shop-page .shop-container .access-block-wrap .access-hidden {
  display: none;
}

.single-shop-page .shop-container .price .inner {
  padding: 60px 0 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price .inner {
    padding: 40px 0 0;
  }
}
.single-shop-page .shop-container .price h2 {
  text-align: center;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 40px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price h2 {
    font-size: 18px;
    margin-bottom: 20px;
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .price h2 small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  display: block;
  font-size: 12px;
  margin-top: 10px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price h2 small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.single-shop-page .shop-container .price .tab-area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  cursor: pointer;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}

.single-shop-page .shop-container .price .tab-area .tab {
  width: 24.6%;
  text-align: center;
  color: white;
  border-radius: 6px 6px 0 0;
  background-color: #1e2f43;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price .tab-area .tab {
    width: 23.3333333333%;
  }
}
.single-shop-page .shop-container .price .tab-area .tab.other {
  padding: 10px 0;
}

.single-shop-page .shop-container .price .tab-area .tab.other .name {
  font-weight: 900;
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price .tab-area .tab.other .name {
    font-size: 12px;
  }
}
.single-shop-page .shop-container .price .tab-area .tab.other .name small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  display: block;
  font-size: 10px;
  margin-top: 2px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price .tab-area .tab.other .name small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    letter-spacing: 0;
  }
}
.single-shop-page .shop-container .price .tab-area .tab.special {
  padding: 10px 10px 10px 30px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price .tab-area .tab.special {
    padding: 10px 2px;
  }
}
.single-shop-page .shop-container .price .tab-area .tab.special .point {
  background-color: #fff268;
  display: block;
  width: 44px;
  height: 44px;
  border-radius: 100%;
  color: #000;
  font-weight: 900;
  position: absolute;
  top: -10px;
  left: -6px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price .tab-area .tab.special .point {
    width: 40px;
    height: 40px;
    top: -30px;
    left: 4px;
  }
}
.single-shop-page .shop-container .price .tab-area .tab.special .point span {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  font-size: 12px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price .tab-area .tab.special .point span {
    font-size: 10px;
  }
}
.single-shop-page .shop-container .price .tab-area .tab.special .point span b {
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price .tab-area .tab.special .point span b {
    font-size: 10px;
  }
}
.single-shop-page .shop-container .price .tab-area .tab.special .name {
  font-weight: 900;
  font-size: 14px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price .tab-area .tab.special .name {
    font-size: 12px;
    letter-spacing: 0;
  }
}
.single-shop-page .shop-container .price .tab-area .tab.special .name small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #fff268;
  display: block;
  font-size: 10px;
  margin-top: 2px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price .tab-area .tab.special .name small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    letter-spacing: 0;
  }
}
.single-shop-page .shop-container .price .tab-area .tab.active {
  background-color: #ff373c;
  padding: 12px 10px 12px 10px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price .tab-area .tab.active {
    padding: 12px 2px 12px 2px;
    width: 29%;
  }
}
.single-shop-page .shop-container .price .tab-area .tab.active .name {
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price .tab-area .tab.active .name {
    font-size: 12px;
  }
}
.single-shop-page .shop-container .price .tab-area .tab.active.special {
  padding: 12px 10px 12px 20px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price .tab-area .tab.active.special {
    padding: 12px 2px 12px 2px;
    width: 29%;
  }
}
.single-shop-page .shop-container .price .content-area .content {
  display: none;
  background-color: #f4f4f4;
  padding: 20px 40px 30px 40px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price .content-area .content {
    padding: 20px;
  }
}
.single-shop-page .shop-container .price .content-area .content .name {
  text-align: center;
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 1px;
  line-height: 1.6;
  margin: 10px 0 20px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price .content-area .content .name {
    font-size: 14px;
    letter-spacing: 0;
    margin: 0 0 20px 0;
  }
}
.single-shop-page .shop-container .price .content-area .content .table {
  width: 100%;
  margin: 20px 0 10px;
  font-weight: 900;
}

.single-shop-page .shop-container .price .content-area .content .table th {
  background-color: #f4fbfe;
  color: #2ca8e8;
  padding: 14px 0;
  letter-spacing: 1px;
  width: 40%;
  border-bottom: 2px solid #f4f4f4;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price .content-area .content .table th {
    padding: 10px 0;
    width: 30%;
    font-size: 12px;
  }
}
.single-shop-page .shop-container .price .content-area .content .table td {
  font-family: Century Gothic;
  background-color: #fff;
  width: 60%;
  text-align: center;
  padding: 20px 10px;
  border-bottom: 2px solid #f4f4f4;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price .content-area .content .table td {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    width: 70%;
    padding: 14px 10px;
    font-size: 14px;
  }
}
.single-shop-page .shop-container .price .content-area .content .table td .font-small {
  font-size: 12px;
  display: inline-block;
  position: relative;
  top: -1px;
}

.single-shop-page .shop-container .price .content-area .content .table td .border {
  text-decoration: line-through;
}

.single-shop-page .shop-container .price .content-area .content .table td .border .font-small {
  font-size: 12px;
  display: inline-block;
  text-decoration: line-through;
  position: relative;
  top: -1px;
}

.single-shop-page .shop-container .price .content-area .content .table td .color {
  color: #ff373c;
}

.single-shop-page .shop-container .price .content-area .content .table td .color .font-small {
  font-size: 12px;
  display: inline-block;
  position: relative;
  top: -1px;
}

.single-shop-page .shop-container .price .content-area .content .attention p {
  font-weight: 900;
  font-size: 12px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price .content-area .content .attention p {
    font-size: 10px;
  }
}
.single-shop-page .shop-container .price .content-area .content.show {
  display: block;
}

.single-shop-page .shop-container .shop-notice {
  margin: 40px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-notice {
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .shop-notice h2 {
  color: #1e2f43;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: 2px;
  padding-bottom: 10px;
  margin: 20px 0;
  position: relative;
  background-repeat: repeat-x;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-notice h2 {
    font-size: 18px;
  }
}
.single-shop-page .shop-container .shop-notice h2:after {
  content: "";
  width: 100%;
  height: 4px;
  bottom: 0;
  left: 0;
  position: absolute;
  background-image: url(../img/page-h2-img.png);
  background-size: contain;
  background-position: 0 100%;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-notice h2:after {
    background-size: auto;
  }
}
.single-shop-page .shop-container .shop-notice .txt {
  background-color: #f4fbfe;
  padding: 20px;
  color: #1e2f43;
  margin-bottom: 30px;
}

.single-shop-page .shop-container .shop-notice .txt p {
  line-height: 1.9;
}

.single-shop-page .shop-container .shop-notice .txt b {
  display: inline-block;
}

.single-shop-page .shop-container .shop-notice .txt b span {
  width: 10px;
  height: 10px;
  display: inline-block;
  background-color: #1e2f43;
  margin-right: 6px;
}

.single-shop-page .shop-container .shop-flow {
  margin: 40px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-flow {
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .shop-flow h2 {
  text-align: center;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 40px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-flow h2 {
    font-size: 18px;
    margin-bottom: 20px;
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .shop-flow h2 small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  display: block;
  font-size: 12px;
  margin-top: 10px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-flow h2 small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.single-shop-page .shop-container .shop-flow .list {
  margin: 20px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-flow .list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.single-shop-page .shop-container .shop-flow .list .ttl {
  width: 120px;
  height: 120px;
  position: relative;
  background-color: #f3fbfe;
  border-radius: 100%;
}

.single-shop-page .shop-container .shop-flow .list .ttl .wrap {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  margin-top: -10px;
  letter-spacing: 1px;
}

.single-shop-page .shop-container .shop-flow .list .ttl .wrap span {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  font-size: 14px;
}

.single-shop-page .shop-container .shop-flow .list .ttl .wrap p {
  font-size: 18px;
  font-weight: 600;
  margin-top: 10px;
}

.single-shop-page .shop-container .shop-flow .list .txt {
  width: 550px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-flow .list .txt {
    width: 100%;
    margin-top: 14px;
  }
}
.single-shop-page .shop-container .shop-flow .list .txt b {
  line-height: 1.4;
  display: block;
  border-bottom: 1px dashed #a5acb4;
  padding-bottom: 4px;
}

.single-shop-page .shop-container .shop-flow .list .txt p {
  margin: 10px 0;
  font-size: 12px;
  letter-spacing: 1px;
  line-height: 1.5;
}

.single-shop-page .shop-container .shop-flow .list .txt span {
  display: inline-block;
}

.single-shop-page .shop-container .shop-flow .list .txt span.blue {
  margin: 0 20px 0 0;
}

.single-shop-page .shop-container .shop-flow .list .txt span.blue a {
  color: #221e3f;
  font-weight: 600;
  font-size: 12px;
}

.single-shop-page .shop-container .shop-flow .list .txt span.green a {
  color: #2acc26;
  font-weight: 600;
  font-size: 12px;
}

.single-shop-page .shop-container .shop-check {
  margin: 40px 0;
}

.single-shop-page .shop-container .shop-check h2 {
  text-align: center;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 40px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-check h2 {
    font-size: 18px;
    margin-bottom: 20px;
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .shop-check h2 small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  display: block;
  font-size: 12px;
  margin-top: 10px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-check h2 small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.single-shop-page .shop-container .shop-check .box {
  padding: 20px 20px 60px 20px;
  background-image: url(../img/single-shop-check-img.png);
  background-size: 86%;
  background-position: 100% 50%;
  background-color: #a0d3ca;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-check .box {
    background-image: none;
    padding: 20px;
  }
}
.single-shop-page .shop-container .shop-check .box .txt {
  width: 50%;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-check .box .txt {
    width: 100%;
  }
}
.single-shop-page .shop-container .shop-check .box .list li {
  margin-bottom: 10px;
  background-color: #1d2f44;
  padding: 12px 10px;
  color: #fff;
}

.single-shop-page .shop-container .shop-check .box .list h3 {
  margin-bottom: 10px;
  font-weight: 600;
}

.single-shop-page .shop-container .shop-check .box .list p {
  font-size: 12px;
  line-height: 1.5;
}

.single-shop-page .shop-container .shop-rule {
  margin: 40px 0 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-rule {
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .shop-rule h2 {
  text-align: center;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 40px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-rule h2 {
    font-size: 18px;
    margin-bottom: 20px;
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .shop-rule .list li {
  border: 2px solid #2ca8e8;
  border-radius: 4px;
  padding: 20px;
  margin-bottom: 10px;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-rule .list li {
    padding: 20px 10px 10px 90px;
  }
}
.single-shop-page .shop-container .shop-rule .list li .txt {
  width: 550px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-rule .list li .txt {
    width: 100%;
  }
}
.single-shop-page .shop-container .shop-rule .list .point {
  display: block;
  width: 80px;
  height: 80px;
  background-color: #2ca8e8;
  border-radius: 100%;
  position: relative;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-rule .list .point {
    position: absolute;
    top: 24px;
    left: 10px;
    margin: 0 auto;
    width: 70px;
    height: 70px;
  }
}
.single-shop-page .shop-container .shop-rule .list .point:before {
  content: "";
  width: 20px;
  height: 20px;
  top: -18px;
  right: -16px;
  left: 0;
  margin: 0 auto;
  position: absolute;
  background-image: url(../img/top-date-icon-img.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-rule .list .point:before {
    right: -22px;
  }
}
.single-shop-page .shop-container .shop-rule .list .date {
  color: #fff;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  font-weight: 900;
  font-size: 24px;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-rule .list .date {
    font-size: 20px;
  }
}
.single-shop-page .shop-container .shop-rule .list .date small {
  display: block;
  line-height: 1;
  font-size: 12px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-rule .list .date small {
    margin-top: 2px;
  }
}
.single-shop-page .shop-container .shop-rule .list h3 {
  margin-bottom: 10px;
  font-weight: 600;
  color: #2ca8e8;
  line-height: 1.5;
  font-size: 18px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-rule .list h3 {
    font-size: 16px;
  }
}
.single-shop-page .shop-container .shop-rule .list p {
  line-height: 1.5;
  font-size: 12px;
}

.single-shop-page .shop-container .faq-wrap .inner {
  padding: 40px 0 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .faq-wrap .inner {
    padding: 40px 0;
  }
}
.single-shop-page .shop-container .faq-wrap h2 {
  text-align: center;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 40px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .faq-wrap h2 {
    font-size: 18px;
    margin-bottom: 20px;
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .faq-wrap h2 small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  display: block;
  font-size: 12px;
  margin-top: 10px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .faq-wrap h2 small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.single-shop-page .shop-container .faq-wrap .list li {
  margin-bottom: 10px;
  position: relative;
  border: 1px solid #f4f4f4;
  border-radius: 6px;
  overflow: hidden;
}

.single-shop-page .shop-container .faq-wrap .list .ttl {
  padding: 20px 20px 20px 40px;
  color: #1e2f43;
  font-size: 16px;
  font-weight: 900;
  cursor: pointer;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .faq-wrap .list .ttl {
    padding: 20px 10px 20px 40px;
    font-size: 14px;
  }
}
.single-shop-page .shop-container .faq-wrap .list .ttl .icon {
  display: inline-block;
  margin-left: -22px;
  margin-right: 6px;
  color: #2a98d2;
}

.single-shop-page .shop-container .faq-wrap .list .txt {
  padding: 0 20px 20px 40px;
  letter-spacing: 1px;
  line-height: 1.75;
  display: none;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .faq-wrap .list .txt {
    padding: 0 10px 20px 40px;
    font-size: 12px;
  }
}
.single-shop-page .shop-container .faq-wrap .list .txt .icon {
  display: inline-block;
  margin-left: -20px;
  margin-right: -3px;
  color: #ff373c;
}

.single-shop-page .shop-container .shop-ttl {
  margin-bottom: 20px;
  color: #241d41;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-ttl {
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .shop-ttl p {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0px;
  margin: 0 0 4px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-ttl p {
    font-size: 10px;
  }
}
.single-shop-page .shop-container .shop-ttl h1 {
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0px;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-ttl h1 {
    font-size: 16px;
  }
}
.single-shop-page .shop-container .page-link {
  margin: 30px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .page-link {
    margin: 20px 0;
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .page-link .link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  background-color: #f3fbfe;
  padding: 6px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .page-link .link {
    padding: 0;
  }
}
.single-shop-page .shop-container .page-link .link li {
  width: 25%;
  text-align: center;
  border-right: 2px solid #1d2a42;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .page-link .link li {
    border-right: none;
  }
}
.single-shop-page .shop-container .page-link .link li:last-child {
  border-right: none;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .page-link .link .img {
    margin-bottom: 8px;
  }
}
@media screen and (max-width: 767px) and (max-width: 767px) {
  .single-shop-page .shop-container .page-link .link .img img {
    width: 30px;
  }
}
.single-shop-page .shop-container .page-link .link a {
  color: #241d41;
  font-weight: 600;
  font-size: 12px;
  display: block;
  padding: 10px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .page-link .link a {
    font-size: 10px;
    padding: 10px 0;
  }
}
.single-shop-page .shop-container .shop-banner {
  margin: 20px 0;
}

.single-shop-page .shop-container .service {
  margin: 40px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .service {
    margin: 20px 0;
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .service h2 {
  margin: 0;
  font-size: 18px;
  padding: 14px 0;
  border-left: 6px solid #221e3f;
  line-height: 1;
  padding-left: 16px;
  color: #221e3f;
  margin-bottom: 20px;
}

.single-shop-page .shop-container .service .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.single-shop-page .shop-container .service .list li {
  width: 14.6666666%;
  margin: 1%;
  background-color: #00b4f0;
  border-radius: 4px;
  padding: 10px 0;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .service .list li {
    width: 23%;
  }
}
.single-shop-page .shop-container .service .list .img {
  margin-bottom: 10px;
  height: 54px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.single-shop-page .shop-container .service .list .img img {
  width: 48px;
}

.single-shop-page .shop-container .service .list p {
  color: #fff;
  font-weight: 600;
  font-size: 12px;
  margin: 4px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .service .list p {
    font-size: 10px;
  }
}
.single-shop-page .shop-container .other-shop.top-shop {
  margin: 20px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .other-shop.top-shop {
    padding: 0 10px;
  }
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .other-shop.top-shop p.toggle-ttl {
    position: relative;
    background-color: #1b2f46;
    color: #fff;
    text-align: center;
    padding: 10px 40px;
    font-weight: 600;
    cursor: pointer;
  }
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .other-shop.top-shop p.toggle-ttl span.line {
    -webkit-transition: all 0.2s;
    transition: all 0.2s;
  }
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .other-shop.top-shop p.toggle-ttl span.line1 {
    width: 16px;
    height: 3px;
    background-color: #fff;
    display: block;
    border-radius: 4px;
    position: absolute;
    top: 50%;
    right: 22px;
    -webkit-transform: translateY(-50%) translateX(0%);
    -ms-transform: translateY(-50%) translateX(0%);
    transform: translateY(-50%) translateX(0%);
  }
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .other-shop.top-shop p.toggle-ttl span.line2 {
    width: 16px;
    height: 3px;
    background-color: #fff;
    display: block;
    border-radius: 4px;
    position: absolute;
    top: 47%;
    right: 23px;
    -webkit-transform: rotate(90deg) translateY(-50%) translateX(0%);
    -ms-transform: rotate(90deg) translateY(-50%) translateX(0%);
    transform: rotate(90deg) translateY(-50%) translateX(0%);
  }
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .other-shop.top-shop p.toggle-ttl.active span.line2 {
    top: 50%;
    right: 22px;
    -webkit-transform: rotate(0deg) translateY(-50%) translateX(0%);
    -ms-transform: rotate(0deg) translateY(-50%) translateX(0%);
    transform: rotate(0deg) translateY(-50%) translateX(0%);
  }
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .other-shop.top-shop .toggle-shop {
    display: none;
  }
}
.single-shop-page .shop-container .other-shop.top-shop .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .other-shop.top-shop .list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.single-shop-page .shop-container .other-shop.top-shop .list li.type1 {
  width: 20%;
  background-color: #1b2f46;
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  font-size: 12px;
  font-weight: 600;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .other-shop.top-shop .list li.type1 {
    display: none;
  }
}
.single-shop-page .shop-container .other-shop.top-shop .list li.type1 a {
  display: inline-block;
  background-color: #fff;
  border-radius: 30px;
  color: #1b2f46;
  font-size: 10px;
  padding: 5px 10px;
  margin-top: 8px;
}

.single-shop-page .shop-container .other-shop.top-shop .list li.type2 {
  width: 40%;
  border: 2px solid #1b2f46;
  padding: 10px 14px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .other-shop.top-shop .list li.type2 {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .other-shop.top-shop .list li.type2 b {
    font-size: 16px;
  }
}
.single-shop-page .shop-container .other-shop.top-shop .list li.type2 p {
  font-size: 10px;
  font-weight: 600;
  margin: 6px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .other-shop.top-shop .list li.type2 p {
    font-size: 12px;
  }
}
.single-shop-page .shop-container .other-shop.top-shop .list li.type2 .link-txt a {
  display: inline-block;
  font-size: 12px;
  color: #00b4f0;
  font-weight: 600;
  margin-right: 6px;
}

.single-shop-page .shop-container .other-shop.top-shop .list li.type2 .link-txt span {
  display: inline-block;
  margin-right: 6px;
  width: 14px;
}

.single-shop-page .shop-container .other-shop.top-shop .list li.type2:nth-child(3) {
  border-left: none;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .other-shop.top-shop .list li.type2:nth-child(3) {
    border-top: none;
    border-left: 2px solid #1b2f46;
  }
}
.single-shop-page .shop-container .other-shop.top-shop .list li.type2:nth-child(n+4) {
  display: none;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .other-shop.top-shop .btn {
    text-align: center;
    margin: 20px 0 30px;
  }
}
@media screen and (max-width: 767px) and (max-width: 767px) {
  .single-shop-page .shop-container .other-shop.top-shop .btn a {
    display: inline-block;
    background-color: #f4f4f4;
    padding: 14px 40px;
    color: #1b2f46;
    font-weight: 600;
    border-radius: 30px;
    font-size: 12px;
  }
}
.single-shop-page .shop-container .shop-wrap .inner {
  padding: 40px 0 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-wrap .inner {
    padding: 0 0 40px;
  }
}
.single-shop-page .shop-container .shop-wrap h2 {
  text-align: center;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 40px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-wrap h2 {
    font-size: 18px;
    margin-bottom: 20px;
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .shop-wrap h2 small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  display: block;
  font-size: 12px;
  margin-top: 10px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-wrap h2 small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-wrap .list {
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .shop-wrap .list li {
  border-top: 2px solid #ededed;
  padding: 14px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.single-shop-page .shop-container .shop-wrap .list li:last-child {
  border-bottom: 2px solid #ededed;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-wrap .list li {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.single-shop-page .shop-container .shop-wrap .list .ttl {
  width: 50%;
  padding-left: 50px;
  color: #1b2f46;
  background-image: url(../img/shop-logo-img.svg);
  background-size: 30px;
  background-position: 8px 50%;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-wrap .list .ttl {
    width: 100%;
    margin-bottom: 20px;
  }
}
.single-shop-page .shop-container .shop-wrap .list .ttl h3 {
  font-weight: 600;
  font-size: 16px;
  margin-bottom: 4px;
}

.single-shop-page .shop-container .shop-wrap .list .ttl p {
  font-weight: 600;
  font-size: 12px;
}

.single-shop-page .shop-container .shop-wrap .list .link-txt {
  width: 42%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-wrap .list .link-txt {
    width: 100%;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}
.single-shop-page .shop-container .shop-wrap .list .link-txt a {
  border: 1px solid #00b4f0;
  color: #00b4f0;
  font-weight: 600;
  font-size: 12px;
  padding: 8px 14px;
  border-radius: 4px;
  margin: 0 6px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-wrap .list .link-txt a {
    font-size: 14px;
    margin: 0 6px;
    padding: 10px 16px;
  }
}
.single-shop-page .shop-container .shop-wrap .list .link-txt span {
  display: inline-block;
  width: 14px;
  margin-right: 6px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .shop-wrap .list .link-txt span {
    width: 16px;
    vertical-align: text-bottom;
  }
}
.single-shop-page .banner.bottom .inner {
  padding: 16px 10px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .inner {
    padding: 20px 10px 10px;
    max-width: 500px;
  }
}
.single-shop-page .banner.bottom h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  padding: 40px 0;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom h2 {
    font-size: 20px;
    padding: 40px 0 20px;
  }
}
.single-shop-page .banner.bottom .campaign {
  margin-top: 10px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
    margin-bottom: 10px;
  }
}
.single-shop-page .banner.bottom .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.single-shop-page .banner.bottom .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.single-shop-page .banner.bottom .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign .img span {
    font-size: 12px;
  }
}
.single-shop-page .banner.bottom .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign .img span b {
    font-size: 10px;
  }
}
.single-shop-page .banner.bottom .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.single-shop-page .banner.bottom .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.single-shop-page .banner.bottom .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.single-shop-page .banner.bottom .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign .txt .cost {
    font-size: 16px;
  }
}
.single-shop-page .banner.bottom .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.single-shop-page .banner.bottom .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.single-shop-page .banner.bottom .attention {
  margin: 10px 0;
}

.single-shop-page .banner.bottom .attention p {
  color: #1e2f43;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.single-shop-page .banner.bottom .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.single-shop-page .banner.bottom .list li {
  width: 49%;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .list li {
    margin: 0 0 10px 0;
  }
}
.single-shop-page .banner.bottom .inner {
  padding: 16px 10px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .inner {
    padding: 20px 10px 10px;
    max-width: 500px;
  }
}
.single-shop-page .banner.bottom h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  padding: 40px 0;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom h2 {
    font-size: 20px;
    padding: 40px 0 20px;
  }
}
.single-shop-page .banner.bottom .campaign {
  margin-top: 10px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
    margin-bottom: 10px;
  }
}
.single-shop-page .banner.bottom .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.single-shop-page .banner.bottom .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.single-shop-page .banner.bottom .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign .img span {
    font-size: 12px;
  }
}
.single-shop-page .banner.bottom .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign .img span b {
    font-size: 10px;
  }
}
.single-shop-page .banner.bottom .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.single-shop-page .banner.bottom .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.single-shop-page .banner.bottom .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.single-shop-page .banner.bottom .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign .txt .cost {
    font-size: 16px;
  }
}
.single-shop-page .banner.bottom .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.single-shop-page .banner.bottom .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.single-shop-page .banner.bottom .attention {
  margin: 10px 0;
}

.single-shop-page .banner.bottom .attention p {
  color: #1e2f43;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.single-shop-page .banner.bottom .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.single-shop-page .banner.bottom .list li {
  width: 49%;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .banner.bottom .list li {
    margin: 0 0 10px 0;
  }
}
.single-shop-page .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.single-shop-page .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.single-shop-page .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .single-shop-page .btn-area.bottom-area .btn {
    margin-top: 0;
  }
}
.single-shop-page .btn-area.bottom-area .btn .left, .single-shop-page .btn-area.bottom-area .btn .right {
  width: 49%;
}

.single-shop-page .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .btn-area.bottom-area .btn .left a {
    background-image: url(../img/top-btn-icon1-img.svg);
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
  }
}
.single-shop-page .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
}
.single-shop-page .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.single-shop-page .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.single-shop-page .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}
.single-trainer-page .re2_t_single_inner {
  width: 800px;
  margin: 0 auto;
  padding: 40px 0;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .re2_t_single_inner {
    width: 100%;
    padding: 0;
  }
}
.single-trainer-page .re2_t_single_headline {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .re2_t_single_headline {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.single-trainer-page .re2_t_single_headline_l {
  width: 50%;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .re2_t_single_headline_l {
    width: 100%;
  }
}
.single-trainer-page .thumb-item-nav1 li {
  padding: 5px;
}

.single-trainer-page .re2_t_single_headline_r {
  width: 50%;
  padding: 0 40px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .re2_t_single_headline_r {
    width: 100%;
    padding: 20px;
  }
}
.single-trainer-page .re2_t_single_headline_r h1 {
  margin: 0 auto;
  color: #000;
  font-size: 46px;
  line-height: 44px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .re2_t_single_headline_r h1 {
    font-size: 36px;
    line-height: 36px;
  }
}
.single-trainer-page .re2_t_single_headline_r p {
  margin: 5px 0 0 0;
  padding: 0 10px;
}

.single-trainer-page .re2_t_single_table {
  padding: 40px 0;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .re2_t_single_table {
    padding: 0;
  }
}
.single-trainer-page .re2_t_single_table dl {
  margin: 0 auto;
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.single-trainer-page .re2_t_single_table dt {
  float: left;
  width: 30%;
  text-align: center;
  padding: 10px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .re2_t_single_table dt {
    padding: 5px;
    width: 45%;
  }
}
.single-trainer-page .re2_t_single_table dt:after {
  content: "";
  width: 1px;
  height: 90%;
  background-color: #b5b5b5;
  position: absolute;
  right: 0;
  top: 3px;
}

.single-trainer-page .re2_t_single_table dt span {
  position: absolute;
  width: 100%;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
}

@media screen and (max-width: 767px) {
  .single-trainer-page .re2_t_single_table dt span {
    width: 100%;
    font-size: 14px;
  }
}
.single-trainer-page .re2_t_single_table dd {
  text-align: center;
  padding: 10px;
  float: left;
  width: 70%;
  margin: 0 0 0 5px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .re2_t_single_table dd {
    padding: 5px;
    font-size: 14px;
    margin: 0 0 0 5px;
    width: 50%;
  }
}
.single-trainer-page .re2_t_single_table_grey {
  background-color: #f6f3f3;
}

.single-trainer-page .re2_t_single_trainer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .re2_t_single_trainer {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
    padding: 5px;
  }
}
.single-trainer-page .re2_t_single_trainer_l {
  width: 40%;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .re2_t_single_trainer_l {
    width: 100%;
  }
}
.single-trainer-page .re2_t_single_trainer_r {
  width: 60%;
  padding: 20px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .re2_t_single_trainer_r {
    width: 100%;
    padding: 10px 5px;
  }
}
.single-trainer-page .re2_t_single_trainer_r h2 {
  margin: 0 auto;
  color: #fe5c5b;
  font-size: 28px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .re2_t_single_trainer_r h2 {
    font-size: 26px;
  }
}
.single-trainer-page .re2_t_single_trainer_r h2 span {
  color: #b8b8b8;
  font-size: 12px;
  margin-left: 10px;
}

.single-trainer-page .re2_t_single_guest {
  padding: 40px 0;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .re2_t_single_guest {
    padding: 20px 0;
  }
}
.single-trainer-page .re2_t_single_guest h2 {
  margin: 0 auto;
  text-align: center;
  color: #000;
  padding-bottom: 40px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .re2_t_single_guest h2 {
    padding-bottom: 20px;
  }
}
.single-trainer-page .re2_t_single_guest ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.single-trainer-page .re2_t_single_guest li {
  width: 25%;
  padding: 5px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .re2_t_single_guest li {
    width: 50%;
  }
}
.single-trainer-page .re2_t_single_guest_img {
  height: 110px;
  overflow: hidden;
}

.single-trainer-page .re2_t_single_guest_txt {
  background-color: rgba(49, 50, 51, 0.8);
  padding: 10px;
  color: #fff;
  margin: -30px 0 0;
  position: relative;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .re2_t_single_guest_txt {
    margin: 0;
    font-size: 14px;
  }
}
.single-trainer-page .re2_t_single_guest_txt h3 {
  margin: 0 auto;
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .re2_t_single_guest_txt h3 {
    font-size: 14px;
  }
}
.single-trainer-page .re2_t_single_guest_txt p {
  color: #fff;
  margin: 5px 0 0 0;
  font-size: 12px;
  line-height: initial;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .re2_t_single_guest_txt p {
    margin: 0;
  }
}
.single-trainer-page .banner.bottom .inner {
  padding: 16px 10px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .banner.bottom .inner {
    padding: 20px 10px 10px;
    max-width: 500px;
  }
}
.single-trainer-page .banner.bottom h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  padding: 40px 0;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .banner.bottom h2 {
    font-size: 20px;
    padding: 40px 0 20px;
  }
}
.single-trainer-page .banner.bottom .campaign {
  margin-top: 10px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .banner.bottom .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
    margin-bottom: 10px;
  }
}
.single-trainer-page .banner.bottom .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .banner.bottom .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.single-trainer-page .banner.bottom .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .banner.bottom .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.single-trainer-page .banner.bottom .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .banner.bottom .campaign .img span {
    font-size: 12px;
  }
}
.single-trainer-page .banner.bottom .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .banner.bottom .campaign .img span b {
    font-size: 10px;
  }
}
.single-trainer-page .banner.bottom .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .banner.bottom .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.single-trainer-page .banner.bottom .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .banner.bottom .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.single-trainer-page .banner.bottom .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.single-trainer-page .banner.bottom .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .banner.bottom .campaign .txt .cost {
    font-size: 16px;
  }
}
.single-trainer-page .banner.bottom .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .banner.bottom .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.single-trainer-page .banner.bottom .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .banner.bottom .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.single-trainer-page .banner.bottom .attention {
  margin: 10px 0;
}

.single-trainer-page .banner.bottom .attention p {
  color: #1e2f43;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.single-trainer-page .banner.bottom .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.single-trainer-page .banner.bottom .list li {
  width: 49%;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .banner.bottom .list li {
    margin: 0 0 10px 0;
  }
}
.single-trainer-page .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.single-trainer-page .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.single-trainer-page .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .btn-area.bottom-area .btn {
    margin-top: 0;
  }
}
.single-trainer-page .btn-area.bottom-area .btn .left, .single-trainer-page .btn-area.bottom-area .btn .right {
  width: 49%;
}

.single-trainer-page .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .btn-area.bottom-area .btn .left a {
    background-image: url(../img/top-btn-icon1-img.svg);
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
  }
}
.single-trainer-page .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
}
.single-trainer-page .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.single-trainer-page .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.single-trainer-page .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .single-trainer-page .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}
.virus-page .virus-fv {
  background-image: url(../img/virus-fv-back.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: 100% 70%;
  padding: 128px 0;
}

@media screen and (max-width: 767px) {
  .virus-page .virus-fv {
    padding: 100px 0;
  }
}
.virus-page .virus-fv h1 {
  margin: 0;
  text-align: center;
  font-size: 26px;
}

.virus-page .virus-fv h1 span {
  background-color: #040404;
  line-height: 1.4;
  display: inline-block;
  padding: 0 6px;
  color: #fff;
}

.virus-page .virus-fv p {
  text-align: center;
  margin: 18px 0;
}

.virus-page .virus-fv p span {
  background-color: #040404;
  line-height: 1.6;
  display: inline-block;
  padding: 0 6px;
  color: #fff;
  font-size: 14px;
  margin: 2px 0;
}

.virus-page .sec1 {
  padding: 60px 0;
}

@media screen and (max-width: 767px) {
  .virus-page .sec1 {
    padding: 40px 0;
  }
}
.virus-page .sec1 .inner {
  max-width: 1000px;
}

@media screen and (max-width: 767px) {
  .virus-page .sec1 .inner {
    width: 100%;
  }
}
.virus-page .sec1 ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 767px) {
  .virus-page .sec1 ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.virus-page .sec1 ul .txt {
  width: 50%;
  padding: 0 10px;
}

@media screen and (max-width: 767px) {
  .virus-page .sec1 ul .txt {
    width: 100%;
    margin-bottom: 20px;
  }
}
.virus-page .sec1 ul .txt h2 {
  margin: 0 0 10px 0;
}

@media screen and (max-width: 767px) {
  .virus-page .sec1 ul .txt h2 {
    text-align: center;
  }
}
.virus-page .sec1 ul .txt h2 span {
  background-color: #040404;
  color: #fff;
  line-height: 1.4;
  padding: 0 6px;
  display: inline-block;
  font-weight: 400;
  font-size: 24px;
}

@media screen and (max-width: 767px) {
  .virus-page .sec1 ul .txt h2 span {
    font-size: 20px;
  }
}
.virus-page .sec1 ul .txt p {
  margin: 0 0 10px 0;
  font-size: 14px;
}

.virus-page .sec1 ul .txt .btn {
  background-color: #040404;
  color: #fff;
  display: inline-block;
  font-size: 12px;
  padding: 8px 20px 8px 10px;
  margin-top: 20px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .virus-page .sec1 ul .txt .btn {
    width: 200px;
    text-align: center;
    padding: 10px 20px 10px 10px;
    display: block;
    margin: 20px auto 0;
  }
}
.virus-page .sec1 ul .txt .btn:after {
  content: "▶︎";
  position: absolute;
  font-size: 10px;
  top: 13px;
  right: 6px;
  line-height: 1;
}

.virus-page .sec1 ul .img {
  width: 50%;
}

@media screen and (max-width: 767px) {
  .virus-page .sec1 ul .img {
    width: 100%;
    padding: 0 10px;
  }
}
.virus-page .sec1 ul .img img {
  width: 100%;
}

.virus-page .sec2 {
  padding: 60px 0;
  background-image: url(../img/virus-sec2-back.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: top;
}

@media screen and (max-width: 767px) {
  .virus-page .sec2 {
    padding: 40px 0;
  }
}
.virus-page .sec2 .inner {
  width: 700px;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .virus-page .sec2 .inner {
    width: 100%;
    padding: 0 10px;
  }
}
.virus-page .sec2 h2 {
  margin: 0 0 40px 0;
  text-align: center;
}

.virus-page .sec2 h2 span {
  background-color: #040404;
  color: #fff;
  line-height: 1.4;
  padding: 0 6px;
  display: inline-block;
  font-weight: 400;
  font-size: 24px;
}

@media screen and (max-width: 767px) {
  .virus-page .sec2 h2 span {
    font-size: 20px;
  }
}
.virus-page .sec2 p {
  margin: 0 0 10px 0;
  font-size: 14px;
}

.virus-page .sec2 h3 {
  margin: 20px 0;
  background-color: #eaeaea;
  padding: 10px;
  font-size: 16px;
}

.virus-page .sec2 .grey-back.list1 {
  background-color: #f9f9f9;
  padding: 20px;
  font-size: 14px;
}

.virus-page .sec2 .grey-back.list1 li {
  width: 300px;
  margin: 0 auto;
}

.virus-page .sec2 .grey-back.list2 {
  background-color: #f9f9f9;
  padding: 20px;
  font-size: 14px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 767px) {
  .virus-page .sec2 .grey-back.list2 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.virus-page .sec2 .grey-back.list2 li {
  width: 50%;
}

@media screen and (max-width: 767px) {
  .virus-page .sec2 .grey-back.list2 li {
    width: 100%;
  }
}
.virus-page .sec2 .grey-back.list2 h4 {
  margin: 0;
  font-size: 16px;
  margin-bottom: 10px;
}

.virus-page .banner .inner {
  padding: 16px 10px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .virus-page .banner .inner {
    padding: 20px 10px 10px;
    max-width: 500px;
  }
}
.virus-page .banner h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  padding: 40px 0;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .virus-page .banner h2 {
    font-size: 20px;
    padding: 40px 0 20px;
  }
}
.virus-page .banner .campaign {
  margin-top: 10px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .virus-page .banner .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
    margin-bottom: 10px;
  }
}
.virus-page .banner .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .virus-page .banner .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.virus-page .banner .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .virus-page .banner .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.virus-page .banner .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .virus-page .banner .campaign .img span {
    font-size: 12px;
  }
}
.virus-page .banner .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .virus-page .banner .campaign .img span b {
    font-size: 10px;
  }
}
.virus-page .banner .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .virus-page .banner .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.virus-page .banner .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .virus-page .banner .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.virus-page .banner .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.virus-page .banner .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .virus-page .banner .campaign .txt .cost {
    font-size: 16px;
  }
}
.virus-page .banner .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .virus-page .banner .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.virus-page .banner .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .virus-page .banner .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.virus-page .banner .attention {
  margin: 10px 0;
}

.virus-page .banner .attention p {
  color: #1e2f43;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.virus-page .banner .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.virus-page .banner .list li {
  width: 49%;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .virus-page .banner .list li {
    margin: 0 0 10px 0;
  }
}
.virus-page .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.virus-page .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .virus-page .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.virus-page .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .virus-page .btn-area.bottom-area .btn {
    margin-top: 0;
  }
}
.virus-page .btn-area.bottom-area .btn .left, .virus-page .btn-area.bottom-area .btn .right {
  width: 49%;
}

.virus-page .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .virus-page .btn-area.bottom-area .btn .left a {
    background-image: url(../img/top-btn-icon1-img.svg);
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
  }
}
.virus-page .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .virus-page .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
}
.virus-page .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .virus-page .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.virus-page .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .virus-page .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.virus-page .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .virus-page .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}
.month-campaign-page .fv {
  background-image: url(../img/month-campaign-fv-img.png);
  background-color: #fd2a15;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

.month-campaign-page .fv .inner {
  padding: 154px 0;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .fv .inner {
    padding: 128px 0;
  }
}
.month-campaign-page .fv .ttl {
  text-align: center;
}

.month-campaign-page .fv h1 {
  color: #fff;
  font-weight: 600;
  font-size: 20px;
}

.month-campaign-page .fv h1 small {
  font-size: 24px;
}

.month-campaign-page .fv h1 b {
  font-size: 30px;
}

.month-campaign-page .banner .inner {
  padding: 16px 10px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .banner .inner {
    padding: 20px 10px 10px;
    max-width: 500px;
  }
}
.month-campaign-page .banner h2 {
  text-align: center;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: 1px;
  padding: 40px 0;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .banner h2 {
    font-size: 20px;
    padding: 40px 0 20px;
  }
}
.month-campaign-page .banner .campaign {
  margin-top: 10px;
  background-image: url(../img/top-campaign-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 10px 40px 20px;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .banner .campaign {
    margin-top: 0;
    padding: 10px 10px 20px;
    min-height: 102px;
    margin-bottom: 10px;
  }
}
.month-campaign-page .banner .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .banner .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.month-campaign-page .banner .campaign .img {
  background-color: #2ca8e8;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
  margin-top: -30px;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .banner .campaign .img {
    width: 90px;
    height: 90px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.month-campaign-page .banner .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .banner .campaign .img span {
    font-size: 12px;
  }
}
.month-campaign-page .banner .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #2ca8e8;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .banner .campaign .img span b {
    font-size: 10px;
  }
}
.month-campaign-page .banner .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .banner .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.month-campaign-page .banner .campaign .txt .date {
  background-color: #c5b07c;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .banner .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
  }
}
.month-campaign-page .banner .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #c5b07c;
}

.month-campaign-page .banner .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 26px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .banner .campaign .txt .cost {
    font-size: 16px;
  }
}
.month-campaign-page .banner .campaign .txt .cost span {
  color: #ff373c;
  font-family: Century Gothic;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .banner .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.month-campaign-page .banner .campaign .txt .cost span b {
  font-size: 42px;
  display: inline-block;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .banner .campaign .txt .cost span b {
    font-size: 28px;
  }
}
.month-campaign-page .banner .attention {
  margin: 10px 0;
}

.month-campaign-page .banner .attention p {
  color: #1e2f43;
  font-size: 10px;
  letter-spacing: 1px;
  line-height: 1.75;
  font-weight: 900;
}

.month-campaign-page .banner .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.month-campaign-page .banner .list li {
  width: 49%;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .banner .list li {
    margin: 0 0 10px 0;
  }
}
.month-campaign-page .banner.type02 {
  margin-top: 40px;
}

.month-campaign-page .banner.type02 h2 {
  font-size: 20px;
  padding: 14px 0;
  width: 550px;
  margin: 0 auto 30px;
  background-color: #fefc36;
  position: relative;
  color: #1e2f43;
  border: 2px dashed #1e2f43;
  background-image: url(../img/month-campaign-ttl1-img.png), url(../img/month-campaign-ttl2-img.png);
  background-size: 30px 30px;
  background-position: 6% 50%, 94% 50%;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .banner.type02 h2 {
    font-size: 18px;
    margin: 0 auto 10px;
    width: 95%;
  }
}
.month-campaign-page .banner.type02 h2:after {
  content: "";
  position: absolute;
  top: 94%;
  left: 50%;
  margin-left: -8px;
  border: 8px solid transparent;
  border-top: 14px solid #1e2f43;
}

.month-campaign-page .exemption {
  background-color: #fd2a15;
}

.month-campaign-page .exemption .inner {
  padding: 40px 10px;
}

.month-campaign-page .exemption h2 {
  font-size: 18px;
  font-weight: 600;
  text-align: center;
  color: #fff;
  margin-bottom: 40px;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .exemption h2 {
    margin-bottom: 20px;
  }
}
.month-campaign-page .exemption .img {
  text-align: center;
  margin: 40px 0;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .exemption .img {
    margin: 20px 0;
  }
}
.month-campaign-page .exemption .img img {
  width: 480px;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .exemption .img img {
    width: 100%;
  }
}
.month-campaign-page .exemption p {
  max-width: 800px;
  margin: 0 auto;
  color: #fff;
  font-weight: 600;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .exemption p {
    font-size: 12px;
    line-height: 1.75;
  }
}
.month-campaign-page .value {
  background-color: #00aaef;
}

.month-campaign-page .value .inner {
  padding: 40px 10px;
}

.month-campaign-page .value h2 {
  font-size: 18px;
  font-weight: 600;
  text-align: center;
  color: #fff;
  margin-bottom: 40px;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .value h2 {
    margin-bottom: 20px;
  }
}
.month-campaign-page .value .list {
  margin: 40px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .value .list {
    margin: 20px 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
@media screen and (max-width: 767px) {
  .month-campaign-page .value .list .img {
    width: 300px;
  }
}
.month-campaign-page .value .list .img img {
  width: 320px;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .value .list .img img {
    width: 100%;
  }
}
.month-campaign-page .value .list .txt {
  padding: 0 20px;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .value .list .txt {
    width: 100%;
    padding: 0;
    text-align: center;
    margin-top: 10px;
  }
}
.month-campaign-page .value .list .txt p.border {
  border: 1px solid #fff;
  border-radius: 6px;
  padding: 8px 20px;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .value .list .txt p.border {
    display: inline-block;
    vertical-align: middle;
    padding: 8px 10px;
  }
}
.month-campaign-page .value .list .txt p.border strong {
  display: block;
  font-size: 20px;
  margin-top: 4px;
  color: #fefc36;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .value .list .txt p.border strong {
    font-size: 18px;
  }
}
@media screen and (max-width: 767px) {
  .month-campaign-page .value .list .txt p {
    display: inline-block;
    vertical-align: middle;
  }
}
.month-campaign-page .value .list .txt p img {
  width: 28px;
}

.month-campaign-page .value p {
  text-align: center;
  color: #fff;
  font-weight: 600;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .value p {
    font-size: 12px;
    line-height: 1.75;
  }
}
.month-campaign-page .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.month-campaign-page .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.month-campaign-page .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .btn-area.bottom-area .btn {
    margin-top: 0;
  }
}
.month-campaign-page .btn-area.bottom-area .btn .left, .month-campaign-page .btn-area.bottom-area .btn .right {
  width: 49%;
}

.month-campaign-page .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .btn-area.bottom-area .btn .left a {
    background-image: url(../img/top-btn-icon1-img.svg);
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
  }
}
.month-campaign-page .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
}
.month-campaign-page .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.month-campaign-page .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.month-campaign-page .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .month-campaign-page .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}
.trainer-temp .fv {
  position: relative;
  overflow: hidden;
}

.trainer-temp .fv:after {
  content: "";
  width: 73%;
  height: 100%;
  background-color: #b8f3fc;
  position: absolute;
  top: 0;
  right: 0;
}

.trainer-temp .fv .inner {
  padding: 40px 100px 0;
  text-align: left;
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .trainer-temp .fv .inner {
    padding: 40px 20px 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
    -webkit-box-align: inherit;
    -ms-flex-align: inherit;
    align-items: inherit;
  }
}
.trainer-temp .fv h1 {
  letter-spacing: 10px;
  line-height: 1.6;
}

.trainer-temp .fv .txt span {
  display: inline-block;
  background-color: #1e2f43;
  color: #fff;
  margin-top: 12px;
  padding: 8px 12px;
  font-size: 14px;
  letter-spacing: 2px;
}

@media screen and (max-width: 767px) {
  .trainer-temp .fv .txt span {
    font-size: 12px;
  }
}
.trainer-temp .fv .img {
  width: 360px;
}

@media screen and (max-width: 767px) {
  .trainer-temp .fv .img {
    width: 180px;
    margin-left: auto;
    margin-right: -10px;
    margin-top: -34px;
    position: relative;
    z-index: 1;
  }
}
.trainer-temp .trainer-box .inner {
  padding: 60px 90px;
}

@media screen and (max-width: 767px) {
  .trainer-temp .trainer-box .inner {
    padding: 40px 10px;
  }
}
.trainer-temp .trainer-box .txt {
  padding: 0 10px;
  color: #1e2f43;
}

.trainer-temp .trainer-box .txt h2 {
  font-weight: 600;
  font-size: 16px;
  margin-bottom: 20px;
}

.trainer-temp .trainer-box .txt h2 span {
  display: inline-block;
  margin-right: 4px;
  font-size: 20px;
  letter-spacing: 2px;
}

.trainer-temp .trainer-box .txt p {
  line-height: 1.5;
}

.trainer-temp .trainer-box.box1 .inner, .trainer-temp .trainer-box.box3 .inner, .trainer-temp .trainer-box.box6 .inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 767px) {
  .trainer-temp .trainer-box.box1 .inner, .trainer-temp .trainer-box.box3 .inner, .trainer-temp .trainer-box.box6 .inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.trainer-temp .trainer-box.box1 .txt, .trainer-temp .trainer-box.box3 .txt, .trainer-temp .trainer-box.box6 .txt {
  width: 50%;
}

@media screen and (max-width: 767px) {
  .trainer-temp .trainer-box.box1 .txt, .trainer-temp .trainer-box.box3 .txt, .trainer-temp .trainer-box.box6 .txt {
    width: 100%;
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 767px) {
  .trainer-temp .trainer-box.box1 .txt:nth-of-type(2), .trainer-temp .trainer-box.box3 .txt:nth-of-type(2), .trainer-temp .trainer-box.box6 .txt:nth-of-type(2) {
    margin-bottom: 0;
  }
}
.trainer-temp .trainer-box.box2, .trainer-temp .trainer-box.box5, .trainer-temp .trainer-box.box7 {
  background-color: #b8f3fc;
}

.trainer-temp .trainer-box.box4 .inner {
  padding-top: 0;
}

@media screen and (max-width: 767px) {
  .trainer-temp .trainer-box.box4 h2 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
@media screen and (max-width: 767px) {
  .trainer-temp .trainer-box.box4 h2 span {
    margin-right: 0;
    width: 60px;
  }
}
.trainer-temp .trainer-box.box2 {
  position: relative;
}

.trainer-temp .trainer-box.box2 .inner {
  position: relative;
}

.trainer-temp .trainer-box.box2 .txt {
  padding-right: 100px;
}

@media screen and (max-width: 767px) {
  .trainer-temp .trainer-box.box2 .txt {
    padding: 0 10px 240px;
  }
}
.trainer-temp .trainer-box.box2 .img {
  position: absolute;
  right: -60px;
  bottom: 0;
  width: 240px;
}

@media screen and (max-width: 767px) {
  .trainer-temp .trainer-box.box2 .img {
    right: 0;
    width: 180px;
  }
}
.trainer-temp .trainer-box.box5 {
  overflow: hidden;
}

@media screen and (max-width: 767px) {
  .trainer-temp .trainer-box.box5 .inner {
    padding-right: 0;
  }
}
.trainer-temp .trainer-box.box5 h2 {
  font-weight: 600;
  font-size: 16px;
  margin-bottom: 20px;
}

.trainer-temp .trainer-box.box5 h2 span {
  display: inline-block;
  margin-right: 4px;
  font-size: 20px;
  letter-spacing: 2px;
}

.trainer-temp .trainer-box.box5 .txt {
  overflow-x: scroll;
}

.trainer-temp .trainer-box.box5 .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

.trainer-temp .trainer-box.box5 .list li {
  width: 250px;
  padding-right: 20px;
  padding-bottom: 60px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .trainer-temp .trainer-box.box5 .list li {
    width: 200px;
  }
}
.trainer-temp .trainer-box.box5 .list li:before {
  content: "";
  width: 20px;
  height: 20px;
  border-radius: 100%;
  background-color: #1e2f43;
  position: absolute;
  bottom: 10px;
  right: 20px;
  left: 0;
  margin: 0 auto;
}

.trainer-temp .trainer-box.box5 .list li::after {
  content: "";
  background-color: #1e2f43;
  position: absolute;
  bottom: 17px;
  width: 250px;
  height: 4px;
  left: -140px;
}

@media screen and (max-width: 767px) {
  .trainer-temp .trainer-box.box5 .list li::after {
    width: 200px;
    left: -120px;
  }
}
.trainer-temp .trainer-box.box5 .list li:nth-of-type(1)::after {
  content: none;
}

.trainer-temp .trainer-box.box5 .list p {
  text-align: center;
  margin-bottom: 10px;
}

.trainer-temp .trainer-box.box5 .list .detail {
  background-color: #fff;
  padding: 10px;
  border-radius: 4px;
  position: relative;
  min-height: 100px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.trainer-temp .trainer-box.box5 .list .detail:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -6px;
  border: 6px solid transparent;
  border-top: 10px solid #fff;
}

.trainer-temp .trainer-box.box5 .list .detail p {
  width: 100%;
  text-align: left;
}

.trainer-temp .trainer-box.box7 .inner {
  padding: 60px 90px 120px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .trainer-temp .trainer-box.box7 .inner {
    padding: 40px 10px 290px;
  }
}
.trainer-temp .trainer-box.box7 .txt {
  padding-right: 160px;
}

@media screen and (max-width: 767px) {
  .trainer-temp .trainer-box.box7 .txt {
    padding: 0 10px;
  }
}
.trainer-temp .trainer-box.box7 .txt h2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .trainer-temp .trainer-box.box7 .txt h2 span {
    margin-right: 0;
    width: 74px;
  }
}
.trainer-temp .trainer-box.box7 .img {
  width: 240px;
  position: absolute;
  right: 0;
  bottom: 0;
}

@media screen and (max-width: 767px) {
  .trainer-temp .trainer-box.box7 .img {
    width: 146px;
    right: 0;
    bottom: 0;
  }
}
.lp-2021 {
  padding-bottom: 85px;
}

@media screen and (max-width: 767px) {
  .lp-2021 {
    padding-bottom: 80px;
  }
}
.lp-2021 .fixed-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 99;
  background-color: #fff;
}

.lp-2021 .fixed-header .inner {
  padding: 10px 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .lp-2021 .fixed-header .inner {
    padding: 10px 10px;
  }
}
.lp-2021 .fixed-header .logo {
  width: 40px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .fixed-header .logo {
    width: 30px;
  }
}
.lp-2021 .fixed-header .btn {
  width: 260px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 767px) {
  .lp-2021 .fixed-header .btn {
    width: 220px;
  }
}
.lp-2021 .fv .codiv-link {
  background-color: #1b2d49;
  text-align: center;
  padding: 8px 0;
}

.lp-2021 .fv .codiv-link a {
  color: #fff;
  font-size: 12px;
  text-decoration: underline;
  position: relative;
}

.lp-2021 .fv .codiv-link a:after {
  content: ">";
  display: inline-block;
  position: absolute;
  right: -16px;
  font-size: 14px;
}

.lp-2021 .fv .inner {
  padding: 0 10px 10px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .fv .inner {
    padding: 0;
  }
}
.lp-2021 .half-price .inner {
  padding: 10px 10px;
  max-width: 600px;
  background: #1d2f45;
}

@media screen and (max-width: 767px) {
  .lp-2021 .half-price .inner {
    padding: 10px 10px 10px;
    background: #1d2f45;
  }
}
.lp-2021 .half-price .box {
  background: #fff !important;
  padding: 10px;
  border: 5px solid #1d2f44;
  text-align: center;
}

.lp-2021 .half-price .box p {
  font-weight: 600;
  color: #000;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .half-price .box p {
    font-size: 14px;
  }
}
.lp-2021 .half-price .box strong {
  display: block;
  color: #de3713;
  font-size: 32px;
  margin: 4px 0;
  letter-spacing: 2px;
}

.lp-2021 .half-price .box span {
  background-color: #1d2f44;
  display: inline-block;
  color: #fff;
  padding: 6px 14px;
  font-size: 12px;
  letter-spacing: 1px;
}

.lp-2021 .btn-area.top-area .inner {
  max-width: 600px;
  padding: 10px;
  background-color: #f3fbfe;
}

.lp-2021 .btn-area.top-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

.lp-2021 .btn-area.top-area .btn .left, .lp-2021 .btn-area.top-area .btn .right {
  width: 49%;
}

.lp-2021 .btn-area.top-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.top-area .btn .left a {
    padding: 10px 10px 10px 30px;
    background-size: 22px;
    background-position: 4px 50%;
    letter-spacing: 0;
    background-image: url(../img/top-btn-icon1-img.svg);
  }
}
.lp-2021 .btn-area.top-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.top-area .btn .left a span {
    font-size: 14px;
  }
}
.lp-2021 .btn-area.top-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.top-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.lp-2021 .btn-area.top-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.top-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.lp-2021 .btn-area.top-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.top-area .btn .right a span {
    font-size: 14px;
  }
}
.lp-2021 .btn-area.top-area .form-btn {
  text-align: center;
  padding: 0 80px 20px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.top-area .form-btn {
    padding: 0 20px 20px;
  }
}
.lp-2021 .btn-area.top-area .form-btn .fuwafuwa {
  -webkit-animation: fuwafuwa 3s infinite linear alternate;
  animation: fuwafuwa 3s infinite linear alternate;
}

@-webkit-keyframes fuwafuwa {
  0% {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
  }
  50% {
    -webkit-transform: translate(0, -5px);
    transform: translate(0, -5px);
  }
  100% {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
  }
}
@keyframes fuwafuwa {
  0% {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
  }
  50% {
    -webkit-transform: translate(0, -5px);
    transform: translate(0, -5px);
  }
  100% {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
  }
}
@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.top-area .mission {
    margin-top: 20px;
    margin-bottom: -20px;
  }
}
.lp-2021 .btn-area.top-area .mission .img {
  margin-left: -10px;
  margin-right: -10px;
}

.lp-2021 .btn-area.top-area .mission .worry-point {
  background-color: #2ba8e8;
  background-image: url(../img/lp2021-worry-point-back-img.jpg);
  background-position: top center;
  background-size: cover;
  padding-bottom: 10px;
}

.lp-2021 .btn-area.top-area .mission .worry-point .point-ttl {
  padding: 0 60px;
  margin-bottom: 40px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.top-area .mission .worry-point .point-ttl {
    padding: 0 40px;
  }
}
.lp-2021 .btn-area.top-area .mission .worry-point .point-box {
  padding: 0 10px;
  margin-bottom: 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

.lp-2021 .btn-area.top-area .mission .worry-point .point-box .point-box-contents {
  width: 49%;
  margin: 0 0.5% 1%;
  background-color: #fff;
  border-radius: 6px;
  overflow: hidden;
}

.lp-2021 .btn-area.top-area .mission .worry-point .point-box .point-box-contents .question {
  padding: 12px 40px;
  font-size: 16px;
  text-align: center;
  color: #182f46;
  font-weight: 600;
  letter-spacing: 1px;
  position: relative;
  cursor: pointer;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.top-area .mission .worry-point .point-box .point-box-contents .question {
    font-size: 14px;
  }
}
.lp-2021 .btn-area.top-area .mission .worry-point .point-box .point-box-contents .question .line {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid #182f46;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  right: 14px;
  -webkit-transform: translateY(-50%) translateX(0%);
  -ms-transform: translateY(-50%) translateX(0%);
  transform: translateY(-50%) translateX(0%);
}

.lp-2021 .btn-area.top-area .mission .worry-point .point-box .point-box-contents .question .line .line1 {
  display: block;
  width: 10px;
  height: 2px;
  background-color: #182f46;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
}

.lp-2021 .btn-area.top-area .mission .worry-point .point-box .point-box-contents .question .line .line2 {
  display: block;
  width: 2px;
  height: 10px;
  background-color: #182f46;
  position: absolute;
  left: 0;
  right: 0;
  margin: 0 auto;
  top: 22%;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}

.lp-2021 .btn-area.top-area .mission .worry-point .point-box .point-box-contents .question.active .line .line2 {
  -webkit-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  transform: rotate(90deg);
}

.lp-2021 .btn-area.top-area .mission .worry-point .point-box .point-box-contents .answer {
  padding: 0 10px 10px;
  font-size: 12px;
  color: #182f46;
  line-height: 1.5;
  display: none;
}

.lp-2021 .btn-area.top-area .ttl {
  margin: 40px 0;
}

.lp-2021 .btn-area.top-area .list {
  margin: 20px 0;
}

.lp-2021 .btn-area.top-area .campaign {
  margin-top: 10px;
  background: #fff !important;
  padding: 10px;
  border: 5px solid #1d2f44;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.top-area .campaign {
    border: 3px solid #1d2f44;
  }
}
.lp-2021 .btn-area.top-area .campaign .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.top-area .campaign .list {
    display: block;
    position: relative;
    padding-left: 84px;
  }
}
.lp-2021 .btn-area.top-area .campaign .img {
  background-color: #1d2f44;
  width: 110px;
  height: 110px;
  border-radius: 100%;
  position: relative;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.top-area .campaign .img {
    width: 76px;
    height: 76px;
    margin-top: 0;
    position: absolute;
    left: -4px;
    top: -4px;
  }
}
.lp-2021 .btn-area.top-area .campaign .img span {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  color: #fff;
  letter-spacing: 1px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.top-area .campaign .img span {
    font-size: 10px;
  }
}
.lp-2021 .btn-area.top-area .campaign .img span b {
  display: inline-block;
  background-color: #fff;
  color: #1d2f44;
  border-radius: 2px;
  padding: 0 2px;
  margin: 0 -2px;
  font-size: 12px;
  letter-spacing: 0;
  margin-bottom: 2px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.top-area .campaign .img span b {
    font-size: 10px;
  }
}
.lp-2021 .btn-area.top-area .campaign .txt {
  margin: 0 20px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.top-area .campaign .txt {
    margin: 0 0 0 6px;
  }
}
.lp-2021 .btn-area.top-area .campaign .txt .date {
  background-color: #1d2f44 !important;
  color: #fff;
  display: inline-block;
  padding: 4px 40px;
  border-radius: 30px;
  position: relative;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 20px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.top-area .campaign .txt .date {
    padding: 4px 0px;
    display: block;
    letter-spacing: 0px;
    font-size: 12px;
  }
}
.lp-2021 .btn-area.top-area .campaign .txt .date:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -4px;
  border: 4px solid transparent;
  border-top: 8px solid #1d2f44;
}

.lp-2021 .btn-area.top-area .campaign .txt .cost {
  font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 22px;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.top-area .campaign .txt .cost {
    font-size: 12px;
  }
}
.lp-2021 .btn-area.top-area .campaign .txt .cost span {
  font-family: Century Gothic;
  letter-spacing: 1px;
  color: #1d2f44 !important;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.top-area .campaign .txt .cost span {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    letter-spacing: 0;
  }
}
.lp-2021 .btn-area.top-area .campaign .txt .cost span b {
  font-size: 40px;
  display: inline-block;
  line-height: 1;
  color: #ff373c !important;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.top-area .campaign .txt .cost span b {
    font-size: 22px;
  }
}
.lp-2021 .btn-area.top-area .attention {
  margin-top: 10px;
  font-size: 12px;
  font-weight: 600;
  color: #000;
  line-height: 1.5;
}

.lp-2021 .try .inner {
  max-width: 600px;
  padding: 10px 10px 0;
  background-color: #f3fbfe;
}

.lp-2021 .try h2 {
  margin: 20px;
}

.lp-2021 .try .img {
  margin: 20px 0 0;
  background-image: url(../img/lp2021-try-back-img.png);
  background-size: cover;
  background-position: center;
  padding: 180px 10px 10px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .try .img {
    margin: 20px -10px 0;
    padding: 160px 10px 10px;
  }
}
.lp-2021 .try .img p {
  text-align: center;
  color: #fff;
  font-weight: 600;
  font-size: 24px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .try .img p {
    font-size: 18px;
    line-height: 1.75;
  }
}
.lp-2021 .try .img .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
  margin: 20px 0 10px;
}

.lp-2021 .try .img .btn .left, .lp-2021 .try .img .btn .right {
  width: 49%;
}

.lp-2021 .try .img .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .try .img .btn .left a {
    padding: 10px 10px 10px 30px;
    background-size: 22px;
    background-position: 4px 50%;
    letter-spacing: 0;
    background-image: url(../img/top-btn-icon1-img.svg);
  }
}
.lp-2021 .try .img .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .try .img .btn .left a span {
    font-size: 14px;
  }
}
.lp-2021 .try .img .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .try .img .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.lp-2021 .try .img .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .try .img .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.lp-2021 .try .img .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .try .img .btn .right a span {
    font-size: 14px;
  }
}
.lp-2021 .try .img .form-btn {
  padding: 20px 60px 0;
}

@media screen and (max-width: 767px) {
  .lp-2021 .try .img .form-btn {
    padding: 20px 20px 0;
  }
}
.lp-2021 .try .img .form-btn .fuwafuwa {
  -webkit-animation: fuwafuwa 3s infinite linear alternate;
  animation: fuwafuwa 3s infinite linear alternate;
}

.lp-2021 .codiv .inner {
  max-width: 600px;
}

.lp-2021 .sns .inner {
  max-width: 600px;
}

.lp-2021 .sns .img img {
  width: 100%;
}

.lp-2021 .media .inner {
  max-width: 600px;
}

.lp-2021 .media .img {
  width: 100%;
}

.lp-2021 .youtube .inner {
  max-width: 600px;
  padding: 40px 30px;
  background-image: url(../img/lp2021-youtube-back-img.jpg);
  background-size: cover;
  background-position: center;
}

@media screen and (max-width: 767px) {
  .lp-2021 .youtube .inner {
    padding: 20px;
  }
}
.lp-2021 .youtube h2 {
  padding: 0 10px;
}

.lp-2021 .youtube .notice {
  font-size: 12px;
  font-weight: 600;
  margin-top: 10px;
}

.lp-2021 .youtube .img {
  margin: 30px 0 0;
}

.lp-2021 .youtube .img iframe {
  width: 100%;
  height: 300px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .youtube .img iframe {
    height: 200px;
  }
}
.lp-2021 .physical .inner {
  max-width: 600px;
  padding: 0 10px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .physical .inner {
    padding: 0;
  }
}
.lp-2021 .gallery .inner {
  max-width: 600px;
  padding: 0 10px 20px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .gallery .inner {
    padding: 0 0 20px;
  }
}
.lp-2021 .gallery .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.lp-2021 .gallery .list li {
  width: 33.33333%;
  position: relative;
}

.lp-2021 .gallery .list li:after {
  content: "";
  width: 40px;
  height: 40px;
  background-image: url(../im-img/voice-plus.png);
  background-repeat: no-repeat;
  background-size: 100%;
  position: absolute;
  bottom: 20px;
  right: 10px;
}

.lp-2021 .before-after .inner {
  max-width: 600px;
  background-color: #f3fbfe;
}

.lp-2021 .before-after h2 {
  margin-bottom: -80px;
  position: relative;
  z-index: 1;
}

.lp-2021 .before-after .list {
  overflow: hidden;
}

.lp-2021 .before-after .list .img {
  position: relative;
  background-color: #f4f4f4;
  padding-top: 30px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .before-after .list .img {
    padding-top: 20px;
  }
}
.lp-2021 .before-after .list .img:before {
  content: "";
  width: 50%;
  height: 100%;
  background-color: #2ca8e8;
  position: absolute;
  top: 0%;
  right: 0%;
}

.lp-2021 .before-after .list .img .inner {
  padding: 0 10px 0 160px;
  position: relative;
  z-index: 1;
  background: transparent;
}

@media screen and (max-width: 767px) {
  .lp-2021 .before-after .list .img .inner {
    padding: 0 10px;
  }
}
.lp-2021 .before-after .list .img .inner img {
  display: block;
  margin-bottom: -40px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .before-after .list .img .inner img {
    margin-bottom: -20px;
  }
}
.lp-2021 .before-after .list .number {
  background-color: #1e2f43;
  position: relative;
}

.lp-2021 .before-after .list .number .inner {
  padding: 60px 10px 30px;
  background: transparent;
}

@media screen and (max-width: 767px) {
  .lp-2021 .before-after .list .number .inner {
    padding: 30px 10px 20px;
  }
}
.lp-2021 .before-after .list .number .inner .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
  justify-content: space-around;
}

.lp-2021 .before-after .list .number .inner .list li {
  width: 32%;
  text-align: center;
  border: 1px solid #fff;
  padding: 20px 0;
  color: #fff;
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .before-after .list .number .inner .list li {
    padding: 10px 0;
    font-size: 12px;
  }
}
.lp-2021 .before-after .list .number .inner .list li span {
  color: #fdfc37;
  display: inline-block;
  margin: 0 2px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .before-after .list .number .inner .list li span {
    margin: 4px 2px 0;
  }
}
.lp-2021 .before-after .list .number .inner .list li b {
  font-family: Century Gothic;
  font-size: 22px;
  display: inline-block;
  vertical-align: baseline;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .lp-2021 .before-after .list .number .inner .list li b {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    font-size: 18px;
  }
}
.lp-2021 .before-after .list .number .inner .attention {
  margin: 10px 0 0 5px;
  color: #fff;
  font-size: 40%;
}

@media screen and (max-width: 767px) {
  .lp-2021 .before-after .list .number .inner .attention {
    margin: 10px 0 0 0;
  }
}
.lp-2021 .before-after .list.list1 .inner {
  padding: 0 60px;
  position: relative;
  z-index: 1;
  background: transparent;
}

@media screen and (max-width: 767px) {
  .lp-2021 .before-after .list.list1 .inner {
    padding: 0 20px;
  }
}
.lp-2021 .before-after .list.list1 .img {
  padding-top: 100px;
}

.lp-2021 .before-after .list.list1 .number .inner {
  padding: 60px 10px 30px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .before-after .list.list1 .number .inner {
    padding: 40px 10px 30px;
  }
}
.lp-2021 .before-after .list.list2 .inner {
  padding: 0 60px;
  position: relative;
  z-index: 1;
  background: transparent;
}

@media screen and (max-width: 767px) {
  .lp-2021 .before-after .list.list2 .inner {
    padding: 0 20px;
  }
}
.lp-2021 .before-after .list.list2 .img {
  padding-top: 20px;
}

.lp-2021 .before-after .list.list2 .number .inner {
  padding: 60px 10px 30px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .before-after .list.list2 .number .inner {
    padding: 40px 10px 30px;
  }
}
.lp-2021 .recommend .inner {
  max-width: 600px;
}

.lp-2021 .recommend.rec1 .inner {
  background-color: #2ccabd;
  padding: 10px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec1 .inner {
    padding: 20px 10px;
  }
}
.lp-2021 .recommend.rec1 .list {
  padding: 0 30px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec1 .list {
    padding: 0;
  }
}
.lp-2021 .recommend.rec1 .txt {
  padding: 14px 120px 0;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec1 .txt {
    padding: 20px 40px 10px;
  }
}
.lp-2021 .recommend.rec2.box .inner {
  padding: 50px 10px 40px;
  max-width: 600px;
  background-image: url(../img/lp2021-rec2-back-img.png);
  background-size: cover;
  background-position: center;
  position: relative;
}

.lp-2021 .recommend.rec2.box .inner:after {
  content: "";
  width: 100%;
  height: 30px;
  position: absolute;
  top: 0;
  left: 0;
  background-image: url(../img/lp2021-rec-bar-pc-img.png);
  background-size: cover;
  background-position: center;
}

.lp-2021 .recommend.rec2.box h3 {
  padding: 0 10px;
  margin: 0 0 20px;
}

.lp-2021 .recommend.rec3.box .inner {
  padding: 50px 10px 40px;
  max-width: 600px;
  background-image: url(../img/lp2021-rec3-back-img.png);
  background-size: cover;
  background-position: center;
  position: relative;
}

.lp-2021 .recommend.rec3.box .inner:after {
  content: "";
  width: 100%;
  height: 30px;
  position: absolute;
  top: 0;
  left: 0;
  background-image: url(../img/lp2021-rec-bar-pc-img.png);
  background-size: cover;
  background-position: center;
}

.lp-2021 .recommend.rec3.box h3 {
  padding: 0 100px 0 10px;
  margin: 0 0 20px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec3.box h3 {
    padding: 0 60px 0 10px;
  }
}
.lp-2021 .recommend.rec3.box .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 30px 0 0;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec3.box .list {
    margin: 20px 0 0;
  }
}
.lp-2021 .recommend.rec3.box .list .left {
  width: 20%;
}

.lp-2021 .recommend.rec3.box .list .right {
  width: 80%;
  padding: 4px 14px 0;
}

.lp-2021 .recommend.rec3.box .list .right h4 {
  color: #1d2f44;
  margin: 10px 0;
  font-size: 20px;
  font-weight: 600;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec3.box .list .right h4 {
    font-size: 16px;
  }
}
.lp-2021 .recommend.rec3.box .list .right p {
  font-size: 12px;
  line-height: 1.75;
}

.lp-2021 .recommend.rec3.box .notice {
  margin-top: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}

.lp-2021 .recommend.rec3.box .notice p {
  width: 80%;
  font-size: 12px;
  line-height: 1.75;
  padding: 0 14px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec3.box .notice p {
    width: 100%;
    padding: 0;
  }
}
.lp-2021 .recommend.rec4.box .inner {
  padding: 50px 10px 40px;
  max-width: 600px;
  background-color: #dbf3ff;
  position: relative;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec4.box .inner {
    background-color: #f3fbfe;
    padding: 50px 10px 20px;
  }
}
.lp-2021 .recommend.rec4.box .inner:after {
  content: "";
  width: 100%;
  height: 30px;
  position: absolute;
  top: 0;
  left: 0;
  background-image: url(../img/lp2021-rec-bar-pc-img.png);
  background-size: cover;
  background-position: center;
}

.lp-2021 .recommend.rec4.box h3 {
  padding: 0 10px;
  margin: 0 0 20px;
}

.lp-2021 .recommend.rec4.box p {
  text-align: center;
  background-color: #fff;
  border-radius: 2px;
  padding: 4px 0;
  font-size: 16px;
  font-weight: 600;
  color: #1d2f44;
}

.lp-2021 .recommend.rec4.box .list {
  margin: 10px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.lp-2021 .recommend.rec4.box .list .name {
  width: 23%;
  margin: 1%;
  background-color: #0ab4b1;
  padding: 4px 4px;
  text-align: center;
  color: #fff;
  font-size: 16px;
  border-radius: 6px;
  -webkit-box-shadow: 0 2px 5px 1px rgba(0, 0, 0, 0.2);
  box-shadow: 0 2px 5px 1px rgba(0, 0, 0, 0.2);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec4.box .list .name {
    width: 31.3333333%;
  }
}
.lp-2021 .recommend.rec4.box .list .name span {
  display: block;
  font-size: 12px;
}

.lp-2021 .recommend.rec5.box .inner {
  padding: 50px 10px 40px;
  max-width: 600px;
  position: relative;
}

.lp-2021 .recommend.rec5.box .inner:after {
  content: "";
  width: 100%;
  height: 30px;
  position: absolute;
  top: 0;
  left: 0;
  background-image: url(../img/lp2021-rec-bar-pc-img.png);
  background-size: cover;
  background-position: center;
}

.lp-2021 .recommend.rec5.box h3 {
  padding: 0 10px;
  margin: 0 0 20px;
}

.lp-2021 .recommend.rec5.box .txt {
  margin: 10px 0 40px;
  padding: 0 10px;
}

.lp-2021 .recommend.rec5.box .list {
  background-color: #dbf3ff;
  padding: 10px 10px 0;
  margin: 20px 0;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec5.box .list {
    background-color: #f3fbfe;
  }
}
.lp-2021 .recommend.rec5.box .list .wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec5.box .list .wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-flow: column-reverse;
    flex-flow: column-reverse;
  }
}
.lp-2021 .recommend.rec5.box .list.list1 h4 {
  padding-right: 80px;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec5.box .list.list1 h4 {
    padding: 0px 40px;
  }
}
.lp-2021 .recommend.rec5.box .list.list1 .right, .lp-2021 .recommend.rec5.box .list.list1 .left {
  width: 50%;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec5.box .list.list1 .right, .lp-2021 .recommend.rec5.box .list.list1 .left {
    width: 100%;
  }
}
.lp-2021 .recommend.rec5.box .list.list1 .left {
  padding: 0 10px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec5.box .list.list1 .left {
    padding: 0;
  }
}
.lp-2021 .recommend.rec5.box .list.list1 .left p {
  font-size: 12px;
  line-height: 1.5;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec5.box .list.list1 .left p {
    font-weight: 600;
  }
}
@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec5.box .list.list1 .right {
    margin: 10px 0;
    padding: 0 20px;
  }
}
.lp-2021 .recommend.rec5.box .list.list2 h4 {
  padding-right: 90px;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec5.box .list.list2 h4 {
    padding: 0px 40px;
  }
}
.lp-2021 .recommend.rec5.box .list.list2 .right {
  width: 20%;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec5.box .list.list2 .right {
    width: 100%;
    text-align: center;
  }
  .lp-2021 .recommend.rec5.box .list.list2 .right img {
    width: 40%;
  }
}
.lp-2021 .recommend.rec5.box .list.list2 .left {
  width: 80%;
  padding: 0 10px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec5.box .list.list2 .left {
    width: 100%;
    padding: 0;
  }
}
.lp-2021 .recommend.rec5.box .list.list2 .left p {
  font-size: 12px;
  line-height: 1.5;
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec5.box .list.list2 .left p {
    font-weight: 600;
  }
}
.lp-2021 .recommend.rec6.box .inner {
  padding: 50px 10px 40px;
  max-width: 600px;
  position: relative;
}

.lp-2021 .recommend.rec6.box .inner:after {
  content: "";
  width: 100%;
  height: 30px;
  position: absolute;
  top: 0;
  left: 0;
  background-image: url(../img/lp2021-rec-bar-pc-img.png);
  background-size: cover;
  background-position: center;
}

.lp-2021 .recommend.rec6.box h3 {
  padding: 0 10px;
  margin: 0 0 20px;
}

.lp-2021 .recommend.rec6.box .img p {
  margin: 10px 0;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec6.box .img p {
    font-size: 12px;
  }
}
.lp-2021 .recommend.rec6.box .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
  justify-content: space-around;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 20px 0;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec6.box .list {
    margin: 20px auto;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    max-width: 500px;
  }
}
.lp-2021 .recommend.rec6.box .list li {
  width: 48%;
  margin: 0 0 10px 0;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: left top;
  text-align: right;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec6.box .list li {
    width: 48%;
    background-position: -16px 50%;
  }
}
.lp-2021 .recommend.rec6.box .list li a {
  display: block;
  position: relative;
  color: #fff;
}

.lp-2021 .recommend.rec6.box .list .txt {
  text-align: left;
  display: inline-block;
  position: relative;
  background: #1e2f43;
  padding: 32px 10px 20px 20px;
  width: 58%;
}

.lp-2021 .recommend.rec6.box .list .txt:before {
  content: "";
  width: 30px;
  height: 100%;
  background-color: #1e2f43;
  position: absolute;
  left: -12px;
  top: 0;
  -webkit-transform: skewX(-10deg);
  -ms-transform: skewX(-10deg);
  transform: skewX(-10deg);
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec6.box .list .txt {
    width: 58%;
    padding: 32px 4px 20px 6px;
  }
}
.lp-2021 .recommend.rec6.box .list .txt .shop {
  background-color: #2ca8e8;
  display: inline-block;
  font-size: 12px;
  padding: 2px 10px;
  position: absolute;
  top: 10px;
  right: 0;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec6.box .list .txt .shop {
    font-size: 10px;
    padding: 2px 8px;
    top: 8px;
  }
}
.lp-2021 .recommend.rec6.box .list .txt .name {
  font-size: 14px;
  font-size: 20px;
  font-weight: 900;
  font-style: italic;
  letter-spacing: 1px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec6.box .list .txt .name {
    letter-spacing: 0;
    word-break: break-all;
    font-size: 14px;
  }
}
.lp-2021 .recommend.rec6.box .list .txt small {
  font-size: 10px;
  letter-spacing: 1px;
  position: relative;
}

.lp-2021 .recommend.rec6.box .list .img {
  width: 30%;
  position: absolute;
  bottom: 0;
  left: 5%;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec6.box .list .img {
    width: 40%;
    left: 2%;
    max-width: 78px;
  }
}
.lp-2021 .recommend.rec6.box .btn {
  text-align: center;
}

.lp-2021 .recommend.rec6.box .btn a {
  display: inline-block;
  font-weight: 900;
  padding: 18px 40px;
  border-radius: 30px;
  color: #1e2f43;
  border: 2px solid #1e2f43;
}

@media screen and (max-width: 767px) {
  .lp-2021 .recommend.rec6.box .btn a {
    padding: 16px 30px;
  }
}
.lp-2021 .course-box .inner {
  padding: 20px 10px;
  max-width: 600px;
  position: relative;
}

.lp-2021 .course-box h2 {
  text-align: center;
  background-color: #2ccabd;
  color: #fff;
  padding: 20px 0;
  font-size: 28px;
  letter-spacing: 2px;
  margin-bottom: 40px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .course-box h2 {
    font-size: 20px;
  }
}
.lp-2021 .course-box h2 b {
  font-size: 34px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .course-box h2 b {
    font-size: 26px;
  }
}
.lp-2021 .course-box .tab-area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  cursor: pointer;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}

.lp-2021 .course-box .tab-area .tab {
  width: 24.6%;
  text-align: center;
  color: white;
  border-radius: 6px 6px 0 0;
  background-color: #1e2f43;
}

@media screen and (max-width: 767px) {
  .lp-2021 .course-box .tab-area .tab {
    width: 23.3333333333%;
  }
}
.lp-2021 .course-box .tab-area .tab.other {
  padding: 10px 0;
}

.lp-2021 .course-box .tab-area .tab.other .name {
  font-weight: 900;
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .course-box .tab-area .tab.other .name {
    font-size: 12px;
  }
}
.lp-2021 .course-box .tab-area .tab.other .name small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  display: block;
  font-size: 10px;
  margin-top: 2px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .course-box .tab-area .tab.other .name small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    letter-spacing: 0;
  }
}
.lp-2021 .course-box .tab-area .tab.special {
  padding: 10px 10px 10px 20px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .lp-2021 .course-box .tab-area .tab.special {
    padding: 10px 2px;
  }
}
.lp-2021 .course-box .tab-area .tab.special .point {
  background-color: #fff268;
  display: block;
  width: 50px;
  height: 50px;
  border-radius: 100%;
  color: #000;
  font-weight: 900;
  position: absolute;
  top: -22px;
  left: -20px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .course-box .tab-area .tab.special .point {
    width: 40px;
    height: 40px;
    top: -30px;
    left: 4px;
  }
}
.lp-2021 .course-box .tab-area .tab.special .point span {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  font-size: 12px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .course-box .tab-area .tab.special .point span {
    font-size: 10px;
  }
}
.lp-2021 .course-box .tab-area .tab.special .point span b {
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .course-box .tab-area .tab.special .point span b {
    font-size: 10px;
  }
}
.lp-2021 .course-box .tab-area .tab.special .name {
  font-weight: 900;
  font-size: 14px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .course-box .tab-area .tab.special .name {
    font-size: 12px;
    letter-spacing: 0;
  }
}
.lp-2021 .course-box .tab-area .tab.special .name small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #fff268;
  display: block;
  font-size: 10px;
  margin-top: 2px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .course-box .tab-area .tab.special .name small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    letter-spacing: 0;
  }
}
.lp-2021 .course-box .tab-area .tab.active {
  background-color: #ff373c;
  padding: 14px 10px 14px 10px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .course-box .tab-area .tab.active {
    padding: 12px 2px 12px 2px;
    width: 29%;
  }
}
.lp-2021 .course-box .tab-area .tab.active .name {
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .course-box .tab-area .tab.active .name {
    font-size: 12px;
  }
}
.lp-2021 .course-box .tab-area .tab.active.special {
  padding: 14px 10px 14px 20px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .course-box .tab-area .tab.active.special {
    padding: 12px 2px 12px 2px;
    width: 29%;
  }
}
.lp-2021 .course-box .content-area .content {
  display: none;
  background-color: #f4f4f4;
  padding: 20px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .course-box .content-area .content {
    padding: 10px;
  }
}
.lp-2021 .course-box .content-area .content .name {
  text-align: center;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: 1px;
  line-height: 1.6;
  margin: 10px 0 20px 0;
}

@media screen and (max-width: 767px) {
  .lp-2021 .course-box .content-area .content .name {
    font-size: 14px;
    letter-spacing: 0;
    margin: 0 0 20px 0;
  }
}
.lp-2021 .course-box .content-area .content .table {
  width: 100%;
  margin: 20px 0 10px;
  font-weight: 900;
}

.lp-2021 .course-box .content-area .content .table th {
  background-color: #f4fbfe;
  color: #2ca8e8;
  padding: 14px 0;
  letter-spacing: 1px;
  width: 40%;
  border-bottom: 2px solid #f4f4f4;
}

@media screen and (max-width: 767px) {
  .lp-2021 .course-box .content-area .content .table th {
    padding: 10px 0;
    width: 30%;
    font-size: 12px;
  }
}
.lp-2021 .course-box .content-area .content .table td {
  font-family: Century Gothic;
  background-color: #fff;
  width: 60%;
  text-align: center;
  padding: 20px 10px;
  border-bottom: 2px solid #f4f4f4;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .course-box .content-area .content .table td {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    width: 70%;
    padding: 14px 10px;
    font-size: 14px;
  }
}
.lp-2021 .course-box .content-area .content .table td .font-small {
  font-size: 12px;
  display: inline-block;
  position: relative;
  top: -1px;
}

.lp-2021 .course-box .content-area .content .table td .border {
  text-decoration: line-through;
}

.lp-2021 .course-box .content-area .content .table td .border .font-small {
  font-size: 12px;
  display: inline-block;
  text-decoration: line-through;
  position: relative;
  top: -1px;
}

.lp-2021 .course-box .content-area .content .table td .color {
  color: #ff373c;
}

.lp-2021 .course-box .content-area .content .table td .color .font-small {
  font-size: 12px;
  display: inline-block;
  position: relative;
  top: -1px;
}

.lp-2021 .course-box .content-area .content .attention p {
  font-weight: 900;
  font-size: 12px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .lp-2021 .course-box .content-area .content .attention p {
    font-size: 10px;
  }
}
.lp-2021 .course-box .content-area .content.show {
  display: block;
}

.lp-2021 .shop-box .inner {
  padding: 20px 10px;
  max-width: 600px;
  position: relative;
}

.lp-2021 .shop-box h2 {
  text-align: center;
  background-color: #2ccabd;
  color: #fff;
  padding: 20px 0;
  font-size: 28px;
  letter-spacing: 2px;
  margin-bottom: 40px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .shop-box h2 {
    font-size: 20px;
    margin-bottom: 20px;
  }
}
.lp-2021 .shop-box h2 b {
  font-size: 34px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .shop-box h2 b {
    font-size: 26px;
  }
}
.lp-2021 .shop-box p {
  background-color: #f3fbfe;
  padding: 4px 0;
  font-size: 16px;
  font-weight: 600;
  color: #1d2f44;
}

.lp-2021 .shop-box .list {
  margin: 10px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.lp-2021 .shop-box .list .name {
  width: 23%;
  margin: 1%;
  padding: 4px 4px;
  text-align: center;
  color: #1d2f44;
  border: 2px solid #1d2f44;
  font-size: 16px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .lp-2021 .shop-box .list .name {
    width: 31.3333333%;
  }
}
.lp-2021 .shop-box .list .name a {
  color: #1d2f44;
}

.lp-2021 .shop-box .list .name span {
  display: block;
  font-size: 12px;
}

.lp-2021 .line-area .inner {
  padding: 20px 10px;
  max-width: 400px;
}

.lp-2021 .line-area .line {
  border-radius: 4px;
  margin-bottom: 10px;
  overflow: hidden;
}

.lp-2021 .line-area .line a {
  display: block;
  background-color: #5fe536;
  text-align: center;
  padding: 20px 10px;
  color: #fff;
  font-weight: 900;
  font-size: 16px;
  letter-spacing: 1px;
  background-image: url(../img/line-icon-img.png), url(../img/icon1-img.png);
  background-size: 32px, 10px;
  background-position: 14px 50%, 90% 53%;
}

.lp-2021 .form-area .inner {
  padding: 10px 10px 80px;
  max-width: 600px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .form-area .inner {
    padding: 10px 10px 60px;
  }
}
.lp-2021 .form-area .form-ttl {
  background-color: #ff363c;
  padding: 14px;
  color: #fff;
  text-align: center;
  font-size: 22px;
  line-height: 1;
  position: relative;
  margin-bottom: 40px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .form-area .form-ttl {
    font-size: 18px;
  }
}
.lp-2021 .form-area .form-ttl:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -12px;
  border: 10px solid transparent;
  border-top: 12px solid #ff363c;
}

.lp-2021 .form-area .box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

@media screen and (max-width: 767px) {
  .lp-2021 .form-area .box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
    margin-bottom: 0;
  }
}
.lp-2021 .form-area .box .half {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0 0 20px 0;
}

@media screen and (max-width: 767px) {
  .lp-2021 .form-area .box .half {
    width: 100%;
    margin-bottom: 10px;
  }
}
.lp-2021 .form-area .box .all {
  width: 100%;
}

.lp-2021 .form-area .box .ttl {
  font-weight: 900;
  color: #1e2f43;
  padding: 14px 10px 8px 10px;
  position: relative;
  width: 38%;
  text-align: center;
  text-indent: -20px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .form-area .box .ttl {
    font-size: 12px;
    padding: 10px 20px 0 10px;
    width: 36%;
    text-indent: 0;
  }
}
.lp-2021 .form-area .box .ttl .req {
  display: inline-block;
  background-color: #ff363c;
  padding: 6px;
  color: #fff;
  line-height: 1;
  font-size: 10px;
  margin-left: 4px;
  position: absolute;
  right: 12px;
  text-indent: 0;
  border-radius: 4px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .form-area .box .ttl .req {
    font-size: 10px;
    padding: 4px;
    right: 0;
    top: 10px;
  }
}
.lp-2021 .form-area .box .ttl .not-req {
  display: inline-block;
  background-color: #1e2f43;
  padding: 6px;
  color: #fff;
  line-height: 1;
  font-size: 10px;
  margin-left: 4px;
  position: absolute;
  right: 12px;
  text-indent: 0;
  border-radius: 4px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .form-area .box .ttl .not-req {
    font-size: 10px;
    padding: 4px;
    right: 0;
  }
}
.lp-2021 .form-area .box .input-area {
  width: 62%;
  position: relative;
}

@media screen and (max-width: 767px) {
  .lp-2021 .form-area .box .input-area {
    padding: 0 10px;
    width: 64%;
  }
}
.lp-2021 .form-area .box .input-area input[type=text], .lp-2021 .form-area .box .input-area input[type=tel], .lp-2021 .form-area .box .input-area input[type=email], .lp-2021 .form-area .box .input-area input[type=date] {
  width: 100%;
  height: 50px;
  padding: 10px;
  border-radius: 4px;
  color: #1e2f43;
  border: 2px solid #ddd;
}

.lp-2021 .form-area .box .input-area input[type=text]::-webkit-input-placeholder, .lp-2021 .form-area .box .input-area input[type=tel]::-webkit-input-placeholder, .lp-2021 .form-area .box .input-area input[type=email]::-webkit-input-placeholder, .lp-2021 .form-area .box .input-area input[type=date]::-webkit-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.lp-2021 .form-area .box .input-area input[type=text]:-ms-input-placeholder, .lp-2021 .form-area .box .input-area input[type=tel]:-ms-input-placeholder, .lp-2021 .form-area .box .input-area input[type=email]:-ms-input-placeholder, .lp-2021 .form-area .box .input-area input[type=date]:-ms-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.lp-2021 .form-area .box .input-area input[type=text]::-ms-input-placeholder, .lp-2021 .form-area .box .input-area input[type=tel]::-ms-input-placeholder, .lp-2021 .form-area .box .input-area input[type=email]::-ms-input-placeholder, .lp-2021 .form-area .box .input-area input[type=date]::-ms-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.lp-2021 .form-area .box .input-area input[type=text]::placeholder, .lp-2021 .form-area .box .input-area input[type=tel]::placeholder, .lp-2021 .form-area .box .input-area input[type=email]::placeholder, .lp-2021 .form-area .box .input-area input[type=date]::placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

@media screen and (max-width: 767px) {
  .lp-2021 .form-area .box .input-area input[type=text], .lp-2021 .form-area .box .input-area input[type=tel], .lp-2021 .form-area .box .input-area input[type=email], .lp-2021 .form-area .box .input-area input[type=date] {
    height: 45px;
  }
}
.lp-2021 .form-area .box .input-area input[type=radio] {
  margin: 0 6px;
  vertical-align: text-bottom;
}

.lp-2021 .form-area .box .input-area select {
  width: 70%;
  height: 50px;
  padding: 10px;
  border-radius: 4px;
  color: #a9a9a9;
  border: 2px solid #ddd;
}

@media screen and (max-width: 767px) {
  .lp-2021 .form-area .box .input-area select {
    height: 45px;
    width: 100%;
  }
}
.lp-2021 .form-area .box .input-area textarea {
  width: 100%;
  height: 160px;
  padding: 10px;
  border-radius: 4px;
  font-weight: 900;
  color: #1e2f43;
  border: 2px solid #ddd;
}

.lp-2021 .form-area .box .input-area textarea::-webkit-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.lp-2021 .form-area .box .input-area textarea:-ms-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.lp-2021 .form-area .box .input-area textarea::-ms-input-placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.lp-2021 .form-area .box .input-area textarea::placeholder {
  color: #a9a9a9;
  font-weight: 900;
}

.lp-2021 .form-area .box .input-area select.req {
  border: 2px solid #ddd;
  font-weight: 900;
  background-color: #ffe9e8;
}

.lp-2021 .form-area .box .input-area input.req[type=text], .lp-2021 .form-area .box .input-area input.req[type=tel], .lp-2021 .form-area .box .input-area input.req[type=email], .lp-2021 .form-area .box .input-area input.req[type=date] {
  border: 2px solid #ddd;
  font-weight: 900;
  background-color: #ffe9e8;
}

.lp-2021 .form-area .box .input-area.radio {
  padding-top: 14px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .form-area .box .input-area.radio {
    padding-top: 10px;
  }
}
.lp-2021 .form-area .box .attention {
  width: 100%;
  margin-top: 10px;
  color: #1e2f43;
  font-weight: 900;
  font-size: 12px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .form-area .box .attention {
    padding: 0 10px;
  }
}
.lp-2021 .form-area .box .select-point.all {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 12px;
  position: absolute;
  top: 18px;
  line-height: 1;
  right: 34%;
  display: block;
}

@media screen and (max-width: 767px) {
  .lp-2021 .form-area .box .select-point.all {
    font-size: 10px;
    right: 10%;
  }
}
.lp-2021 .form-area .btn {
  text-align: center;
  margin-top: 40px;
}

.lp-2021 .form-area .btn input[type=submit] {
  background-color: #ff363c;
  color: #fff;
  font-weight: 900;
  padding: 20px 60px;
  display: inline-block;
  border-radius: 6px;
  background-image: url(../img/contact-btn-icon1.png);
  background-size: 22px;
  background-position: 94% 50%;
  background-repeat: no-repeat;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
}

.lp-2021 .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.lp-2021 .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.lp-2021 .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.bottom-area .btn {
    margin-top: 0;
  }
}
.lp-2021 .btn-area.bottom-area .btn .left, .lp-2021 .btn-area.bottom-area .btn .right {
  width: 49%;
}

.lp-2021 .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.bottom-area .btn .left a {
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
    background-image: url(../img/top-btn-icon1-img.svg);
  }
}
.lp-2021 .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
}
.lp-2021 .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.lp-2021 .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 40px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.lp-2021 .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .lp-2021 .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}
.lp-2021 .copyright {
  margin: 0;
  text-align: center;
  padding: 10px;
  background-color: #2ccabd;
  color: #fff;
}

.Lp-wrapper.lp-c .btn-area.bottom-area.lp-fixed-btn {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}

.Lp-wrapper.lp-c .btn-area.bottom-area.lp-fixed-btn .inner {
  padding: 10px 60px;
  max-width: 800px;
}

@media screen and (max-width: 767px) {
  .Lp-wrapper.lp-c .btn-area.bottom-area.lp-fixed-btn .inner {
    padding: 10px;
    max-width: 500px;
  }
}
.Lp-wrapper.lp-c .btn-area.bottom-area.lp-fixed-btn .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .Lp-wrapper.lp-c .btn-area.bottom-area.lp-fixed-btn .btn {
    margin-top: 0;
  }
}
.Lp-wrapper.lp-c .btn-area.bottom-area.lp-fixed-btn .btn .left, .Lp-wrapper.lp-c .btn-area.bottom-area.lp-fixed-btn .btn .right {
  width: 49%;
}

.Lp-wrapper.lp-c .btn-area.bottom-area.lp-fixed-btn .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .Lp-wrapper.lp-c .btn-area.bottom-area.lp-fixed-btn .btn .left a {
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
    background-image: url(../img/top-btn-icon1-img.svg);
  }
}
.Lp-wrapper.lp-c .btn-area.bottom-area.lp-fixed-btn .btn .left a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .Lp-wrapper.lp-c .btn-area.bottom-area.lp-fixed-btn .btn .left a span {
    font-size: 14px;
  }
}
.Lp-wrapper.lp-c .btn-area.bottom-area.lp-fixed-btn .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}

@media screen and (max-width: 767px) {
  .Lp-wrapper.lp-c .btn-area.bottom-area.lp-fixed-btn .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
}
.Lp-wrapper.lp-c .btn-area.bottom-area.lp-fixed-btn .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .Lp-wrapper.lp-c .btn-area.bottom-area.lp-fixed-btn .btn .right a {
    padding: 21px 10px 21px 40px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
}
.Lp-wrapper.lp-c .btn-area.bottom-area.lp-fixed-btn .btn .right a span {
  color: #fff;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .Lp-wrapper.lp-c .btn-area.bottom-area.lp-fixed-btn .btn .right a span {
    font-size: 14px;
  }
}
.Lp-wrapper.lp-c .top-line {
  padding: 14px 10px;
  max-width: 500px;
  margin: 0 auto 40px;
}

.Lp-wrapper.lp-c .top-line .line {
  border-radius: 4px;
  overflow: hidden;
}

.Lp-wrapper.lp-c .top-line .line a {
  display: block;
  background-color: #00b900;
  text-align: center;
  padding: 20px 10px;
  color: #fff;
  font-weight: 900;
  font-size: 16px;
  letter-spacing: 1px;
  background-image: url(../img/line-icon-img.png), url(../img/icon1-img.png);
  background-size: 32px, 10px;
  background-position: 14px 50%, 90% 53%;
}

.taxonomy-shop-page .shop .shop-wrap {
  margin-bottom: 20px;
}

.taxonomy-shop-page .shop .shop-wrap .shop-ttl {
  margin-bottom: 20px;
  color: #241d41;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-wrap .shop-ttl {
    padding: 0 10px;
  }
}
.taxonomy-shop-page .shop .shop-wrap .shop-ttl p {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0px;
  margin: 0 0 4px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-wrap .shop-ttl p {
    font-size: 10px;
  }
}
.taxonomy-shop-page .shop .shop-wrap .shop-ttl h2 {
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0px;
  margin: 10px 0;
  color: #47b2ea;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-wrap .shop-ttl h2 {
    font-size: 16px;
  }
}
.taxonomy-shop-page .shop .shop-wrap .main-img-wrap .main-shop {
  margin-bottom: 20px;
}

.taxonomy-shop-page .shop .shop-wrap .main-img-wrap .main-shop .txt {
  margin-top: 16px;
}

.taxonomy-shop-page .shop .shop-wrap .main-img-wrap .main-shop p {
  font-size: 12px;
  margin-top: 6px;
  line-height: 1.6;
}

.taxonomy-shop-page .shop .shop-wrap .main-img-wrap .sub-shop {
  overflow: hidden;
}

.taxonomy-shop-page .shop .shop-wrap .main-img-wrap .sub-shop .scroll {
  overflow: scroll;
  -webkit-overflow-scrolling: touch;
}

.taxonomy-shop-page .shop .shop-wrap .main-img-wrap .sub-shop .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

.taxonomy-shop-page .shop .shop-wrap .main-img-wrap .sub-shop .list li {
  width: 200px;
  margin-right: 10px;
  display: block;
  margin-bottom: 0;
}

.taxonomy-shop-page .shop .shop-wrap .main-img-wrap .sub-shop .list li:last-child {
  margin-right: 0;
}

.taxonomy-shop-page .shop .shop-wrap .main-img-wrap .sub-shop .list .img {
  width: 100%;
}

.taxonomy-shop-page .shop .shop-wrap .main-img-wrap .sub-shop .list .txt {
  width: 100%;
  margin-top: 10px;
}

.taxonomy-shop-page .shop .shop-wrap .main-img-wrap .sub-shop .list p {
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.5;
}

.taxonomy-shop-page .shop .shop-wrap .shop-info {
  margin: 20px 0;
  padding: 10px;
  background-color: #f2fbfe;
}

.taxonomy-shop-page .shop .shop-wrap .shop-info h2 {
  margin: 0;
  font-size: 12px;
  font-weight: 600;
  margin-bottom: 10px;
  line-height: 1;
  color: #221e3f;
}

.taxonomy-shop-page .shop .shop-wrap .shop-info .shop-table table {
  width: 100%;
  border-collapse: collapse;
}

.taxonomy-shop-page .shop .shop-wrap .shop-info .shop-table tr:last-child th, .taxonomy-shop-page .shop .shop-wrap .shop-info .shop-table tr:last-child td {
  border-bottom: none;
}

.taxonomy-shop-page .shop .shop-wrap .shop-info .shop-table th {
  color: #47b2ea;
  padding: 10px 14px;
  width: 26%;
  line-height: 1;
  background-color: #fff;
  font-size: 12px;
  text-align: left;
  border-bottom: 4px solid #f2fbfe;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-wrap .shop-info .shop-table th {
    padding: 12px;
    width: 30%;
  }
}
.taxonomy-shop-page .shop .shop-wrap .shop-info .shop-table td {
  color: #47b2ea;
  font-size: 12px;
  background-color: #fff;
  padding: 10px 18px;
  border-bottom: 6px solid #f2fbfe;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-wrap .shop-info .shop-table td {
    padding: 10px 12px;
  }
}
.taxonomy-shop-page .shop .shop-wrap .shop-info .shop-table .shop-btn {
  display: inline-block;
  background-color: #221e3f;
  color: #fff;
  font-size: 10px;
  line-height: 1;
  padding: 6px 12px;
  border-radius: 4px;
  margin-left: 20px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-wrap .shop-info .shop-table .shop-btn {
    margin-top: 10px;
    margin-left: 10px;
  }
}
.taxonomy-shop-page .shop .shop-wrap .shop-more-btn {
  margin: 30px 0;
  text-align: center;
}

.taxonomy-shop-page .shop .shop-wrap .shop-more-btn a {
  display: inline-block;
  background-color: #221e3f;
  color: #fff;
  border-radius: 30px;
  padding: 16px 30px;
  font-size: 12px;
}

.taxonomy-shop-page .shop .price .inner {
  margin: 40px 0;
}

.taxonomy-shop-page .shop .price h2 {
  text-align: center;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 40px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .price h2 {
    font-size: 18px;
    margin-bottom: 20px;
    padding: 0 10px;
  }
}
.taxonomy-shop-page .shop .price h2 small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  display: block;
  font-size: 12px;
  margin-top: 10px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .price h2 small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.taxonomy-shop-page .shop .price .tab-area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  cursor: pointer;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}

.taxonomy-shop-page .shop .price .tab-area .tab {
  width: 24.6%;
  text-align: center;
  color: white;
  border-radius: 6px 6px 0 0;
  background-color: #1e2f43;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .price .tab-area .tab {
    width: 23.3333333333%;
  }
}
.taxonomy-shop-page .shop .price .tab-area .tab.other {
  padding: 10px 0;
}

.taxonomy-shop-page .shop .price .tab-area .tab.other .name {
  font-weight: 900;
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .price .tab-area .tab.other .name {
    font-size: 12px;
  }
}
.taxonomy-shop-page .shop .price .tab-area .tab.other .name small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  display: block;
  font-size: 10px;
  margin-top: 2px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .price .tab-area .tab.other .name small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    letter-spacing: 0;
  }
}
.taxonomy-shop-page .shop .price .tab-area .tab.special {
  padding: 10px 10px 10px 30px;
  position: relative;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .price .tab-area .tab.special {
    padding: 10px 2px;
  }
}
.taxonomy-shop-page .shop .price .tab-area .tab.special .point {
  background-color: #fff268;
  display: block;
  width: 44px;
  height: 44px;
  border-radius: 100%;
  color: #000;
  font-weight: 900;
  position: absolute;
  top: -10px;
  left: -6px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .price .tab-area .tab.special .point {
    width: 40px;
    height: 40px;
    top: -30px;
    left: 4px;
  }
}
.taxonomy-shop-page .shop .price .tab-area .tab.special .point span {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  font-size: 12px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .price .tab-area .tab.special .point span {
    font-size: 10px;
  }
}
.taxonomy-shop-page .shop .price .tab-area .tab.special .point span b {
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .price .tab-area .tab.special .point span b {
    font-size: 10px;
  }
}
.taxonomy-shop-page .shop .price .tab-area .tab.special .name {
  font-weight: 900;
  font-size: 14px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .price .tab-area .tab.special .name {
    font-size: 12px;
    letter-spacing: 0;
  }
}
.taxonomy-shop-page .shop .price .tab-area .tab.special .name small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #fff268;
  display: block;
  font-size: 10px;
  margin-top: 2px;
  letter-spacing: 1px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .price .tab-area .tab.special .name small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    letter-spacing: 0;
  }
}
.taxonomy-shop-page .shop .price .tab-area .tab.active {
  background-color: #ff373c;
  padding: 12px 10px 12px 10px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .price .tab-area .tab.active {
    padding: 12px 2px 12px 2px;
    width: 29%;
  }
}
.taxonomy-shop-page .shop .price .tab-area .tab.active .name {
  font-size: 14px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .price .tab-area .tab.active .name {
    font-size: 12px;
  }
}
.taxonomy-shop-page .shop .price .tab-area .tab.active.special {
  padding: 12px 10px 12px 20px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .price .tab-area .tab.active.special {
    padding: 12px 2px 12px 2px;
    width: 29%;
  }
}
.taxonomy-shop-page .shop .price .content-area .content {
  display: none;
  background-color: #f4f4f4;
  padding: 20px 40px 30px 40px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .price .content-area .content {
    padding: 20px;
  }
}
.taxonomy-shop-page .shop .price .content-area .content .name {
  text-align: center;
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 1px;
  line-height: 1.6;
  margin: 10px 0 20px 0;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .price .content-area .content .name {
    font-size: 14px;
    letter-spacing: 0;
    margin: 0 0 20px 0;
  }
}
.taxonomy-shop-page .shop .price .content-area .content .table {
  width: 100%;
  margin: 20px 0 10px;
  font-weight: 900;
}

.taxonomy-shop-page .shop .price .content-area .content .table th {
  background-color: #f4fbfe;
  color: #2ca8e8;
  padding: 14px 0;
  letter-spacing: 1px;
  width: 40%;
  border-bottom: 2px solid #f4f4f4;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .price .content-area .content .table th {
    padding: 10px 0;
    width: 30%;
    font-size: 12px;
  }
}
.taxonomy-shop-page .shop .price .content-area .content .table td {
  font-family: Century Gothic;
  background-color: #fff;
  width: 60%;
  text-align: center;
  padding: 20px 10px;
  border-bottom: 2px solid #f4f4f4;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .price .content-area .content .table td {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
    width: 70%;
    padding: 14px 10px;
    font-size: 14px;
  }
}
.taxonomy-shop-page .shop .price .content-area .content .table td .font-small {
  font-size: 12px;
  display: inline-block;
  position: relative;
  top: -1px;
}

.taxonomy-shop-page .shop .price .content-area .content .table td .border {
  text-decoration: line-through;
}

.taxonomy-shop-page .shop .price .content-area .content .table td .border .font-small {
  font-size: 12px;
  display: inline-block;
  text-decoration: line-through;
  position: relative;
  top: -1px;
}

.taxonomy-shop-page .shop .price .content-area .content .table td .color {
  color: #ff373c;
}

.taxonomy-shop-page .shop .price .content-area .content .table td .color .font-small {
  font-size: 12px;
  display: inline-block;
  position: relative;
  top: -1px;
}

.taxonomy-shop-page .shop .price .content-area .content .attention p {
  font-weight: 900;
  font-size: 12px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .price .content-area .content .attention p {
    font-size: 10px;
  }
}
.taxonomy-shop-page .shop .price .content-area .content.show {
  display: block;
}

.taxonomy-shop-page .shop .shop-notice {
  margin: 40px 0;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-notice {
    padding: 0 10px;
  }
}
.taxonomy-shop-page .shop .shop-notice h2 {
  color: #1e2f43;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: 2px;
  padding-bottom: 10px;
  margin: 20px 0;
  position: relative;
  background-repeat: repeat-x;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-notice h2 {
    font-size: 18px;
  }
}
.taxonomy-shop-page .shop .shop-notice h2:after {
  content: "";
  width: 100%;
  height: 4px;
  bottom: 0;
  left: 0;
  position: absolute;
  background-image: url(../img/page-h2-img.png);
  background-size: contain;
  background-position: 0 100%;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-notice h2:after {
    background-size: auto;
  }
}
.taxonomy-shop-page .shop .shop-notice .txt {
  background-color: #f4fbfe;
  padding: 20px;
  color: #1e2f43;
  margin-bottom: 30px;
}

.taxonomy-shop-page .shop .shop-notice .txt p {
  line-height: 1.9;
}

.taxonomy-shop-page .shop .shop-notice .txt b {
  display: inline-block;
}

.taxonomy-shop-page .shop .shop-notice .txt b span {
  width: 10px;
  height: 10px;
  display: inline-block;
  background-color: #1e2f43;
  margin-right: 6px;
}

.taxonomy-shop-page .shop .shop-flow {
  margin: 40px 0;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-flow {
    padding: 0 10px;
  }
}
.taxonomy-shop-page .shop .shop-flow h2 {
  text-align: center;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 40px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-flow h2 {
    font-size: 18px;
    margin-bottom: 20px;
    padding: 0 10px;
  }
}
.taxonomy-shop-page .shop .shop-flow h2 small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  display: block;
  font-size: 12px;
  margin-top: 10px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-flow h2 small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.taxonomy-shop-page .shop .shop-flow .list {
  margin: 20px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-flow .list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.taxonomy-shop-page .shop .shop-flow .list .ttl {
  width: 120px;
  height: 120px;
  position: relative;
  background-color: #f3fbfe;
  border-radius: 100%;
}

.taxonomy-shop-page .shop .shop-flow .list .ttl .wrap {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  margin-top: -10px;
  letter-spacing: 1px;
}

.taxonomy-shop-page .shop .shop-flow .list .ttl .wrap span {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  font-size: 14px;
}

.taxonomy-shop-page .shop .shop-flow .list .ttl .wrap p {
  font-size: 18px;
  font-weight: 600;
  margin-top: 10px;
}

.taxonomy-shop-page .shop .shop-flow .list .txt {
  width: 550px;
  display: block;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-flow .list .txt {
    width: 100%;
    margin-top: 14px;
  }
}
.taxonomy-shop-page .shop .shop-flow .list .txt b {
  line-height: 1.4;
  display: block;
  border-bottom: 1px dashed #a5acb4;
  padding-bottom: 4px;
}

.taxonomy-shop-page .shop .shop-flow .list .txt p {
  margin: 10px 0;
  font-size: 12px;
  letter-spacing: 1px;
  line-height: 1.5;
}

.taxonomy-shop-page .shop .shop-flow .list .txt span {
  display: inline-block;
}

.taxonomy-shop-page .shop .shop-flow .list .txt span.blue {
  margin: 0 20px 0 0;
}

.taxonomy-shop-page .shop .shop-flow .list .txt span.blue a {
  color: #221e3f;
  font-weight: 600;
  font-size: 12px;
}

.taxonomy-shop-page .shop .shop-flow .list .txt span.green a {
  color: #2acc26;
  font-weight: 600;
  font-size: 12px;
}

.taxonomy-shop-page .shop .shop-check {
  margin: 40px 0;
}

.taxonomy-shop-page .shop .shop-check h2 {
  text-align: center;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 40px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-check h2 {
    font-size: 18px;
    margin-bottom: 20px;
    padding: 0 10px;
  }
}
.taxonomy-shop-page .shop .shop-check h2 small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  display: block;
  font-size: 12px;
  margin-top: 10px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-check h2 small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.taxonomy-shop-page .shop .shop-check .box {
  padding: 20px 20px 60px 20px;
  background-image: url(../img/single-shop-check-img.png);
  background-size: 86%;
  background-position: 100% 50%;
  background-color: #a0d3ca;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-check .box {
    background-image: none;
    padding: 20px;
  }
}
.taxonomy-shop-page .shop .shop-check .box .txt {
  width: 50%;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-check .box .txt {
    width: 100%;
  }
}
.taxonomy-shop-page .shop .shop-check .box .list li {
  display: block;
  margin-bottom: 10px;
  background-color: #1d2f44;
  padding: 12px 10px;
  color: #fff;
}

.taxonomy-shop-page .shop .shop-check .box .list h3 {
  margin-bottom: 10px;
  font-weight: 600;
}

.taxonomy-shop-page .shop .shop-check .box .list p {
  font-size: 12px;
  line-height: 1.5;
}

.taxonomy-shop-page .shop .shop-rule {
  margin: 40px 0 0;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-rule {
    padding: 0 10px;
  }
}
.taxonomy-shop-page .shop .shop-rule h2 {
  text-align: center;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 40px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-rule h2 {
    font-size: 18px;
    margin-bottom: 20px;
    padding: 0 10px;
  }
}
.taxonomy-shop-page .shop .shop-rule .list li {
  border: 2px solid #2ca8e8;
  border-radius: 4px;
  padding: 20px;
  margin-bottom: 10px;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-rule .list li {
    padding: 20px 10px 10px 90px;
  }
}
.taxonomy-shop-page .shop .shop-rule .list li .txt {
  width: 550px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-rule .list li .txt {
    width: 100%;
  }
}
.taxonomy-shop-page .shop .shop-rule .list .point {
  display: block;
  width: 80px;
  height: 80px;
  background-color: #2ca8e8;
  border-radius: 100%;
  position: relative;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-rule .list .point {
    position: absolute;
    top: 24px;
    left: 10px;
    margin: 0 auto;
    width: 70px;
    height: 70px;
  }
}
.taxonomy-shop-page .shop .shop-rule .list .point:before {
  content: "";
  width: 20px;
  height: 20px;
  top: -18px;
  right: -16px;
  left: 0;
  margin: 0 auto;
  position: absolute;
  background-image: url(../img/top-date-icon-img.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-rule .list .point:before {
    right: -22px;
  }
}
.taxonomy-shop-page .shop .shop-rule .list .date {
  color: #fff;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  -ms-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  text-align: center;
  font-weight: 900;
  font-size: 24px;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-rule .list .date {
    font-size: 20px;
  }
}
.taxonomy-shop-page .shop .shop-rule .list .date small {
  display: block;
  line-height: 1;
  font-size: 12px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-rule .list .date small {
    margin-top: 2px;
  }
}
.taxonomy-shop-page .shop .shop-rule .list h3 {
  margin-bottom: 10px;
  font-weight: 600;
  color: #2ca8e8;
  line-height: 1.5;
  font-size: 18px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .shop-rule .list h3 {
    font-size: 16px;
  }
}
.taxonomy-shop-page .shop .shop-rule .list p {
  line-height: 1.5;
  font-size: 12px;
}

.taxonomy-shop-page .shop .faq-wrap .inner {
  padding: 40px 0 0;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .faq-wrap .inner {
    padding: 40px 0;
  }
}
.taxonomy-shop-page .shop .faq-wrap h2 {
  text-align: center;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: 1px;
  margin-bottom: 40px;
  line-height: 1.6;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .faq-wrap h2 {
    font-size: 18px;
    margin-bottom: 20px;
    padding: 0 10px;
  }
}
.taxonomy-shop-page .shop .faq-wrap h2 small {
  font-family: Century Gothic;
  font-weight: 900;
  color: #2ca8e8;
  display: block;
  font-size: 12px;
  margin-top: 10px;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .faq-wrap h2 small {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.taxonomy-shop-page .shop .faq-wrap .list li {
  margin-bottom: 10px;
  position: relative;
  border: 1px solid #f4f4f4;
  border-radius: 6px;
  overflow: hidden;
  display: block;
}

.taxonomy-shop-page .shop .faq-wrap .list .ttl {
  padding: 20px 20px 20px 40px;
  color: #1e2f43;
  font-size: 16px;
  font-weight: 900;
  cursor: pointer;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .faq-wrap .list .ttl {
    padding: 20px 10px 20px 40px;
    font-size: 14px;
  }
}
.taxonomy-shop-page .shop .faq-wrap .list .ttl .icon {
  display: inline-block;
  margin-left: -22px;
  margin-right: 6px;
  color: #2a98d2;
}

.taxonomy-shop-page .shop .faq-wrap .list .txt {
  padding: 0 20px 20px 40px;
  letter-spacing: 1px;
  line-height: 1.75;
  display: none;
  font-weight: 900;
  width: 100%;
}

@media screen and (max-width: 767px) {
  .taxonomy-shop-page .shop .faq-wrap .list .txt {
    padding: 0 10px 20px 40px;
    font-size: 12px;
  }
}
.taxonomy-shop-page .shop .faq-wrap .list .txt .icon {
  display: inline-block;
  margin-left: -20px;
  margin-right: -3px;
  color: #ff373c;
}

.top .campaign-re-wrap {
  background-color: #f4f4f4;
}

.top .campaign-re-wrap .inner {
  padding: 20px 10px;
}

.top .campaign-re-wrap .ttl {
  letter-spacing: 2px;
  text-align: center;
  background-color: #1e2f43;
  color: #fff;
  padding: 12px 0;
  font-size: 18px;
  position: relative;
  font-weight: 600;
  margin: 10px 0 40px;
}

@media screen and (max-width: 767px) {
  .top .campaign-re-wrap .ttl {
    margin: 10px 0 20px;
  }
}
.top .campaign-re-wrap .ttl:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -6px;
  border: 6px solid transparent;
  border-top: 8px solid #000000;
}

.top .campaign-re-wrap .ttl b {
  color: #fff000;
}

.top .campaign-re-wrap .ttl span {
  position: relative;
  display: inline-block;
}

.top .campaign-re-wrap .ttl span:after {
  content: "";
  width: 80px;
  height: 22px;
  position: absolute;
  background-image: url(../img/campaign-re-ttl-img.png);
  background-position: center;
  background-size: cover;
  right: -36px;
  bottom: -6px;
}

.top .campaign-re-wrap .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-bottom: 20px;
}

@media screen and (max-width: 767px) {
  .top .campaign-re-wrap .list {
    margin-bottom: 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.top .campaign-re-wrap .list .right, .top .campaign-re-wrap .list .left {
  width: 49%;
  padding: 14px 18px;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .top .campaign-re-wrap .list .right, .top .campaign-re-wrap .list .left {
    width: 100%;
    padding: 10px 10px;
  }
}
.top .campaign-re-wrap .list .left {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 767px) {
  .top .campaign-re-wrap .list .left {
    margin-bottom: 10px;
  }
}
.top .campaign-re-wrap .list .left .topic {
  width: 60px;
  height: 60px;
  background-color: #fff000;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-weight: 600;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  position: relative;
  z-index: 2;
}

.top .campaign-re-wrap .list .left .topic b {
  display: block;
  font-size: 16px;
  line-height: 1;
  margin-top: 2px;
}

.top .campaign-re-wrap .list .left .border {
  border: 2px solid #fff;
  text-align: center;
  color: #fff;
  font-size: 16px;
  padding: 2px 6px;
  display: inline-block;
  font-weight: 600;
  margin: 0 10px;
  letter-spacing: 2px;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .top .campaign-re-wrap .list .left .border {
    font-size: 14px;
    margin: 0 8px;
  }
}
.top .campaign-re-wrap .list .left p {
  color: #fff;
  font-weight: 600;
  font-size: 24px;
  letter-spacing: 1px;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .top .campaign-re-wrap .list .left p {
    font-size: 20px;
  }
}
.top .campaign-re-wrap .list .left p .color {
  color: #fff000;
  font-size: 20px;
}

@media screen and (max-width: 767px) {
  .top .campaign-re-wrap .list .left p .color {
    font-size: 16px;
  }
}
.top .campaign-re-wrap .list .left p .color b {
  font-size: 28px;
  letter-spacing: 0;
}

@media screen and (max-width: 767px) {
  .top .campaign-re-wrap .list .left p .color b {
    font-size: 24px;
  }
}
.top .campaign-re-wrap .list .left img {
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

@media screen and (max-width: 767px) {
  .top .campaign-re-wrap .list .right {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
.top .campaign-re-wrap .list .right .topic {
  width: 60px;
  height: 60px;
  background-color: #fff000;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-weight: 600;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  position: relative;
  z-index: 2;
}

.top .campaign-re-wrap .list .right .topic b {
  display: block;
  font-size: 16px;
  line-height: 1;
  margin-top: 2px;
}

.top .campaign-re-wrap .list .right .txt {
  margin-left: 40px;
  color: #fff;
  font-size: 18px;
  letter-spacing: 2px;
  font-weight: 600;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .top .campaign-re-wrap .list .right .txt {
    margin-left: 6px;
    font-size: 16px;
    letter-spacing: 1px;
  }
}
@media screen and (max-width: 767px) {
  .top .campaign-re-wrap .list .right .txt .max {
    display: inline-block;
    -webkit-writing-mode: tb;
    -ms-writing-mode: tb;
    writing-mode: tb;
    vertical-align: bottom;
    margin-right: 4px;
  }
}
.top .campaign-re-wrap .list .right .txt .color {
  color: #fff000;
  font-size: 20px;
}

@media screen and (max-width: 767px) {
  .top .campaign-re-wrap .list .right .txt .color {
    font-size: 16px;
  }
}
.top .campaign-re-wrap .list .right .txt .color b {
  font-size: 28px;
  letter-spacing: 0;
}

@media screen and (max-width: 767px) {
  .top .campaign-re-wrap .list .right .txt .color b {
    font-size: 24px;
  }
}
.top .campaign-re-wrap .list .right img {
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

@media screen and (max-width: 767px) {
  .top .campaign-re-wrap .attention {
    margin-top: 10px;
  }
}
.top .campaign-re-wrap .attention p {
  font-size: 12px;
  font-weight: 600;
}

.banner.bottom .re-campaign-wrap .ttl {
  letter-spacing: 2px;
  text-align: center;
  background-color: #1e2f43;
  color: #fff;
  padding: 12px 0;
  font-size: 18px;
  position: relative;
  font-weight: 600;
  margin: 10px 0 20px;
}

@media screen and (max-width: 767px) {
  .banner.bottom .re-campaign-wrap .ttl {
    margin: 10px 0 20px;
  }
}
.banner.bottom .re-campaign-wrap .ttl:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -6px;
  border: 6px solid transparent;
  border-top: 8px solid #000000;
}

.banner.bottom .re-campaign-wrap .ttl b {
  color: #fff000;
}

.banner.bottom .re-campaign-wrap .ttl span {
  position: relative;
  display: inline-block;
}

.banner.bottom .re-campaign-wrap .ttl span:after {
  content: "";
  width: 80px;
  height: 22px;
  position: absolute;
  background-image: url(../img/campaign-re-ttl-img.png);
  background-position: center;
  background-size: cover;
  right: -36px;
  bottom: -6px;
}

.banner.bottom .re-campaign-wrap .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .banner.bottom .re-campaign-wrap .list {
    margin-bottom: 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.banner.bottom .re-campaign-wrap .list .right, .banner.bottom .re-campaign-wrap .list .left {
  width: 49%;
  padding: 10px;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .banner.bottom .re-campaign-wrap .list .right, .banner.bottom .re-campaign-wrap .list .left {
    width: 100%;
    padding: 10px 10px;
  }
}
.banner.bottom .re-campaign-wrap .list .left {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 767px) {
  .banner.bottom .re-campaign-wrap .list .left {
    margin-bottom: 10px;
  }
}
.banner.bottom .re-campaign-wrap .list .left .topic {
  width: 60px;
  height: 60px;
  background-color: #fff000;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-weight: 600;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  position: relative;
  z-index: 2;
}

.banner.bottom .re-campaign-wrap .list .left .topic b {
  display: block;
  font-size: 16px;
  line-height: 1;
  margin-top: 2px;
}

.banner.bottom .re-campaign-wrap .list .left .border {
  border: 2px solid #fff;
  text-align: center;
  color: #fff;
  font-size: 16px;
  padding: 2px 6px;
  display: inline-block;
  font-weight: 600;
  margin: 0 10px;
  letter-spacing: 2px;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .banner.bottom .re-campaign-wrap .list .left .border {
    font-size: 14px;
    margin: 0 8px;
  }
}
.banner.bottom .re-campaign-wrap .list .left p {
  color: #fff;
  font-weight: 600;
  font-size: 24px;
  letter-spacing: 1px;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .banner.bottom .re-campaign-wrap .list .left p {
    font-size: 20px;
  }
}
.banner.bottom .re-campaign-wrap .list .left p .color {
  color: #fff000;
  font-size: 20px;
}

@media screen and (max-width: 767px) {
  .banner.bottom .re-campaign-wrap .list .left p .color {
    font-size: 16px;
  }
}
.banner.bottom .re-campaign-wrap .list .left p .color b {
  font-size: 28px;
  letter-spacing: 0;
}

@media screen and (max-width: 767px) {
  .banner.bottom .re-campaign-wrap .list .left p .color b {
    font-size: 24px;
  }
}
.banner.bottom .re-campaign-wrap .list .left img {
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

@media screen and (max-width: 767px) {
  .banner.bottom .re-campaign-wrap .list .right {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
.banner.bottom .re-campaign-wrap .list .right .topic {
  width: 60px;
  height: 60px;
  background-color: #fff000;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-weight: 600;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  position: relative;
  z-index: 2;
}

.banner.bottom .re-campaign-wrap .list .right .topic b {
  display: block;
  font-size: 16px;
  line-height: 1;
  margin-top: 2px;
}

.banner.bottom .re-campaign-wrap .list .right .txt {
  margin-left: 10px;
  color: #fff;
  font-size: 18px;
  letter-spacing: 2px;
  font-weight: 600;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .banner.bottom .re-campaign-wrap .list .right .txt {
    margin-left: 6px;
    font-size: 16px;
    letter-spacing: 1px;
  }
}
@media screen and (max-width: 767px) {
  .banner.bottom .re-campaign-wrap .list .right .txt .max {
    display: inline-block;
    -webkit-writing-mode: tb;
    -ms-writing-mode: tb;
    writing-mode: tb;
    vertical-align: bottom;
    margin-right: 4px;
  }
}
.banner.bottom .re-campaign-wrap .list .right .txt .color {
  color: #fff000;
  font-size: 20px;
}

@media screen and (max-width: 767px) {
  .banner.bottom .re-campaign-wrap .list .right .txt .color {
    font-size: 16px;
  }
}
.banner.bottom .re-campaign-wrap .list .right .txt .color b {
  font-size: 28px;
  letter-spacing: 0;
}

@media screen and (max-width: 767px) {
  .banner.bottom .re-campaign-wrap .list .right .txt .color b {
    font-size: 24px;
  }
}
.banner.bottom .re-campaign-wrap .list .right img {
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .re-campaign-wrap {
    padding: 0 10px;
  }
}
.contact-page .btn-area.top-area .re-campaign-wrap .ttl {
  letter-spacing: 2px;
  text-align: center;
  background-color: #1e2f43;
  color: #fff;
  padding: 12px 0;
  font-size: 18px;
  position: relative;
  font-weight: 600;
  margin: 10px 0 20px;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .re-campaign-wrap .ttl {
    margin: 10px 0 20px;
  }
}
.contact-page .btn-area.top-area .re-campaign-wrap .ttl:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -6px;
  border: 6px solid transparent;
  border-top: 8px solid #000000;
}

.contact-page .btn-area.top-area .re-campaign-wrap .ttl b {
  color: #fff000;
}

.contact-page .btn-area.top-area .re-campaign-wrap .ttl span {
  position: relative;
  display: inline-block;
}

.contact-page .btn-area.top-area .re-campaign-wrap .ttl span:after {
  content: "";
  width: 80px;
  height: 22px;
  position: absolute;
  background-image: url(../img/campaign-re-ttl-img.png);
  background-position: center;
  background-size: cover;
  right: -36px;
  bottom: -6px;
}

.contact-page .btn-area.top-area .re-campaign-wrap .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .re-campaign-wrap .list {
    margin-bottom: 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.contact-page .btn-area.top-area .re-campaign-wrap .list .right, .contact-page .btn-area.top-area .re-campaign-wrap .list .left {
  width: 49%;
  padding: 10px;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .re-campaign-wrap .list .right, .contact-page .btn-area.top-area .re-campaign-wrap .list .left {
    width: 100%;
    padding: 10px 10px;
  }
}
.contact-page .btn-area.top-area .re-campaign-wrap .list .left {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .re-campaign-wrap .list .left {
    margin-bottom: 10px;
  }
}
.contact-page .btn-area.top-area .re-campaign-wrap .list .left .topic {
  width: 60px;
  height: 60px;
  background-color: #fff000;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-weight: 600;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  position: relative;
  z-index: 2;
}

.contact-page .btn-area.top-area .re-campaign-wrap .list .left .topic b {
  display: block;
  font-size: 16px;
  line-height: 1;
  margin-top: 2px;
}

.contact-page .btn-area.top-area .re-campaign-wrap .list .left .border {
  border: 2px solid #fff;
  text-align: center;
  color: #fff;
  font-size: 16px;
  padding: 2px 6px;
  display: inline-block;
  font-weight: 600;
  margin: 0 10px;
  letter-spacing: 2px;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .re-campaign-wrap .list .left .border {
    font-size: 14px;
    margin: 0 8px;
  }
}
.contact-page .btn-area.top-area .re-campaign-wrap .list .left p {
  color: #fff;
  font-weight: 600;
  font-size: 24px;
  letter-spacing: 1px;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .re-campaign-wrap .list .left p {
    font-size: 20px;
  }
}
.contact-page .btn-area.top-area .re-campaign-wrap .list .left p .color {
  color: #fff000;
  font-size: 20px;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .re-campaign-wrap .list .left p .color {
    font-size: 16px;
  }
}
.contact-page .btn-area.top-area .re-campaign-wrap .list .left p .color b {
  font-size: 28px;
  letter-spacing: 0;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .re-campaign-wrap .list .left p .color b {
    font-size: 24px;
  }
}
.contact-page .btn-area.top-area .re-campaign-wrap .list .left img {
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .re-campaign-wrap .list .right {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
.contact-page .btn-area.top-area .re-campaign-wrap .list .right .topic {
  width: 60px;
  height: 60px;
  background-color: #fff000;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-weight: 600;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  position: relative;
  z-index: 2;
}

.contact-page .btn-area.top-area .re-campaign-wrap .list .right .topic b {
  display: block;
  font-size: 16px;
  line-height: 1;
  margin-top: 2px;
}

.contact-page .btn-area.top-area .re-campaign-wrap .list .right .txt {
  margin-left: 10px;
  color: #fff;
  font-size: 18px;
  letter-spacing: 2px;
  font-weight: 600;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .re-campaign-wrap .list .right .txt {
    margin-left: 6px;
    font-size: 16px;
    letter-spacing: 1px;
  }
}
@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .re-campaign-wrap .list .right .txt .max {
    display: inline-block;
    -webkit-writing-mode: tb;
    -ms-writing-mode: tb;
    writing-mode: tb;
    vertical-align: bottom;
    margin-right: 4px;
  }
}
.contact-page .btn-area.top-area .re-campaign-wrap .list .right .txt .color {
  color: #fff000;
  font-size: 20px;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .re-campaign-wrap .list .right .txt .color {
    font-size: 16px;
  }
}
.contact-page .btn-area.top-area .re-campaign-wrap .list .right .txt .color b {
  font-size: 28px;
  letter-spacing: 0;
}

@media screen and (max-width: 767px) {
  .contact-page .btn-area.top-area .re-campaign-wrap .list .right .txt .color b {
    font-size: 24px;
  }
}
.contact-page .btn-area.top-area .re-campaign-wrap .list .right img {
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

.course-page .price-campaign-box .inner {
  padding: 20px 10px;
}

.course-page .price-campaign-box .re-campaign-wrap .ttl {
  letter-spacing: 2px;
  text-align: center;
  background-color: #1e2f43;
  color: #fff;
  padding: 12px 0;
  font-size: 18px;
  position: relative;
  font-weight: 600;
  margin: 10px 0 20px;
}

@media screen and (max-width: 767px) {
  .course-page .price-campaign-box .re-campaign-wrap .ttl {
    margin: 10px 0 20px;
  }
}
.course-page .price-campaign-box .re-campaign-wrap .ttl:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -6px;
  border: 6px solid transparent;
  border-top: 8px solid #000000;
}

.course-page .price-campaign-box .re-campaign-wrap .ttl b {
  color: #fff000;
}

.course-page .price-campaign-box .re-campaign-wrap .ttl span {
  position: relative;
  display: inline-block;
}

.course-page .price-campaign-box .re-campaign-wrap .ttl span:after {
  content: "";
  width: 80px;
  height: 22px;
  position: absolute;
  background-image: url(../img/campaign-re-ttl-img.png);
  background-position: center;
  background-size: cover;
  right: -36px;
  bottom: -6px;
}

.course-page .price-campaign-box .re-campaign-wrap .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .course-page .price-campaign-box .re-campaign-wrap .list {
    margin-bottom: 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.course-page .price-campaign-box .re-campaign-wrap .list .right, .course-page .price-campaign-box .re-campaign-wrap .list .left {
  width: 49%;
  padding: 10px;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .course-page .price-campaign-box .re-campaign-wrap .list .right, .course-page .price-campaign-box .re-campaign-wrap .list .left {
    width: 100%;
    padding: 10px 10px;
  }
}
.course-page .price-campaign-box .re-campaign-wrap .list .left {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 767px) {
  .course-page .price-campaign-box .re-campaign-wrap .list .left {
    margin-bottom: 10px;
  }
}
.course-page .price-campaign-box .re-campaign-wrap .list .left .topic {
  width: 60px;
  height: 60px;
  background-color: #fff000;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-weight: 600;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  position: relative;
  z-index: 2;
}

.course-page .price-campaign-box .re-campaign-wrap .list .left .topic b {
  display: block;
  font-size: 16px;
  line-height: 1;
  margin-top: 2px;
}

.course-page .price-campaign-box .re-campaign-wrap .list .left .border {
  border: 2px solid #fff;
  text-align: center;
  color: #fff;
  font-size: 16px;
  padding: 2px 6px;
  display: inline-block;
  font-weight: 600;
  margin: 0 10px;
  letter-spacing: 2px;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .course-page .price-campaign-box .re-campaign-wrap .list .left .border {
    font-size: 14px;
    margin: 0 8px;
  }
}
.course-page .price-campaign-box .re-campaign-wrap .list .left p {
  color: #fff;
  font-weight: 600;
  font-size: 24px;
  letter-spacing: 1px;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .course-page .price-campaign-box .re-campaign-wrap .list .left p {
    font-size: 20px;
  }
}
.course-page .price-campaign-box .re-campaign-wrap .list .left p .color {
  color: #fff000;
  font-size: 20px;
}

@media screen and (max-width: 767px) {
  .course-page .price-campaign-box .re-campaign-wrap .list .left p .color {
    font-size: 16px;
  }
}
.course-page .price-campaign-box .re-campaign-wrap .list .left p .color b {
  font-size: 28px;
  letter-spacing: 0;
}

@media screen and (max-width: 767px) {
  .course-page .price-campaign-box .re-campaign-wrap .list .left p .color b {
    font-size: 24px;
  }
}
.course-page .price-campaign-box .re-campaign-wrap .list .left img {
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

@media screen and (max-width: 767px) {
  .course-page .price-campaign-box .re-campaign-wrap .list .right {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
.course-page .price-campaign-box .re-campaign-wrap .list .right .topic {
  width: 60px;
  height: 60px;
  background-color: #fff000;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-weight: 600;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  position: relative;
  z-index: 2;
}

.course-page .price-campaign-box .re-campaign-wrap .list .right .topic b {
  display: block;
  font-size: 16px;
  line-height: 1;
  margin-top: 2px;
}

.course-page .price-campaign-box .re-campaign-wrap .list .right .txt {
  margin-left: 10px;
  color: #fff;
  font-size: 18px;
  letter-spacing: 2px;
  font-weight: 600;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .course-page .price-campaign-box .re-campaign-wrap .list .right .txt {
    margin-left: 6px;
    font-size: 16px;
    letter-spacing: 1px;
  }
}
@media screen and (max-width: 767px) {
  .course-page .price-campaign-box .re-campaign-wrap .list .right .txt .max {
    display: inline-block;
    -webkit-writing-mode: tb;
    -ms-writing-mode: tb;
    writing-mode: tb;
    vertical-align: bottom;
    margin-right: 4px;
  }
}
.course-page .price-campaign-box .re-campaign-wrap .list .right .txt .color {
  color: #fff000;
  font-size: 20px;
}

@media screen and (max-width: 767px) {
  .course-page .price-campaign-box .re-campaign-wrap .list .right .txt .color {
    font-size: 16px;
  }
}
.course-page .price-campaign-box .re-campaign-wrap .list .right .txt .color b {
  font-size: 28px;
  letter-spacing: 0;
}

@media screen and (max-width: 767px) {
  .course-page .price-campaign-box .re-campaign-wrap .list .right .txt .color b {
    font-size: 24px;
  }
}
.course-page .price-campaign-box .re-campaign-wrap .list .right img {
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

.course-page .price-campaign-box .attention {
  margin-top: 10px;
}

.course-page .price-campaign-box .attention p {
  font-size: 12px;
  font-weight: 600;
}

.single-shop-page .shop-container .price-campaign-box {
  margin: 20px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price-campaign-box {
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .ttl {
  letter-spacing: 2px;
  text-align: center;
  background-color: #1e2f43;
  color: #fff;
  padding: 12px 0;
  font-size: 18px;
  position: relative;
  font-weight: 600;
  margin: 10px 0 20px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .ttl {
    margin: 10px 0 20px;
  }
}
.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .ttl:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -6px;
  border: 6px solid transparent;
  border-top: 8px solid #000000;
}

.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .ttl b {
  color: #fff000;
}

.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .ttl span {
  position: relative;
  display: inline-block;
}

.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .ttl span:after {
  content: "";
  width: 80px;
  height: 22px;
  position: absolute;
  background-image: url(../img/campaign-re-ttl-img.png);
  background-position: center;
  background-size: cover;
  right: -36px;
  bottom: -6px;
}

.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list {
    margin-bottom: 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-flow: column;
    flex-flow: column;
  }
}
.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .right, .single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .left {
  width: 49%;
  padding: 10px;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .right, .single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .left {
    width: 100%;
    padding: 10px 10px;
  }
}
.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .left {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .left {
    margin-bottom: 10px;
  }
}
.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .left .topic {
  width: 50px;
  height: 50px;
  background-color: #fff000;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-weight: 600;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  position: relative;
  z-index: 2;
}

.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .left .topic b {
  display: block;
  font-size: 16px;
  line-height: 1;
  margin-top: 2px;
}

.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .left .border {
  border: 2px solid #fff;
  text-align: center;
  color: #fff;
  font-size: 14px;
  padding: 2px 4px;
  display: inline-block;
  font-weight: 600;
  margin: 0 6px;
  letter-spacing: 0px;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .left .border {
    font-size: 14px;
    margin: 0 8px;
  }
}
.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .left p {
  color: #fff;
  font-weight: 600;
  font-size: 24px;
  letter-spacing: 1px;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .left p {
    font-size: 20px;
  }
}
.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .left p .color {
  color: #fff000;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .left p .color {
    font-size: 16px;
  }
}
.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .left p .color b {
  font-size: 24px;
  letter-spacing: 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .left p .color b {
    font-size: 24px;
  }
}
.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .left img {
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .right {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .right .topic {
  width: 50px;
  height: 50px;
  background-color: #fff000;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-weight: 600;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  position: relative;
  z-index: 2;
}

.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .right .topic b {
  display: block;
  font-size: 16px;
  line-height: 1;
  margin-top: 2px;
}

.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .right .txt {
  margin-left: 10px;
  color: #fff;
  font-size: 16px;
  letter-spacing: 2px;
  font-weight: 600;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .right .txt {
    margin-left: 6px;
    font-size: 16px;
    letter-spacing: 1px;
  }
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .right .txt .max {
    display: inline-block;
    -webkit-writing-mode: tb;
    -ms-writing-mode: tb;
    writing-mode: tb;
    vertical-align: bottom;
    margin-right: 4px;
  }
}
.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .right .txt .color {
  color: #fff000;
  font-size: 16px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .right .txt .color {
    font-size: 16px;
  }
}
.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .right .txt .color b {
  font-size: 24px;
  letter-spacing: 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .right .txt .color b {
    font-size: 24px;
  }
}
.single-shop-page .shop-container .price-campaign-box .re-campaign-wrap .list .right img {
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

.single-shop-page .shop-container .price-campaign-box .attention {
  margin-top: 10px;
}

.single-shop-page .shop-container .price-campaign-box .attention p {
  font-size: 12px;
  font-weight: 600;
}

.single-shop-page .shop-main .shop-review {
  margin: 40px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-main .shop-review {
    padding: 0 10px;
    margin: 20px 0;
  }
}
.single-shop-page .shop-main .shop-review h2 {
  margin: 0;
  font-size: 18px;
  padding: 14px 0;
  border-left: 6px solid #221e3f;
  line-height: 1;
  padding-left: 16px;
  color: #221e3f;
  margin-bottom: 20px;
}

.single-shop-page .shop-main .shop-review .total-point {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding-bottom: 10px;
  border-bottom: 2px solid #f4f4f4;
  margin-bottom: 20px;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-main .shop-review .total-point {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}
.single-shop-page .shop-main .shop-review .total-point .num {
  color: #47b2ea;
  font-size: 20px;
  letter-spacing: 1px;
  display: inline-block;
}

.single-shop-page .shop-main .shop-review .total-point .point {
  margin: 0 10px;
  font-size: 16px;
}

.single-shop-page .shop-main .shop-review .total-point .point span {
  color: #f4f4f4;
  font-weight: 600;
}

.single-shop-page .shop-main .shop-review .total-point .point.star5 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .total-point .point.star4-5 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .total-point .point.star4-5 span:nth-child(5) {
  color: #d1d1d1;
  background: -webkit-linear-gradient(180deg, #d1d1d1 50%, #f0c73e 50%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.single-shop-page .shop-main .shop-review .total-point .point.star4 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .total-point .point.star4 span:nth-child(5) {
  color: #d1d1d1;
}

.single-shop-page .shop-main .shop-review .total-point .point.star3-5 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .total-point .point.star3-5 span:nth-child(4) {
  color: #d1d1d1;
  background: -webkit-linear-gradient(180deg, #d1d1d1 50%, #f0c73e 50%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.single-shop-page .shop-main .shop-review .total-point .point.star3-5 span:nth-child(5) {
  color: #d1d1d1;
}

.single-shop-page .shop-main .shop-review .total-point .point.star3 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .total-point .point.star3 span:nth-child(4), .single-shop-page .shop-main .shop-review .total-point .point.star3 span:nth-child(5) {
  color: #d1d1d1;
}

.single-shop-page .shop-main .shop-review .total-point .point.star2-5 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .total-point .point.star2-5 span:nth-child(3) {
  color: #d1d1d1;
  background: -webkit-linear-gradient(180deg, #d1d1d1 50%, #f0c73e 50%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.single-shop-page .shop-main .shop-review .total-point .point.star2-5 span:nth-child(4), .single-shop-page .shop-main .shop-review .total-point .point.star2-5 span:nth-child(5) {
  color: #d1d1d1;
}

.single-shop-page .shop-main .shop-review .total-point .point.star2 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .total-point .point.star2 span:nth-child(3), .single-shop-page .shop-main .shop-review .total-point .point.star2 span:nth-child(4), .single-shop-page .shop-main .shop-review .total-point .point.star2 span:nth-child(5) {
  color: #d1d1d1;
}

.single-shop-page .shop-main .shop-review .total-point .point.star1-5 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .total-point .point.star1-5 span:nth-child(2) {
  color: #d1d1d1;
  background: -webkit-linear-gradient(180deg, #d1d1d1 50%, #f0c73e 50%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.single-shop-page .shop-main .shop-review .total-point .point.star1-5 span:nth-child(3), .single-shop-page .shop-main .shop-review .total-point .point.star1-5 span:nth-child(4), .single-shop-page .shop-main .shop-review .total-point .point.star1-5 span:nth-child(5) {
  color: #d1d1d1;
}

.single-shop-page .shop-main .shop-review .total-point .point.star1 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .total-point .point.star1 span:nth-child(2), .single-shop-page .shop-main .shop-review .total-point .point.star1 span:nth-child(3), .single-shop-page .shop-main .shop-review .total-point .point.star1 span:nth-child(4), .single-shop-page .shop-main .shop-review .total-point .point.star1 span:nth-child(5) {
  color: #d1d1d1;
}

.single-shop-page .shop-main .shop-review .total-point .point.star0-5 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .total-point .point.star0-5 span:nth-child(1) {
  color: #d1d1d1;
  background: -webkit-linear-gradient(180deg, #d1d1d1 50%, #f0c73e 50%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.single-shop-page .shop-main .shop-review .total-point .point.star0-5 span:nth-child(2), .single-shop-page .shop-main .shop-review .total-point .point.star0-5 span:nth-child(3), .single-shop-page .shop-main .shop-review .total-point .point.star0-5 span:nth-child(4), .single-shop-page .shop-main .shop-review .total-point .point.star0-5 span:nth-child(5) {
  color: #d1d1d1;
}

.single-shop-page .shop-main .shop-review .total-point .link {
  font-size: 12px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-main .shop-review .total-point .link {
    width: 100%;
    margin-top: 6px;
  }
}
.single-shop-page .shop-main .shop-review .total-point .link a {
  color: #47b2ea;
}

.single-shop-page .shop-main .shop-review .box {
  padding-bottom: 20px;
  border-bottom: 2px solid #f4f4f4;
  margin-bottom: 20px;
}

.single-shop-page .shop-main .shop-review .box .name {
  color: #1e2f43;
  font-weight: 600;
  font-size: 16px;
}

.single-shop-page .shop-main .shop-review .box .point {
  margin: 10px 0;
  font-size: 16px;
}

.single-shop-page .shop-main .shop-review .box .point span {
  color: #f4f4f4;
  font-weight: 600;
}

.single-shop-page .shop-main .shop-review .box .point.star5 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .box .point.star4-5 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .box .point.star4-5 span:nth-child(5) {
  color: #d1d1d1;
  background: -webkit-linear-gradient(180deg, #d1d1d1 50%, #f0c73e 50%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.single-shop-page .shop-main .shop-review .box .point.star4 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .box .point.star4 span:nth-child(5) {
  color: #d1d1d1;
}

.single-shop-page .shop-main .shop-review .box .point.star3-5 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .box .point.star3-5 span:nth-child(4) {
  color: #d1d1d1;
  background: -webkit-linear-gradient(180deg, #d1d1d1 50%, #f0c73e 50%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.single-shop-page .shop-main .shop-review .box .point.star3-5 span:nth-child(5) {
  color: #d1d1d1;
}

.single-shop-page .shop-main .shop-review .box .point.star3 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .box .point.star3 span:nth-child(4), .single-shop-page .shop-main .shop-review .box .point.star3 span:nth-child(5) {
  color: #d1d1d1;
}

.single-shop-page .shop-main .shop-review .box .point.star2-5 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .box .point.star2-5 span:nth-child(3) {
  color: #d1d1d1;
  background: -webkit-linear-gradient(180deg, #d1d1d1 50%, #f0c73e 50%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.single-shop-page .shop-main .shop-review .box .point.star2-5 span:nth-child(4), .single-shop-page .shop-main .shop-review .box .point.star2-5 span:nth-child(5) {
  color: #d1d1d1;
}

.single-shop-page .shop-main .shop-review .box .point.star2 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .box .point.star2 span:nth-child(3), .single-shop-page .shop-main .shop-review .box .point.star2 span:nth-child(4), .single-shop-page .shop-main .shop-review .box .point.star2 span:nth-child(5) {
  color: #d1d1d1;
}

.single-shop-page .shop-main .shop-review .box .point.star1-5 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .box .point.star1-5 span:nth-child(2) {
  color: #d1d1d1;
  background: -webkit-linear-gradient(180deg, #d1d1d1 50%, #f0c73e 50%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.single-shop-page .shop-main .shop-review .box .point.star1-5 span:nth-child(3), .single-shop-page .shop-main .shop-review .box .point.star1-5 span:nth-child(4), .single-shop-page .shop-main .shop-review .box .point.star1-5 span:nth-child(5) {
  color: #d1d1d1;
}

.single-shop-page .shop-main .shop-review .box .point.star1 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .box .point.star1 span:nth-child(2), .single-shop-page .shop-main .shop-review .box .point.star1 span:nth-child(3), .single-shop-page .shop-main .shop-review .box .point.star1 span:nth-child(4), .single-shop-page .shop-main .shop-review .box .point.star1 span:nth-child(5) {
  color: #d1d1d1;
}

.single-shop-page .shop-main .shop-review .box .point.star0-5 span {
  color: #f0c73e;
}

.single-shop-page .shop-main .shop-review .box .point.star0-5 span:nth-child(1) {
  color: #d1d1d1;
  background: -webkit-linear-gradient(180deg, #d1d1d1 50%, #f0c73e 50%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.single-shop-page .shop-main .shop-review .box .point.star0-5 span:nth-child(2), .single-shop-page .shop-main .shop-review .box .point.star0-5 span:nth-child(3), .single-shop-page .shop-main .shop-review .box .point.star0-5 span:nth-child(4), .single-shop-page .shop-main .shop-review .box .point.star0-5 span:nth-child(5) {
  color: #d1d1d1;
}

.single-shop-page .shop-main .shop-review .box .txt {
  margin: 10px 0;
  font-size: 14px;
  letter-spacing: 1px;
  line-height: 1.75;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-main .shop-review .box .txt {
    font-size: 12px;
  }
}
.single-shop-page .shop-main .shop-review .box .link {
  margin: 10px 0 16px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-main .shop-review .box .link {
    font-size: 12px;
  }
}
.single-shop-page .shop-main .shop-review .box .link a {
  color: #47b2ea;
}

.single-shop-page .shop-main .shop-review .box .img img {
  width: 140px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-main .shop-review .box .img img {
    width: 120px;
  }
}
.single-shop-page .shop-main .all-campaign-info {
  padding-top: 40px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-main .all-campaign-info {
    padding: 0 10px 10px;
  }
}
.single-shop-page .shop-main .all-campaign-info h2 {
  margin: 0;
  font-size: 18px;
  padding: 14px 0;
  border-left: 6px solid #221e3f;
  line-height: 1;
  padding-left: 16px;
  color: #221e3f;
  margin-bottom: 20px;
}

.single-shop-page .shop-main .all-campaign-info .box {
  background-color: #f4fbfe;
  padding: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin: 0 0 20px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-main .all-campaign-info .box {
    padding: 10px;
    margin: 0 0 10px 0;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}
.single-shop-page .shop-main .all-campaign-info .box .img {
  width: 15%;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-main .all-campaign-info .box .img {
    width: 20%;
    text-align: center;
  }
}
.single-shop-page .shop-main .all-campaign-info .box .detail {
  width: 65%;
  padding: 0 10px;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-main .all-campaign-info .box .detail {
    width: 80%;
    padding: 0 0 0 10px;
  }
}
.single-shop-page .shop-main .all-campaign-info .box .detail p {
  color: #1e2f43;
  font-size: 12px;
  margin-bottom: 6px;
}

.single-shop-page .shop-main .all-campaign-info .box .detail .price {
  color: #1e2f43;
  margin: 6px 0;
  font-weight: 600;
  font-size: 16px;
}

.single-shop-page .shop-main .all-campaign-info .box .detail .price b {
  display: inline-block;
  margin-right: 6px;
  font-size: 18px;
}

.single-shop-page .shop-main .all-campaign-info .box .detail .txt {
  color: #1e2f43;
  font-size: 12px;
  line-height: 1.5;
}

.single-shop-page .shop-main .all-campaign-info .box .btn {
  width: 20%;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-main .all-campaign-info .box .btn {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-top: 14px;
  }
}
.single-shop-page .shop-main .all-campaign-info .box .btn a {
  display: block;
  text-align: center;
  margin: 6px 0;
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-main .all-campaign-info .box .btn a {
    margin: 0 6px;
    width: 40%;
  }
}
.single-shop-page .shop-main .all-campaign-info .box .btn a.btn1 {
  background-color: #ff373c;
  padding: 10px 10px;
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1px;
  border-radius: 30px;
}

.single-shop-page .shop-main .all-campaign-info .box .btn a.btn2 {
  background-color: #00c800;
  padding: 10px 10px;
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1px;
  border-radius: 30px;
}

@media print, screen and (min-width: 768px) {
  .under-page .sp {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .under-page .pc {
    display: none;
  }
}
.under-page .m-century {
  font-family: Century Gothic;
}
@media screen and (max-width: 767px) {
  .under-page .m-century {
    font-family: "ヒラギノ角ゴ StdN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  }
}
.under-page .m-del {
  display: inline-block;
  position: relative;
}
.under-page .m-del::after {
  content: "";
  width: 100%;
  height: 1px;
  background-color: #000000;
  display: block;
  position: absolute;
  top: 50%;
}
.under-page .l-content-inner {
  width: 980px;
  max-width: 100%;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .under-page .l-content-inner {
    width: 100%;
    padding: 0 15px;
  }
}
.under-page .mv {
  height: 300px;
  background-color: #DAF6F0;
}
@media screen and (max-width: 767px) {
  .under-page .mv {
    height: auto;
    position: relative;
  }
}
.under-page .mv .l-content-inner {
  height: 100%;
  display: flex;
  align-items: center;
  flex-direction: row-reverse;
}
@media screen and (max-width: 767px) {
  .under-page .mv .l-content-inner {
    display: block;
    padding: 0;
  }
}
.under-page .mv-cnt {
  width: 50%;
}
@media screen and (max-width: 767px) {
  .under-page .mv-cnt {
    width: 100%;
    position: absolute;
    height: 100%;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
.under-page .mv-text1 {
  width: 365px;
  max-width: 100%;
  margin: auto auto auto;
  background-color: #ffffff;
  border-radius: 25px;
  height: 43px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 0.1em;
  padding-top: 0.2em;
}
@media screen and (max-width: 767px) {
  .under-page .mv-text1 {
    width: 296px;
    max-width: 75.8974358974vw;
    height: 35px;
    font-size: min(16px, 4.1025641026vw);
  }
}
.under-page .mv-text1 span {
  display: inline-block;
  position: relative;
}
.under-page .mv-text1 span::before {
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background-color: #09B9C6;
  display: block;
  position: absolute;
  top: -0.2em;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  .under-page .mv-text1 span::before {
    width: 4px;
    height: 4px;
  }
}
.under-page .mv-title {
  text-align: center;
  font-weight: bold;
  font-size: 50px;
  color: #166775;
  letter-spacing: 0.08em;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .under-page .mv-title {
    font-size: min(40px, 10.2564102564vw);
    margin-top: 10px;
  }
}
.under-page .mv-list-out {
  display: flex;
  justify-content: center;
}
.under-page .mv-list__item {
  font-size: 16px;
  font-weight: bold;
  line-height: 1.75;
  letter-spacing: 0.08em;
  position: relative;
  padding-left: 1.8em;
}
@media screen and (max-width: 767px) {
  .under-page .mv-list__item {
    font-size: min(12px, 3.0769230769vw);
    line-height: 2.3333333333;
    padding-left: 2.3em;
  }
}
.under-page .mv-list__item::before {
  content: "";
  width: 19px;
  height: 19px;
  background-image: url(../img/pair-icon-check.svg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  display: block;
  position: absolute;
  left: 0;
  top: 0.3em;
}
@media screen and (max-width: 767px) {
  .under-page .mv-list__item::before {
    top: 0.25em;
  }
}
.under-page .mv-img {
  width: 50%;
}
@media screen and (max-width: 767px) {
  .under-page .mv-img {
    width: 100%;
  }
}
.under-page .mv-img img {
  display: block;
  margin: auto;
}
.under-page .under-title {
  text-align: center;
  font-size: 28px;
  font-weight: bold;
  color: #166775;
  letter-spacing: 0.06em;
  margin-bottom: 1em;
}
@media screen and (max-width: 767px) {
  .under-page .under-title {
    font-size: min(28px, 7.1794871795vw);
  }
}
.under-page .btn-area.bottom-area {
  background-color: #fff;
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
}
.under-page .btn-area.bottom-area .inner {
  padding: 10px 60px;
  max-width: 800px;
}
.under-page .btn-area.bottom-area .btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  text-align: center;
}
.under-page .btn-area.bottom-area .btn .left, .under-page .btn-area.bottom-area .btn .right {
  width: 49%;
}
.under-page .btn-area.bottom-area .btn .left a {
  display: block;
  background-color: #ff373c;
  padding: 10px 10px 10px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon1-img.png);
  background-size: 30px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}
.under-page .btn-area.bottom-area .btn .left a span {
  color: #fff;
  font-size: 16px;
}
.under-page .btn-area.bottom-area .btn .left a b {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: #fff;
  padding: 2px 20px;
  border-radius: 30px;
  color: #ff373c;
  font-weight: 900;
  font-size: 12px;
  margin: 0 auto 4px;
}
.under-page .btn-area.bottom-area .btn .right a {
  display: block;
  background-color: #5fe536;
  padding: 22px 10px 22px 10px;
  border-radius: 4px;
  background-image: url(../img/top-btn-icon2-img.png);
  background-size: 44px;
  background-position: 8% 50%;
  font-weight: 900;
  letter-spacing: 1px;
}
.under-page .btn-area.bottom-area .btn .right a span {
  color: #fff;
  font-size: 16px;
}
@media screen and (max-width: 767px) {
  .under-page .btn-area.bottom-area .inner {
    padding: 10px;
    max-width: 500px;
  }
  .under-page .btn-area.bottom-area .btn {
    margin-top: 0;
  }
  .under-page .btn-area.bottom-area .btn .left a {
    background-image: url(../img/top-btn-icon1-img.svg);
    padding: 10px 10px 10px 40px;
    background-size: 22px;
    background-position: 8px 50%;
    letter-spacing: 0;
  }
  .under-page .btn-area.bottom-area .btn .left a span {
    font-size: 14px;
  }
  .under-page .btn-area.bottom-area .btn .left a b {
    padding: 2px 10px;
    font-size: 10px;
    margin-left: 0;
  }
  .under-page .btn-area.bottom-area .btn .right a {
    padding: 21px 10px 21px 50px;
    background-size: 32px;
    background-position: 10px 50%;
    letter-spacing: 0;
  }
  .under-page .btn-area.bottom-area .btn .right a span {
    font-size: 14px;
  }
}

.pair-page .p-about {
  padding-top: 50px;
  padding-bottom: 60px;
}
@media screen and (max-width: 767px) {
  .pair-page .p-about {
    padding: 50px 0;
  }
}
.pair-page .p-about-text {
  text-align: center;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.75;
  letter-spacing: 0.08em;
  margin-top: 1em;
}
@media screen and (max-width: 767px) {
  .pair-page .p-about-text {
    font-size: min(14px, 3.5897435897vw);
    text-align: left;
  }
}
.pair-page .p-flow {
  padding-top: 90px;
  padding-bottom: 115px;
  background-color: #E5F3F4;
}
@media screen and (max-width: 767px) {
  .pair-page .p-flow {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}
.pair-page .p-flow-list {
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .pair-page .p-flow-list {
    margin-top: 30px;
  }
}
.pair-page .p-flow-item {
  display: flex;
  margin-top: 85px;
}
@media screen and (max-width: 767px) {
  .pair-page .p-flow-item {
    display: block;
    margin-top: 70px;
  }
}
.pair-page .p-flow-item:first-of-type {
  margin-top: 0;
}
@media screen and (max-width: 767px) {
  .pair-page .p-flow-item:first-of-type {
    margin-top: 70px;
  }
}
.pair-page .p-flow-item__img {
  width: 332px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .pair-page .p-flow-item__img {
    margin: auto;
    max-width: 100%;
  }
}
.pair-page .p-flow-item__img img {
  width: 100%;
  display: block;
}
@media screen and (max-width: 767px) {
  .pair-page .p-flow-item__img img {
    max-height: 100%;
  }
}
.pair-page .p-flow-item__num {
  height: 97px;
  position: absolute;
  left: 0;
  top: -32px;
}
@media screen and (max-width: 767px) {
  .pair-page .p-flow-item__num {
    height: 60px;
    top: -25px;
  }
}
.pair-page .p-flow-item__num img {
  display: block;
}
.pair-page .p-flow-item__cnt {
  width: calc(100% - 332px);
  padding-left: 30px;
  padding-top: 10px;
}
@media screen and (max-width: 767px) {
  .pair-page .p-flow-item__cnt {
    width: 100%;
    padding: 20px 0 0;
  }
}
.pair-page .p-flow-item__title {
  font-weight: bold;
  font-size: 26px;
  border-bottom: 2px solid #09B9C6;
  padding-bottom: 22px;
  margin-bottom: 16px;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 767px) {
  .pair-page .p-flow-item__title {
    font-size: min(20px, 5.1282051282vw);
    padding-bottom: 0.8em;
    margin-bottom: 0.8em;
  }
}
.pair-page .p-flow-item__text {
  font-size: 16px;
  line-height: 1.75;
  letter-spacing: 0.08em;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .pair-page .p-flow-item__text {
    font-size: min(14px, 3.5897435897vw);
  }
}
.pair-page .p-price {
  padding-top: 90px;
  padding-bottom: 165px;
}
@media screen and (max-width: 767px) {
  .pair-page .p-price {
    padding-top: 60px;
    padding-bottom: 100px;
  }
}
.pair-page .p-price-box__head {
  background-color: #09B9C6;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  font-weight: bold;
  color: #ffffff;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 767px) {
  .pair-page .p-price-box__head {
    font-size: min(20px, 5.1282051282vw);
  }
}
.pair-page .p-price-box.-box1 {
  margin-top: 55px;
  display: flex;
  height: 94px;
}
@media screen and (max-width: 767px) {
  .pair-page .p-price-box.-box1 {
    display: block;
    height: auto;
  }
}
.pair-page .p-price-box.-box1 .p-price-box__head {
  width: 235px;
  border-radius: 10px 0 0 10px;
  height: 100%;
}
@media screen and (max-width: 767px) {
  .pair-page .p-price-box.-box1 .p-price-box__head {
    width: 100%;
    border-radius: 10px 10px 0 0;
    height: 50px;
  }
}
.pair-page .p-price-box.-box1 .p-price-box__cnt {
  width: calc(100% - 235px);
  background-color: #E5F3F4;
  border-radius: 0 10px 10px 0;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .pair-page .p-price-box.-box1 .p-price-box__cnt {
    width: 100%;
    border-radius: 0 0 10px 10px;
    display: block;
    padding: 10px;
  }
}
.pair-page .p-price-box.-box1 .p-price-box__cnt .text1 {
  color: #09B9C6;
  font-size: 20px;
  font-weight: bold;
  margin-right: 22px;
}
@media screen and (max-width: 767px) {
  .pair-page .p-price-box.-box1 .p-price-box__cnt .text1 {
    font-size: min(18px, 4.6153846154vw);
    margin: 0;
    text-align: center;
  }
}
.pair-page .p-price-box.-box1 .p-price-box__cnt .text2 {
  font-weight: bold;
  font-size: 28px;
  margin-right: 12px;
}
@media screen and (max-width: 767px) {
  .pair-page .p-price-box.-box1 .p-price-box__cnt .text2 {
    font-size: min(25px, 6.4102564103vw);
    margin: 0;
    text-align: center;
  }
}
.pair-page .p-price-box.-box1 .p-price-box__cnt .text2 .m-del::after {
  height: 2px;
}
.pair-page .p-price-box.-box1 .p-price-box__cnt .text3 {
  font-size: 18px;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .pair-page .p-price-box.-box1 .p-price-box__cnt .text3 {
    font-size: min(16px, 4.1025641026vw);
    text-align: center;
  }
}
.pair-page .p-price-box.-box1 .p-price-box__cnt .arrow {
  width: 48px;
  margin: 0 29px 0 20px;
}
@media screen and (max-width: 767px) {
  .pair-page .p-price-box.-box1 .p-price-box__cnt .arrow {
    margin: 0 auto;
  }
  .pair-page .p-price-box.-box1 .p-price-box__cnt .arrow img {
    transform: rotate(90deg);
  }
}
.pair-page .p-price-box.-box1 .p-price-box__cnt .text4 {
  font-size: 46px;
  font-weight: bold;
  color: #09B9C6;
}
@media screen and (max-width: 767px) {
  .pair-page .p-price-box.-box1 .p-price-box__cnt .text4 {
    font-size: min(40px, 10.2564102564vw);
    text-align: center;
  }
}
.pair-page .p-price-box.-box1 .p-price-box__cnt .text4-box {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .pair-page .p-price-box.-box1 .p-price-box__cnt .text4-box {
    justify-content: center;
  }
}
.pair-page .p-price-box.-box1 .p-price-box__cnt .star {
  width: 34px;
  margin-left: 20px;
}
@media screen and (max-width: 767px) {
  .pair-page .p-price-box.-box1 .p-price-box__cnt .star {
    margin: 0 0 0 10px;
  }
}
.pair-page .p-price-box.-box2 {
  margin-top: 10px;
  border-radius: 10px;
  background-color: #E5F3F4;
  padding: 33px 22px 48px;
  display: flex;
  gap: 25px;
}
@media screen and (max-width: 767px) {
  .pair-page .p-price-box.-box2 {
    flex-direction: column;
    gap: 15px;
    padding: 30px 20px 30px;
  }
}
.pair-page .p-price-box.-box2 .p-price-box__head {
  border-radius: 10px 10px 0 0;
  border: 3px solid #09B9C6;
  height: 60px;
}
.pair-page .p-price-box.-box2 .p-price-box__cnt {
  border-radius: 0 0 10px 10px;
  background-color: #ffffff;
  border: 3px solid #09B9C6;
  padding: 8px 8px 8px;
}
.pair-page .p-price-box.-box2 .p-price-box__cnt .text1 {
  background-color: #F1F1F1;
  height: 2em;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .pair-page .p-price-box.-box2 .p-price-box__cnt .text1 {
    font-size: min(16px, 4.1025641026vw);
  }
}
.pair-page .p-price-box.-box2 .p-price-box__cnt .text2 {
  font-size: 61px;
  color: #09B9C6;
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .pair-page .p-price-box.-box2 .p-price-box__cnt .text2 {
    font-size: min(50px, 12.8205128205vw);
  }
}
.pair-page .p-price-box.-box2 .p-price-box__cnt .text3 {
  font-size: 18px;
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .pair-page .p-price-box.-box2 .p-price-box__cnt .text3 {
    font-size: min(16px, 4.1025641026vw);
  }
}
.pair-page .p-price-box__item {
  width: 295px;
}
@media screen and (max-width: 767px) {
  .pair-page .p-price-box__item {
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .norikae-page .mv-cnt {
    padding: 0 80px 0 16px;
  }
  .norikae-page .mv-title {
    font-size: min(38px, 9.7435897436vw);
  }
  .norikae-page .mv-list {
    padding-left: 11px;
  }
  .norikae-page .mv-list-out {
    justify-content: flex-start;
  }
}
.norikae-page .p-about {
  padding-top: 60px;
  padding-bottom: 60px;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-about {
    padding: 50px 0;
  }
}
.norikae-page .p-about-content {
  margin-top: 55px;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-about-content {
    margin-top: 0;
  }
}
.norikae-page .p-about-box {
  background-color: #E5F3F4;
  border-radius: 10px;
  display: flex;
  margin-top: 25px;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-about-box {
    display: block;
  }
}
.norikae-page .p-about-box:first-of-type {
  margin-top: 0;
}
.norikae-page .p-about-box__img {
  width: 50%;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-about-box__img {
    width: 80%;
    margin: auto;
  }
}
.norikae-page .p-about-box__img img {
  width: 100%;
  display: block;
}
.norikae-page .p-about-box__cnt {
  width: 50%;
  padding: 22px 22px 22px 0;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-about-box__cnt {
    width: 100%;
    padding: 15px;
  }
}
.norikae-page .p-about-box.-box2 .p-about-box__img {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-about-box.-box2 .p-about-box__img {
    display: block;
    padding: 0;
  }
}
.norikae-page .p-about-box.-box2 .p-about-price__cnt {
  padding-top: 0;
  padding-bottom: 0;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-about-box.-box2 .p-about-price__cnt {
    padding: 10px;
  }
}
.norikae-page .p-about-price {
  margin-top: 15px;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-about-price {
    margin-top: 10px;
  }
}
.norikae-page .p-about-price:first-of-type {
  margin-top: 0;
}
.norikae-page .p-about-price__head {
  background-color: #09B9C6;
  border-radius: 10px 10px 0 0;
  height: 2.4em;
  font-size: 22px;
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-about-price__head {
    font-size: min(18px, 4.6153846154vw);
  }
}
.norikae-page .p-about-price__cnt {
  background-color: #ffffff;
  border-radius: 0 0 10px 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 16px 12px 0;
  padding-right: 65px;
  padding-left: 35px;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-about-price__cnt {
    padding: 10px;
    justify-content: center;
  }
}
.norikae-page .p-about-price__cnt .price1 {
  width: 140px;
}
.norikae-page .p-about-price__cnt .text1 {
  font-weight: bold;
  text-align: center;
  font-size: 34px;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-about-price__cnt .text1 {
    font-size: min(28px, 7.1794871795vw);
  }
}
.norikae-page .p-about-price__cnt .text1 .m-del::after {
  height: 2px;
}
.norikae-page .p-about-price__cnt .text2 {
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  margin-top: -3px;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-about-price__cnt .text2 {
    font-size: min(14px, 3.5897435897vw);
    margin-top: 0;
  }
}
@media screen and (max-width: 767px) {
  .norikae-page .p-about-price__cnt .arrow {
    margin: 0 20px;
  }
}
.norikae-page .p-about-price__cnt .text3 {
  color: #09B9C6;
  font-weight: bold;
  font-size: 68px;
  line-height: 1;
  padding-bottom: 6px;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-about-price__cnt .text3 {
    font-size: min(40px, 10.2564102564vw);
  }
}
.norikae-page .p-about-price__cnt .text3 .m-century {
  font-size: 98px;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-about-price__cnt .text3 .m-century {
    font-size: min(60px, 15.3846153846vw);
  }
}
.norikae-page .p-about-hatena {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: bold;
}
.norikae-page .p-about-hatena::before {
  content: "";
  width: 22px;
  height: 24px;
  background-image: url(../img/norikae-icon-hatena.svg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  margin-right: 0.5em;
}
.norikae-page .p-about-hatena__link {
  text-decoration: underline;
  color: #000000;
}
.norikae-page .p-about-text {
  text-align: center;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.75;
  letter-spacing: 0.08em;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-about-text {
    font-size: min(14px, 3.5897435897vw);
    text-align: left;
    margin-top: 30px;
  }
}
.norikae-page .p-apply {
  background-color: #E5F3F4;
  padding-top: 60px;
  padding-bottom: 60px;
}
.norikae-page .p-apply-list {
  background-color: #ffffff;
  border-radius: 10px;
  padding: 55px 64px 55px;
  margin-top: 45px;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-apply-list {
    padding: 20px;
    margin-top: 0;
  }
}
.norikae-page .p-apply-item__title {
  border-bottom: 2px solid #09B9C6;
  display: flex;
  align-items: flex-end;
  padding-bottom: 14px;
  margin-bottom: 23px;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-apply-item__title {
    padding-bottom: 10px;
    margin-bottom: 20px;
    align-items: flex-start;
  }
}
.norikae-page .p-apply-item__title .num {
  color: #09B9C6;
  font-weight: bold;
  font-size: 36px;
  letter-spacing: 0.08em;
  width: 51px;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-apply-item__title .num {
    font-size: min(30px, 7.6923076923vw);
    width: 41px;
  }
}
.norikae-page .p-apply-item__title .title {
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 0.08em;
  padding-bottom: 6px;
  width: calc(100% - 51px);
}
@media screen and (max-width: 767px) {
  .norikae-page .p-apply-item__title .title {
    font-size: min(16px, 4.1025641026vw);
    width: calc(100% - 41px);
  }
}
.norikae-page .p-apply-item__text {
  padding-left: 51px;
  font-size: 16px;
  line-height: 1.75;
  letter-spacing: 0.08em;
  font-weight: bold;
  margin-bottom: 30px;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-apply-item__text {
    font-size: min(14px, 3.5897435897vw);
    padding-left: 0;
  }
}
.norikae-page .p-apply-item__list {
  margin-left: 51px;
  background-color: #F8F8F8;
  border-radius: 10px;
  padding: 20px 0 20px 12px;
  margin-bottom: 18px;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-apply-item__list {
    margin-left: 0;
    padding: 10px 0 10px 10px;
  }
}
.norikae-page .p-apply-item__list li {
  font-size: 16px;
  line-height: 1.75;
  padding-left: 1em;
  text-indent: -1em;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-apply-item__list li {
    font-size: min(14px, 3.5897435897vw);
  }
}
.norikae-page .p-apply-item:last-of-type .p-apply-item__text {
  margin-bottom: 0;
}
.norikae-page .p-suports-zym {
  padding-top: 35px;
  padding-bottom: 95px;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-suports-zym {
    padding-top: 40px;
    padding-bottom: 80px;
  }
}
.norikae-page .p-suports-zym-box__head {
  background-color: #09B9C6;
  color: #ffffff;
  height: 91px;
  font-size: 26px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px 10px 0 0;
  border: 3px solid #09B9C6;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-suports-zym-box__head {
    height: 3em;
    font-size: min(20px, 5.1282051282vw);
  }
}
.norikae-page .p-suports-zym-box__cnt {
  display: flex;
  align-items: center;
  padding: 26px 31px;
  border: 3px solid #09B9C6;
  border-radius: 0 0 10px 10px;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-suports-zym-box__cnt {
    padding: 10px 15px;
    display: block;
  }
}
.norikae-page .p-suports-zym-box__cnt .img {
  width: 319px;
  max-width: 100%;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-suports-zym-box__cnt .img {
    margin: auto;
  }
}
.norikae-page .p-suports-zym-box__cnt .cnt {
  width: calc(100% - 319px);
  padding-left: 26px;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-suports-zym-box__cnt .cnt {
    width: 100%;
    padding: 15px 0 0;
  }
}
.norikae-page .p-suports-zym-box__cnt .cnt-text {
  font-size: 16px;
  line-height: 1.75;
  letter-spacing: 0.08em;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-suports-zym-box__cnt .cnt-text {
    font-size: min(14px, 3.5897435897vw);
  }
}
.norikae-page .p-suports-zym-box__cnt .cnt-ng {
  margin-top: 32px;
  display: flex;
  align-items: center;
  background-color: #F8F8F8;
  border-radius: 10px;
  padding: 20px 17px;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-suports-zym-box__cnt .cnt-ng {
    display: block;
    margin-top: 20px;
    padding: 10px;
  }
}
.norikae-page .p-suports-zym-box__cnt .cnt-ng__head {
  color: #09B9C6;
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 0.06em;
  width: calc(100% - 420px);
  text-align: center;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-suports-zym-box__cnt .cnt-ng__head {
    width: 100%;
    font-size: min(16px, 4.1025641026vw);
  }
}
.norikae-page .p-suports-zym-box__cnt .cnt-ng__cnt {
  width: 420px;
  padding-left: 16px;
  font-size: 16px;
  line-height: 1.75;
  letter-spacing: 0.08em;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .norikae-page .p-suports-zym-box__cnt .cnt-ng__cnt {
    font-size: min(14px, 3.5897435897vw);
    width: 100%;
    padding: 0;
  }
}

.meal-page .mv .l-content-inner {
  position: relative;
  flex-direction: row;
}
.meal-page .mv-img {
  width: 100%;
}
.meal-page .mv-cnt {
  position: absolute;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-left: 150px;
}
@media screen and (max-width: 767px) {
  .meal-page .mv-cnt {
    padding: 0 120px 0 16px;
  }
}
.meal-page .mv-text1 {
  width: 265px;
  max-width: 100%;
}
@media screen and (max-width: 767px) {
  .meal-page .mv-text1 {
    width: 220px;
  }
}
.meal-page .mv-title {
  margin-top: 10px;
  font-size: 30px;
  line-height: 1.6666666667;
}
@media screen and (max-width: 767px) {
  .meal-page .mv-title {
    font-size: min(23px, 5.8974358974vw);
  }
}
.meal-page .mv-title .marker {
  display: inline-block;
  position: relative;
}
.meal-page .mv-title .marker::before {
  content: "";
  width: 100%;
  height: 2px;
  background-color: #F3F932;
  display: block;
  position: absolute;
  bottom: 12px;
}
@media screen and (max-width: 767px) {
  .meal-page .mv-title .marker::before {
    bottom: 0.25em;
    height: 4px;
  }
}
.meal-page .mv-title .marker span {
  display: inline-block;
  position: relative;
}
.meal-page .p-about {
  padding-top: 60px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-about {
    padding-top: 35px;
  }
}
.meal-page .p-about .l-content-inner {
  position: relative;
  padding-bottom: 90px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-about .l-content-inner {
    padding-bottom: 0;
  }
}
.meal-page .p-about-img {
  position: absolute;
  right: 60px;
  bottom: 0;
}
@media screen and (max-width: 767px) {
  .meal-page .p-about-img {
    width: 220px;
    position: static;
    margin: 20px auto auto;
  }
}
.meal-page .p-about-cnt {
  width: 600px;
  max-width: 100%;
  margin-top: 75px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-about-cnt {
    width: 100%;
    margin-top: 40px;
  }
}
.meal-page .p-about-text {
  font-size: 16px;
  line-height: 1.75;
  letter-spacing: 0.08em;
}
@media screen and (max-width: 767px) {
  .meal-page .p-about-text {
    font-size: min(14px, 3.5897435897vw);
  }
}
.meal-page .p-nutrition {
  background-color: #E5F3F4;
  padding-top: 80px;
  padding-bottom: 120px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-nutrition {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}
.meal-page .p-nutrition-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 70px 0;
  margin-top: 90px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-nutrition-list {
    gap: 50px 0;
    margin-top: 50px;
  }
}
.meal-page .p-nutrition-item {
  width: 472px;
  background-color: #ffffff;
  border-radius: 10px;
  border-top: 20px solid #09B9C6;
  padding: 0 20px 20px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-nutrition-item {
    width: 100%;
  }
}
.meal-page .p-nutrition-item__img {
  width: 176px;
  width: auto;
  height: 183px;
  margin: auto auto -50px;
  transform: translateY(-50px);
}
.meal-page .p-nutrition-item__img img {
  height: 100%;
  width: auto;
  display: block;
  margin: auto;
}
.meal-page .p-nutrition-item__title {
  margin-top: 25px;
  text-align: center;
  font-weight: bold;
  font-size: 26px;
  color: #166775;
}
@media screen and (max-width: 767px) {
  .meal-page .p-nutrition-item__title {
    font-size: min(20px, 5.1282051282vw);
  }
}
.meal-page .p-nutrition-item__text {
  margin-top: 20px;
  font-size: 16px;
  line-height: 1.75;
  letter-spacing: 0.08em;
}
@media screen and (max-width: 767px) {
  .meal-page .p-nutrition-item__text {
    font-size: min(14px, 3.5897435897vw);
  }
}
.meal-page .p-nutrition-item__box {
  border-radius: 10px;
  border: 2px solid #09B9C6;
  background-color: #E5F3F4;
  padding: 15px 15px 15px;
  margin-top: 20px;
}
.meal-page .p-nutrition-item__box-title {
  color: #166775;
  font-weight: bold;
  font-size: 14px;
  font-weight: bold;
  letter-spacing: 0.08em;
}
@media screen and (max-width: 767px) {
  .meal-page .p-nutrition-item__box-title {
    font-size: min(14px, 3.5897435897vw);
  }
}
.meal-page .p-nutrition-item__box-text {
  font-size: 14px;
  line-height: 1.7857142857;
  letter-spacing: 0.08em;
  margin-top: 0.5em;
}
@media screen and (max-width: 767px) {
  .meal-page .p-nutrition-item__box-text {
    font-size: min(12px, 3.0769230769vw);
  }
}
.meal-page .p-nutrition-item:nth-of-type(4) .p-nutrition-item__img {
  width: 382px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-nutrition-item:nth-of-type(4) .p-nutrition-item__img {
    max-width: 100%;
  }
}
.meal-page .p-example {
  padding-top: 80px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-example {
    padding-top: 60px;
  }
}
.meal-page .p-example-content {
  margin-top: 75px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-example-content {
    margin-top: 50px;
  }
}
.meal-page .p-example-content__box {
  margin-top: 85px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-example-content__box {
    margin-top: 50px;
  }
}
.meal-page .p-example-content__box:first-of-type {
  margin-top: 0;
}
.meal-page .p-example-content__title {
  text-align: center;
  color: #166775;
  font-weight: bold;
  font-size: 26px;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 767px) {
  .meal-page .p-example-content__title {
    font-size: min(26px, 6.6666666667vw);
  }
}
.meal-page .p-example-content__title::before {
  content: "";
  width: 29px;
  height: 29px;
  display: inline-block;
  margin-right: 0.8em;
  background-image: url(../img/meal-icon-check.svg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  position: relative;
  top: 0.2em;
}
.meal-page .p-example-list {
  background-color: #E5F3F4;
  border-radius: 10px;
  padding: 40px;
  margin-top: 35px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-example-list {
    padding: 20px;
    margin-top: 20px;
  }
}
.meal-page .p-example-list__item {
  margin-top: 20px;
  display: flex;
}
@media screen and (max-width: 767px) {
  .meal-page .p-example-list__item {
    display: block;
  }
}
.meal-page .p-example-list__item:first-of-type {
  margin-top: 0;
}
.meal-page .p-example-list__item .img {
  width: 182px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-example-list__item .img {
    margin: auto auto 20px;
  }
}
.meal-page .p-example-list__item .cnt {
  width: calc(100% - 182px);
  padding-left: 40px;
  padding-top: 13px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-example-list__item .cnt {
    width: 100%;
    padding: 0;
  }
}
.meal-page .p-example-list__item .cnt .title {
  font-weight: bold;
  font-size: 22px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-example-list__item .cnt .title {
    font-size: min(20px, 5.1282051282vw);
    text-align: center;
  }
}
.meal-page .p-example-list__item .cnt .text {
  font-size: 16px;
  line-height: 1.75;
  font-weight: 500;
  margin-top: 1em;
  letter-spacing: 0.08em;
}
@media screen and (max-width: 767px) {
  .meal-page .p-example-list__item .cnt .text {
    font-size: min(14px, 3.5897435897vw);
  }
}
.meal-page .p-question {
  padding-top: 85px;
  padding-bottom: 130px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-question {
    padding-top: 100px;
    padding-bottom: 60px;
  }
}
.meal-page .p-question-box {
  background-color: #E5F3F4;
  border-radius: 10px;
  padding: 40px 40px 40px;
  background-image: url(../img/meal-bg-question.svg);
  background-repeat: no-repeat;
  background-position: right 40px bottom 25px;
  min-height: 330px;
  margin-top: 35px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-question-box {
    padding: 30px 20px;
    min-height: auto;
    margin-top: 20px;
    background-position: right 25px bottom 25px;
    background-size: 160px;
  }
}
.meal-page .p-question-box:first-of-type {
  margin-top: 0;
}
.meal-page .p-question-box__title {
  font-weight: bold;
  font-size: 26px;
  color: #166775;
}
@media screen and (max-width: 767px) {
  .meal-page .p-question-box__title {
    font-size: min(22px, 5.641025641vw);
    text-align: center;
  }
}
.meal-page .p-question-box__text {
  font-size: 16px;
  line-height: 1.75;
  font-weight: 500;
  margin-top: 2em;
  letter-spacing: 0.08em;
}
@media screen and (max-width: 767px) {
  .meal-page .p-question-box__text {
    font-size: min(14px, 3.5897435897vw);
    margin-top: 1em;
  }
}
.meal-page .p-guide {
  background-color: #E5F3F4;
  padding-top: 70px;
  padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide {
    padding-top: 60px;
    padding-bottom: 80px;
  }
}
.meal-page .p-guide-content {
  margin-top: 45px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content {
    margin-top: 30px;
  }
}
.meal-page .p-guide-content__box {
  margin-top: 35px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__box {
    margin-top: 20px;
  }
}
.meal-page .p-guide-content__box:first-of-type {
  margin-top: 0;
}
.meal-page .p-guide-content__head {
  border-radius: 10px 10px 0 0;
  background-color: #09B9C6;
  height: 90px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-right: 35px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__head {
    height: auto;
    padding: 10px;
  }
}
.meal-page .p-guide-content__head .head-inn {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__head .head-inn {
    display: block;
  }
}
.meal-page .p-guide-content__head .head-inn dt .text {
  margin-right: 1em;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__head .head-inn dt .text {
    margin-right: 0;
    text-align: center;
  }
}
.meal-page .p-guide-content__head .head-inn dd {
  display: flex;
  align-items: center;
  font-size: 26px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__head .head-inn dd {
    font-size: min(22px, 5.641025641vw);
  }
}
.meal-page .p-guide-content__head .head-inn dd .text {
  margin-left: 0.7em;
}
.meal-page .p-guide-content__head .head-inn dd + dd {
  margin-left: 1em;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__head .head-inn dd + dd {
    margin-left: 0;
  }
}
.meal-page .p-guide-content__head .head-inn .text {
  color: #ffffff;
  font-size: 26px;
  font-weight: bold;
  letter-spacing: 0.08em;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__head .head-inn .text {
    font-size: min(22px, 5.641025641vw);
  }
}
.meal-page .p-guide-content__head .head-inn .tag {
  border-radius: 5px;
  background-color: #ffffff;
  color: #166775;
  font-size: 19px;
  font-weight: bold;
  letter-spacing: 0.08em;
  width: 60px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__head .head-inn .tag {
    width: auto;
    height: auto;
    font-size: min(16px, 4.1025641026vw);
    line-height: 1;
    display: inline-flex;
    padding: 0.2em 0.5em 0.1em;
  }
}
.meal-page .p-guide-content__cnt {
  background-color: #ffffff;
  border-radius: 0 0 10px 10px;
  padding-bottom: 28px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__cnt {
    padding: 20px;
  }
}
.meal-page .p-guide-content__cnt .guide {
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__cnt .guide {
    display: block;
  }
}
.meal-page .p-guide-content__cnt .guide-img {
  width: 197px;
  margin-right: 30px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__cnt .guide-img {
    width: 120px;
    margin: auto;
  }
}
.meal-page .p-guide-content__cnt .guide-img img {
  display: block;
  margin: auto;
  margin-top: -76px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__cnt .guide-img img {
    margin-top: 0;
  }
}
.meal-page .p-guide-content__cnt .guide .num {
  text-align: center;
  font-weight: bold;
  font-size: 22px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__cnt .guide .num {
    font-size: min(16px, 4.1025641026vw);
  }
}
.meal-page .p-guide-content__cnt .guide .name {
  text-align: center;
  font-size: 14px;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__cnt .guide .name {
    font-size: min(12px, 3.0769230769vw);
  }
}
.meal-page .p-guide-content__cnt .guide-list {
  display: flex;
  gap: 0 10px;
  margin-right: 25px;
  padding-top: 30px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__cnt .guide-list {
    gap: 0;
    justify-content: center;
    padding-top: 0;
    margin: 20px -5px 0;
  }
}
.meal-page .p-guide-content__cnt .guide-list__item {
  width: 70px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__cnt .guide-list__item {
    width: 65px;
  }
}
.meal-page .p-guide-content__cnt .guide-list__item .icon {
  width: 50px;
  margin: 15px auto 16px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__cnt .guide-list__item .icon {
    width: 40px;
    margin: 5px auto;
  }
}
.meal-page .p-guide-content__cnt .guide-alchol {
  padding-top: 30px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__cnt .guide-alchol {
    padding-top: 0;
    margin-top: 15px;
  }
}
.meal-page .p-guide-content__cnt .guide-alchol__list {
  display: flex;
  justify-content: center;
  margin-bottom: 10px;
  gap: 0 6px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__cnt .guide-alchol__list {
    gap: 0 5px;
  }
}
.meal-page .p-guide-content__cnt .guide-alchol__list li {
  width: 34px;
}
.meal-page .p-guide-content__cnt .guide-alchol__box {
  border-radius: 10px;
  background-color: #EFEFEF;
  width: 290px;
  height: 93px;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 3px;
  padding-top: 8px;
}
@media screen and (max-width: 767px) {
  .meal-page .p-guide-content__cnt .guide-alchol__box {
    margin: 3px auto auto;
    height: auto;
    padding: 10px;
  }
}
.meal-page .p-guide-content__cnt .guide-alchol__box .name {
  letter-spacing: 0.08em;
}

@font-face {
  font-family: century;
  src: local("Century Gothic");
  unicode-range: U+0030-0039, 7E;
}
.course-page .price .box {
  margin: 0;
}
.course-page .price .top {
  padding-bottom: 57px;
}
@media screen and (max-width: 767px) {
  .course-page .price .top {
    padding-bottom: 38px;
  }
}
.course-page .price .top .txt {
  font-size: 24px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 767px) {
  .course-page .price .top .txt {
    font-size: 16px;
  }
}
.course-page .price .top .txt .line {
  display: inline-block;
  position: relative;
  text-align: center;
}
.course-page .price .top .txt .line::after {
  content: "";
  width: 100%;
  height: 3px;
  position: absolute;
  left: 0;
  bottom: 0;
  background-color: #FDFC37;
}
@media screen and (max-width: 767px) {
  .course-page .price .top .txt .line::after {
    height: 2px;
  }
}
.course-page .price .top .ttl {
  margin-top: 10px;
  color: #2BA8E8;
  font-size: 36px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 767px) {
  .course-page .price .top .ttl {
    font-size: 24px;
  }
}
.course-page .price .top .img {
  max-width: 600px;
  margin: 70px auto 0;
}
@media screen and (max-width: 767px) {
  .course-page .price .top .img {
    margin-top: 25px;
  }
}
.course-page .price .top .ad {
  margin-top: 65px;
}
@media screen and (max-width: 767px) {
  .course-page .price .top .ad {
    margin-top: 28px;
  }
}
.course-page .price .top .ad .ttl {
  margin-top: 0;
  border-radius: 6px 6px 0 0;
  color: #fff;
  font-size: 30px;
  line-height: 63px;
  text-align: center;
  letter-spacing: 0.06em;
  background-color: #2BA8E8;
}
@media screen and (max-width: 767px) {
  .course-page .price .top .ad .ttl {
    font-size: min(20px, 5.1282051282vw);
    line-height: 41px;
  }
}
.course-page .price .top .ad .box {
  height: 159px;
  border-radius: 0 0 6px 6px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 30px;
  position: relative;
  font-family: century, Helvetica Neue, sans-serif;
  background-color: #DEFAFB;
}
@media screen and (max-width: 767px) {
  .course-page .price .top .ad .box {
    height: min(93px, 23.8461538462vw);
    padding-left: 3%;
    gap: 0;
    justify-content: space-around;
  }
}
.course-page .price .top .ad .box .old {
  font-size: 43px;
  font-weight: bold;
  line-height: 0.8;
}
@media screen and (max-width: 767px) {
  .course-page .price .top .ad .box .old {
    font-size: min(25px, 6.4102564103vw);
  }
}
.course-page .price .top .ad .box .old .big {
  text-decoration: line-through;
  text-decoration-thickness: 1.5px;
}
.course-page .price .top .ad .box .old .small {
  font-size: 23px;
  text-decoration: line-through;
  text-decoration-thickness: 1.5px;
}
@media screen and (max-width: 767px) {
  .course-page .price .top .ad .box .old .small {
    font-size: min(13px, 3.3333333333vw);
  }
}
.course-page .price .top .ad .box .arrow {
  width: 18px;
  height: 28px;
  display: block;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
  background-color: #2BA8E8;
}
@media screen and (max-width: 767px) {
  .course-page .price .top .ad .box .arrow {
    width: min(10px, 2.5641025641vw);
    height: min(16px, 4.1025641026vw);
  }
}
.course-page .price .top .ad .box .now {
  color: #FF373C;
  font-size: 62px;
  font-weight: bold;
  line-height: 0.5;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .course-page .price .top .ad .box .now {
    font-size: min(36px, 9.2307692308vw);
  }
}
.course-page .price .top .ad .box .now .yen {
  font-size: 45px;
}
@media screen and (max-width: 767px) {
  .course-page .price .top .ad .box .now .yen {
    font-size: min(26px, 6.6666666667vw);
  }
}
.course-page .price .top .ad .box .now .small {
  font-size: 21px;
}
@media screen and (max-width: 767px) {
  .course-page .price .top .ad .box .now .small {
    font-size: min(11px, 2.8205128205vw);
  }
}
.course-page .price .top .ad .box .off {
  width: 150px;
  position: absolute;
  top: -30%;
  right: 4%;
}
@media screen and (max-width: 767px) {
  .course-page .price .top .ad .box .off {
    width: min(72px, 18.4615384615vw);
    margin-bottom: min(15px, 3.8461538462vw);
    position: static;
  }
}
.course-page .price .mid {
  padding-top: 33px;
  padding-bottom: 55px;
  background-color: #F9F9F9;
}
@media screen and (max-width: 767px) {
  .course-page .price .mid {
    padding-top: 1px;
  }
}
@media print, screen and (min-width: 768px) {
  .course-page .price .plan .pc {
    display: block;
  }
  .course-page .price .plan .sp {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .course-page .price .plan .pc {
    display: none;
  }
  .course-page .price .plan .sp {
    display: block;
  }
}
.course-page .price .plan .ttl {
  margin-top: 48px;
  color: #2BA8E8;
  font-size: 30px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 767px) {
  .course-page .price .plan .ttl {
    margin-top: 47px;
    font-size: 24px;
  }
}
.course-page .price .plan .txt {
  margin-top: 45px;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 767px) {
  .course-page .price .plan .txt {
    margin-top: 25px;
    font-size: 14px;
    line-height: 2;
  }
}
.course-page .price .plan .btn {
  max-width: 392px;
  margin: 35px auto 0;
}
@media screen and (max-width: 767px) {
  .course-page .price .plan .btn {
    margin-top: 30px;
  }
}
.course-page .price .plan .btn a {
  height: 58px;
  border: 2px solid #2BA8E8;
  border-radius: 6px;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #2BA8E8;
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 0.06em;
  background-color: #fff;
  transition: opacity 0.3s;
}
.course-page .price .plan .btn a:hover {
  opacity: 0.7;
}
@media screen and (max-width: 767px) {
  .course-page .price .plan .btn a {
    height: min(58px, 14.8717948718vw);
    font-size: min(20px, 5.1282051282vw);
  }
}
.course-page .price .plan .btn a .icon {
  width: 39px;
  aspect-ratio: 1/1;
  margin-right: 14px;
  border-radius: 999px;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  background-color: #2BA8E8;
}
@media screen and (max-width: 767px) {
  .course-page .price .plan .btn a .icon {
    width: min(39px, 10vw);
  }
}
.course-page .price .plan .list {
  margin-top: 56px;
  display: flex;
  gap: 9px;
  font-family: century, Helvetica Neue, sans-serif;
}
@media screen and (max-width: 767px) {
  .course-page .price .plan .list {
    margin-top: 31px;
    flex-direction: column;
    gap: 20px;
  }
}
.course-page .price .plan .item {
  flex: 1;
}
.course-page .price .plan .item .ttl {
  margin-top: 0;
  border-radius: 10px 10px 0 0;
  color: #fff;
  font-size: 25px;
  font-weight: bold;
  line-height: 54px;
  letter-spacing: 0.06em;
  background-color: #2BA8E8;
}
@media screen and (max-width: 767px) {
  .course-page .price .plan .item .ttl {
    font-size: min(25px, 6.4102564103vw);
    line-height: min(54px, 13.8461538462vw);
  }
}
.course-page .price .plan .item .ttl.no1 {
  position: relative;
}
.course-page .price .plan .item .ttl.no1::before {
  content: "";
  width: 71px;
  aspect-ratio: 1/1;
  position: absolute;
  bottom: 8%;
  left: 2%;
  background: url(../img/price-no1.png) no-repeat center center/100% 100%;
}
@media screen and (max-width: 767px) {
  .course-page .price .plan .item .ttl.no1::before {
    width: min(71px, 18.2051282051vw);
    top: 50%;
    bottom: auto;
    left: 5%;
    translate: 0 -50%;
  }
}
.course-page .price .plan .item .box {
  border: 3px solid #DBDBDB;
  border-top: none;
  border-radius: 0 0 10px 10px;
  padding: 24px 0 19px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-direction: column;
  background-color: #fff;
}
.course-page .price .plan .item .box .fee {
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 34px;
  color: #2BA8E8;
  text-align: center;
}
.course-page .price .plan .item .box .fee .money .border {
  border: 1px solid #2BA8E8;
  display: block;
  color: #2BA8E8;
  font-size: 10px;
  font-weight: bold;
  line-height: 1.8;
}
.course-page .price .plan .item .box .fee .money .big {
  display: block;
  color: #2BA8E8;
  font-size: 42px;
  font-weight: bold;
}
.course-page .price .plan .item .box .fee .money .small {
  display: block;
  color: #C4C4C4;
  font-size: 14px;
  font-weight: bold;
}
.course-page .price .plan .item .box .fee .one {
  max-width: 88px;
  border: 1px solid #2BA8E8;
  border-radius: 10px;
  padding: 7px 15px 5px;
  position: relative;
}
.course-page .price .plan .item .box .fee .one::before {
  content: "";
  width: 11px;
  height: 17px;
  position: absolute;
  top: 50%;
  right: 100%;
  translate: 0 -50%;
  clip-path: polygon(100% 0, 100% 100%, 0 50%);
  background-color: #2BA8E8;
}
.course-page .price .plan .item .box .fee .one .small {
  display: block;
  color: #2BA8E8;
  font-size: 12px;
  font-weight: bold;
}
.course-page .price .plan .item .box .fee .one .big {
  display: block;
  color: #2BA8E8;
  font-size: 22px;
  font-weight: bold;
}
.course-page .price .plan .item .box .fee .one .small2 {
  display: block;
  color: #9D9D9D;
  font-size: 9px;
  font-weight: bold;
}
.course-page .price .plan .item .box .to {
  width: 88%;
  max-width: 345px;
  min-height: 46px;
  margin: 11px auto 15px;
  padding-top: 5px;
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #2BA8E8;
  font-size: 10px;
  font-weight: bold;
  line-height: 1.4;
  clip-path: polygon(0 0, 100% 0, 100% 63%, 50% 100%, 0 63%);
  background-color: #DEFAFB;
}
@media screen and (max-width: 767px) {
  .course-page .price .plan .item .box .to {
    font-size: 12px;
  }
}
.course-page .price .plan .item .box .to .line {
  position: relative;
}
.course-page .price .plan .item .box .to .line::after {
  z-index: -1;
  content: "";
  width: 100%;
  height: 6px;
  position: absolute;
  bottom: 0;
  left: 0;
  background-color: #F3F932;
}
@media screen and (max-width: 767px) {
  .course-page .price .plan .item .box .to .line::after {
    bottom: 20%;
  }
}

@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap {
    padding: 0 10px;
  }
}
.single-shop-page .shop-container .plan-wrap .plan-btn {
  max-width: 520px;
  margin: -15px auto 37px;
  display: flex;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .plan-btn {
    margin-top: 10px;
  }
}
.single-shop-page .shop-container .plan-wrap .plan-btn .plan {
  cursor: pointer;
  width: 50%;
  color: #2BA8E8;
  font-size: 18px;
  font-weight: bold;
  line-height: 40px;
  text-align: center;
  letter-spacing: 0.06em;
  background-color: #F4F4F4;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .plan-btn .plan {
    font-size: min(16px, 4.1025641026vw);
  }
}
.single-shop-page .shop-container .plan-wrap .plan-btn .plan.active {
  cursor: auto;
  position: relative;
  color: #fff;
  background-color: #2BA8E8;
}
.single-shop-page .shop-container .plan-wrap .plan-btn .plan.active::after {
  content: "";
  width: 13px;
  height: 9px;
  position: absolute;
  top: calc(100% - 1px);
  left: 50%;
  translate: -50% 0;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  background-color: #2BA8E8;
}
.single-shop-page .shop-container .plan-wrap .panel {
  display: none;
}
@media print, screen and (min-width: 768px) {
  .single-shop-page .shop-container .plan-wrap .panel .pc {
    display: block;
  }
  .single-shop-page .shop-container .plan-wrap .panel .sp {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .panel .pc {
    display: none;
  }
  .single-shop-page .shop-container .plan-wrap .panel .sp {
    display: block;
  }
}
.single-shop-page .shop-container .plan-wrap .panel.show {
  display: block;
}
.single-shop-page .shop-container .plan-wrap .panel .txt {
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .panel .txt {
    font-size: 14px;
    line-height: 2;
  }
}
.single-shop-page .shop-container .plan-wrap .panel .btn {
  max-width: 392px;
  margin: 35px auto 0;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .panel .btn {
    margin-top: 30px;
  }
}
.single-shop-page .shop-container .plan-wrap .panel .btn a {
  height: 58px;
  border: 2px solid #2BA8E8;
  border-radius: 6px;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #2BA8E8;
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 0.06em;
  background-color: #fff;
  transition: opacity 0.3s;
}
.single-shop-page .shop-container .plan-wrap .panel .btn a:hover {
  opacity: 0.7;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .panel .btn a {
    height: min(58px, 14.8717948718vw);
    font-size: min(20px, 5.1282051282vw);
  }
}
.single-shop-page .shop-container .plan-wrap .panel .btn a .icon {
  width: 39px;
  aspect-ratio: 1/1;
  margin-right: 14px;
  border-radius: 999px;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  background-color: #2BA8E8;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .panel .btn a .icon {
    width: min(39px, 10vw);
  }
}
.single-shop-page .shop-container .plan-wrap .panel .list {
  margin-top: 41px;
  display: flex;
  gap: 9px;
  font-family: century, Helvetica Neue, sans-serif;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .panel .list {
    margin-top: 31px;
    flex-direction: column;
    gap: 20px;
  }
}
.single-shop-page .shop-container .plan-wrap .panel .item {
  flex: 1;
}
.single-shop-page .shop-container .plan-wrap .panel .item .ttl {
  margin-top: 0;
  border-radius: 10px 10px 0 0;
  color: #fff;
  font-size: 21px;
  font-weight: bold;
  line-height: 46px;
  text-align: center;
  letter-spacing: 0.06em;
  background-color: #2BA8E8;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .panel .item .ttl {
    font-size: min(25px, 6.4102564103vw);
    line-height: min(54px, 13.8461538462vw);
  }
}
.single-shop-page .shop-container .plan-wrap .panel .item .ttl.no1 {
  padding-left: 20%;
  position: relative;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .panel .item .ttl.no1 {
    padding-left: 0;
  }
}
.single-shop-page .shop-container .plan-wrap .panel .item .ttl.no1::before {
  content: "";
  width: 61px;
  aspect-ratio: 1/1;
  position: absolute;
  bottom: 8%;
  left: 2%;
  background: url(../img/price-no1.png) no-repeat center center/100% 100%;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .panel .item .ttl.no1::before {
    width: min(71px, 18.2051282051vw);
    top: 50%;
    bottom: auto;
    left: 5%;
    translate: 0 -50%;
  }
}
.single-shop-page .shop-container .plan-wrap .panel .item .box {
  border: 3px solid #DBDBDB;
  border-top: none;
  border-radius: 0 0 10px 10px;
  padding: 15px 0 11px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-direction: column;
  background-color: #fff;
}
.single-shop-page .shop-container .plan-wrap .panel .item .box .fee {
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  color: #2BA8E8;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .panel .item .box .fee {
    gap: 35px;
  }
}
.single-shop-page .shop-container .plan-wrap .panel .item .box .fee .money .border {
  border: 1px solid #2BA8E8;
  display: block;
  color: #2BA8E8;
  font-size: 10px;
  font-weight: bold;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .panel .item .box .fee .money .border {
    font-size: 11px;
  }
}
.single-shop-page .shop-container .plan-wrap .panel .item .box .fee .money .big {
  display: block;
  color: #2BA8E8;
  font-size: 32px;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .panel .item .box .fee .money .big {
    font-size: 45px;
  }
}
.single-shop-page .shop-container .plan-wrap .panel .item .box .fee .money .small {
  display: block;
  color: #C4C4C4;
  font-size: 12px;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .panel .item .box .fee .money .small {
    font-size: 16px;
  }
}
.single-shop-page .shop-container .plan-wrap .panel .item .box .fee .one {
  max-width: 88px;
  border: 1px solid #2BA8E8;
  border-radius: 10px;
  padding: 7px 13px 4px;
  position: relative;
}
.single-shop-page .shop-container .plan-wrap .panel .item .box .fee .one::before {
  content: "";
  width: 9px;
  height: 15px;
  position: absolute;
  top: 50%;
  right: 100%;
  translate: 0 -50%;
  clip-path: polygon(100% 0, 100% 100%, 0 50%);
  background-color: #2BA8E8;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .panel .item .box .fee .one::before {
    width: 12px;
    height: 19px;
  }
}
.single-shop-page .shop-container .plan-wrap .panel .item .box .fee .one .small {
  display: block;
  color: #2BA8E8;
  font-size: 10px;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .panel .item .box .fee .one .small {
    font-size: 12px;
  }
}
.single-shop-page .shop-container .plan-wrap .panel .item .box .fee .one .big {
  display: block;
  color: #2BA8E8;
  font-size: 18px;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .panel .item .box .fee .one .big {
    font-size: 24px;
  }
}
.single-shop-page .shop-container .plan-wrap .panel .item .box .fee .one .small2 {
  display: block;
  color: #9D9D9D;
  font-size: 8px;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .panel .item .box .fee .one .small2 {
    font-size: 10px;
  }
}
.single-shop-page .shop-container .plan-wrap .panel .item .box .to {
  width: 92%;
  max-width: 345px;
  min-height: 41px;
  margin: 10px auto 12px;
  padding-top: 2px;
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #2BA8E8;
  font-size: 10px;
  font-weight: bold;
  line-height: 1.4;
  clip-path: polygon(0 0, 100% 0, 100% 63%, 50% 100%, 0 63%);
  background-color: #DEFAFB;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .panel .item .box .to {
    min-height: 46px;
    padding-top: 3px;
    font-size: 12px;
  }
}
.single-shop-page .shop-container .plan-wrap .panel .item .box .to .line {
  position: relative;
}
.single-shop-page .shop-container .plan-wrap .panel .item .box .to .line::after {
  z-index: -1;
  content: "";
  width: 100%;
  height: 6px;
  position: absolute;
  bottom: 0;
  left: 0;
  background-color: #F3F932;
}
@media screen and (max-width: 767px) {
  .single-shop-page .shop-container .plan-wrap .panel .item .box .to .line::after {
    bottom: 20%;
  }
}

.single-shop-page .fixed-campaign-box + .btn-area.bottom-area .btn-line {
  bottom: calc(100% + 35px);
}
@media print, screen and (min-width: 768px) {
  .single-shop-page .btn-area.bottom-area .btn-sp, .single-shop-page .btn-area.bottom-area .btn-line {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .single-shop-page .btn-area.bottom-area .btn.btn-pc {
    display: none;
  }
  .single-shop-page .btn-area.bottom-area .btn-sp {
    display: flex;
  }
  .single-shop-page .btn-area.bottom-area .inner {
    height: 100%;
  }
}
@media screen and (max-width: 767px) {
  .single-shop-page .btn-area.bottom-area {
    width: 95%;
    height: 70px;
    bottom: 10px;
    left: 2.5%;
    border-radius: 999px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.12);
  }
}
.single-shop-page .btn-area.bottom-area .btn-line {
  width: 19%;
  border-radius: 999px;
  position: absolute;
  bottom: calc(100% + 10px);
  right: 0;
  box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.25);
}
.single-shop-page .btn-area.bottom-area .btn-sp {
  height: 100%;
  justify-content: space-between;
}
.single-shop-page .btn-area.bottom-area .btn-sp .item {
  width: 25%;
}
.single-shop-page .btn-area.bottom-area .btn-sp .item a {
  height: 100%;
  display: flex;
  flex-direction: column;
}
.single-shop-page .btn-area.bottom-area .btn-sp .img {
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0 10px;
}
.single-shop-page .btn-area.bottom-area .btn-sp .img img {
  max-width: 20px;
  max-height: 20px;
  object-fit: contain;
}
.single-shop-page .btn-area.bottom-area .btn-sp .txt {
  margin-top: 5px;
  color: #1db0c1;
  font-size: 11px;
  font-weight: bold;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .top .price .plan-wrap {
    padding: 0 10px;
  }
}
.top .price .plan-wrap .plan-btn {
  max-width: 520px;
  margin: -15px auto 37px;
  display: flex;
}
@media screen and (max-width: 767px) {
  .top .price .plan-wrap .plan-btn {
    margin-top: 10px;
  }
}
.top .price .plan-wrap .plan-btn .plan {
  cursor: pointer;
  width: 50%;
  color: #2BA8E8;
  font-size: 18px;
  font-weight: bold;
  line-height: 40px;
  text-align: center;
  letter-spacing: 0.06em;
  background-color: #F4F4F4;
}
@media screen and (max-width: 767px) {
  .top .price .plan-wrap .plan-btn .plan {
    font-size: min(16px, 4.1025641026vw);
  }
}
.top .price .plan-wrap .plan-btn .plan.active {
  cursor: auto;
  position: relative;
  color: #fff;
  background-color: #2BA8E8;
}
.top .price .plan-wrap .plan-btn .plan.active::after {
  content: "";
  width: 13px;
  height: 9px;
  position: absolute;
  top: calc(100% - 1px);
  left: 50%;
  translate: -50% 0;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  background-color: #2BA8E8;
}
.top .price .plan-wrap .panel {
  margin-bottom: 50px;
  display: none;
}
@media print, screen and (min-width: 768px) {
  .top .price .plan-wrap .panel .pc {
    display: block;
  }
  .top .price .plan-wrap .panel .sp {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .top .price .plan-wrap .panel .pc {
    display: none;
  }
  .top .price .plan-wrap .panel .sp {
    display: block;
  }
}
.top .price .plan-wrap .panel.show {
  display: block;
}
.top .price .plan-wrap .panel .txt {
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.06em;
}
@media screen and (max-width: 767px) {
  .top .price .plan-wrap .panel .txt {
    font-size: 14px;
    line-height: 2;
  }
}
.top .price .plan-wrap .panel .btn {
  max-width: 392px;
  margin: 35px auto 0;
}
@media screen and (max-width: 767px) {
  .top .price .plan-wrap .panel .btn {
    margin-top: 30px;
  }
}
.top .price .plan-wrap .panel .btn a {
  height: 58px;
  border: 2px solid #2BA8E8;
  border-radius: 6px;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #2BA8E8;
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 0.06em;
  background-color: #fff;
  transition: opacity 0.3s;
}
.top .price .plan-wrap .panel .btn a:hover {
  opacity: 0.7;
}
@media screen and (max-width: 767px) {
  .top .price .plan-wrap .panel .btn a {
    height: min(58px, 14.8717948718vw);
    font-size: min(20px, 5.1282051282vw);
  }
}
.top .price .plan-wrap .panel .btn a .icon {
  width: 39px;
  aspect-ratio: 1/1;
  margin-right: 14px;
  border-radius: 999px;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  background-color: #2BA8E8;
}
@media screen and (max-width: 767px) {
  .top .price .plan-wrap .panel .btn a .icon {
    width: min(39px, 10vw);
  }
}
.top .price .plan-wrap .panel .list {
  margin-top: 41px;
  display: flex;
  gap: 9px;
  font-family: century, Helvetica Neue, sans-serif;
}
@media screen and (max-width: 767px) {
  .top .price .plan-wrap .panel .list {
    margin-top: 31px;
    flex-direction: column;
    gap: 20px;
  }
}
.top .price .plan-wrap .panel .item {
  flex: 1;
}
.top .price .plan-wrap .panel .item .ttl {
  margin-top: 0;
  border-radius: 10px 10px 0 0;
  color: #fff;
  font-size: 21px;
  font-weight: bold;
  line-height: 46px;
  text-align: center;
  letter-spacing: 0.06em;
  background-color: #2BA8E8;
}
@media screen and (max-width: 767px) {
  .top .price .plan-wrap .panel .item .ttl {
    font-size: min(25px, 6.4102564103vw);
    line-height: min(54px, 13.8461538462vw);
  }
}
.top .price .plan-wrap .panel .item .ttl.no1 {
  padding-left: 20%;
  position: relative;
}
@media screen and (max-width: 767px) {
  .top .price .plan-wrap .panel .item .ttl.no1 {
    padding-left: 0;
  }
}
.top .price .plan-wrap .panel .item .ttl.no1::before {
  content: "";
  width: 61px;
  aspect-ratio: 1/1;
  position: absolute;
  bottom: 8%;
  left: 2%;
  background: url(../img/price-no1.png) no-repeat center center/100% 100%;
}
@media screen and (max-width: 767px) {
  .top .price .plan-wrap .panel .item .ttl.no1::before {
    width: min(71px, 18.2051282051vw);
    top: 50%;
    bottom: auto;
    left: 5%;
    translate: 0 -50%;
  }
}
.top .price .plan-wrap .panel .item .box {
  border: 3px solid #DBDBDB;
  border-top: none;
  border-radius: 0 0 10px 10px;
  padding: 24px 0 19px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-direction: column;
  background-color: #fff;
}
.top .price .plan-wrap .panel .item .box .fee {
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 34px;
  color: #2BA8E8;
  text-align: center;
}
.top .price .plan-wrap .panel .item .box .fee .money .border {
  border: 1px solid #2BA8E8;
  display: block;
  color: #2BA8E8;
  font-size: 10px;
  font-weight: bold;
  line-height: 1.8;
}
.top .price .plan-wrap .panel .item .box .fee .money .big {
  display: block;
  color: #2BA8E8;
  font-size: 42px;
  font-weight: bold;
}
.top .price .plan-wrap .panel .item .box .fee .money .small {
  display: block;
  color: #C4C4C4;
  font-size: 14px;
  font-weight: bold;
}
.top .price .plan-wrap .panel .item .box .fee .one {
  max-width: 88px;
  border: 1px solid #2BA8E8;
  border-radius: 10px;
  padding: 7px 15px 5px;
  position: relative;
}
.top .price .plan-wrap .panel .item .box .fee .one::before {
  content: "";
  width: 11px;
  height: 17px;
  position: absolute;
  top: 50%;
  right: 100%;
  translate: 0 -50%;
  clip-path: polygon(100% 0, 100% 100%, 0 50%);
  background-color: #2BA8E8;
}
.top .price .plan-wrap .panel .item .box .fee .one .small {
  display: block;
  color: #2BA8E8;
  font-size: 12px;
  font-weight: bold;
}
.top .price .plan-wrap .panel .item .box .fee .one .big {
  display: block;
  color: #2BA8E8;
  font-size: 22px;
  font-weight: bold;
}
.top .price .plan-wrap .panel .item .box .fee .one .small2 {
  display: block;
  color: #9D9D9D;
  font-size: 9px;
  font-weight: bold;
}
.top .price .plan-wrap .panel .item .box .to {
  width: 88%;
  max-width: 345px;
  min-height: 46px;
  margin: 11px auto 15px;
  padding-top: 5px;
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #2BA8E8;
  font-size: 10px;
  font-weight: bold;
  line-height: 1.4;
  clip-path: polygon(0 0, 100% 0, 100% 63%, 50% 100%, 0 63%);
  background-color: #DEFAFB;
}
@media screen and (max-width: 767px) {
  .top .price .plan-wrap .panel .item .box .to {
    font-size: 12px;
  }
}
.top .price .plan-wrap .panel .item .box .to .line {
  position: relative;
}
.top .price .plan-wrap .panel .item .box .to .line::after {
  z-index: -1;
  content: "";
  width: 100%;
  height: 6px;
  position: absolute;
  bottom: 0;
  left: 0;
  background-color: #F3F932;
}
@media screen and (max-width: 767px) {
  .top .price .plan-wrap .panel .item .box .to .line::after {
    bottom: 20%;
  }
}

/*# sourceMappingURL=style.css.map */
