@charset "UTF-8";
:root {
  --color-main: #28325A;
  --color-blue: #006DC9;
  --color-lightblue: #BBDFFF;
  --color-darkblue: #01478F;
  --color-pink: #FF557E;
  --color-lightpink: #FFF0F4;
  --color-yellow: #F1F376;
  --bg-lightblue: #ECF3FB;
}

/* common */
.lp-container {
  padding-top: 0;
}
.lp-header,
.lp-contents {
  color: var(--color-main);
  font-size: calc(28 / 700 * 100vw);
  font-weight: 400;
}
.lp-header,
.lp-contents * {
  font-family: 'Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3','メイリオ', Meiryo, "Myriad Set Pro", sans-serif;
  line-height: 1.78;
  letter-spacing: .01em;
}
.lp-contents section {
  margin: 0;
}
.lp-contents .line {
  position: relative;
  display: inline-block;
}
.lp-contents .line::after {
  content: '';
  position: absolute;
  left: 0;
  width: 100%;
  background: var(--color-yellow);
}
.lp-contents .line > * {
  position: relative;
  z-index: 2;
}
.lp-inner {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 calc(70 / 700 * 100vw);
}
.lp-section-heading {
  font-size: calc(36 / 700 * 100vw);
  text-align: center;
}
.lp-section-heading * {
  line-height: 1.8;
}
.lp-section-heading strong {
  font-size: calc(55 / 700 * 100vw);
}
.lp-section-heading .pink {
  color: var(--color-pink);
}
.lp-comment-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 calc(32 / 700 * 100vw);
}
.lp-comment-text {
  position: relative;
  padding: calc(60 / 700 * 100vw) calc(30 / 700 * 100vw) calc(70 / 700 * 100vw);
  background: var(--color-lightblue);
  border-radius: calc(10 / 700 * 100vw);
  text-align: center;
}
.lp-comment-text::after {
  content: '';
  position: absolute;
  left: calc(50% - calc(35 / 700 * 100vw));
  bottom: calc(-38 / 700 * 100vw);
  width: 0;
  height: 0;
  border-style: solid;
  border-color: var(--color-lightblue) transparent transparent transparent;
  border-width: calc(40 / 700 * 100vw) calc(35 / 700 * 100vw) 0px calc(35 / 700 * 100vw);
}
.lp-comment-text p:first-child {
  margin-bottom: 0;
}
.lp-comment-text p:first-child .line {
  margin-top: .2em;
}
.lp-comment-text p:last-child {
  margin-top: .5em;
}
.lp-comment-text .line::after {
  bottom: .25em;
  height: calc(18 / 700 * 100vw);
}
.lp-comment-text .line:first-of-type {
  font-size: calc(47 / 700 * 100vw);
}
.lp-comment-text .pclg {
  display: inline-block;
}
.lp-comment-profile {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: calc(60 / 700 * 100vw);
  color: var(--color-darkblue);
}
.lp-comment-profile-image {
  width: calc(200 / 700 * 100vw);
  margin-right: calc(45 / 700 * 100vw);
}
.lp-comment-profile-text {
  margin: 0;
  font-size: calc(28 / 700 * 100vw);
  line-height: 1.3;
}
.lp-comment-profile-text span {
  font-weight: 700;
}
@media screen and (min-width: 768px), print {
  .lp-header,
  .lp-contents {
    font-size: 16px;
  }
  .lp-inner {
    padding: 0 40px;
  }
  .lp-section-heading {
    font-size: 40px;
  }
  .lp-section-heading strong {
    font-size: 55px;
  }
  .lp-comment-inner {
    padding: 0 40px;
  }
  .lp-comment-text {
    flex: none;
    padding: 35px;
    border-radius: 5px;
  }
  .lp-comment-text::after {
    left: calc(50% - 38px);
    bottom: -45px;
    border-width: 45px 38px 0px 38px;
  }
  .lp-comment-text .line::after {
    bottom: .35em;
    height: 10px;
  }
  .lp-comment-text .line:nth-child(n),
  .lp-comment-text .pclg {
    font-size: 34px;
  }
  .lp-comment-text .line > span span,
  .lp-comment-text .pclg span {
    font-size: 24px;
  }
  .lp-comment-profile {
    justify-content: center;
    margin-top: 60px;
  }
  .lp-comment-profile-image {
    width: 120px;
    margin-right: 40px;
  }
  .lp-comment-profile-text {
    font-size: 16px;
    font-weight: 700;
  }
}
@media screen and (min-width: 960px), print {
  .lp-comment-inner {
    display: flex;
    flex-direction: row-reverse;
    padding: 0 30px 0 10px;
  }
  .lp-comment-text {
    flex: 1;
    padding: 35px 70px;
  }
  .lp-comment-text * {
    letter-spacing: -.02em;
  }
  .lp-comment-text::after {
    left: -60px;
    bottom: calc(50% - 22px);
    border-color: var(--color-lightblue) transparent transparent transparent;
    transform: rotate(90deg);
  }
  .lp-comment-text p:last-child {
    margin-top: 20px;
  }
  .lp-comment-text p:last-child .pclg,
  .lp-comment-text p:last-child .line {
    margin-top: 15px;
  }
  .lp-comment-profile {
    flex-direction: column;
    width: 20%;
    margin: 0 40px 0 0;
    text-align: center;
  }
  .lp-comment-profile-image {
    margin: 0 auto 25px;
  }
}

/* js animation */
.js-scrollanime-element {
  opacity: 0;
  visibility: hidden;
  transform: translateY(10%);
  transition: opacity .8s cubic-bezier(0.33, 1, 0.68, 1), visibility .8s cubic-bezier(0.33, 1, 0.68, 1), transform .8s cubic-bezier(0.33, 1, 0.68, 1);
  transition-delay: .3s;
}
.js-scrollanime-element.is-show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* utility */
.sm\:hidden {
  display: none;
}
@media screen and (min-width: 768px), print {
  .sm\:hidden {
    display: inline;
  }
  .md\:hidden {
    display: none;
  }
}
@media screen and (min-width: 960px), print {
  .sm\:hidden,
  .md\:hidden {
    display: inline;
  }
  .lg\:hidden {
    display: none;
  }
}

/* header */
.lp-header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9;
  width: 100%;
  padding: calc(30 / 700 * 100vw) calc(27 / 700 * 100vw) 0;
  text-align: right;
}
.lp-header-nav-trigger {
  position: relative;
  z-index: 11;
  width: calc(68 / 700 * 100vw);
  height: calc(68 / 700 * 100vw);
  margin-top: -.5em;
  padding: 0;
  background: #fff;
  border: none;
  border-radius: 100vmax;
  box-shadow: 0px calc(3 / 700 * 100vw) calc(6 / 700 * 100vw) 0px rgba(0, 0, 0, .1);
  cursor: pointer;
  outline: none;
  appearance: none;
}
.lp-header-nav-trigger.is-show {
  box-shadow: none;
}
.lp-header-nav-trigger.is-show span:nth-child(1) {
  transform: rotate(45deg);
}
.lp-header-nav-trigger.is-show span:nth-child(2) {
  opacity: 0;
}
.lp-header-nav-trigger.is-show span:nth-child(3) {
  margin-top: calc(-16 / 700 * 100vw);
  transform: rotate(-45deg);
}
.lp-header-nav-trigger span {
  display: block;
  width: calc(34 / 700 * 100vw);
  height: calc(4 / 700 * 100vw);
  margin: 0 auto;
  background: var(--color-main);
}
.lp-header-nav-trigger span + span {
  margin-top: calc(8 / 700 * 100vw);
}
.lp-header-nav {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  background: #fff;
  border-radius: 0 0 calc(25 / 700 * 100vw) calc(25 / 700 * 100vw);
  box-shadow: 0px calc(3 / 700 * 100vw) calc(6 / 700 * 100vw) 0px rgba(0, 0, 0, .1);
  opacity: 0;
  visibility: hidden;
  transition: .2s ease opacity, .2s ease visibility;
}
.lp-header-nav.is-show {
  opacity: 1;
  visibility: visible;
}
.lp-header-logo {
  position: absolute;
  top: calc(30 / 700 * 100vw);
  left: calc(27 / 700 * 100vw);
  width: calc(115 / 700 * 100vw);
  font-size: 0;
}
.lp-header-logo a {
  display: block;
}
.lp-header-nav ul {
  margin: 0;
  padding: calc(24 / 700 * 100vw) 0;
  text-align: center;
}
.lp-header-nav li {
  list-style: none;
}
.lp-header-nav li + li {
  margin-top: calc(8 / 700 * 100vw);
}
.lp-header-nav a {
  color: #A2A2A2;
  font-size: calc(20 / 700 * 100vw);
  font-weight: 700;
}
.lp-header-nav .blue a {
  position: relative;
  display: inline-block;
  padding-right: calc(30 / 700 * 100vw);
  color: var(--color-blue);
}
.lp-header-nav .blue a::after {
  content: '▶';
  position: absolute;
  top: 0;
  right: 0;
}
@media (hover: hover) and (pointer: fine) and (min-width: 768px) {
  .lp-header-nav-trigger {
    transition: opacity .3s;
  }
  .lp-header-nav-trigger:hover {
    opacity: .6;
  }
}
@media screen and (min-width: 768px), print {
  .lp-header {
    padding: 25px 35px 0;
  }
  .lp-header-nav-trigger {
    width: 50px;
    height: 50px;
    box-shadow: 0px 2px 3px 0px rgba(0, 0, 0, .1);
  }
  .lp-header-nav-trigger.is-show span:nth-child(3) {
    margin-top: -11px;
  }
  .lp-header-nav-trigger span {
    width: 24px;
    height: 3px;
  }
  .lp-header-nav-trigger span + span {
    margin-top: 5px;
  }
  .lp-header-nav {
    border-radius: 0 0 12px 12px;
    box-shadow: 0px 2px 3px 0px rgba(0, 0, 0, .1);
  }
  .lp-header-logo {
    top: 25px;
    left: 35px;
    width: 93px;
  }
  .lp-header-nav ul {
    padding: 24px 0;
  }
  .lp-header-nav li + li {
    margin-top: 20px;
  }
  .lp-header-nav .blue a::after {
    top: 3px;
    font-size: 12px;
  }
  .lp-header-nav a {
    font-size: 16px;
  }
  .lp-header-nav .blue a {
    padding-right: 20px;
  }
}

/* visual */
.lp-visual * {
  margin: 0;
}

/* floating */
.lp-floating {
  position: fixed;
  left: 0;
  bottom: 0;
  z-index: 8;
  margin: 0;
  width: 100%;
  background: #fff;
  box-shadow: 0px 0px calc(10 / 700 * 100vw) 0px rgba(0, 0, 0, .1);
  transition: opacity .2s, visibility .2s;
  opacity: 0;
  visibility: hidden;
}
.lp-floating.is-show {
  opacity: 1;
  visibility: visible;
}
.lp-floating.is-hidden {
  opacity: 0;
  visibility: hidden;
}
.lp-floating-inner {
  max-width: 785px;
  margin: 0 auto;
  padding: calc(19 / 700 * 100vw) calc(30 / 700 * 100vw) calc(50 / 700 * 100vw);
}
.lp-floating-text {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
}
.lp-floating-text p {
  margin: 0;
}
.lp-floating-text p:first-child span {
  display: block;
  text-align: center;
  line-height: 1;
}
.lp-floating-text p:first-child span:first-child {
  color: var(--color-blue);
  font-size: calc(25 / 700 * 100vw);
}
.lp-floating-text p:first-child span:nth-child(2) {
  margin-top: calc(4 / 700 * 100vw);
  padding: calc(4 / 700 * 100vw);
  background: var(--color-yellow);
  color: var(--color-main);
  font-size: calc(20 / 700 * 100vw);
}
.lp-floating-text p:nth-child(2) {
  margin-left: calc(15 / 700 * 100vw);
  color: var(--color-blue);
  font-size: calc(68 / 700 * 100vw);
  line-height: 1;
}
.lp-floating-button {
  margin-top: calc(16 / 700 * 100vw);
}
.lp-floating-button a {
  position: relative;
  display: block;
  width: 100%;
  padding: calc(8 / 700 * 100vw);
  background: var(--color-blue);
  border-radius: 100vmax;
  color: #fff;
  font-size: calc(27 / 700 * 100vw);
  font-weight: 700;
  text-align: center;
}
.lp-floating-button a::after {
  content: '▶';
  position: absolute;
  top: 50%;
  right: calc(24 / 700 * 100vw);
  font-size: calc(20 / 700 * 100vw);
  transform: translateY(-50%);
}
@media screen and (min-width: 768px), print {
  .lp-floating {
    box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, .1);
  }
  .lp-floating-inner {
    display: flex;
    align-items: center;
    padding: 12px 40px;
  }
  .lp-floating-text p:first-child span:first-child {
    font-size: 25px;
  }
  .lp-floating-text p:first-child span:nth-child(2) {
    margin-top: 4px;
    padding: 4px;
    font-size: 21px;
  }
  .lp-floating-text p:nth-child(2) {
    margin-left: 10px;
    font-size: 55px;
  }
  .lp-floating-button {
    flex: 1;
    margin: 0 0 0 20px;
  }
  .lp-floating-button a {
    padding: 5px;
    font-size: 19px;
  }
  .lp-floating-button a::after {
    right: 15px;
    font-size: 12px;
  }
}

/* question */
.lp-question {
  padding-top: calc(40 / 700 * 100vw);
  background: var(--bg-lightblue);
}
.lp-question-lead {
  text-align: center;
}
.lp-question-lead p {
  margin: 0;
}
.lp-question-lead p:nth-child(2) {
  margin: calc(5 / 700 * 100vw) 0 calc(10 / 700 * 100vw);
  font-size: calc(60 / 700 * 100vw);
  font-weight: 700;
}
.lp-question-lead p:nth-child(2) > .line::after {
  left: .5em;
  bottom: .3em;
  width: calc(100% - 1em);
  height: calc(18 / 700 * 100vw);
}
.lp-question-contents {
  margin: calc(80 / 700 * 100vw) calc(-35 / 700 * 100vw) 0;
  background: #fff;
  border: calc(3 / 700 * 100vw) solid var(--color-darkblue);
  border-radius: calc(10 / 700 * 100vw);
  overflow: hidden;
}
.lp-question-contents-heading {
  padding: calc(4 / 700 * 100vw) 0 calc(14 / 700 * 100vw);
  background: var(--color-darkblue);
  color: #fff;
  font-size: calc(36 / 700 * 100vw);
  text-align: center;
}
.lp-question-contents-heading span {
  display: block;
  font-size: calc(40 / 700 * 100vw);
  line-height: 1.25;
}
.lp-question-contents div {
  max-width: 820px;
  margin: 0 auto;
  padding: calc(24 / 700 * 100vw) calc(35 / 700 * 100vw) 0;
}
.lp-question-contents div + p {
  margin: 0;
  padding: calc(40 / 700 * 100vw) 0 calc(60 / 700 * 100vw) calc(80 / 700 * 100vw);
  font-size: calc(20 / 700 * 100vw);
}
.lp-question-contents div + p span {
  font-weight: 700;
}
@media screen and (min-width: 768px), print {
  .lp-question {
    padding-top: 80px;
  }
  .lp-question-lead p {
    font-size: 24px;
  }
  .lp-question-lead p:nth-child(2) {
    margin: 0;
    font-size: 50px;
  }
  .lp-question-lead p:nth-child(2) > .line::after {
    height: 10px;
  }
  .lp-question-contents {
    margin: 80px 0 0;
    border-width: 3px;
    border-radius: 5px;
  }
  .lp-question-contents-heading {
    margin-bottom: 0;
    padding: 10px;
    font-size: 24px;
  }
  .lp-question-contents-heading span {
    display: inline-block;
    margin-left: 14px;
    font-size: 27px;
  }
  .lp-question-contents div {
    padding: 60px 40px 0;
  }
  .lp-question-contents div + p {
    margin: 0;
    padding: 60px 0 45px;
    font-size: 12px;
    text-align: center;
    line-height: 1.3;
  }
}

/* example */
.lp-example {
  padding-top: calc(100 / 700 * 100vw);
  background: var(--bg-lightblue);
}
.lp-example .lp-section-heading-inner {
  position: relative;
  display: inline-block;
  line-height: 1;
}
.lp-example .lp-section-heading-inner::after {
  content: '';
  position: absolute;
  top: calc(-8 / 700 * 100vw);
  right: calc(-16 / 700 * 100vw);
  width: calc(77 / 700 * 100vw);
  height: calc(45 / 700 * 100vw);
  background: url(/campaign/s/down/assets/images/icn_deco_01.svg) center center / contain no-repeat;
}
.lp-example-slider-item {
  padding-bottom: 1em;
}
.lp-example-slider-item-inner {
  background: #fff;
  border-radius: calc(10 / 700 * 100vw);
  box-shadow: calc(7 / 700 * 100vw) calc(7 / 700 * 100vw) calc(20 / 700 * 100vw) 0px rgba(0, 0, 0, .1);
  overflow: hidden;
}
.lp-example-slider-item-heading {
  background: var(--color-darkblue);
  color: #fff;
  font-size: calc(25 / 700 * 100vw);
  font-weight: 700;
  text-align: center;
}
.lp-example-slider-item-heading span {
  font-size: calc(35 / 700 * 100vw);
}
.lp-example-slider-item-image {
  padding: 0 calc(20 / 700 * 100vw) calc(32 / 700 * 100vw);
}
.lp-example-slider .swiper-button-prev,
.lp-example-slider .swiper-button-next {
  position: absolute;
  top: calc(50% - calc(20 / 700 * 100vw));
  z-index: 2;
  width: calc(40 / 700 * 100vw);
  height: calc(40 / 700 * 100vw);
  cursor: pointer;
}
.lp-example-slider .swiper-button-prev {
  left: calc(100 / 700 * 100vw);
  transform: scale(-1, 1);
}
.lp-example-slider .swiper-button-next {
  right: calc(100 / 700 * 100vw);
}
@media (hover: hover) and (pointer: fine) and (min-width: 768px) {
  .lp-example-slider .swiper-button-prev,
  .lp-example-slider .swiper-button-next {
    transition: opacity .3s;
  }
  .lp-example-slider .swiper-button-prev:hover,
  .lp-example-slider .swiper-button-next:hover {
    opacity: .6;
  }
}
@media screen and (min-width: 768px), print {
  .lp-example {
    padding-top: 100px;
  }
  .lp-example .lp-section-heading-inner::after {
    top: -20px;
    right: -20px;
    width: 80px;
    height: 50px;
  }
  .lp-example-slider-item-inner {
    width: 85.6481%;
    margin: 0 auto;
    border-radius: 5px;
    box-shadow: 4px 4px 10px 0px rgba(0, 0, 0, .1);
  }
  .lp-example-slider-item-heading {
    font-size: 16px;
  }
  .lp-example-slider-item-heading span {
    font-size: 22px;
  }
  .lp-example-slider-item-image {
    padding: 0 16px 20px;
  }
  .lp-example-slider .swiper-button-prev,
  .lp-example-slider .swiper-button-next {
    top: calc(50% - 20px);
    width: 40px;
    height: 40px;
  }
  .lp-example-slider .swiper-button-prev {
    left: 28.125%;
  }
  .lp-example-slider .swiper-button-next {
    right: 28.125%;
  }
}
@media screen and (min-width: 960px), print {
  .lp-example .lp-section-heading-inner::after {
    right: 20px;
  }
}

/* advice */
.lp-advice {
  padding-top: calc(100 / 700 * 100vw);
  background: var(--bg-lightblue);
}
.lp-advice > .lp-section-heading .lp-section-heading-inner {
  position: relative;
  display: inline-block;
  line-height: 1;
}
.lp-advice > .lp-section-heading .lp-section-heading-inner::after {
  content: '';
  position: absolute;
  top: calc(-24 / 700* 100vw);
  left: calc(15 / 700* 100vw);
  width: calc(80 / 700* 100vw);
  height: calc(66 / 700* 100vw);
  background: url(/campaign/s/down/assets/images/icn_deco_02.svg) center center / contain no-repeat;
}
.lp-advice-movie {
  padding: calc(80 / 700 * 100vw) calc(70 / 700 * 100vw) calc(140 / 700 * 100vw);
}
.lp-advice-movie .lp-section-heading {
  margin-left: calc(-70 / 700 * 100vw);
  margin-right: calc(-70 / 700 * 100vw);
}
.lp-advice-movie .lp-section-heading strong {
  line-height: 1;
}
.lp-advice-movie-inner {
  max-width: 685px;
  margin: calc(50 / 700 * 100vw) auto 0;
}
.lp-advice-movie-contents {
  position: relative;
  padding-top: 56.25%;
}
.lp-advice-movie-contents iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: calc(23 / 700 * 100vw);
  border: calc(6 / 700 * 100vw) solid var(--color-darkblue);
}
@media screen and (min-width: 768px), print {
  .lp-advice {
    padding-top: 100px;
  }
  .lp-advice > .lp-section-heading .lp-section-heading-inner::after {
    top: -30px;
    right: auto;
    left: -50px;
    width: 95px;
    height: 70px;
    background: url(/campaign/s/down/assets/images/icn_deco_04.svg) center center / contain no-repeat;
  }
  .lp-advice > .lp-section-heading {
    margin-bottom: 70px;
  }
  .lp-advice .lp-comment-text {
    padding-left: 0;
    padding-right: 0;
  }
  .lp-advice-movie {
    padding: 80px 40px;
  }
  .lp-advice-movie .lp-section-heading {
    margin-left: 0;
    margin-right: 0;
  }
  .lp-advice-movie-inner {
    margin: 0px auto 0;
  }
  .lp-advice-movie-contents iframe {
    border-radius: 5px;
    border: 3px solid var(--color-darkblue);
  }
  .lp-advice-movie-contents iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
}

/* map */
.lp-map {
  padding: calc(120 / 700 * 100vw) 0 calc(50 / 700 * 100vw);
}
.lp-map .lp-section-heading * {
  line-height: 1.2;
}
.lp-map .lp-section-heading-inner {
  position: relative;
  display: inline-block;
}
.lp-map .lp-section-heading-inner::after {
  content: '';
  position: absolute;
  top: calc(-25 / 700* 100vw);
  right: calc(15 / 700* 100vw);
  width: calc(80 / 700* 100vw);
  height: calc(80 / 700* 100vw);
  background: url(/campaign/s/down/assets/images/icn_deco_03.svg) center center / contain no-repeat;
  transform: scale(-1, 1);
}
.lp-map .lp-section-heading .line {
  margin-bottom: .3em;
}
.lp-map .lp-section-heading .line::after {
  bottom: .1em;
  height: calc(16 / 700 * 100vw);
}
.lp-map-lead {
  margin-top: calc(60 / 700 * 100vw);
  text-align: center;
}
.lp-map-lead-head {
  margin: 0;
  font-size: calc(40 / 700 * 100vw);
}
.lp-map-lead p:nth-child(2) {
  margin: calc(10 / 700 * 100vw) 0;
  letter-spacing: -.05em;
}
.lp-map-lead p:last-child {
  margin: 0;
  font-size: calc(20 / 700 * 100vw);
}
.lp-map-contents {
  position: relative;
  width: 100%;
  max-width: 1000px;
  height: calc(744 / 700 * 100vw);
  margin: calc(70 / 700 * 100vw) auto calc(100 / 700 * 100vw);
}
.lp-map-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}
.lp-map-area > div {
  position: absolute;
  z-index: 2;
  display: block;
  width: calc(147 / 700 * 100vw);
  padding: .7em 0;
  border: calc(4 / 700 * 100vw) solid var(--color-blue);
  border-radius: calc(17 / 700 * 100vw);
  font-size: calc(20 / 700 * 100vw);
  text-align: center;
  line-height: 1;
}
.lp-map-area > div span {
  display: block;
  margin-top: .3em;
  font-weight: 700;
  line-height: 1;
}
.lp-map-area .hokkaido {
  top: calc(45 / 700 * 100vw);
  right: calc(30 / 700 * 100vw);
  padding: .5em 0;
  border-color: var(--color-pink);
}
.lp-map-area .hokkaido span {
  line-height: 1.2;
}
.lp-map-area .tohoku {
  top: 0;
  right: calc(200 / 700 * 100vw);
  border-color: var(--color-pink);
}
.lp-map-area .hokuriku {
  top: calc(110 / 700 * 100vw);
  right: calc(260 / 700 * 100vw);
  border-color: var(--color-pink);
}
.lp-map-area .kanto {
  top: calc(355 / 700 * 100vw);
  right: calc(20 / 700 * 100vw);
  border-color: var(--color-pink);
}
.lp-map-area .koshin {
  top: calc(480 / 700 * 100vw);
  right: calc(30 / 700 * 100vw);
  border-color: var(--color-pink);
}
.lp-map-area .tokai {
  top: calc(590 / 700 * 100vw);
  right: calc(125 / 700 * 100vw);
  border-color: var(--color-pink);
}
.lp-map-area .kitakyushu {
  top: calc(180 / 700 * 100vw);
  left: calc(70 / 700 * 100vw);
  border-color: var(--color-pink);
}
.lp-map-area .chugoku {
  top: calc(230 / 700 * 100vw);
  left: calc(240 / 700 * 100vw);
  border-color: var(--color-pink);
}
.lp-map-area .minamikyushu {
  top: calc(295 / 700 * 100vw);
  left: calc(50 / 700 * 100vw);
  border-color: var(--color-pink);
}
.lp-map-area .kinki {
  top: calc(560 / 700 * 100vw);
  left: calc(260 / 700 * 100vw);
  border-color: var(--color-pink);
}
.lp-map-area .shikoku {
  bottom: 0;
  left: calc(215 / 700 * 100vw);
  border-color: var(--color-pink);
}
.lp-map-area .okinawa {
  top: calc(635 / 700 * 100vw);
  left: calc(50 / 700 * 100vw);
  border-color: var(--color-pink);
}
.lp-map .lp-comment-text {
  background: var(--color-lightpink);
}
.lp-map .lp-comment-text::after {
  border-color: var(--color-lightpink) transparent transparent transparent;
}
.lp-map .lp-comment-text strong:not([class]) {
  color: var(--color-pink);
}
.lp-map .lp-comment-text p {
  margin: 0;
}
.lp-map .lp-comment-text p:first-child strong {
  font-size: calc(34 / 700 * 100vw);
}
.lp-map .lp-comment-text p:last-child {
  margin-top: calc(60 / 700 * 100vw);
  font-size: calc(36 / 700 * 100vw);
  font-weight: 700;
}
.lp-map .lp-comment-text p:last-child strong {
  font-size: calc(44 / 700 * 100vw);
  line-height: 1.4;
}
.lp-map .lp-comment-text p:last-child strong span {
  line-height: 1;
}
.lp-map .lp-comment-profile-text {
  color: var(--color-pink);
}
@media screen and (min-width: 768px), print {
  .lp-map {
    padding: 160px 0 65px;
  }
  .lp-map .lp-section-heading-inner::after {
    top: -120px;
    right: auto;
    left: -40px;
    width: 120px;
    height: 120px;
    transform: none;
  }
  .lp-map .lp-section-heading .line::after {
    height: 10px;
  }
  .lp-map-lead {
    margin-top: 60px;
  }
  .lp-map-lead-head {
    font-size: 34px;
  }
  .lp-map-lead p:nth-child(2) {
    margin: 8px 0 10px;
  }
  .lp-map-lead p:last-child {
    font-size: 12px;
  }
  .lp-map-contents {
    height: 630px;
    margin: 60px auto 90px;
  }
  .lp-map-image {
    top: 50%;
    transform: translateY(-50%);
  }
  .lp-map-area > div {
    width: 120px;
    border-width: 4px;
    border-radius: 8px;
    font-size: 17px;
  }
  .lp-map-area .hokkaido {
    top: 0;
    right: 7.5%;
  }
  .lp-map-area .tohoku {
    top: 7.9%;
    right: 43%;
  }
  .lp-map-area .hokuriku {
    top: 26%;
    right: 45%;
  }
  .lp-map-area .kanto {
    top: 42%;
    right: 10%;
  }
  .lp-map-area .koshin {
    top: 58%;
    right: 7%;
  }
  .lp-map-area .tokai {
    top: 75%;
    right: 20%;
  }
  .lp-map-area .kitakyushu {
    top: 39%;
    left: 3%;
  }
  .lp-map-area .chugoku {
    top: 34%;
    left: 23%;
  }
  .lp-map-area .minamikyushu {
    top: 55%;
    left: 6%;
  }
  .lp-map-area .kinki {
    top: 78%;
    left: 48%;
  }
  .lp-map-area .shikoku {
    left: 30%;
  }
  .lp-map-area .okinawa {
    top: 78%;
    left: 1%;
  }
  .lp-map .lp-comment-text p + p {
    margin-top: 20px;
  }
  .lp-map .lp-comment-text p:first-child strong {
    font-size: 21px;
  }
  .lp-map .lp-comment-text p:last-child {
    margin-top: 15px;
    font-size: 16px;
  }
  .lp-map .lp-comment-text p:last-child span,
  .lp-map .lp-comment-text p:last-child strong {
    font-size: 24px;
  }
  .lp-map .lp-comment-text p:last-child .line::after {
    bottom: .15em;
    height: 7px;
  }
}
@media screen and (min-width: 960px), print {
  .lp-map-area > div {
    width: 130px;
  }
  .lp-map .lp-comment-profile::after {
    border-color: var(--color-lightpink) transparent transparent transparent;
  }
}

/* point */
.lp-point {
  padding: calc(80 / 700 * 100vw) 0 calc(100 / 700 * 100vw);
  background: var(--bg-lightblue);
}
.lp-point .lp-section-heading {
  margin-bottom: calc(60 / 700 * 100vw);
}
.lp-point .lp-section-heading strong {
  line-height: 1;
}
.lp-point .lp-section-heading-inner {
  position: relative;
  display: inline-block;
}
.lp-point .lp-section-heading-inner::after {
  content: '';
  position: absolute;
  bottom: calc(10 / 700 * 100vw);
  right: 0;
  width: calc(70 / 700 * 100vw);
  height: calc(60 / 700 * 100vw);
  background: url(/campaign/s/down/assets/images/icn_deco_03.svg) center center / contain no-repeat;
  transform: scale(-1, 1);
}
.lp-point ul {
  padding: 0;
}
.lp-point li {
  margin: 0;
  list-style: none;
}
.lp-point-item:not(:first-child) {
  margin-top: calc(50 / 700 * 100vw);
}
.lp-point-item-text {
  margin-top: calc(30 / 700 * 100vw);
}
.lp-point-item-text * {
  margin: 0;
}
.lp-point-item-heading {
  margin-bottom: calc(20 / 700 * 100vw);
  color: var(--color-blue);
  font-size: calc(40 / 700 * 100vw);
  text-align: center;
}
.lp-point-item-image {
  position: relative;
}
.lp-point-item-label {
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  background: var(--color-blue);
  padding: 0 .8em;
  color: #fff;
}
.lp-point-item-label > span {
  display: inline-block;
  margin-left: .5em;
  font-size: calc(34 / 700 * 100vw);
}
.lp-point-item-text ul {
  margin: calc(30 / 700 * 100vw) 0;
}
.lp-point-item-text ul li {
  position: relative;
  padding-left: 1.5em;
}
.lp-point-item-text ul li::before {
  content: '⚫︎';
  position: absolute;
  top: .15em;
  left: 0;
  color: var(--color-blue);
  font-size: calc(24 / 700 * 100vw);
}
.lp-point-item-text ul li + li {
  margin-top: calc(20 / 700 * 100vw);
}
.lp-point-item-text .note {
  font-size: calc(20 / 700 * 100vw);
}
.lp-point-item-text .note a {
  color: #0044CC;
  text-decoration: underline;
}
.lp-point-campaign {
  margin-top: calc(160 / 700 * 100vw);
}
.lp-point-campaign .lp-section-heading {
  margin-bottom: calc(10 / 700 * 100vw);
}
.lp-point-campaign .lp-section-heading-inner::after {
  top: calc(-55 / 700* 100vw);
  right: auto;
  bottom: auto;
  left: calc(65 / 700* 100vw);
  width: calc(80 / 700* 100vw);
  height: calc(85 / 700* 100vw);
}
.lp-point-campaign p {
  margin: 0;
  text-align: center;
}
.lp-point-campaign p .line::after {
  bottom: .25em;
  height: calc(10 / 700* 100vw);
}
.lp-point-campaign-button {
  max-width: 475px;
  margin: calc(35 / 700* 100vw) auto 0;
}
.lp-point-campaign-button a {
  position: relative;
  display: block;
  width: 100%;
  padding: calc(14 / 700* 100vw) 0 calc(20 / 700* 100vw);
  background: var(--color-blue);
  border-radius: 100vmax;
  color: #fff;
  font-size: calc(34 / 700* 100vw);
  font-weight: 700;
  text-align: center;
  line-height: 1.5;
  box-shadow: 0px calc(6 / 700 * 100vw) calc(20 / 700 * 100vw) 0px rgba(0, 0, 0, .1);
}
.lp-point-campaign-button a::after {
  content: '▶';
  position: absolute;
  top: 50%;
  right: calc(40 / 700* 100vw);
  font-size: calc(24 / 700* 100vw);
  transform: translateY(-50%);
}
.lp-point-campaign-button a span {
  display: inline-block;
  line-height: 1;
}
.lp-point-campaign-button a span:nth-of-type(2) {
  font-size: calc(54 / 700* 100vw);
}
@media (hover: hover) and (pointer: fine) and (min-width: 768px) {
  .lp-point-item-text .note a:hover {
    text-decoration: none;
  }
}
@media screen and (min-width: 768px), print {
  .lp-point {
    padding: 70px 0 150px;
  }
  .lp-point .lp-section-heading {
    margin-bottom: 40px;
  }
  .lp-point .lp-section-heading-inner::after {
    display: none;
  }
  .lp-point-item {
    display: flex;
    align-items: center;
  }
  .lp-point-item:not(:first-child) {
    margin-top: 50px;
  }
  .lp-point-item-label {
    font-size: 14px;
  }
  .lp-point-item-label > span {
    font-size: 17px;
  }
  .lp-point-item-image {
    width: 50%;
    max-width: 310px;
  }
  .lp-point-item-text {
    flex: 1;
    margin: -10px 0 0 35px;
  }
  .lp-point-item-heading {
    margin-bottom: 0;
    font-size: 24px;
    text-align: left;
  }
  .lp-point-item-text p {
    line-height: 2.18;
  }
  .lp-point-item-text ul {
    margin: 8px 0 14px;
    font-size: 14px;
  }
  .lp-point-item-text ul li::before {
    top: 0;
    font-size: 16px;
  }
  .lp-point-item-text ul li + li {
    margin-top: 6px;
  }
  .lp-point-item-text .note {
    font-size: 12px;
    line-height: 1.3;
  }
  .lp-point-campaign {
    margin-top: 130px;
  }
  .lp-point-campaign .lp-section-heading {
    margin-bottom: 30px;
  }
  .lp-point-campaign .lp-section-heading-inner::after {
    display: block;
    top: -60px;
    left: -50px;
    width: 88px;
    height: 93px;
    transform: none;
  }
  .lp-point-campaign p {
    font-size: 24px;
  }
  .lp-point-campaign p .line::after {
    height: 7px;
  }
  .lp-point-campaign-button {
    margin: 50px auto 0;
  }
  .lp-point-campaign-button a {
    padding: 20px;
    font-size: 34px;
    box-shadow: 0px 6px 20px 0px rgba(0, 0, 0, .1);
  }
  .lp-point-campaign-button a::after {
    right: 25px;
    font-size: 16px;
  }
  .lp-point-campaign-button a span:nth-of-type(n) {
    font-size: 34px;
  }
}