@charset "UTF-8";
/*! destyle.css v1.0.15 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Reset box-model */
/* ============================================ */
* {
  box-sizing: border-box;
}

::before,
::after {
  box-sizing: inherit;
}

/* Document */
/* ============================================ */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 * 3. Remove gray overlay on links for iOS.
 */
html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -webkit-tap-highlight-color: transparent; /* 3*/
}

/* Sections */
/* ============================================ */
/**
 * Remove the margin in all browsers.
 */
body {
  font-size: 1rem;
  margin: 0;
  font-family: "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  background-color: #F7F2E7;
  color: #333333;
  letter-spacing: 0.1em;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block;
}

/* Vertical rhythm */
/* ============================================ */
p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}

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

/* Lists (enumeration) */
/* ============================================ */
ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

/* Lists (definition) */
/* ============================================ */
dt {
  font-weight: bold;
}

dd {
  margin-left: 0;
}

/* Grouping content */
/* ============================================ */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
  border: 0;
  border-top: 1px solid;
  margin: 0;
  clear: both;
  color: inherit;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: inherit; /* 2 */
}

address {
  font-style: inherit;
}

/* Text-level semantics */
/* ============================================ */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: inherit; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content */
/* ============================================ */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none;
  vertical-align: bottom;
  width: 100%;
}

embed,
object,
iframe {
  border: 0;
  vertical-align: bottom;
}

/* Forms */
/* ============================================ */
/**
 * Reset form fields to make them styleable
 */
button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  border: 0;
  background: transparent;
  padding: 0;
  margin: 0;
  outline: 0;
  border-radius: 0;
  text-align: inherit;
}

/**
 * Reset radio and checkbox appearance to preserve their look in iOS.
 */
[type=checkbox] {
  -webkit-appearance: checkbox;
  -moz-appearance: checkbox;
       appearance: checkbox;
}

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

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}

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

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Remove arrow in IE10 & IE11
 */
select::-ms-expand {
  display: none;
}

/**
 * Remove padding
 */
option {
  padding: 0;
}

/**
 * Reset to invisible
 */
fieldset {
  margin: 0;
  padding: 0;
  border: 0;
  min-width: 0;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the outline style in Safari.
 */
[type=search] {
  outline-offset: -2px; /* 1 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/**
 * Clickable labels
 */
label[for] {
  cursor: pointer;
}

/* Interactive */
/* ============================================ */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/*
 * Remove outline for editable content.
 */
[contenteditable] {
  outline: none;
}

/* Table */
/* ============================================ */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

caption {
  text-align: left;
}

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

th {
  text-align: left;
  font-weight: bold;
}

/* Misc */
/* ============================================ */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none;
}

.l-container {
  width: 100%;
  max-width: 1080px;
  margin-inline: auto;
  padding-inline: 40px;
}
@media screen and (max-width: 767px) {
  .l-container {
    width: 100%;
    padding-inline: 20px;
  }
}

.l-container-min {
  width: 100%;
  max-width: 880px;
  margin-inline: auto;
  padding-inline: 40px;
}
@media screen and (max-width: 767px) {
  .l-container-min {
    width: 100%;
    padding-inline: 20px;
  }
}

.l-main {
  margin-top: 180px;
}
@media screen and (max-width: 767px) {
  .l-main {
    margin-top: 120px;
  }
}

.l-spacer-primary {
  margin-top: 64px;
}
@media screen and (max-width: 767px) {
  .l-spacer-primary {
    margin-top: 48px;
  }
}

.l-spacer__heading {
  margin-top: 120px;
}
@media screen and (max-width: 1160px) {
  .l-spacer__heading {
    margin-top: 100px;
  }
}
@media screen and (max-width: 820px) {
  .l-spacer__heading {
    margin-top: 80px;
  }
}
@media screen and (max-width: 767px) {
  .l-spacer__heading {
    margin-top: 60px;
  }
}

.l-bg {
  background-color: #F7F2E7;
}

.l-bg-wh {
  padding-block: 64px;
  background-color: #fff;
}
@media screen and (max-width: 767px) {
  .l-bg-wh {
    padding-block: 48px;
  }
}

.c-heading-primary {
  margin-bottom: 56px;
  text-align: center;
  font-size: 28px;
  font-weight: 700;
  line-height: 1.5;
}
.c-heading-primary span {
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .c-heading-primary {
    margin-bottom: 40px;
    font-size: 22px;
  }
}

.c-heading-primary-en {
  margin-bottom: 8px;
  text-align: center;
  font-family: "Josefin Sans", serif;
  color: #F49584;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0;
}

.c-button-wrap {
  margin-top: 48px;
  text-align: center;
}

.c-button-primary {
  position: relative;
  display: inline-block;
  width: 180px;
  background-color: #F49584;
  color: #fff;
  border-radius: 30px;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  line-height: 46px;
  letter-spacing: 0.1em;
  transition: background 0.3s;
}
@media (hover: hover) and (pointer: fine) {
  .c-button-primary:hover {
    background-color: #ffb2a4;
  }
}

.c-button-next {
  position: relative;
  display: inline-block;
  width: 180px;
  background-color: #F49584;
  color: #fff;
  border-radius: 30px;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  line-height: 46px;
  letter-spacing: 0.1em;
  transition: background 0.3s;
}
@media (hover: hover) and (pointer: fine) {
  .c-button-next:hover {
    background-color: #ffb2a4;
  }
}
.c-button-next::after {
  content: "";
  position: absolute;
  top: 0;
  right: 16px;
  bottom: 0;
  width: 16px;
  height: 16px;
  margin: auto;
  background: url(../img/common/icon-arrow.svg) no-repeat center/cover;
  pointer-events: none;
}

.pager {
  margin-top: 64px;
}
@media screen and (max-width: 767px) {
  .pager {
    margin-top: 40px;
  }
}
.pager ul {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
}
@media screen and (max-width: 767px) {
  .pager ul {
    gap: 8px;
  }
}
.pager ul li a {
  padding: 8px;
  font-weight: 700;
}
@media (hover: hover) and (pointer: fine) {
  .pager ul li a {
    transition: opacity 0.3s;
  }
  .pager ul li a:hover {
    opacity: 0.7;
  }
}
@media screen and (max-width: 767px) {
  .pager ul li a {
    font-size: 12px;
  }
}
.pager ul li span {
  display: inline-block;
  width: 40px;
  height: 40px;
  background-color: #F49584;
  color: #fff;
  border-radius: 2px;
  text-align: center;
  font-weight: 700;
  line-height: 40px;
}
@media screen and (max-width: 767px) {
  .pager ul li span {
    width: 32px;
    height: 32px;
    font-size: 12px;
    line-height: 32px;
  }
}

.c-form__label {
  display: block;
  margin-bottom: 8px;
  font-size: 16px;
  font-weight: 700;
}
.c-form__subLabel {
  display: inline-block;
  margin-bottom: 8px;
  font-size: 14px;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .c-form__subLabel {
    font-size: 12px;
  }
}
.c-form__eq {
  display: inline-block;
  margin-left: 8px;
  padding: 0 8px;
  background-color: #BC1F1F;
  color: #fff;
  border-radius: 3px;
  font-size: 10px;
  font-weight: 700;
  line-height: 18px;
  vertical-align: text-bottom;
}
.c-form__any {
  display: inline-block;
  margin-left: 8px;
  padding: 0 8px;
  background-color: #cccccc;
  color: #fff;
  border-radius: 3px;
  font-size: 10px;
  font-weight: 700;
  line-height: 18px;
  vertical-align: text-bottom;
}
.c-form__item + .c-form__item {
  margin-top: 32px;
}
@media screen and (max-width: 767px) {
  .c-form__item + .c-form__item {
    margin-top: 16px;
  }
}
.c-form__input {
  padding-left: 0 !important;
  cursor: none;
}
.c-form__input input {
  width: 100%;
  background-color: #fff;
  border: 1px solid #ccc;
  border-radius: 5px;
  padding: 13px 16px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .c-form__input input {
    padding: 8px 16px;
  }
}
.c-form__input.-postnum input {
  display: block;
  width: 50%;
  max-width: 200px;
}
.c-form__input.-age input {
  margin-right: 8px;
  width: 100px;
}
.c-form__textarea textarea {
  width: 100%;
  height: 160px;
  background-color: #fff;
  border: 1px solid #ccc;
  border-radius: 5px;
  padding: 13px 16px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .c-form__textarea textarea {
    padding: 8px 16px;
  }
}
.c-form__2col {
  display: flex;
  align-items: flex-end;
  gap: 16px;
}
@media screen and (max-width: 767px) {
  .c-form__2col {
    gap: 8px;
  }
}
.c-form__2col .c-form__input {
  width: 100%;
}
.c-form__subItem {
  margin-top: 16px;
}
.c-form__postnum .c-form__input input {
  width: 114px;
}
.c-form__attr {
  margin-top: 4px;
  text-indent: -1em;
  margin-left: 1em;
  font-size: 12px;
  line-height: 1.5;
  font-weight: 500;
}
.c-form__text {
  margin-bottom: 40px;
  text-align: center;
  font-size: 16px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .c-form__text {
    margin-bottom: 32px;
    font-size: 14px;
  }
}
.c-form__text span {
  display: inline-block;
}
.c-form__data {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.5;
}
.c-form__agree {
  text-align: center;
  margin-top: 32px;
}
.c-form__answer {
  margin-bottom: 8px;
  font-size: 16px;
  line-height: 1.75;
}
.c-form__err {
  margin-bottom: 56px;
  padding: 24px 32px;
  background-color: #fff;
  border: 1px solid #BC1F1F;
  color: #BC1F1F;
  border-radius: 5px;
}
@media screen and (max-width: 767px) {
  .c-form__err {
    margin-bottom: 40px;
    padding: 16px;
  }
}
.c-form__err li {
  font-size: 14px;
  line-height: 1.5;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .c-form__err li {
    font-size: 12px;
  }
}
.c-form__err li + li {
  margin-top: 8px;
}
@media screen and (max-width: 767px) {
  .c-form__timeOther {
    width: 260px;
  }
}

.c-radio__list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .c-radio__list {
    gap: 16px;
  }
}
.c-radio__grid {
  display: flex;
  gap: 40px;
}
.c-radio label {
  position: relative;
  padding-left: 32px;
  font-weight: 400;
  line-height: 28px;
}
@media screen and (max-width: 767px) {
  .c-radio label {
    padding-left: 36px;
    font-size: 14px;
  }
}
.c-radio label input[type=radio] {
  display: inline;
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  cursor: pointer;
}
.c-radio label input[type=radio]::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 24px;
  height: 24px;
  margin: auto;
  border-radius: 24px;
  background-color: #fff;
  border: 1px solid #ccc;
  cursor: pointer;
}
.c-radio label input[type=radio]::after {
  content: "";
  position: absolute;
  top: 0;
  left: 5px;
  bottom: 0;
  width: 14px;
  height: 14px;
  margin: auto;
  border-radius: 20px;
  background-color: #F49584;
  opacity: 0;
}
@media screen and (max-width: 767px) {
  .c-radio label input[type=radio]::after {
    left: 3px;
    width: 18px;
    height: 18px;
  }
}
.c-radio label input[type=radio]:checked::after {
  opacity: 1;
}
.c-radio label + .c-form__item, .c-radio label + .c-select {
  margin-top: 16px;
}
.c-radio .c-form__label {
  padding-left: 0;
  font-weight: 700;
  line-height: 1.125;
}
.c-radio__data {
  margin-top: 16px;
  padding-left: 32px;
  font-size: 14px;
}

.c-select {
  position: relative;
}
.c-select::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 16px;
  border-top: 8px solid #333333;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  transform: translateY(-50%);
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .c-select::after {
    right: 10px;
  }
}
.c-select select {
  display: block;
  width: 100%;
  background-color: #fff;
  border: 1px solid #ccc;
  border-radius: 5px;
  padding: 13px 40px 13px 24px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .c-select select {
    padding: 8px 32px 8px 16px;
  }
}
.c-select.-age {
  width: 100px;
}
.c-select.-month {
  width: 95px;
}
.c-select.-year {
  width: 108px;
}
.c-select.-pref {
  width: 50%;
  max-width: 200px;
}

.c-checkbox__list {
  display: flex;
  flex-direction: column;
  gap: 24px;
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .c-checkbox__list {
    gap: 16px;
  }
}
.c-checkbox__grid {
  display: flex;
  gap: 40px;
}
.c-checkbox label {
  position: relative;
  padding-left: 40px;
  font-weight: 400;
}
@media screen and (max-width: 767px) {
  .c-checkbox label {
    font-size: 14px;
  }
}
.c-checkbox label input[type=checkbox] {
  display: inline;
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  cursor: pointer;
}
.c-checkbox label input[type=checkbox]::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 28px;
  height: 28px;
  margin: auto;
  background-color: #fff;
  border: 2px solid #333333;
}
.c-checkbox label input[type=checkbox]::after {
  content: "";
  position: absolute;
  top: -2px;
  left: 6px;
  bottom: 0;
  width: 16px;
  height: 8px;
  margin: auto;
  border-left: 3px solid #e8e8e8;
  border-bottom: 3px solid #e8e8e8;
  transform: rotate(-45deg);
}
.c-checkbox label input[type=checkbox]:checked::after {
  border-color: #F49584;
}
.c-checkbox .c-checkbox__name {
  display: block;
  margin: -24px -24px 24px -24px;
  padding: 16px 40px 16px 64px;
  background-color: #f9d2cb;
  border-radius: 7px 7px 0 0;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .c-checkbox .c-checkbox__name {
    font-size: 16px;
  }
}
.c-checkbox .c-checkbox__name input[type=checkbox]::before {
  left: 24px;
}
.c-checkbox .c-checkbox__name input[type=checkbox]::after {
  left: 30px;
}

.c-form-next {
  position: relative;
  display: inline-block;
}
.c-form-next input[type=button],
.c-form-next input[type=submit] {
  position: relative;
  display: inline-block;
  width: 180px;
  background-color: #F49584;
  color: #fff;
  border-radius: 30px;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  line-height: 46px;
  letter-spacing: 0.1em;
  transition: background 0.3s;
}
@media (hover: hover) and (pointer: fine) {
  .c-form-next input[type=button]:hover,
.c-form-next input[type=submit]:hover {
    background-color: #ffb2a4;
  }
}
.c-form-next::after {
  content: "";
  position: absolute;
  top: 0;
  right: 16px;
  bottom: 0;
  width: 16px;
  height: 16px;
  margin: auto;
  background: url(../img/common/icon-arrow.svg) no-repeat center/cover;
  pointer-events: none;
}
.c-form-next input:disabled {
  background-color: #cccccc;
  color: #999;
  pointer-events: none;
}
.c-form-next:has(input:disabled)::after {
  background: url(../img/common/icon-arrow-gy.svg) no-repeat center/cover;
}

.c-form-submit {
  position: relative;
  display: inline-block;
  width: 100%;
  max-width: 400px;
}
.c-form-submit.-check::before {
  content: "ご利用規約に同意の上";
  position: absolute;
  top: 26px;
  left: 0;
  right: 0;
  margin: auto;
  font-size: 13px;
  font-weight: 700;
}
.c-form-submit input[type=submit],
.c-form-submit input[type=button] {
  display: inline-block;
  width: 100%;
  padding: 24px;
  background-color: #FFEC5F;
  border: 3px solid #333333;
  border-radius: 10px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.1em;
  transition: background 0.3s;
}
@media (hover: hover) and (pointer: fine) {
  .c-form-submit input[type=submit]:hover,
.c-form-submit input[type=button]:hover {
    background-color: #fff28e;
  }
}
.c-form-submit.-check input[type=submit], .c-form-submit.-check input[type=button] {
  padding: 48px 24px 24px;
  font-size: 18px;
}
.c-form-submit input:disabled {
  pointer-events: none;
  background-color: #cccccc;
  border-color: #cccccc;
  color: #999;
}

.c-form-back {
  position: relative;
  display: inline-block;
  margin-top: 24px;
  padding-left: 16px;
}
@media (hover: hover) and (pointer: fine) {
  .c-form-back {
    transition: opacity 0.3s;
  }
  .c-form-back:hover {
    opacity: 0.7;
  }
}
.c-form-back::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 8px;
  height: 8px;
  margin: auto;
  border-bottom: 2px solid #333333;
  border-left: 2px solid #333333;
  border-radius: 1px;
  transform: rotate(45deg);
}
.c-form-back input[type=submit],
.c-form-back input[type=button] {
  padding-bottom: 2px;
  border-bottom: 1px solid #333333;
  font-size: 14px;
  font-weight: 500;
}

.p-step {
  position: relative;
  display: flex;
  justify-content: space-between;
  width: 100%;
  max-width: 880px;
  margin: 80px auto;
  padding-inline: 40px;
}
@media screen and (max-width: 767px) {
  .p-step {
    width: 100%;
    margin-block: 40px;
    padding-inline: 20px;
  }
}
.p-step::after {
  content: "";
  position: absolute;
  top: 38px;
  left: 0;
  right: 0;
  width: calc(100% - 100px);
  height: 4px;
  margin: auto;
  background-color: #e8e8e8;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-step::after {
    top: 32px;
    height: 2px;
  }
}
.p-step__icon {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  width: 80px;
  height: 80px;
  margin: auto;
  padding-top: 12px;
  background-color: #e8e8e8;
  color: #afafaf;
  border-radius: 80px;
  text-align: center;
  font-family: "Josefin Sans", serif;
  font-size: 40px;
  font-weight: 400;
  letter-spacing: 0;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .p-step__icon {
    width: 64px;
    height: 64px;
    padding-top: 10px;
    border-radius: 64px;
    font-size: 30px;
  }
}
.p-step__icon span {
  font-size: 16px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-step__icon span {
    font-size: 12px;
  }
}
.is-active .p-step__icon {
  background-color: #fff;
  color: #333333;
  border: 3px solid #333333;
}
@media screen and (max-width: 767px) {
  .is-active .p-step__icon {
    border-width: 2px;
  }
}

.p-step__text {
  margin-top: 8px;
  color: #afafaf;
  text-align: center;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 767px) {
  .p-step__text {
    font-size: 12px;
  }
}
.is-active .p-step__text {
  color: #333333;
}

.c-tags__container {
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid #ccc;
}
@media screen and (max-width: 767px) {
  .c-tags__container {
    margin-top: 16px;
    padding-top: 16px;
  }
}
.c-tags__block {
  display: flex;
  gap: 24px;
}
.c-tags__block + .c-tags__block {
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .c-tags__block {
    gap: 16px;
  }
}
.c-tags__cate {
  flex-shrink: 0;
  width: 180px;
  font-size: 14px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .c-tags__cate {
    width: 60px;
    font-size: 12px;
  }
}
.c-tags__list {
  align-self: flex-start;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.c-tags__list li {
  padding: 4px 10px;
  background-color: #e8e8e8;
  border-radius: 10px;
  font-size: 12px;
  letter-spacing: 0.05em;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .c-tags__list li {
    font-size: 10px;
  }
}

.c-modal__bg {
  position: fixed;
  top: 0;
  left: 0;
  display: none;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.45);
  z-index: 1;
}
.c-modal__card {
  position: fixed;
  top: 10%;
  left: 50%;
  display: none;
  width: 90%;
  max-width: 800px;
  max-height: 80%;
  background-color: #fff;
  border-radius: 10px;
  transform: translateX(-50%);
  overflow: auto;
  z-index: 1;
}
.c-modal__label {
  display: block;
  padding: 24px 40px;
  text-align: center;
  border-bottom: 1px solid #F49584;
  font-size: 24px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .c-modal__label {
    padding: 16px;
    font-size: 18px;
  }
}
.c-modal__close {
  position: absolute;
  right: 16px;
  top: 24px;
  width: 28px;
  height: 28px;
}
@media screen and (max-width: 767px) {
  .c-modal__close {
    top: 16px;
    width: 24px;
    height: 24px;
  }
}
.c-modal__close::before {
  content: "";
  position: absolute;
  width: 28px;
  height: 2px;
  background-color: #333333;
  border-radius: 2px;
  transform: rotate(45deg);
}
@media screen and (max-width: 767px) {
  .c-modal__close::before {
    width: 24px;
  }
}
.c-modal__close::after {
  content: "";
  position: absolute;
  width: 28px;
  height: 2px;
  background-color: #333333;
  border-radius: 2px;
  transform: rotate(-45deg);
}
@media screen and (max-width: 767px) {
  .c-modal__close::after {
    width: 24px;
  }
}
.c-modal__content {
  padding: 24px;
}
.c-modal__button-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-bottom: -16px;
}
@media screen and (max-width: 767px) {
  .c-modal__button-list {
    gap: 8px;
  }
}
.c-modal__button-list input[type=radio],
.c-modal__button-list input[type=checkbox] {
  display: none;
}
.c-modal__button-list label {
  display: inline-block;
  padding: 16px 4px;
  background-color: #fff;
  border: 2px solid #333333;
  border-radius: 10px;
  text-align: center;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.75;
  letter-spacing: 0;
  cursor: pointer;
  transition: 0.2s ease-in;
}
@media screen and (max-width: 767px) {
  .c-modal__button-list label {
    font-size: 13px;
  }
}
.c-modal__button-list label:has(input[type=radio]:checked),
.c-modal__button-list label:has(input[type=checkbox]:checked) {
  background-color: #fff;
  color: #F49584;
  border: 2px solid #F49584;
}
.c-modal__counter {
  margin-top: 16px;
  text-align: center;
  color: #F49584;
  font-size: 14px;
  font-weight: 500;
}
.c-modal__select select {
  border: 2px solid #333333;
}

.p-footer {
  margin-top: 80px;
  background-color: #EBE2CD;
  padding-block: 64px 24px;
}
.p-footer__navList {
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .p-footer__navList {
    flex-direction: column;
    align-items: center;
    gap: 16px;
  }
}
.p-footer__navItem + .p-footer__navItem::before {
  content: "/";
  display: inline-block;
  margin-inline: 1em;
}
@media screen and (max-width: 767px) {
  .p-footer__navItem + .p-footer__navItem::before {
    content: none;
  }
}
.p-footer__navLink {
  position: relative;
}
@media (hover: hover) and (pointer: fine) {
  .p-footer__navLink::after {
    content: "";
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 0;
    height: 1px;
    background-color: #333333;
    transition: width 0.3s;
  }
  .p-footer__navLink:hover::after {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .p-footer__navLink {
    font-size: 14px;
  }
}
.p-footer__buttonWrap {
  display: flex;
  justify-content: center;
  gap: 40px;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-footer__buttonWrap {
    flex-direction: column;
    align-items: center;
    gap: 16px;
    margin-top: 32px;
  }
}
.p-footer__button {
  width: 400px;
  background-color: #fff;
  border: 3px solid #333333;
  border-radius: 40px;
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  line-height: 74px;
}
@media screen and (max-width: 767px) {
  .p-footer__button {
    width: 100%;
    max-width: 300px;
    font-size: 16px;
    line-height: 58px;
  }
}
.p-footer__logo {
  margin-top: 56px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-footer__logo {
    margin-top: 40px;
  }
}
.p-footer__logo a {
  display: inline-block;
}
.p-footer__logo img {
  display: block;
  width: auto;
  height: 70px;
}
@media screen and (max-width: 767px) {
  .p-footer__logo img {
    height: 50px;
  }
}
.p-footer__copy {
  margin-top: 40px;
  text-align: center;
  font-size: 10px;
}
@media screen and (max-width: 767px) {
  .p-footer__copy {
    margin-top: 32px;
  }
}

.u-pc {
  display: block;
}
@media screen and (max-width: 767px) {
  .u-pc {
    display: none;
  }
}

.u-sp {
  display: none;
}
@media screen and (max-width: 767px) {
  .u-sp {
    display: block;
  }
}

.u-link {
  text-decoration: underline;
}
@media (hover: hover) and (pointer: fine) {
  .u-link {
    transition: opacity 0.3s;
  }
  .u-link:hover {
    opacity: 0.7;
  }
}

@media screen and (max-width: 767px) {
  .u-sp-left {
    text-align: left;
  }
}

.u-center {
  text-align: center;
}

.u-text {
  font-size: 16px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .u-text {
    font-size: 14px;
  }
}
.u-text + .c-heading-border {
  margin-top: 48px;
}
@media screen and (max-width: 767px) {
  .u-text + .c-heading-border {
    margin-top: 40px;
  }
}

.u-visuallyHidden {
  position: absolute;
  white-space: nowrap;
  width: 1px;
  height: 1px;
  overflow: hidden;
  border: 0;
  padding: 0;
  clip: rect(0 0 0 0);
  -webkit-clip-path: inset(50%);
          clip-path: inset(50%);
  margin: -1px;
}

.p-top {
  position: relative;
}
.p-top__heading {
  margin-bottom: 40px;
  padding-left: 0.11em;
  text-align: center;
  font-size: 32px;
  line-height: 1.75;
  font-weight: 700;
  letter-spacing: 0.11em;
}
@media screen and (max-width: 767px) {
  .p-top__heading {
    margin-bottom: 32px;
    font-size: 23px;
  }
}
.p-top__heading span {
  display: inline-block;
}
.p-top__heading small {
  font-size: 24px;
}
@media screen and (max-width: 767px) {
  .p-top__heading small {
    font-size: 15px;
  }
}
.p-top__text {
  text-align: center;
  font-size: 20px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-top__text {
    font-size: 16px;
  }
}
.p-top__bnr {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  padding: 16px 0 24px;
  background-color: #F49584;
  text-align: center;
  z-index: 100;
}
@media screen and (max-width: 767px) {
  .p-top__bnr {
    padding: 8px 0;
  }
}

.p-topCard__title {
  margin-top: 16px;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.7;
}
@media screen and (max-width: 767px) {
  .p-topCard__title {
    font-size: 18px;
  }
}
.p-topCard__title span {
  display: inline-block;
}
.p-topCard__text {
  margin-top: 8px;
  font-size: 18px;
  line-height: 1.7;
}
@media screen and (max-width: 767px) {
  .p-topCard__text {
    font-size: 14px;
  }
}

.p-topHero {
  position: relative;
  padding: 1.66666666vw 1.66666666vw 2.5vw;
  background: url(../img/top/hero_pc.png) no-repeat right 16px/42.7083333vw;
}
@media screen and (max-width: 767px) {
  .p-topHero {
    background-position-y: 52.13333333vw;
    background-size: 90vw;
  }
}
.p-topHero::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 5vw;
  width: 10.5729167vw;
  padding-top: 5.57291667vw;
  background: url(../img/top/yakiimo.svg) no-repeat center/cover;
}
@media screen and (max-width: 767px) {
  .p-topHero::after {
    content: none;
  }
}
.p-topHero__heading {
  font-size: 13px;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .p-topHero__heading {
    font-size: 10px;
  }
}
.p-topHero__read {
  margin-top: 2.9vw;
}
.p-topHero__read img {
  width: 44.0625vw;
}
@media screen and (max-width: 767px) {
  .p-topHero__read img {
    margin-left: -4vw;
    width: 81.0666667vw;
  }
}
.p-topHero__copy {
  margin-top: -2.45vw;
  margin-left: 2.3vw;
  font-size: 3.02083333vw;
  font-weight: 700;
  line-height: 1.55;
  letter-spacing: 0.11em;
}
@media screen and (max-width: 767px) {
  .p-topHero__copy {
    margin-top: -6vw;
    font-size: 5.866666667vw;
  }
}
.p-topHero__copy span {
  color: #E97337;
  font-size: 3.54166667vw;
}
@media screen and (max-width: 767px) {
  .p-topHero__copy span {
    font-size: 6.93333333vw;
  }
}
.p-topHero__point {
  position: relative;
  display: flex;
  gap: 16px;
  width: 44.7916667vw;
  margin-top: 4.166666667vw;
  margin-left: 2.3vw;
}
@media screen and (max-width: 767px) {
  .p-topHero__point {
    gap: 8px;
    width: 100%;
    margin-left: 0;
  }
}
.p-topHero__point::before {
  content: "";
  position: absolute;
  bottom: -3vw;
  right: -12vw;
  width: 14.7395833vw;
  padding-top: 18.59375vw;
  background: url(../img/top/kobaton1_pc.png) no-repeat center/cover;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .p-topHero__point::before {
    bottom: 36vw;
    right: auto;
    left: -2.5vw;
    width: 28.53333333vw;
    padding-top: 45.2666667vw;
    background-image: url(../img/top/kobaton1_sp.png);
  }
}
.p-topHero__item {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 24px 8px 16px;
  border: 5px solid #333333;
  border-radius: 5px;
  background-color: #fff;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-topHero__item {
    padding: 16px 10px;
    border-width: 3px;
  }
}
.p-topHero__item::after {
  content: "";
  position: absolute;
  top: -19px;
  left: 0;
  right: 0;
  width: 34px;
  height: 34px;
  margin: auto;
  background-color: #F49584;
  border: 5px solid #333333;
  border-radius: 34px;
}
@media screen and (max-width: 767px) {
  .p-topHero__item::after {
    top: -10px;
    width: 16px;
    height: 16px;
    border-width: 3px;
  }
}
.p-topHero__text {
  font-size: 1.14583333vw;
  font-weight: 700;
  line-height: 1.55;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 767px) {
  .p-topHero__text {
    font-size: 3.2vw;
  }
}
.p-topHero__text span {
  font-size: 1.45833333vw;
}
@media screen and (max-width: 767px) {
  .p-topHero__text span {
    font-size: 4vw;
  }
}
.p-topHero__attr {
  margin-top: 4.583333333vw;
  text-align: right;
  font-size: 12px;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .p-topHero__attr {
    margin-top: 98.4vw;
    text-align: left;
    font-size: 11px;
  }
}
.p-topHero__tokuten {
  position: absolute;
  top: 2.08333333vw;
  left: 49.8958333vw;
  width: 19.270833333vw;
  height: 19.270833333vw;
}
@media screen and (max-width: 767px) {
  .p-topHero__tokuten {
    top: 52.5vw;
    left: 0;
    width: 43.626667vw;
    height: 43.626667vw;
  }
}
.p-topHero__tokuten svg {
  width: 100%;
  height: 100%;
}

.p-topSlider__list {
  display: flex;
}
.p-topSlider__item {
  position: relative;
  width: 25%;
}
.p-topSlider__item figcaption {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 16px;
  width: 154px;
  margin: auto;
  padding: 8px;
  background-color: #fff;
  border-radius: 5px;
  text-align: center;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .p-topSlider__item figcaption {
    bottom: 8px;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    padding: 4px 8px;
    font-size: 12px;
  }
}
.p-topSlider .swiper-wrapper {
  transition-timing-function: linear;
}

.p-topPoint {
  position: relative;
  margin-top: 32px;
  padding: 88px 0 64px;
  background-color: #fff;
}
.p-topPoint::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100px;
  height: 50px;
  margin: auto;
  border-top: 40px solid #F7F2E7;
  border-left: 50px solid transparent;
  border-right: 50px solid transparent;
}
.p-topPoint__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px 40px;
}
@media screen and (max-width: 767px) {
  .p-topPoint__list {
    grid-template-columns: repeat(1, 1fr);
  }
}
.p-topPoint__item {
  position: relative;
  margin-top: 50px;
  padding: 66px 32px 32px;
  border: 4px solid #333333;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .p-topPoint__item {
    margin-top: 40px;
    padding: 48px 24px 24px;
    border-width: 3px;
  }
}
.p-topPoint__point {
  position: absolute;
  top: -50px;
  left: 0;
  right: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100px;
  height: 100px;
  margin: auto;
  padding-top: 16px;
  background-color: #fff;
  border-radius: 100px;
  border: 4px solid #333333;
  text-align: center;
  font-family: "Josefin Sans", serif;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0;
}
@media screen and (max-width: 767px) {
  .p-topPoint__point {
    top: -40px;
    width: 80px;
    height: 80px;
    border-radius: 80px;
    border-width: 3px;
    font-size: 12px;
  }
}
.p-topPoint__point span {
  display: block;
  margin-top: -8px;
  font-size: 56px;
  font-weight: 400;
}
@media screen and (max-width: 767px) {
  .p-topPoint__point span {
    font-size: 46px;
  }
}
.p-topPoint__img {
  display: block;
  width: auto;
  height: 180px;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .p-topPoint__img {
    height: 150px;
  }
}

.p-topCase {
  margin: 40px;
  padding: 64px 40px;
  background-color: #fff;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .p-topCase {
    margin: 20px;
    padding: 40px 16px;
  }
}
.p-topCase__inner {
  position: relative;
  max-width: 1000px;
  margin: auto;
}
.p-topCase__inner::after {
  content: "";
  position: absolute;
  bottom: -16%;
  right: -8%;
  width: 21.7%;
  padding-top: 30.4%;
  background: url(../img/top/kobaton2.png) no-repeat center/cover;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .p-topCase__inner::after {
    bottom: -14%;
    width: 27.272%;
    padding-top: 38.256%;
  }
}
.p-topCase__image {
  display: block;
  width: 90%;
  margin: auto;
}

.p-topBenefits {
  position: relative;
  padding-block: 64px;
  background-color: #fff;
}
@media screen and (max-width: 767px) {
  .p-topBenefits {
    padding-block: 40px;
  }
}
.p-topBenefits__icon {
  width: 180px;
  height: 180px;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .p-topBenefits__icon {
    width: 130px;
    height: 130px;
  }
}
.p-topBenefits__heading {
  text-align: center;
  font-size: 56px;
  letter-spacing: 0.11em;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-topBenefits__heading {
    font-size: 32px;
  }
}
.p-topBenefits__heading span {
  font-size: 40px;
}
@media screen and (max-width: 767px) {
  .p-topBenefits__heading span {
    font-size: 24px;
  }
}
.p-topBenefits__heading strong {
  display: inline-block;
  padding: 8px;
  border: 6px solid #333333;
  border-radius: 10px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-topBenefits__heading strong {
    border-width: 3px;
  }
}
.p-topBenefits__read {
  margin-top: 24px;
  text-align: center;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-topBenefits__read {
    font-size: 16px;
  }
}
.p-topBenefits__read span {
  display: inline-block;
}
.p-topBenefits__read strong {
  color: #E97337;
  font-weight: 700;
}
.p-topBenefits__logo {
  margin-top: 16px;
  text-align: center;
}
.p-topBenefits__logo img {
  width: auto;
  height: 70px;
}
@media screen and (max-width: 767px) {
  .p-topBenefits__logo img {
    height: 50px;
  }
}
.p-topBenefits__title {
  display: flex;
  justify-content: center;
  gap: 32px;
  margin-top: 24px;
  text-align: center;
  font-size: 32px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-topBenefits__title {
    gap: 16px;
    font-size: 20px;
  }
}
.p-topBenefits__title::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 48px;
  background-color: #333333;
  border-radius: 4px;
  transform: rotate(-30deg);
}
@media screen and (max-width: 767px) {
  .p-topBenefits__title::before {
    height: 32px;
    width: 3px;
  }
}
.p-topBenefits__title::after {
  content: "";
  display: inline-block;
  width: 4px;
  height: 48px;
  background-color: #333333;
  border-radius: 4px;
  transform: rotate(30deg);
}
@media screen and (max-width: 767px) {
  .p-topBenefits__title::after {
    height: 32px;
    width: 3px;
  }
}
.p-topBenefits__attr {
  margin-top: 32px;
  text-align: center;
  font-size: 12px;
  line-height: 1.75;
}
.p-topBenefits__attr span {
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .p-topBenefits__attr {
    margin-top: 24px;
  }
}

.p-vr {
  position: relative;
  width: 100%;
  margin-top: 24px;
  padding-top: 56.8%;
  background: url(../img/top/bg-pc.svg) no-repeat center/cover;
}
@media screen and (max-width: 767px) {
  .p-vr {
    background: none;
    border: 3px solid #333333;
    border-radius: 10px;
  }
}
.p-vr__inner {
  position: absolute;
  top: 32px;
  left: 40px;
  width: calc(100% - 80px);
  height: calc(77% - 32px);
  border: 6px solid #333333;
}
@media screen and (max-width: 767px) {
  .p-vr__inner {
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: calc(100% - 24px);
    height: calc(100% - 16px);
    margin: auto;
    border: none;
  }
}

.p-topPlan {
  position: relative;
  padding: 64px 56px;
  background-color: #F7F2E7;
  border-radius: 20px;
}
@media screen and (max-width: 767px) {
  .p-topPlan {
    padding: 32px 24px;
  }
}
.p-topPlan::before {
  content: "";
  position: absolute;
  top: -7%;
  left: 4%;
  width: 14.5%;
  padding-top: 17.929%;
  background: url(../img/top/kabu.svg) no-repeat center/cover;
}
@media screen and (max-width: 767px) {
  .p-topPlan::before {
    top: -3.5%;
    width: 16.176%;
    padding-top: 20%;
  }
}
.p-topPlan::after {
  content: "";
  position: absolute;
  bottom: -3.5%;
  right: 4%;
  width: 7.371%;
  padding-top: 12.738%;
  background: url(../img/top/kuwai.svg) no-repeat center/cover;
}
@media screen and (max-width: 767px) {
  .p-topPlan::after {
    bottom: -2%;
    width: 9.936%;
    padding-top: 17.1706667%;
  }
}
.p-topPlan__heading {
  text-align: center;
  font-size: 28px;
  font-weight: 700;
  line-height: 1.5;
}
.p-topPlan__heading span {
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .p-topPlan__heading {
    font-size: 18px;
  }
}
.p-topPlan__read {
  margin-top: 16px;
  text-align: center;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .p-topPlan__read {
    margin-top: 8px;
    font-size: 12px;
  }
}
.p-topPlan__block {
  display: flex;
  gap: 8%;
  margin-top: 48px;
}
@media screen and (max-width: 767px) {
  .p-topPlan__block {
    flex-direction: column;
    gap: 16px;
    margin-top: 24px;
  }
}
.p-topPlan__image {
  width: 40%;
}
@media screen and (max-width: 767px) {
  .p-topPlan__image {
    width: 85%;
    margin: auto;
  }
}
.p-topPlan__contents {
  flex: 1;
  align-self: center;
}
.p-topPlan__title {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  max-width: 100%;
  margin: auto;
  padding: 16px 40px;
  background-color: #fff;
  border: 4px solid #333333;
  border-bottom: none;
  border-radius: 10px 10px 0 0;
  font-size: 20px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-topPlan__title {
    padding: 16px 24px;
    border-width: 3px;
    font-size: 18px;
  }
}
.p-topPlan__list {
  padding: 32px;
  background-color: #fff;
  border: 4px solid #333333;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .p-topPlan__list {
    padding: 24px 16px;
    border-width: 3px;
  }
}
.p-topPlan__item {
  display: flex;
  gap: 16px;
}
@media screen and (max-width: 767px) {
  .p-topPlan__item {
    gap: 8px;
  }
}
.p-topPlan__item + .p-topPlan__item {
  margin-top: 24px;
}
@media screen and (max-width: 767px) {
  .p-topPlan__item + .p-topPlan__item {
    margin-top: 16px;
  }
}
.p-topPlan__num {
  flex-shrink: 0;
  width: 33px;
  text-align: center;
  font-family: "Josefin Sans", serif;
  font-size: 28px;
  letter-spacing: 0;
}
@media screen and (max-width: 767px) {
  .p-topPlan__num {
    width: 24px;
    font-size: 20px;
  }
}
.p-topPlan__textBox {
  flex: 1;
}
.p-topPlan__name {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-topPlan__name {
    font-size: 14px;
  }
}
.p-topPlan__text {
  margin-top: 4px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-topPlan__text {
    font-size: 12px;
  }
}
.p-topPlan__title-small {
  margin-top: 56px;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-topPlan__title-small {
    margin-top: 24px;
    font-size: 12px;
  }
}
.p-topPlan__attr {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  margin: 16px auto 0;
  padding-left: 1em;
  text-indent: -1em;
  text-align: left;
  font-size: 14px;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .p-topPlan__attr {
    width: 100%;
    font-size: 12px;
  }
}

.p-topStep__list {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 40px;
}
.p-topStep__item {
  display: flex;
  background-color: #fff;
  padding: 32px 40px 32px 56px;
  border: 4px solid #333333;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .p-topStep__item {
    flex-wrap: wrap;
    padding: 24px;
  }
}
.p-topStep__num {
  align-self: center;
  width: 60px;
  text-align: center;
  font-family: "Josefin Sans", serif;
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0;
}
.p-topStep__num span {
  display: block;
  margin-top: -6px;
  font-size: 50px;
  font-weight: 400;
}
.p-topStep__image {
  align-self: center;
  flex-shrink: 0;
  display: block;
  width: 137px;
  margin-inline: 56px 40px;
}
@media screen and (max-width: 767px) {
  .p-topStep__image {
    margin: auto;
  }
}
@media screen and (max-width: 767px) {
  .p-topStep__textBox {
    width: 100%;
    margin-top: -16px;
  }
}
.p-topStep__text {
  margin-top: 16px;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-topStep__text {
    margin-top: 8px;
    font-size: 14px;
  }
}

.p-topVoice {
  position: relative;
  padding: 64px 0;
  background-color: #fff;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .p-topVoice {
    padding-block: 40px;
  }
}
.p-topVoice__inner {
  position: relative;
}
.p-topVoice__inner::before {
  content: "";
  position: absolute;
  top: 4%;
  right: -10px;
  width: 14.2768519%;
  padding-top: 19.3185185%;
  background: url(../img/top/shirona.svg) no-repeat center/cover;
}
@media screen and (max-width: 767px) {
  .p-topVoice__inner::before {
    content: none;
  }
}
.p-topVoice__item {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 40px;
  padding: 40px;
  background-color: #fff;
  border: 4px solid #333333;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .p-topVoice__item {
    gap: 16px;
    padding: 24px;
  }
}
.p-topVoice__item + .p-topVoice__item {
  margin-top: 16px;
}
.p-topVoice__icon {
  width: 120px;
  height: 120px;
  border-radius: 120px;
  border: 4px solid #333333;
}
@media screen and (max-width: 767px) {
  .p-topVoice__icon {
    width: 70px;
    height: 70px;
    border-width: 3px;
  }
}
.p-topVoice__title {
  align-self: center;
  flex: 1;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-topVoice__title {
    font-size: 18px;
  }
}
.p-topVoice__text {
  width: 100%;
  font-size: 18px;
  font-weight: 500;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .p-topVoice__text {
    font-size: 14px;
  }
}

.p-topSupport {
  position: relative;
  padding-bottom: 80px;
}
.p-topSupport::before {
  content: "";
  position: absolute;
  top: -32%;
  left: -40px;
  width: 23.362963%;
  padding-top: 29.9685185%;
  background: url(../img/top/negiimo.svg) no-repeat center/cover;
}
@media screen and (max-width: 767px) {
  .p-topSupport::before {
    content: none;
  }
}
.p-topSupport__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-block: 64px 56px;
}
@media screen and (max-width: 767px) {
  .p-topSupport__list {
    grid-template-columns: repeat(1, 1fr);
    margin-block: 24px 40px;
  }
}
.p-topSupport__item {
  padding: 16px 24px 32px;
  background-color: #fff;
  border: 4px solid #333333;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .p-topSupport__item {
    padding: 8px 24px 16px;
    border-width: 3px;
  }
}

.rotate {
  -webkit-animation: anime-rotate 15s linear infinite;
          animation: anime-rotate 15s linear infinite;
  transform-origin: 50% 50%;
}

@-webkit-keyframes anime-rotate {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

@keyframes anime-rotate {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
.p-chat__contents {
  margin-top: 80px;
}
@media screen and (max-width: 767px) {
  .p-chat__contents {
    margin-top: 64px;
  }
}
.p-chat__contents + .p-choice__item {
  margin-top: 24px;
}
@media screen and (max-width: 767px) {
  .p-chat__contents + .p-choice__item {
    margin-top: 16px;
  }
}
.p-chat__msg {
  display: flex;
  gap: 24px;
  align-items: center;
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  .p-chat__msg {
    gap: 8px;
    margin-bottom: 24px;
  }
}
.p-chat__msg img {
  width: 72px;
  height: 72px;
}
@media screen and (max-width: 767px) {
  .p-chat__msg img {
    width: 48px;
    height: 48px;
  }
}
.p-chat__ballon {
  padding: 24px;
  background-color: #fff;
  border: 1px solid #333333;
  border-radius: 15px 15px 15px 0;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0;
}
@media screen and (max-width: 767px) {
  .p-chat__ballon {
    padding: 8px 16px;
    border-radius: 10px 10px 10px 0;
    font-size: 14px;
  }
}
.p-chat__ballon span {
  color: #F49584;
  font-weight: 700;
}
.p-chat__title {
  display: inline-block;
  margin-bottom: 8px;
}
@media screen and (max-width: 767px) {
  .p-chat__title {
    font-size: 14px;
  }
}
.p-chat__title span {
  display: block;
  font-size: 12px;
  margin-top: 8px;
}
.p-chat__attr {
  margin-top: 8px;
  font-size: 12px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-chat__attr {
    font-size: 10px;
  }
}
.p-chat__attr ul {
  list-style: disc;
  margin-left: 1.5em;
}
.p-chat__buttonWrap {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-top: 56px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-chat__buttonWrap {
    margin-top: 40px;
  }
}

.p-choice__item {
  padding: 24px;
  background-color: #fff;
  border: 3px solid #333333;
  border-radius: 10px;
}
.p-choice__item + .p-choice__item {
  margin-top: 24px;
}
@media screen and (max-width: 767px) {
  .p-choice__item + .p-choice__item {
    margin-top: 16px;
  }
}
.p-choice__area {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16PX;
}
.p-choice__area li {
  padding: 4px 8px;
  border: 1px solid #333333;
  border-radius: 5px;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 767px) {
  .p-choice__area li {
    font-size: 10px;
  }
}
.p-choice__grid {
  display: flex;
  gap: 24px;
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .p-choice__grid {
    flex-direction: column;
    gap: 16px;
  }
}
.p-choice__grid img {
  align-self: start;
  width: 40%;
}
@media screen and (max-width: 767px) {
  .p-choice__grid img {
    width: 100%;
  }
}
.p-choice__textBox {
  flex: 1;
}
.p-choice__copy {
  font-size: 18px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-choice__copy {
    font-size: 14px;
  }
}
.p-choice__read {
  margin-top: 16px;
  font-size: 16px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-choice__read {
    margin-top: 8px;
    font-size: 12px;
  }
}
.p-choice__button {
  margin-top: 24px;
  text-align: center;
}
.p-choice__fixed {
  position: fixed;
  right: 5vw;
  bottom: 5vw;
  display: inline-block;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .p-choice__fixed {
    right: 0;
    bottom: 0;
    width: 100%;
  }
}
.p-choice__fixed::before {
  content: "+";
  position: absolute;
  top: 8px;
  left: 0;
  right: 0;
  width: 24px;
  height: 24px;
  margin: auto;
  background-color: #fff;
  color: #E97337;
  border-radius: 24px;
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0;
}
@media screen and (max-width: 767px) {
  .p-choice__fixed::before {
    top: 0;
    bottom: 0;
    left: auto;
    right: calc(50% - 110px);
    width: 18px;
    height: 18px;
    font-size: 16px;
    line-height: 16px;
  }
}
.p-choice__fixed button {
  width: 140px;
  height: 140px;
  padding: 40px 16px 24px;
  background-color: #E97337;
  color: #fff;
  border-radius: 200px;
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-choice__fixed button {
    width: 100%;
    height: auto;
    padding: 24px;
    border-radius: 0;
    font-size: 14px;
    letter-spacing: 0.1em;
  }
}
.p-choice__vr {
  margin-top: 16px;
  font-weight: 500;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-choice__vr {
    font-size: 14px;
  }
}
.p-choice__attr {
  margin-top: 24px;
  font-size: 12px;
  line-height: 1.7;
}
@media screen and (max-width: 767px) {
  .p-choice__attr {
    margin-top: 16px;
    font-size: 10px;
  }
}
.p-choice__select {
  text-align: center;
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  .p-choice__select {
    margin-bottom: 24px;
  }
}
.p-choice__select button {
  width: 400px;
  padding: 24px 40px;
  background-color: #E97337;
  color: #fff;
  border-radius: 5px;
  font-size: 18px;
  letter-spacing: 0.1em;
  font-weight: 500;
  transition: 0.3s opacity;
}
@media (hover: hover) and (pointer: fine) {
  .p-choice__select button:hover {
    opacity: 0.8;
  }
}
@media screen and (max-width: 767px) {
  .p-choice__select button {
    max-width: 90%;
    padding: 16px;
    font-size: 16px;
  }
}
.p-choice__name {
  display: block;
  margin: -24px -24px 24px -24px;
  padding: 16px 24px;
  background-color: #f9d2cb;
  border-radius: 7px 7px 0 0;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-choice__name {
    font-size: 16px;
  }
}

.p-company__heading {
  padding: 80px;
  text-align: center;
  background-color: #F49584;
  color: #fff;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-company__heading {
    padding: 48px 20px;
    font-size: 24px;
  }
}
.p-company__nav {
  display: flex;
  max-width: 1000px;
  margin: 64px auto 0;
}
.p-company__navItem {
  width: 100%;
}
.p-company__navItem.is-active {
  padding: 16px;
  background-color: #fff;
  color: #F49584;
  border-top: 3px solid #F49584;
  text-align: center;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-company__navItem.is-active {
    border-width: 2px;
    font-size: 14px;
  }
}
.p-company__navItem a {
  display: block;
  width: 100%;
  height: 100%;
  padding: 16px;
  background-color: #e8e8e8;
  color: #afafaf;
  text-align: center;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-company__navItem a {
    font-size: 14px;
  }
}
.p-company__body {
  margin-bottom: -80px;
  padding-block: 48px 56px;
  background-color: #fff;
}
.p-company__grid {
  display: flex;
  gap: 48px;
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .p-company__grid {
    flex-direction: column;
    gap: 16px;
  }
}
.p-company__grid img {
  align-self: start;
  width: 45%;
}
@media screen and (max-width: 767px) {
  .p-company__grid img {
    width: 100%;
  }
}
.p-company__textBox {
  flex: 1;
}
.p-company__copy {
  font-size: 20px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-company__copy {
    font-size: 18px;
  }
}
.p-company__read {
  margin-top: 16px;
  font-size: 16px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-company__read {
    margin-top: 16px;
    font-size: 14px;
  }
}
.p-company__info {
  display: flex;
  gap: 40px;
  padding: 24px;
  border-bottom: 1px solid #ccc;
}
@media screen and (max-width: 767px) {
  .p-company__info {
    flex-direction: column;
    gap: 8px;
    padding: 16px 8px;
  }
}
.p-company__info:nth-child(odd) {
  background-color: #FFFDF6;
}
.p-company__info dt {
  flex-shrink: 0;
  width: 150px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-company__info dt {
    width: 100%;
    font-size: 14px;
  }
}
.p-company__info dd {
  flex: 1;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-company__info dd {
    font-size: 14px;
  }
}
.p-company__swiper {
  margin-top: 40px;
}
.p-company__thumbs {
  margin-top: 24px;
}
.p-company__privacy {
  height: 300px;
  padding: 32px;
  background-color: #fff;
  overflow-y: auto;
}
@media screen and (max-width: 767px) {
  .p-company__privacy {
    height: 250px;
    padding: 24px 16px;
  }
}

.p-point__list {
  display: grid;
  gap: 32px;
  grid-template-columns: repeat(3, 1fr);
}
@media screen and (max-width: 767px) {
  .p-point__list {
    gap: 16px 8px;
    grid-template-columns: repeat(2, 1fr);
  }
}
.p-point__item figcaption {
  margin-top: 8px;
  font-size: 14px;
  line-height: 1.5;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .p-point__item figcaption {
    font-size: 12px;
  }
}

.p-privacy__title {
  margin-bottom: 8px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5;
}
.p-privacy__text {
  font-size: 14px;
  line-height: 1.75;
}
.p-privacy__text + .p-privacy__title {
  margin-top: 24px;
}
.p-privacy__text + .p-privacy__text {
  margin-top: 16px;
}
.p-privacy__list {
  padding-left: 1.5em;
  font-size: 14px;
  line-height: 1.75;
  text-indent: -1.5em;
}
.p-privacy__list + .p-privacy__title {
  margin-top: 24px;
}

.p-ad__hero {
  position: relative;
  padding: 180px 80px;
}
@media screen and (max-width: 767px) {
  .p-ad__hero {
    padding: 88px 20px;
  }
}
.p-ad__read {
  position: absolute;
  top: 32px;
  left: 32px;
  font-size: 10px;
}
@media screen and (max-width: 767px) {
  .p-ad__read {
    top: 16px;
    left: 20px;
  }
}
.p-ad__heading {
  text-align: center;
  font-size: 50px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-ad__heading {
    font-size: 32px;
  }
}
.p-ad__title {
  margin-bottom: 40px;
  text-align: center;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.5;
}
.p-ad__title span {
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .p-ad__title {
    margin-bottom: 32px;
    font-size: 24px;
  }
}
.p-ad__text {
  text-align: center;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.75;
}
.p-ad__text span {
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .p-ad__text {
    font-size: 16px;
  }
}
.p-ad__form {
  margin-top: 64px;
}
@media screen and (max-width: 767px) {
  .p-ad__form {
    margin-top: 48px;
  }
}
.p-ad__privacy {
  height: 300px;
  margin-top: 64px;
  padding: 32px;
  background-color: #FFFDF6;
  border: 1px solid #ccc;
  overflow-y: auto;
}
@media screen and (max-width: 767px) {
  .p-ad__privacy {
    margin-top: 48px;
    height: 250px;
    padding: 24px 16px;
  }
}
.p-ad__bottom {
  margin-bottom: -80px;
}

.p-adMessage {
  position: relative;
  margin-bottom: 115px;
  padding-block: 64px;
  background-color: #fff;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-adMessage {
    margin-bottom: 80px;
    padding-block: 56px;
  }
}
.p-adMessage::after {
  content: "";
  position: absolute;
  bottom: -40px;
  left: 50%;
  border-top: 40px solid #fff;
  border-left: 40px solid transparent;
  border-right: 40px solid transparent;
  transform: translateX(-50%);
}

.p-adPoint {
  position: relative;
  margin-top: 32px;
  padding: 88px 0 64px;
  background-color: #fff;
}
.p-adPoint::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100px;
  height: 50px;
  margin: auto;
  border-top: 40px solid #F7F2E7;
  border-left: 50px solid transparent;
  border-right: 50px solid transparent;
}
.p-adPoint__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px 40px;
}
@media screen and (max-width: 767px) {
  .p-adPoint__list {
    grid-template-columns: repeat(1, 1fr);
  }
}
.p-adPoint__item {
  position: relative;
  margin-top: 50px;
  padding: 66px 32px 32px;
  background-color: #fff;
  border: 4px solid #333333;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .p-adPoint__item {
    margin-top: 40px;
    padding: 48px 24px 24px;
    border-width: 3px;
  }
}
.p-adPoint__point {
  position: absolute;
  top: -50px;
  left: 0;
  right: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100px;
  height: 100px;
  margin: auto;
  padding-top: 16px;
  background-color: #fff;
  border-radius: 100px;
  border: 4px solid #333333;
  text-align: center;
  font-family: "Josefin Sans", serif;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0;
}
@media screen and (max-width: 767px) {
  .p-adPoint__point {
    top: -40px;
    width: 80px;
    height: 80px;
    border-radius: 80px;
    border-width: 3px;
    font-size: 12px;
  }
}
.p-adPoint__point span {
  display: block;
  margin-top: -8px;
  font-size: 56px;
  font-weight: 400;
}
@media screen and (max-width: 767px) {
  .p-adPoint__point span {
    font-size: 46px;
  }
}
.p-adPoint__img {
  display: block;
  width: auto;
  height: 180px;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .p-adPoint__img {
    height: 150px;
  }
}
.p-adPoint__text {
  margin-top: 16px;
  font-size: 18px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-adPoint__text {
    font-size: 16px;
  }
}

.p-lp {
  background-color: #fff;
}
.p-lp__heading {
  text-align: center;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.5;
}
.p-lp__heading span {
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .p-lp__heading {
    font-size: 20px;
  }
}
@media screen and (max-width: 767px) {
  .p-lp__heading--comp {
    font-size: 18px;
  }
}
.p-lp__marker {
  padding-bottom: 3px;
  font-weight: 700;
  background: linear-gradient(#FD908E, #FD908E) 0 100%/100% 3px no-repeat;
}
.p-lp__list {
  display: flex;
  gap: 24px;
  margin-top: 56px;
}
@media screen and (max-width: 767px) {
  .p-lp__list {
    flex-direction: column;
    gap: 28px;
    margin-top: 40px;
  }
}
.p-lp__item {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 0 16px 16px;
  background-color: #fff;
  text-align: center;
}
.p-lp__item img {
  width: 64px;
  margin-top: -32px;
}
@media screen and (max-width: 767px) {
  .p-lp__item img {
    width: 40px;
    margin-top: -20px;
  }
}
.p-lp__itemText {
  margin: auto;
  font-size: 16px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lp__itemText {
    font-size: 14px;
  }
}
.p-lp__itemText span {
  font-size: 18px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lp__itemText span {
    font-size: 16px;
  }
}

.p-lpHero {
  position: relative;
  padding-top: 56px;
  z-index: 0;
  overflow: hidden;
}
.p-lpHero::after {
  content: "";
  position: absolute;
  top: 0;
  width: 100%;
  aspect-ratio: 2.625/1; /* 幅に対して高さが1/2の比率 */
  background-color: #FCF7F1;
  border-bottom-left-radius: 100% 100%;
  border-bottom-right-radius: 100% 100%;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  overflow: hidden;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-lpHero::after {
    top: 50vw;
    aspect-ratio: 2.25/1;
  }
}
@media screen and (max-width: 767px) {
  .p-lpHero::before {
    content: "";
    position: absolute;
    top: 0;
    width: 100%;
    height: 50vw;
    background-color: #FCF7F1;
    z-index: -1;
  }
}
.p-lpHero__logo {
  position: absolute;
  top: 32px;
  left: 32px;
}
@media screen and (max-width: 767px) {
  .p-lpHero__logo {
    top: 16px;
    left: 16px;
  }
}
.p-lpHero__logo img {
  width: auto;
  height: 44px;
}
@media screen and (max-width: 767px) {
  .p-lpHero__logo img {
    height: 22px;
  }
}
.p-lpHero__inner {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .p-lpHero__inner {
    flex-direction: column;
  }
}
.p-lpHero__textBlock {
  position: absolute;
  flex: 1;
  align-self: center;
  padding-left: 5.555555556vw;
}
@media screen and (max-width: 767px) {
  .p-lpHero__textBlock {
    position: relative;
    align-self: flex-start;
    width: 100%;
  }
}
.p-lpHero__textBlock::after {
  content: "";
  position: absolute;
  right: 0;
  top: -10vw;
  width: 13.19444444vw;
  padding-top: 12.15277778vw;
  background: url(../img/lp/hero-balloon.svg) no-repeat center/cover;
}
@media screen and (max-width: 767px) {
  .p-lpHero__textBlock::after {
    right: calc(50% - 42vw);
    top: -5vw;
    width: 28vw;
    height: 25.866666667vw;
  }
}
.p-lpHero__label {
  display: inline-block;
  padding: 16px 32px;
  background-color: #FD908E;
  color: #fff;
  border-radius: 5vw;
  font-size: 1.666666667vw;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lpHero__label {
    padding: 8px 16px;
    font-size: 3.733333333vw;
  }
}
.p-lpHero__label span {
  font-size: 2.22222222vw;
}
@media screen and (max-width: 767px) {
  .p-lpHero__label span {
    font-size: 4.8vw;
  }
  .p-lpHero__label span:nth-of-type(2) {
    font-size: 4.26666667vw;
  }
}
.p-lpHero__heading {
  margin-top: 1vw;
  margin-left: 8px;
  font-size: 3.88888888vw;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-lpHero__heading {
    margin-top: 8px;
    margin-left: 4px;
    font-size: 8vw;
    line-height: 1.375;
  }
}
.p-lpHero__heading strong {
  color: #E43D30;
  font-size: 5.25vw;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lpHero__heading strong {
    font-size: 9.6vw;
  }
}
.p-lpHero__read {
  margin-top: 16px;
  margin-left: 8px;
  font-size: 1.25vw;
  font-weight: 600;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 767px) {
  .p-lpHero__read {
    margin-top: 3vw;
    margin-left: 0;
    text-align: center;
    font-size: 3.2vw;
  }
}
.p-lpHero__image {
  width: 61.38888889%;
  margin-left: auto;
}
@media screen and (max-width: 767px) {
  .p-lpHero__image {
    width: 100%;
    margin-left: 6.5vw;
  }
}
.p-lpHero__benefits {
  margin-top: 40px;
  padding: 8px;
  background-color: #FD908E;
  color: #fff;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-lpHero__benefits {
    margin-top: 16px;
  }
}
.p-lpHero__benefits-text {
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 767px) {
  .p-lpHero__benefits-text {
    font-size: clamp(0.75rem, 0.511rem + 1.02vw, 1rem);
  }
}
.p-lpHero__benefits-text span {
  display: inline-block;
  margin-right: 16px;
  padding: 4px 8px;
  background-color: #fff;
  color: #FD908E;
  border-radius: 16px;
  font-size: 12px;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 767px) {
  .p-lpHero__benefits-text span {
    margin-right: 8px;
    font-size: 11px;
  }
}

.p-lpWorries {
  padding-block: 64px;
  background-color: #FFF6EB;
}
@media screen and (max-width: 767px) {
  .p-lpWorries {
    padding-block: 48px;
  }
}
.p-lpWorries__list {
  display: flex;
  gap: 24px;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-lpWorries__list {
    flex-direction: column;
    gap: 8px;
    margin-top: 24px;
  }
}
.p-lpWorries__item {
  width: 100%;
  padding: 24px;
  background-color: #fff;
  border: 1px solid #000;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .p-lpWorries__item {
    display: flex;
    gap: 5vw;
    padding: 16px;
    border-radius: 6px;
  }
}
.p-lpWorries__item img {
  display: block;
  width: 120px;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .p-lpWorries__item img {
    width: 26.58%;
  }
}
.p-lpWorries__text {
  text-align: center;
  font-weight: 500;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lpWorries__text {
    align-self: center;
    flex: 1;
    text-align: left;
    font-size: 14px;
  }
}
@media screen and (max-width: 767px) {
  .p-lpWorries__text span {
    font-size: 16px;
    font-weight: 700;
  }
}
.p-lpWorries__text span span {
  display: inline-block;
}

.p-lpMessage {
  padding-bottom: 16px;
}
.p-lpMessage__read {
  margin-top: 48px;
  text-align: center;
  font-size: 18px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lpMessage__read {
    margin-top: 32px;
    font-size: 14px;
  }
}

.p-lpStrong {
  position: relative;
  padding-bottom: 64px;
  background-color: #FFF3EF;
  z-index: 0;
}
@media screen and (max-width: 767px) {
  .p-lpStrong {
    padding-bottom: 48px;
  }
}
.p-lpStrong::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  aspect-ratio: 13/1;
  background-color: #fff;
  -webkit-clip-path: polygon(0 0, 100% 0%, 50% 100%);
          clip-path: polygon(0 0, 100% 0%, 50% 100%);
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-lpStrong::before {
    aspect-ratio: 7/1;
  }
}
.p-lpStrong__image {
  display: block;
  width: 600px;
  margin: 0 auto 48px;
}
@media screen and (max-width: 767px) {
  .p-lpStrong__image {
    width: 100%;
    max-width: 600px;
    margin-bottom: 32px;
  }
}

.p-lpPoint__copy {
  text-align: center;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__copy {
    font-size: 14px;
  }
}
.p-lpPoint__copy span {
  font-size: 48px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__copy span {
    font-size: 32px;
  }
}
.p-lpPoint__body {
  position: relative;
  margin-top: 48px;
  padding-block: 7rem;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__body {
    margin-top: 32px;
    padding-block: 16vw;
  }
}
.p-lpPoint__body::before {
  content: "";
  position: absolute;
  top: 0;
  width: 100%;
  aspect-ratio: 6/1; /* 幅に対して高さが1/2の比率 */
  background-color: #FFF6EB;
  border-top-left-radius: 100% 100%;
  border-top-right-radius: 100% 100%;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  overflow: hidden;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__body::before {
    aspect-ratio: 3/1;
  }
}
.p-lpPoint__body::after {
  content: "";
  position: absolute;
  bottom: 0;
  width: 100%;
  aspect-ratio: 6/1; /* 幅に対して高さが1/2の比率 */
  background-color: #FFF6EB;
  border-bottom-left-radius: 100% 100%;
  border-bottom-right-radius: 100% 100%;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  overflow: hidden;
  z-index: -1;
}
.p-lpPoint__label {
  width: 120px;
  margin: 0 auto 8px;
  padding: 10px 8px 6px;
  background-color: #FD908E;
  color: #fff;
  border-radius: 20px;
  font-family: "Josefin Sans", serif;
  text-align: center;
  font-size: 16px;
  font-weight: 600;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__label {
    width: 100px;
    font-size: 14px;
  }
}
.p-lpPoint__label span {
  font-size: 18px;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__label span {
    font-size: 16px;
  }
}
.p-lpPoint__image {
  display: block;
  width: 100%;
  max-width: 500px;
  margin: 40px auto 0;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__image {
    width: 73%;
    margin-top: 32px;
  }
}
.p-lpPoint__read {
  margin-top: 24px;
  text-align: center;
  font-size: 18px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__read {
    font-size: 14px;
  }
}
.p-lpPoint__read + .p-lpPoint__title {
  margin-top: 48px;
}
.p-lpPoint__read span {
  display: inline-block;
}
.p-lpPoint__block {
  width: 100%;
  max-width: 700px;
  margin: 40px auto 0;
  padding: 32px;
  background-color: #fff;
  border: 1px solid #000;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__block {
    padding: 24px;
  }
}
.p-lpPoint__title {
  position: relative;
  padding-bottom: 16px;
  text-align: center;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__title {
    padding-bottom: 8px;
    font-size: 18px;
  }
}
.p-lpPoint__title::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 40px;
  height: 3px;
  background-color: #FD908E;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__title::after {
    width: 32px;
    height: 3px;
  }
}
.p-lpPoint__list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 24px;
}
.p-lpPoint__item {
  position: relative;
  padding-bottom: 8px;
  padding-left: 32px;
  border-bottom: 2px dashed #e5e5e5;
  font-size: 18px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__item {
    padding-left: 28px;
    font-size: 14px;
  }
}
.p-lpPoint__item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 6px;
  width: 24px;
  height: 24px;
  background: url(../img/lp/icon-check.svg) no-repeat center/cover;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__item::before {
    top: 4px;
    width: 20px;
    height: 20px;
  }
}
.p-lpPoint__item span {
  font-size: 20px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__item span {
    font-size: 16px;
  }
}
.p-lpPoint__card {
  padding: 40px;
  background: #FCF9F7;
  border-radius: 8px;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__card {
    padding: 16px 24px;
  }
}
.p-lpPoint__card-block {
  display: flex;
  gap: 32px;
  align-items: center;
  padding-bottom: 24px;
  border-bottom: 1px solid #FD908E;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__card-block {
    gap: 16px;
    padding-bottom: 16px;
  }
}
.p-lpPoint__card-block img {
  align-self: flex-start;
  flex-shrink: 0;
  width: 220px;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__card-block img {
    width: 110px;
  }
}
.p-lpPoint__card-name {
  font-size: 18px;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__card-name {
    font-size: 12px;
  }
}
.p-lpPoint__card-read {
  margin-top: 8px;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__card-read {
    font-size: 14px;
  }
}
.p-lpPoint__card-read span {
  display: inline-block;
}
.p-lpPoint__swiper {
  position: relative;
  margin-top: 32px;
  padding-bottom: 24px;
}
.p-lpPoint__swiper .swiper-pagination {
  bottom: 0;
}
.p-lpPoint__swiper .swiper-pagination-bullet {
  background-color: #e5e5e5;
  opacity: 1;
}
.p-lpPoint__swiper .swiper-pagination-bullet-active {
  background-color: #FD908E;
}
.p-lpPoint__swiper .swiper-button-prev,
.p-lpPoint__swiper .swiper-button-next {
  height: 80px;
  width: 40px;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__swiper .swiper-button-prev,
.p-lpPoint__swiper .swiper-button-next {
    height: 48px;
    width: 24px;
  }
}
.p-lpPoint__swiper .swiper-button-prev {
  left: 0;
}
.p-lpPoint__swiper .swiper-button-next {
  right: 0;
}
.p-lpPoint__swiper .swiper-button-prev::after,
.p-lpPoint__swiper .swiper-button-next::after {
  content: "";
  height: 80px;
  margin: auto;
  width: 40px;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__swiper .swiper-button-prev::after,
.p-lpPoint__swiper .swiper-button-next::after {
    height: 48px;
    width: 24px;
  }
}
.p-lpPoint__swiper .swiper-button-prev::after {
  background: url(../img/lp/arrow-prev.svg) no-repeat center/cover;
}
.p-lpPoint__swiper .swiper-button-next::after {
  background: url(../img/lp/arrow-next.svg) no-repeat center/cover;
}

.p-lpPoint1 {
  padding-bottom: 64px;
  background-color: #FFF6EB;
}
@media screen and (max-width: 767px) {
  .p-lpPoint1 {
    padding-bottom: 48px;
  }
}

.p-lpPoint3 {
  padding-block: 64px;
  background-color: #FFF6EB;
}
@media screen and (max-width: 767px) {
  .p-lpPoint3 {
    padding-block: 48px;
  }
}

.p-lpPoint4 {
  padding-bottom: 16px;
}

.p-lpPoint__question {
  position: relative;
  padding-top: 10vw;
  background-color: #FFF6EB;
  z-index: 0;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__question {
    padding-top: 14vw;
  }
}
.p-lpPoint__question::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  aspect-ratio: 12/1;
  background-color: #fff;
  -webkit-clip-path: polygon(0 0, 100% 0%, 50% 100%);
          clip-path: polygon(0 0, 100% 0%, 50% 100%);
  z-index: -1;
}
.p-lpPoint__question-title {
  padding-bottom: 8px;
  background: url(../img/lp/bg-balloon.svg) no-repeat center/300px;
  text-align: center;
  font-size: 22px;
  font-weight: 700;
  line-height: 100px;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__question-title {
    background-size: 215px;
    margin-bottom: -8px;
    font-size: 18px;
    line-height: 60px;
  }
}
.p-lpPoint__question-read {
  margin-top: 48px;
  text-align: center;
  font-size: 20px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__question-read {
    font-size: 14px;
  }
}
.p-lpPoint__question-read span {
  font-size: 24px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lpPoint__question-read span {
    font-size: 16px;
  }
}

.p-lpCompare__table-wrap {
  width: 100%;
  overflow-x: auto;
}
.p-lpCompare__table {
  width: 100%;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-lpCompare__table {
    width: 500px;
  }
}
.p-lpCompare__table thead th {
  vertical-align: bottom;
  border-right: 1px solid #fff;
}
.p-lpCompare__table thead th div {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  height: 70px;
  padding: 8px;
  background-color: #FFF6EB;
}
@media screen and (max-width: 767px) {
  .p-lpCompare__table thead th div {
    font-size: 12px;
  }
}
.p-lpCompare__table thead th:nth-child(2) div {
  height: 80px;
  background-color: #FCC4B6;
}
.p-lpCompare__table tbody {
  border-top: 1px solid #e5e5e5;
}
.p-lpCompare__table tbody tr:last-child td:nth-of-type(1) div {
  height: 74px;
}
.p-lpCompare__table tbody th {
  display: flex;
  align-items: center;
  gap: 8px;
  height: 64px;
  padding-right: 8px;
  border-bottom: 1px solid #e5e5e5;
}
.p-lpCompare__table tbody th img {
  width: 32px;
  height: 32px;
}
@media screen and (max-width: 767px) {
  .p-lpCompare__table tbody th img {
    width: 22px;
    height: 22px;
  }
}
@media screen and (max-width: 767px) {
  .p-lpCompare__table tbody th span {
    font-size: 12px;
  }
}
.p-lpCompare__table tbody th span span {
  display: inline-block;
}
.p-lpCompare__table tbody td div {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  height: 64px;
  padding: 8px;
  border-bottom: 1px solid #e5e5e5;
  border-right: 1px solid #e5e5e5;
  text-align: center;
  letter-spacing: 0;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-lpCompare__table tbody td div {
    padding: 8px 4px;
    font-size: 12px;
  }
}
.p-lpCompare__table tbody td div span span {
  display: inline-block;
}
.p-lpCompare__table tbody td:nth-of-type(1) div {
  background-color: #FFF3EF;
  border-left: 1px solid #e5e5e5;
}

.p-lpRecommend {
  padding-block: 64px;
  background-color: #FFF6EB;
}

.p-lpStory__block {
  padding: 40px;
  background-color: #FFF3EF;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .p-lpStory__block {
    padding: 32px 24px;
  }
}
.p-lpStory__heading {
  padding-left: 24px;
  border-left: 4px solid #FD908E;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-lpStory__heading {
    font-size: 14px;
  }
}
.p-lpStory__name {
  margin-top: 24px;
  text-align: right;
}
@media screen and (max-width: 767px) {
  .p-lpStory__name {
    font-size: 12px;
  }
}
.p-lpStory__textBlock {
  position: relative;
  height: 254px;
  overflow: hidden;
  margin-top: 32px;
}
.p-lpStory__textBlock::before {
  position: absolute;
  display: block;
  content: "";
  bottom: 0;
  left: 0;
  width: 100%;
  height: 75px;
  background: linear-gradient(rgba(255, 243, 239, 0) 0%, rgba(255, 243, 239, 0.5) 50%, #FFF3EF 100%);
}
.p-lpStory__textBlock::after {
  content: "";
  display: block;
  clear: both;
}
.p-lpStory__textBlock img {
  float: right;
  width: 45%;
  max-width: 350px;
  margin-left: 32px;
  border-radius: 8px;
}
@media screen and (max-width: 767px) {
  .p-lpStory__textBlock img {
    width: 40%;
    min-width: 140px;
    margin-left: 16px;
  }
}
.p-lpStory__text {
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lpStory__text {
    font-size: 12px;
  }
}
.p-lpStory__text b {
  font-size: 18px;
}
@media screen and (max-width: 767px) {
  .p-lpStory__text b {
    font-size: 12px;
  }
}
.p-lpStory__readmore {
  position: relative;
  padding-bottom: 72px;
}
@media screen and (max-width: 767px) {
  .p-lpStory__readmore {
    padding-bottom: 40px;
  }
}
.p-lpStory__readmore input[type=checkbox] {
  display: none;
}
.p-lpStory__readmore input[type=checkbox]:checked ~ label::before {
  content: "閉じる　ー";
}
.p-lpStory__readmore input[type=checkbox]:checked ~ .p-lpStory__textBlock {
  height: auto;
}
.p-lpStory__readmore input[type=checkbox]:checked ~ .p-lpStory__textBlock::before {
  content: none;
}
.p-lpStory__button {
  position: absolute;
  bottom: 0;
  left: 50%;
  translate: -50% 0;
}
.p-lpStory__button::before {
  content: "もっと見る ＋";
  display: block;
  width: 200px;
  padding: 16px 8px;
  background-color: #FD908E;
  color: #fff;
  border-radius: 4px;
  text-align: center;
  font-weight: 600;
}
@media screen and (max-width: 767px) {
  .p-lpStory__button::before {
    width: 120px;
    padding: 8px 16px;
    font-size: 12px;
  }
}
.p-lpStory__swiper {
  position: relative;
  margin-top: 48px;
  padding-bottom: 24px;
}
@media screen and (max-width: 767px) {
  .p-lpStory__swiper {
    margin-top: 24px;
  }
}
.p-lpStory__swiper .swiper-button-prev,
.p-lpStory__swiper .swiper-button-next {
  top: 194px;
  margin: 0;
  height: 80px;
  width: 40px;
}
@media screen and (max-width: 767px) {
  .p-lpStory__swiper .swiper-button-prev,
.p-lpStory__swiper .swiper-button-next {
    top: 193.5px;
    height: 48px;
    width: 24px;
  }
}
.p-lpStory__swiper .swiper-button-prev {
  left: 0;
}
.p-lpStory__swiper .swiper-button-next {
  right: 0;
}
.p-lpStory__swiper .swiper-button-prev::after,
.p-lpStory__swiper .swiper-button-next::after {
  content: "";
  height: 80px;
  margin: auto;
  width: 40px;
}
@media screen and (max-width: 767px) {
  .p-lpStory__swiper .swiper-button-prev::after,
.p-lpStory__swiper .swiper-button-next::after {
    height: 48px;
    width: 24px;
  }
}
.p-lpStory__swiper .swiper-button-prev::after {
  background: url(../img/lp/arrow-prev.svg) no-repeat center/cover;
}
.p-lpStory__swiper .swiper-button-next::after {
  background: url(../img/lp/arrow-next.svg) no-repeat center/cover;
}

.p-lpBenefits {
  padding-block: 64px;
  background-color: #FFF6EB;
}
@media screen and (max-width: 767px) {
  .p-lpBenefits {
    padding-block: 48px;
  }
}
.p-lpBenefits__read {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 32px auto 0;
  padding-inline: 110px;
  background: url(../img/lp/deco01.svg) no-repeat left/60px, url(../img/lp/deco02.svg) no-repeat right/60px;
  text-align: center;
  font-size: 20px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lpBenefits__read {
    margin-top: 24px;
    padding-inline: 40px;
    background-size: 34px;
    font-size: 14px;
  }
}
.p-lpBenefits__read b {
  font-size: 24px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lpBenefits__read b {
    font-size: 16px;
  }
}
.p-lpBenefits__heading {
  margin-top: 40px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-lpBenefits__heading {
    margin-top: 32px;
  }
}
.p-lpBenefits__heading span {
  display: inline-block;
  padding: 8px 16px;
  background-color: #fff;
  border: 1px solid #000;
  border-radius: 20px;
  font-size: 20px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lpBenefits__heading span {
    font-size: 12px;
  }
}
.p-lpBenefits__block {
  display: flex;
  justify-content: center;
  gap: 24px;
  width: 100%;
  max-width: 600px;
  margin: 16px auto 0;
  padding: 24px;
  background-color: #fff;
  border: 1px solid #000;
  border-radius: 10px;
}
.p-lpBenefits__block img {
  width: 160px;
  align-self: flex-start;
}
@media screen and (max-width: 767px) {
  .p-lpBenefits__block img {
    width: 100px;
  }
}
.p-lpBenefits__textBlock {
  align-self: center;
}
.p-lpBenefits__title {
  font-size: 18px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lpBenefits__title {
    font-size: 14px;
  }
}
.p-lpBenefits__text {
  margin-top: 8px;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lpBenefits__text {
    font-size: 14px;
  }
}
.p-lpBenefits__text span {
  display: inline-block;
}

.p-lpStep__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px 24px;
  margin-top: 56px;
}
@media screen and (max-width: 767px) {
  .p-lpStep__list {
    grid-template-columns: repeat(2, 1fr);
    gap: 32px 8px;
  }
}
.p-lpStep__item {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 28px 24px 16px;
  background: #FFF3EF;
  border-radius: 8px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-lpStep__item {
    padding: 20px 4px 16px;
  }
}
.p-lpStep__item img {
  width: 80%;
  max-width: 200px;
  margin-top: 8px;
}
.p-lpStep__num {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 56px;
  height: 56px;
  margin: -56px auto 8px;
  padding-top: 6px;
  background-color: #FD908E;
  color: #fff;
  border-radius: 56px;
  font-family: "Josefin Sans", serif;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0;
}
@media screen and (max-width: 767px) {
  .p-lpStep__num {
    width: 40px;
    height: 40px;
    margin-top: -40px;
    font-size: 10px;
  }
}
.p-lpStep__num span {
  font-size: 18px;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .p-lpStep__num span {
    font-size: 14px;
  }
}
.p-lpStep__title {
  margin: auto;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
}
@media screen and (max-width: 767px) {
  .p-lpStep__title {
    font-size: 14px;
  }
}
.p-lpStep__title span {
  display: inline-block;
}

.p-lpForm {
  margin-top: 64px;
  padding-block: 64px;
  background-color: #FFF6EB;
}
.p-lpForm__body {
  margin-top: 32px;
}
.p-lpForm__text {
  margin-top: 32px;
  text-align: center;
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lpForm__text {
    font-size: 0.9rem;
  }
}
@media screen and (max-width: 767px) {
  .p-lpForm__text--comp {
    text-align: left;
  }
}

.p-lpThought {
  margin-top: 56px;
}
.p-lpThought img {
  display: block;
  width: 100%;
  max-width: 600px;
  margin: auto;
}
.p-lpThought__block {
  max-width: 700px;
  margin: -56px auto 0;
  padding: 72px 40px 32px;
  border: 1px solid #000;
  border-radius: 10px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-lpThought__block {
    margin-top: -40px;
    padding: 56px 24px 24px;
  }
}
.p-lpThought__read {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lpThought__read {
    font-size: 14px;
  }
}
.p-lpThought__read span {
  display: inline-block;
}
.p-lpThought__read .p-lp__marker {
  display: inline;
  font-size: 22px;
}
@media screen and (max-width: 767px) {
  .p-lpThought__read .p-lp__marker {
    font-size: 16px;
  }
}
.p-lpThought__text {
  margin-top: 16px;
  font-size: 18px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lpThought__text {
    font-size: 14px;
  }
}
.p-lpThought__text span {
  display: inline-block;
}

.p-lpCta {
  padding-top: 64px;
  background-color: #FD908E;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .p-lpCta {
    padding-top: 48px;
  }
}
.p-lpCta__block {
  display: flex;
  justify-content: center;
  gap: 24px 5%;
  flex-wrap: wrap;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .p-lpCta__textBlock {
    text-align: center;
  }
}
.p-lpCta__read {
  font-size: 16px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lpCta__read {
    font-size: 14px;
  }
}
.p-lpCta__heading {
  margin-top: 8px;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lpCta__heading {
    font-size: 20px;
  }
}
.p-lpCta__heading span {
  display: inline-block;
}
.p-lpCta__dorm {
  flex-shrink: 0;
  align-self: flex-end;
  position: relative;
  width: 480px;
  min-height: 240px;
  padding-left: 200px;
  z-index: 0;
  background: url(../img/lp/dorm.svg) no-repeat top/cover;
}
@media screen and (max-width: 767px) {
  .p-lpCta__dorm {
    width: 100%;
    max-width: 335px;
    min-height: 178px;
    margin: auto;
    padding-left: 134px;
  }
}
.p-lpCta__dorm img {
  position: absolute;
  bottom: 0;
  left: 10px;
  width: 206px;
}
@media screen and (max-width: 767px) {
  .p-lpCta__dorm img {
    left: 0;
    width: 154px;
  }
}
.p-lpCta__text {
  margin-left: -40px;
  margin-top: 60px;
  color: #000;
  font-size: 26px;
  font-weight: 700;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lpCta__text {
    margin-left: -40px;
    margin-top: 30px;
    font-size: 20px;
  }
}
.p-lpCta__text span {
  display: block;
  margin-left: 4rem;
}
@media screen and (max-width: 767px) {
  .p-lpCta__text span {
    margin-left: 2.125rem;
  }
}
.p-lpCta__wrap {
  margin-block: 24px;
}
@media screen and (max-width: 767px) {
  .p-lpCta__wrap {
    margin-bottom: 8px;
  }
}
.p-lpCta__button {
  position: relative;
  display: inline-block;
  width: 260px;
  padding: 16px 40px;
  background-color: #FD908E;
  border-radius: 5px;
  font-size: 18px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lpCta__button {
    width: 175px;
    padding: 12px 24px;
    font-size: 14px;
  }
}
.p-lpCta__button::after {
  content: "↗";
  position: absolute;
  top: 0;
  right: 8px;
  bottom: 0;
  width: 42px;
  height: 42px;
  margin: auto;
  background-color: #fff;
  color: #FD908E;
  border-radius: 42px;
  text-align: center;
  line-height: 40px;
}
@media screen and (max-width: 767px) {
  .p-lpCta__button::after {
    right: 4px;
    width: 32px;
    height: 32px;
    font-size: 14px;
    line-height: 30px;
  }
}

.p-lpFooter__inner {
  padding-block: 64px 32px;
  background-color: #EDE7E0;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-lpFooter__inner {
    padding-block: 48px 16px;
  }
}
.p-lpFooter__name {
  font-size: 18px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lpFooter__name {
    font-size: 14px;
  }
}
.p-lpFooter__text {
  margin-top: 16px;
  font-size: 16px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lpFooter__text {
    font-size: 12px;
  }
}
.p-lpFooter__map {
  position: relative;
  width: 100%;
  height: 300px;
  margin-top: 32px;
}
@media screen and (max-width: 767px) {
  .p-lpFooter__map {
    height: 200px;
  }
}
.p-lpFooter__map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.p-lpFooter__copy {
  text-align: center;
  background-color: #fff;
  padding: 16px 20px;
  font-size: 12px;
}

.p-lpFixed {
  position: fixed;
  bottom: 24px;
  width: 100%;
  z-index: 100;
  -webkit-animation: fluffy 3s infinite;
          animation: fluffy 3s infinite;
}
.p-lpFixed__button {
  position: relative;
  display: block;
  width: 400px;
  margin: auto;
  padding: 16px 24px;
  background-color: #FFDF4F;
  border-radius: 6px;
  border: 2px solid #333;
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .p-lpFixed__button {
    width: 90%;
    max-width: 320px;
    font-size: 18px;
  }
}
.p-lpFixed__button::before {
  content: "";
  position: absolute;
  top: -30px;
  left: -20px;
  width: 80px;
  height: 48px;
  background: url(../img/lp/free-balloon.svg) no-repeat center/cover;
}
@media screen and (max-width: 767px) {
  .p-lpFixed__button::before {
    top: -20px;
    left: -10px;
    width: 65px;
    height: 39px;
  }
}
.p-lpFixed__button::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 16px;
  width: 28px;
  height: 28px;
  margin: auto;
  background: url(../img/lp/icon-arrow.svg) no-repeat center/cover;
}
@media screen and (max-width: 767px) {
  .p-lpFixed__button::after {
    width: 24px;
    height: 24px;
  }
}

@-webkit-keyframes fluffy {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-7px);
  }
}

@keyframes fluffy {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-7px);
  }
}
.p-lp02 {
  background-color: #fff;
}
.p-lp02__header {
  display: flex;
  justify-content: space-between;
  gap: 40px;
  padding: 8px;
}
.p-lp02__logo img {
  width: auto;
  height: 48px;
}
@media screen and (max-width: 767px) {
  .p-lp02__logo img {
    height: 36px;
  }
}
.p-lp02__spot {
  align-self: center;
  padding: 8px 16px;
  background-color: #FFEC5F;
  border: 2px solid #333333;
  border-radius: 4px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lp02__spot {
    font-size: 0.875rem;
  }
}
.p-lp02__heading {
  text-align: center;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.5;
}
.p-lp02__heading span {
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .p-lp02__heading {
    font-size: 20px;
  }
}
@media screen and (max-width: 767px) {
  .p-lp02__heading--comp {
    font-size: 18px;
  }
}
.p-lp02__marker {
  display: inline !important;
  padding-bottom: 3px;
  font-weight: 700;
  background: linear-gradient(#FD908E, #FD908E) 0 100%/100% 3px no-repeat;
}
.p-lp02__list {
  display: flex;
  gap: 24px;
  margin-top: 56px;
}
@media screen and (max-width: 767px) {
  .p-lp02__list {
    flex-direction: column;
    gap: 28px;
    margin-top: 40px;
  }
}
.p-lp02__item {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 0 16px 16px;
  background-color: #fff;
  text-align: center;
}
.p-lp02__item img {
  width: 64px;
  margin-top: -32px;
}
@media screen and (max-width: 767px) {
  .p-lp02__item img {
    width: 40px;
    margin-top: -20px;
  }
}
.p-lp02__itemTitle {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lp02__itemTitle {
    font-size: 16px;
  }
}
.p-lp02__itemTitle span {
  display: inline-block;
}
.p-lp02__itemText {
  margin: auto;
  font-size: 16px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lp02__itemText {
    font-size: 14px;
  }
}
.p-lp02__itemText span {
  display: inline-block;
}
.p-lp02__itemText strong {
  font-size: 18px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lp02__itemText strong {
    font-size: 16px;
  }
}

.p-lp02Hero {
  position: relative;
  padding-top: 56px;
  z-index: 0;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .p-lp02Hero {
    padding-top: 8.533333333vw;
  }
}
.p-lp02Hero::after {
  content: "";
  position: absolute;
  top: 0;
  width: 100%;
  aspect-ratio: 2.625/1; /* 幅に対して高さが1/2の比率 */
  background-color: #FCF7F1;
  border-bottom-left-radius: 100% 100%;
  border-bottom-right-radius: 100% 100%;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  overflow: hidden;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-lp02Hero::after {
    top: 50vw;
    aspect-ratio: 2.25/1;
  }
}
@media screen and (max-width: 767px) {
  .p-lp02Hero::before {
    content: "";
    position: absolute;
    top: 0;
    width: 100%;
    height: 50vw;
    background-color: #FCF7F1;
    z-index: -1;
  }
}
.p-lp02Hero__inner {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .p-lp02Hero__inner {
    flex-direction: column;
  }
}
.p-lp02Hero__textBlock {
  position: absolute;
  flex: 1;
  padding-left: 5.555555556vw;
}
@media screen and (max-width: 767px) {
  .p-lp02Hero__textBlock {
    position: relative;
    align-self: flex-start;
    width: 100%;
    padding-left: 0;
  }
}
.p-lp02Hero__label {
  display: inline-block;
  margin-top: 2.7777777778vw;
  padding: 8px 16px;
  background-color: #DD4247;
  color: #fff;
  border-radius: 5vw;
  font-size: 1.666666667vw;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lp02Hero__label {
    display: block;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 4.266666667vw auto 0;
    font-size: 3.733333333vw;
  }
}
.p-lp02Hero__heading {
  margin-top: 4px;
  font-size: 5vw;
  font-weight: 700;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .p-lp02Hero__heading {
    text-align: center;
    font-size: 8.53333333vw;
    line-height: 1.375;
  }
}
.p-lp02Hero__heading small {
  font-size: 0.77777778em;
}
.p-lp02Hero__heading strong {
  display: inline-block;
  padding: 4px 4px 10px;
  background-color: #fff;
  color: #DD4247;
  border: 2px solid #DD4247;
  border-radius: 4px;
  font-size: 1em;
  font-weight: 700;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .p-lp02Hero__heading strong {
    padding: 4px 4px 8px;
  }
}
.p-lp02Hero__read {
  font-size: 5vw;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lp02Hero__read {
    text-align: center;
    font-size: 8.53333333vw;
  }
}
.p-lp02Hero__read span {
  color: #DD4247;
}
.p-lp02Hero__read small {
  font-size: 0.77777778em;
}
.p-lp02Hero__list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 1.1vw;
}
@media screen and (max-width: 767px) {
  .p-lp02Hero__list {
    justify-content: center;
    width: 80%;
    margin: 4.266666667vw auto 0;
  }
}
.p-lp02Hero__item {
  padding: 4px 16px;
  background-color: #fff;
  border-radius: 10vw;
  font-size: 0.97222222vw;
  font-weight: 600;
}
@media screen and (max-width: 767px) {
  .p-lp02Hero__item {
    font-size: max(12px, 3.2vw);
  }
}
.p-lp02Hero__image {
  width: 57.0833333333%;
  margin-left: auto;
  margin-right: -2.5%;
}
@media screen and (max-width: 767px) {
  .p-lp02Hero__image {
    width: 98%;
    margin: 4.266666667vw auto 0;
  }
}
.p-lp02Hero__benefits {
  margin-top: 40px;
  padding: 8px 1.6vw;
  background-color: #FD908E;
  color: #fff;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-lp02Hero__benefits {
    margin-top: 16px;
  }
}
.p-lp02Hero__benefits-text {
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0;
}
@media screen and (max-width: 767px) {
  .p-lp02Hero__benefits-text {
    font-size: max(10px, 2.933333333vw);
  }
}
.p-lp02Hero__benefits-text span {
  display: inline-block;
  margin-right: 16px;
  padding: 4px 8px;
  background-color: #fff;
  color: #FD908E;
  border-radius: 16px;
  font-size: 12px;
  letter-spacing: 0;
}
@media screen and (max-width: 767px) {
  .p-lp02Hero__benefits-text span {
    margin-right: 1.066666667vw;
    font-size: 2.6666666667vw;
  }
}

.p-lp02Message {
  padding-bottom: 16px;
}
.p-lp02Message__read {
  margin-top: 48px;
  text-align: center;
  font-size: 18px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lp02Message__read {
    margin-top: 32px;
    font-size: 14px;
  }
}
.p-lp02Message__read span {
  display: inline-block;
}

.p-lp02Strong {
  position: relative;
  padding-bottom: 64px;
  background-color: #FFF3EF;
  z-index: 0;
}
@media screen and (max-width: 767px) {
  .p-lp02Strong {
    padding-bottom: 48px;
  }
}
.p-lp02Strong::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  aspect-ratio: 13/1;
  background-color: #fff;
  -webkit-clip-path: polygon(0 0, 100% 0%, 50% 100%);
          clip-path: polygon(0 0, 100% 0%, 50% 100%);
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-lp02Strong::before {
    aspect-ratio: 7/1;
  }
}
.p-lp02Strong__image {
  display: block;
  width: 600px;
  margin: 0 auto 48px;
}
@media screen and (max-width: 767px) {
  .p-lp02Strong__image {
    width: 100%;
    max-width: 600px;
    margin-bottom: 32px;
  }
}

.p-lp02Point__copy {
  text-align: center;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__copy {
    font-size: 14px;
  }
}
.p-lp02Point__copy span {
  font-size: 48px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__copy span {
    font-size: 32px;
  }
}
.p-lp02Point__body {
  position: relative;
  margin-top: 48px;
  padding-block: 7rem;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__body {
    margin-top: 32px;
    padding-block: 16vw;
  }
}
.p-lp02Point__body::before {
  content: "";
  position: absolute;
  top: 0;
  width: 100%;
  aspect-ratio: 6/1; /* 幅に対して高さが1/2の比率 */
  background-color: #FFF6EB;
  border-top-left-radius: 100% 100%;
  border-top-right-radius: 100% 100%;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  overflow: hidden;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__body::before {
    aspect-ratio: 3/1;
  }
}
.p-lp02Point__body::after {
  content: "";
  position: absolute;
  bottom: 0;
  width: 100%;
  aspect-ratio: 6/1; /* 幅に対して高さが1/2の比率 */
  background-color: #FFF6EB;
  border-bottom-left-radius: 100% 100%;
  border-bottom-right-radius: 100% 100%;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  overflow: hidden;
  z-index: -1;
}
.p-lp02Point__label {
  width: 120px;
  margin: 0 auto 8px;
  padding: 10px 8px 6px;
  background-color: #FD908E;
  color: #fff;
  border-radius: 20px;
  font-family: "Josefin Sans", serif;
  text-align: center;
  font-size: 16px;
  font-weight: 600;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__label {
    width: 100px;
    font-size: 14px;
  }
}
.p-lp02Point__label span {
  font-size: 18px;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__label span {
    font-size: 16px;
  }
}
.p-lp02Point__image {
  display: block;
  width: 100%;
  max-width: 500px;
  margin: 40px auto 0;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__image {
    width: 73%;
    margin-top: 32px;
  }
}
.p-lp02Point__read {
  margin-top: 24px;
  text-align: center;
  font-size: 18px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__read {
    font-size: 14px;
  }
}
.p-lp02Point__read + .p-lp02Point__title {
  margin-top: 48px;
}
.p-lp02Point__read span {
  display: inline-block;
}
.p-lp02Point__block {
  width: 100%;
  max-width: 700px;
  margin: 40px auto 0;
  padding: 32px;
  background-color: #fff;
  border: 1px solid #000;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__block {
    padding: 24px;
  }
}
.p-lp02Point__block + .p-lp02Point__title {
  margin-top: 56px;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__block + .p-lp02Point__title {
    margin-top: 32px;
  }
}
.p-lp02Point__title {
  position: relative;
  padding-bottom: 16px;
  text-align: center;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__title {
    padding-bottom: 8px;
    font-size: 18px;
  }
}
.p-lp02Point__title::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 40px;
  height: 3px;
  background-color: #FD908E;
  margin: auto;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__title::after {
    width: 32px;
    height: 3px;
  }
}
.p-lp02Point__list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 24px;
}
.p-lp02Point__item {
  position: relative;
  padding-bottom: 8px;
  padding-left: 32px;
  border-bottom: 2px dashed #e5e5e5;
  font-size: 18px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__item {
    padding-left: 28px;
    font-size: 14px;
  }
}
.p-lp02Point__item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 6px;
  width: 24px;
  height: 24px;
  background: url(../img/lp02/icon-check.svg) no-repeat center/cover;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__item::before {
    top: 4px;
    width: 20px;
    height: 20px;
  }
}
.p-lp02Point__item span {
  font-size: 20px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__item span {
    font-size: 16px;
  }
}
.p-lp02Point__card {
  padding: 40px;
  background: #fff;
  border-radius: 8px;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__card {
    padding: 16px 24px;
  }
}
.p-lp02Point__card-block {
  display: flex;
  gap: 32px;
  align-items: center;
  padding-bottom: 24px;
  border-bottom: 1px solid #FD908E;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__card-block {
    gap: 16px;
    padding-bottom: 16px;
  }
}
.p-lp02Point__card-block img {
  align-self: flex-start;
  flex-shrink: 0;
  width: 220px;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__card-block img {
    width: 110px;
  }
}
.p-lp02Point__card-name {
  font-size: 18px;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__card-name {
    font-size: 12px;
  }
}
.p-lp02Point__card-read {
  margin-top: 8px;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__card-read {
    font-size: 14px;
  }
}
.p-lp02Point__card-read span {
  display: inline-block;
}
.p-lp02Point__swiper {
  position: relative;
  margin-top: 32px;
  padding-bottom: 24px;
}
.p-lp02Point__swiper .swiper-pagination {
  bottom: 0;
}
.p-lp02Point__swiper .swiper-pagination-bullet {
  background-color: #e5e5e5;
  opacity: 1;
}
.p-lp02Point__swiper .swiper-pagination-bullet-active {
  background-color: #FD908E;
}
.p-lp02Point__swiper .swiper-button-prev,
.p-lp02Point__swiper .swiper-button-next {
  height: 80px;
  width: 40px;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__swiper .swiper-button-prev,
.p-lp02Point__swiper .swiper-button-next {
    height: 48px;
    width: 24px;
  }
}
.p-lp02Point__swiper .swiper-button-prev {
  left: 0;
}
.p-lp02Point__swiper .swiper-button-next {
  right: 0;
}
.p-lp02Point__swiper .swiper-button-prev::after,
.p-lp02Point__swiper .swiper-button-next::after {
  content: "";
  height: 80px;
  margin: auto;
  width: 40px;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__swiper .swiper-button-prev::after,
.p-lp02Point__swiper .swiper-button-next::after {
    height: 48px;
    width: 24px;
  }
}
.p-lp02Point__swiper .swiper-button-prev::after {
  background: url(../img/lp02/arrow-prev.svg) no-repeat center/cover;
}
.p-lp02Point__swiper .swiper-button-next::after {
  background: url(../img/lp02/arrow-next.svg) no-repeat center/cover;
}

.p-lp02Point1 {
  padding-bottom: 64px;
  background-color: #FFF6EB;
}
@media screen and (max-width: 767px) {
  .p-lp02Point1 {
    padding-bottom: 48px;
  }
}

.p-lp02Point2 {
  padding-block: 64px;
  background-color: #FFF3EF;
}
@media screen and (max-width: 767px) {
  .p-lp02Point2 {
    padding-block: 48px;
  }
}

.p-lp02Point3 {
  padding-bottom: 16px;
}

.p-lp02Point__question {
  position: relative;
  padding-top: 10vw;
  background-color: #FFF6EB;
  z-index: 0;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__question {
    padding-top: 14vw;
  }
}
.p-lp02Point__question::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  aspect-ratio: 12/1;
  background-color: #fff;
  -webkit-clip-path: polygon(0 0, 100% 0%, 50% 100%);
          clip-path: polygon(0 0, 100% 0%, 50% 100%);
  z-index: -1;
}
.p-lp02Point__question-title {
  padding-bottom: 8px;
  background: url(../img/lp02/bg-balloon.svg) no-repeat center/300px;
  text-align: center;
  font-size: 22px;
  font-weight: 700;
  line-height: 100px;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__question-title {
    background-size: 215px;
    margin-bottom: -8px;
    font-size: 18px;
    line-height: 60px;
  }
}
.p-lp02Point__question-read {
  margin-top: 48px;
  text-align: center;
  font-size: 20px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__question-read {
    font-size: 14px;
  }
}
.p-lp02Point__question-read span {
  font-size: 24px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lp02Point__question-read span {
    font-size: 16px;
  }
}

.p-lp02Compare__table-wrap {
  width: 100%;
  overflow-x: auto;
}
.p-lp02Compare__table {
  width: 100%;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .p-lp02Compare__table {
    width: 500px;
  }
}
.p-lp02Compare__table thead th {
  vertical-align: bottom;
  border-right: 1px solid #fff;
}
.p-lp02Compare__table thead th div {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  height: 70px;
  padding: 8px;
  background-color: #FFF6EB;
}
@media screen and (max-width: 767px) {
  .p-lp02Compare__table thead th div {
    font-size: 12px;
  }
}
.p-lp02Compare__table thead th:nth-child(2) div {
  height: 80px;
  background-color: #FCC4B6;
}
.p-lp02Compare__table tbody {
  border-top: 1px solid #e5e5e5;
}
.p-lp02Compare__table tbody tr:last-child td:nth-of-type(1) div {
  height: 74px;
}
.p-lp02Compare__table tbody th {
  display: flex;
  align-items: center;
  gap: 8px;
  height: 64px;
  padding-right: 8px;
  border-bottom: 1px solid #e5e5e5;
}
.p-lp02Compare__table tbody th img {
  width: 32px;
  height: 32px;
}
@media screen and (max-width: 767px) {
  .p-lp02Compare__table tbody th img {
    width: 22px;
    height: 22px;
  }
}
@media screen and (max-width: 767px) {
  .p-lp02Compare__table tbody th span {
    font-size: 12px;
  }
}
.p-lp02Compare__table tbody th span span {
  display: inline-block;
}
.p-lp02Compare__table tbody td div {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  height: 64px;
  padding: 8px;
  border-bottom: 1px solid #e5e5e5;
  border-right: 1px solid #e5e5e5;
  text-align: center;
  letter-spacing: 0;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-lp02Compare__table tbody td div {
    padding: 8px 4px;
    font-size: 12px;
  }
}
.p-lp02Compare__table tbody td div span span {
  display: inline-block;
}
.p-lp02Compare__table tbody td:nth-of-type(1) div {
  background-color: #FFF3EF;
  border-left: 1px solid #e5e5e5;
}

.p-lp02Story {
  padding-block: 64px 40px;
  background-color: #FFF6EB;
}
@media screen and (max-width: 767px) {
  .p-lp02Story {
    padding-block: 40px 16px;
  }
}
.p-lp02Story .p-lp02__heading {
  font-size: 2.5rem;
}
@media screen and (max-width: 767px) {
  .p-lp02Story .p-lp02__heading {
    font-size: 1.5rem;
  }
}
.p-lp02Story__block {
  padding: 40px;
  background-color: #fff;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .p-lp02Story__block {
    padding: 32px 24px;
  }
}
.p-lp02Story__heading {
  padding-left: 24px;
  border-left: 4px solid #FD908E;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-lp02Story__heading {
    font-size: 14px;
  }
}
.p-lp02Story__name {
  margin-top: 24px;
  text-align: right;
}
@media screen and (max-width: 767px) {
  .p-lp02Story__name {
    font-size: 12px;
  }
}
.p-lp02Story__textBlock {
  position: relative;
  height: 254px;
  overflow: hidden;
  margin-top: 32px;
}
.p-lp02Story__textBlock::before {
  position: absolute;
  display: block;
  content: "";
  bottom: 0;
  left: 0;
  width: 100%;
  height: 75px;
  background: linear-gradient(rgba(255, 243, 239, 0) 0%, rgba(255, 255, 255, 0.5) 50%, #fff 100%);
}
.p-lp02Story__textBlock::after {
  content: "";
  display: block;
  clear: both;
}
.p-lp02Story__textBlock img {
  float: right;
  width: 45%;
  max-width: 350px;
  margin-left: 32px;
  border-radius: 8px;
}
@media screen and (max-width: 767px) {
  .p-lp02Story__textBlock img {
    width: 40%;
    min-width: 140px;
    margin-left: 16px;
  }
}
.p-lp02Story__text {
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lp02Story__text {
    font-size: 12px;
  }
}
.p-lp02Story__text b {
  font-size: 18px;
}
@media screen and (max-width: 767px) {
  .p-lp02Story__text b {
    font-size: 12px;
  }
}
.p-lp02Story__readmore {
  position: relative;
  padding-bottom: 72px;
}
@media screen and (max-width: 767px) {
  .p-lp02Story__readmore {
    padding-bottom: 40px;
  }
}
.p-lp02Story__readmore input[type=checkbox] {
  display: none;
}
.p-lp02Story__readmore input[type=checkbox]:checked ~ label::before {
  content: "閉じる　ー";
}
.p-lp02Story__readmore input[type=checkbox]:checked ~ .p-lp02Story__textBlock {
  height: auto;
}
.p-lp02Story__readmore input[type=checkbox]:checked ~ .p-lp02Story__textBlock::before {
  content: none;
}
.p-lp02Story__button {
  position: absolute;
  bottom: 0;
  left: 50%;
  translate: -50% 0;
}
.p-lp02Story__button::before {
  content: "もっと見る ＋";
  display: block;
  width: 200px;
  padding: 16px 8px;
  background-color: #FD908E;
  color: #fff;
  border-radius: 4px;
  text-align: center;
  font-weight: 600;
}
@media screen and (max-width: 767px) {
  .p-lp02Story__button::before {
    width: 120px;
    padding: 8px 16px;
    font-size: 12px;
  }
}
.p-lp02Story__swiper {
  position: relative;
  margin-top: 48px;
  padding-bottom: 24px;
}
.p-lp02Story__swiper .swiper-button-prev,
.p-lp02Story__swiper .swiper-button-next {
  top: 194px;
  margin: 0;
  height: 80px;
  width: 40px;
}
@media screen and (max-width: 767px) {
  .p-lp02Story__swiper .swiper-button-prev,
.p-lp02Story__swiper .swiper-button-next {
    top: 193.5px;
    height: 48px;
    width: 24px;
  }
}
.p-lp02Story__swiper .swiper-button-prev {
  left: 0;
}
.p-lp02Story__swiper .swiper-button-next {
  right: 0;
}
.p-lp02Story__swiper .swiper-button-prev::after,
.p-lp02Story__swiper .swiper-button-next::after {
  content: "";
  height: 80px;
  margin: auto;
  width: 40px;
}
@media screen and (max-width: 767px) {
  .p-lp02Story__swiper .swiper-button-prev::after,
.p-lp02Story__swiper .swiper-button-next::after {
    height: 48px;
    width: 24px;
  }
}
.p-lp02Story__swiper .swiper-button-prev::after {
  background: url(../img/lp02/arrow-prev.svg) no-repeat center/cover;
}
.p-lp02Story__swiper .swiper-button-next::after {
  background: url(../img/lp02/arrow-next.svg) no-repeat center/cover;
}

.p-lp02Benefits__read {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 32px auto 0;
  padding-inline: 110px;
  background: url(../img/lp02/deco01.svg) no-repeat left/60px, url(../img/lp02/deco02.svg) no-repeat right/60px;
  text-align: center;
  font-size: 20px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lp02Benefits__read {
    margin-top: 24px;
    padding-inline: 40px;
    background-size: 34px;
    font-size: 14px;
  }
}
.p-lp02Benefits__read b {
  font-size: 24px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lp02Benefits__read b {
    font-size: 16px;
  }
}
.p-lp02Benefits__heading {
  margin-top: 40px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-lp02Benefits__heading {
    margin-top: 32px;
  }
}
.p-lp02Benefits__heading span {
  display: inline-block;
  padding: 8px 16px;
  background-color: #fff;
  border: 1px solid #000;
  border-radius: 20px;
  font-size: 20px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lp02Benefits__heading span {
    font-size: 12px;
  }
}
.p-lp02Benefits__block {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px 24px;
  width: 100%;
  max-width: 600px;
  margin: 24px auto 0;
  padding: 24px;
  background-color: #fff;
  border: 1px solid #000;
  border-radius: 10px;
}
.p-lp02Benefits__block img {
  width: 160px;
  align-self: flex-start;
}
@media screen and (max-width: 767px) {
  .p-lp02Benefits__block img {
    width: 100px;
  }
}
.p-lp02Benefits__textBlock {
  align-self: center;
  flex: 1;
}
.p-lp02Benefits__title {
  font-size: 18px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lp02Benefits__title {
    font-size: 14px;
  }
}
.p-lp02Benefits__text {
  margin-top: 8px;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lp02Benefits__text {
    font-size: 14px;
  }
}
.p-lp02Benefits__text span {
  display: inline-block;
}
.p-lp02Benefits__list {
  width: 100%;
  padding-top: 16px;
  border-top: 2px dashed #ccc;
}
.p-lp02Benefits__item + .p-lp02Benefits__item {
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .p-lp02Benefits__item + .p-lp02Benefits__item {
    margin-top: 8px;
  }
}
.p-lp02Benefits__name {
  text-align: center;
  font-size: 18px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lp02Benefits__name {
    font-size: 14px;
  }
}
.p-lp02Benefits__overview {
  margin-top: 8px;
  font-size: 14px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .p-lp02Benefits__overview {
    margin-top: 4px;
    font-size: 12px;
  }
}
.p-lp02Benefits__attr {
  margin-top: 8px;
  text-align: center;
  font-size: 0.75rem;
  line-height: 1.5;
}

.p-lp02Form {
  padding-block: 64px;
  background-color: #FFF6EB;
}
@media screen and (max-width: 767px) {
  .p-lp02Form {
    padding-block: 40px;
  }
}
.p-lp02Form__body {
  margin-top: 32px;
}
.p-lp02Form__text {
  margin-top: 32px;
  text-align: center;
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lp02Form__text {
    font-size: 0.9rem;
  }
}
@media screen and (max-width: 767px) {
  .p-lp02Form__text--comp {
    text-align: left;
  }
}

.p-lp02Thought {
  margin-top: 56px;
}
.p-lp02Thought img {
  display: block;
  width: 100%;
  max-width: 600px;
  margin: auto;
}
.p-lp02Thought__block {
  max-width: 700px;
  margin: -56px auto 0;
  padding: 72px 40px 32px;
  border: 1px solid #000;
  border-radius: 10px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-lp02Thought__block {
    margin-top: -40px;
    padding: 56px 24px 24px;
  }
}
.p-lp02Thought__read {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lp02Thought__read {
    font-size: 14px;
  }
}
.p-lp02Thought__read span {
  display: inline-block;
}
.p-lp02Thought__read .p-lp02__marker {
  display: inline;
  font-size: 22px;
}
@media screen and (max-width: 767px) {
  .p-lp02Thought__read .p-lp02__marker {
    font-size: 16px;
  }
}
.p-lp02Thought__text {
  margin-top: 16px;
  font-size: 18px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lp02Thought__text {
    font-size: 14px;
  }
}
.p-lp02Thought__text span {
  display: inline-block;
}

.p-lp02Cta {
  padding-top: 64px;
  background-color: #FD908E;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .p-lp02Cta {
    padding-top: 48px;
  }
}
.p-lp02Cta__block {
  display: flex;
  justify-content: center;
  gap: 24px 5%;
  flex-wrap: wrap;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .p-lp02Cta__textBlock {
    text-align: center;
  }
}
.p-lp02Cta__read {
  font-size: 16px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lp02Cta__read {
    font-size: 14px;
  }
}
.p-lp02Cta__heading {
  margin-top: 8px;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lp02Cta__heading {
    font-size: 20px;
  }
}
.p-lp02Cta__heading span {
  display: inline-block;
}
.p-lp02Cta__dorm {
  flex-shrink: 0;
  align-self: flex-end;
  position: relative;
  width: 480px;
  min-height: 240px;
  padding-left: 200px;
  z-index: 0;
  background: url(../img/lp02/dorm.svg) no-repeat top/cover;
}
@media screen and (max-width: 767px) {
  .p-lp02Cta__dorm {
    width: 100%;
    max-width: 335px;
    min-height: 178px;
    margin: auto;
    padding-left: 134px;
  }
}
.p-lp02Cta__dorm img {
  position: absolute;
  bottom: 0;
  left: 10px;
  width: 206px;
}
@media screen and (max-width: 767px) {
  .p-lp02Cta__dorm img {
    left: 0;
    width: 154px;
  }
}
.p-lp02Cta__text {
  margin-left: -40px;
  margin-top: 60px;
  color: #000;
  font-size: 26px;
  font-weight: 700;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lp02Cta__text {
    margin-left: -40px;
    margin-top: 30px;
    font-size: 20px;
  }
}
.p-lp02Cta__text span {
  display: block;
  margin-left: 4rem;
}
@media screen and (max-width: 767px) {
  .p-lp02Cta__text span {
    margin-left: 2.125rem;
  }
}
.p-lp02Cta__wrap {
  margin-block: 24px;
}
@media screen and (max-width: 767px) {
  .p-lp02Cta__wrap {
    margin-bottom: 8px;
  }
}
.p-lp02Cta__button {
  position: relative;
  display: inline-block;
  width: 260px;
  padding: 16px 40px;
  background-color: #FD908E;
  border-radius: 5px;
  font-size: 18px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lp02Cta__button {
    width: 175px;
    padding: 12px 24px;
    font-size: 14px;
  }
}
.p-lp02Cta__button::after {
  content: "↗";
  position: absolute;
  top: 0;
  right: 8px;
  bottom: 0;
  width: 42px;
  height: 42px;
  margin: auto;
  background-color: #fff;
  color: #FD908E;
  border-radius: 42px;
  text-align: center;
  line-height: 40px;
}
@media screen and (max-width: 767px) {
  .p-lp02Cta__button::after {
    right: 4px;
    width: 32px;
    height: 32px;
    font-size: 14px;
    line-height: 30px;
  }
}

.p-lp02Footer__inner {
  padding-block: 64px 32px;
  background-color: #EDE7E0;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-lp02Footer__inner {
    padding-block: 48px 16px;
  }
}
.p-lp02Footer__name {
  font-size: 18px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .p-lp02Footer__name {
    font-size: 14px;
  }
}
.p-lp02Footer__text {
  margin-top: 16px;
  font-size: 16px;
  line-height: 1.75;
}
@media screen and (max-width: 767px) {
  .p-lp02Footer__text {
    font-size: 12px;
  }
}
.p-lp02Footer__map {
  position: relative;
  width: 100%;
  height: 300px;
  margin-top: 32px;
}
@media screen and (max-width: 767px) {
  .p-lp02Footer__map {
    height: 200px;
  }
}
.p-lp02Footer__map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.p-lp02Footer__copy {
  text-align: center;
  background-color: #fff;
  padding: 16px 20px;
  font-size: 12px;
}

.p-lp02Fixed {
  position: fixed;
  bottom: 24px;
  width: 100%;
  z-index: 100;
  -webkit-animation: fluffy 3s infinite;
          animation: fluffy 3s infinite;
}
.p-lp02Fixed__button {
  position: relative;
  display: block;
  width: 400px;
  margin: auto;
  padding: 16px 24px;
  background-color: #FFDF4F;
  border-radius: 6px;
  border: 2px solid #333;
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .p-lp02Fixed__button {
    width: 90%;
    max-width: 320px;
    font-size: 18px;
  }
}
.p-lp02Fixed__button::before {
  content: "";
  position: absolute;
  top: -30px;
  left: -20px;
  width: 80px;
  height: 48px;
  background: url(../img/lp02/free-balloon.svg) no-repeat center/cover;
}
@media screen and (max-width: 767px) {
  .p-lp02Fixed__button::before {
    top: -20px;
    left: -10px;
    width: 65px;
    height: 39px;
  }
}
.p-lp02Fixed__button::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 16px;
  width: 28px;
  height: 28px;
  margin: auto;
  background: url(../img/lp02/icon-arrow.svg) no-repeat center/cover;
}
@media screen and (max-width: 767px) {
  .p-lp02Fixed__button::after {
    width: 24px;
    height: 24px;
  }
}

@keyframes fluffy {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-7px);
  }
}
/*# sourceMappingURL=style.css.map */