@charset "UTF-8";
/*
リセットcssを記述
*/
/*! destyle.css v4.0.1 | MIT License | https://github.com/nicolas-cusan/destyle.min.css */
*, ::before, ::after {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
  min-width: 0;
}

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

body {
  margin: 0;
}

main {
  display: block;
}

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

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

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

dt {
  font-weight: 700;
}

dd {
  margin-left: 0;
}

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

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

address {
  font-style: inherit;
}

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

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

b, strong {
  font-weight: bolder;
}

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

small {
  font-size: 80%;
}

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

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

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

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

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

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

:-moz-focusring {
  outline: auto;
}

select:disabled {
  opacity: inherit;
}

option {
  padding: 0;
}

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

legend {
  padding: 0;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

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

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

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

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

[type=number] {
  -moz-appearance: textfield;
}

label[for] {
  cursor: pointer;
}

details {
  display: block;
}

summary {
  display: list-item;
}

[contenteditable]:focus {
  outline: auto;
}

table {
  border-color: inherit;
  border-collapse: collapse;
}

caption {
  text-align: left;
}

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

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

/* メディアクエリ */
/* //メディアクエリ */
/* position 中央寄せ */
/* //position 中央寄せ */
html {
  font-size: 100%;
}

body {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  overflow-x: hidden;
  position: relative;
  color: #5D5D5D;
  -webkit-font-smoothing: antialiased; /* macで文字が太くなる現象を解消 */
}
body.noscroll {
  overflow: hidden;
}
body .header-and-main--syonan {
  color: #333333;
}

main {
  margin-top: 151.2px;
  overflow: hidden;
}
@media screen and (max-width: 1024px) {
  main {
    margin-top: 16.6538461538vw;
  }
}

p {
  line-height: 1.6;
}

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

ul {
  list-style: none;
  padding-left: 0;
}

a {
  transition: all 0.3s;
}
a:hover {
  opacity: 0.7;
}

.header-and-main--syonan {
  background-color: #FBF5ED;
}
.header-and-main--syonan main {
  margin-top: 124.67px;
}
@media screen and (max-width: 1280px) {
  .header-and-main--syonan main {
    margin-top: 119.38px;
  }
}
@media screen and (max-width: 1024px) {
  .header-and-main--syonan main {
    margin-top: 16.4820512821vw;
  }
}
.header-and-main--syonan a {
  transition: all 0.4s;
}
.header-and-main--syonan a:hover {
  opacity: 0.6;
}

.p-child-fv::before {
  background: url(../images/for-first-visitor/fv.webp) no-repeat center center/cover;
}

.p-web-reserve {
  margin-bottom: 50px;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .p-web-reserve {
    margin-bottom: 12.8205128205vw;
  }
}
.p-web-reserve__inner {
  display: flex;
  gap: 80px;
}
@media screen and (max-width: 1024px) {
  .p-web-reserve__inner {
    flex-direction: column;
    gap: 7.6923076923vw;
  }
}
.p-web-reserve__image {
  flex: 0 0 40%;
}
@media screen and (max-width: 1024px) {
  .p-web-reserve__image {
    flex: 0 0 100%;
  }
}
.p-web-reserve__image img {
  border-radius: 10px;
}
@media screen and (max-width: 1024px) {
  .p-web-reserve__image img {
    border-radius: 2.5641025641vw;
  }
}
.p-web-reserve__contact {
  flex: 0 0 50%;
}
@media screen and (max-width: 1024px) {
  .p-web-reserve__contact {
    flex: 0 0 100%;
  }
}
.p-web-reserve__text {
  line-height: 1.4;
  letter-spacing: 0.03em;
  margin-bottom: 30px;
}
@media screen and (max-width: 1024px) {
  .p-web-reserve__text {
    font-size: 4.1025641026vw;
    margin-bottom: 7.6923076923vw;
  }
}
.p-web-reserve__box {
  margin-bottom: 30px;
}
@media screen and (max-width: 1024px) {
  .p-web-reserve__box {
    margin-bottom: 7.6923076923vw;
  }
}
.p-web-reserve__button:first-of-type {
  width: 172px;
  margin-bottom: 15px;
}
@media screen and (max-width: 1024px) {
  .p-web-reserve__button:first-of-type {
    width: 100%;
    margin-bottom: 3.8461538462vw;
  }
}
.p-web-reserve__button:last-of-type {
  width: 299px;
}
@media screen and (max-width: 1024px) {
  .p-web-reserve__button:last-of-type {
    width: 100%;
  }
}
.p-web-reserve__bird {
  position: absolute;
  bottom: 15px;
  right: 166px;
}
@media screen and (max-width: 1024px) {
  .p-web-reserve__bird {
    bottom: -24.8717948718vw;
    right: 2.5641025641vw;
  }
}

.p-visit-info {
  padding: 100px 0;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .p-visit-info {
    padding: 19.7435897436vw 0 29.7435897436vw;
  }
}
.p-visit-info__inner {
  max-width: 681px;
  margin: 0 auto;
  display: flex;
  gap: 32px;
}
@media screen and (max-width: 1024px) {
  .p-visit-info__inner {
    max-width: none;
    flex-direction: column;
    gap: 8.2051282051vw;
  }
}
.p-visit-info__item-list {
  flex: 0 0 34%;
}
@media screen and (max-width: 1024px) {
  .p-visit-info__item-list {
    flex: 0 0 100%;
  }
}
.p-visit-info__item-list-title {
  height: 53px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 1024px) {
  .p-visit-info__item-list-title {
    height: 13.5897435897vw;
  }
}
.p-visit-info__item-list--text-small {
  font-size: 14px;
}
@media screen and (max-width: 1024px) {
  .p-visit-info__item-list--text-small {
    font-size: 3.5897435897vw;
  }
}
.p-visit-info__item-list ul {
  padding: 19px 15px;
}
@media screen and (max-width: 1024px) {
  .p-visit-info__item-list ul {
    padding: 4.8717948718vw 3.8461538462vw;
    width: max-content;
    margin: 0 auto;
  }
}
.p-visit-info__item-list ul li {
  line-height: 1.4;
  padding-left: 16px;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .p-visit-info__item-list ul li {
    font-size: 4.1025641026vw;
    padding-left: 4.1025641026vw;
  }
}
.p-visit-info__item-list ul li:not(:last-of-type) {
  margin-bottom: 10px;
}
@media screen and (max-width: 1024px) {
  .p-visit-info__item-list ul li:not(:last-of-type) {
    margin-bottom: 2.5641025641vw;
  }
}
.p-visit-info__item-list ul li::before {
  content: "・";
  font-size: 16px;
  position: absolute;
  top: 0;
  left: 0;
}
@media screen and (max-width: 1024px) {
  .p-visit-info__item-list ul li::before {
    font-size: 4.1025641026vw;
  }
}
.p-visit-info__price-table {
  flex: 0 0 61%;
  border: 1px solid #B0D396;
  border-radius: 10px;
  overflow: hidden;
}
@media screen and (max-width: 1024px) {
  .p-visit-info__price-table {
    flex: 0 0 100%;
    border: 0.2564102564vw solid #B0D396;
    border-radius: 2.5641025641vw;
  }
}
.p-visit-info__price-table table {
  width: 100%;
  height: 100%;
}
.p-visit-info__price-table table th, .p-visit-info__price-table table td {
  text-align: center;
  vertical-align: middle;
}
@media screen and (max-width: 1024px) {
  .p-visit-info__price-table table th, .p-visit-info__price-table table td {
    font-size: 4.1025641026vw;
  }
}
.p-visit-info__price-table table th {
  font-weight: 500;
}
.p-visit-info__price-table table thead tr {
  border-bottom: 1px solid #B0D396;
}
@media screen and (max-width: 1024px) {
  .p-visit-info__price-table table thead tr {
    border-bottom: 0.2564102564vw solid #B0D396;
  }
}
.p-visit-info__price-table table thead th {
  background-color: #F4FBEC;
  color: #30871E;
  height: 53px;
}
@media screen and (max-width: 1024px) {
  .p-visit-info__price-table table thead th {
    height: 13.5897435897vw;
  }
}
.p-visit-info__price-table table thead th:first-of-type {
  border-right: 1px solid #B0D396;
  width: 216px;
}
@media screen and (max-width: 1024px) {
  .p-visit-info__price-table table thead th:first-of-type {
    width: 55.3846153846vw;
  }
}
.p-visit-info__price-table table tbody th, .p-visit-info__price-table table tbody td {
  line-height: 1.4;
  letter-spacing: 0.03em;
  padding: 5px 0;
}
@media screen and (max-width: 1024px) {
  .p-visit-info__price-table table tbody th, .p-visit-info__price-table table tbody td {
    padding: 1.2820512821vw 0;
  }
}
.p-visit-info__price-table table tbody tr:not(:last-of-type) {
  border-bottom: 1px solid #B0D396;
}
@media screen and (max-width: 1024px) {
  .p-visit-info__price-table table tbody tr:not(:last-of-type) {
    border-bottom: 0.2564102564vw solid #B0D396;
  }
}
.p-visit-info__price-table table tbody th {
  border-right: 1px solid #B0D396;
}
@media screen and (max-width: 1024px) {
  .p-visit-info__price-table table tbody th {
    border-right: 0.2564102564vw solid #B0D396;
  }
}
.p-visit-info__price-table table .p-visit-info__price-table--text-small {
  font-size: 14px;
  display: block;
  line-height: 1.4;
  letter-spacing: 0;
}
@media screen and (max-width: 1024px) {
  .p-visit-info__price-table table .p-visit-info__price-table--text-small {
    font-size: 3.5897435897vw;
  }
}
.p-visit-info__bird {
  position: absolute;
  left: 134px;
  bottom: 113px;
}
@media screen and (max-width: 1024px) {
  .p-visit-info__bird {
    left: 2.5641025641vw;
    bottom: 5.1282051282vw;
  }
}

.p-flow {
  padding: 100px 0;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .p-flow {
    padding: 25.641025641vw 0 12.8205128205vw;
  }
}
.p-flow::before {
  content: "";
  width: 100%;
  height: 1376px;
  background: url(../images/for-first-visitor/flow-bg.svg) no-repeat center top/cover;
  position: absolute;
  top: -51px;
  left: 0;
  z-index: -1;
}
@media screen and (max-width: 1024px) {
  .p-flow::before {
    background-image: url(../images/for-first-visitor/flow-bg-sp.svg);
    height: 480vw;
    top: -5.1282051282vw;
  }
}
.p-flow__inner {
  background-color: #FFFFFF;
  border-radius: 10px;
  padding: 50px 70px;
}
@media screen and (max-width: 1024px) {
  .p-flow__inner {
    padding: 7.6923076923vw 3.8461538462vw;
    border-radius: 2.5641025641vw;
  }
}
.p-flow-step {
  padding-bottom: 30px;
  position: relative;
}
@media screen and (max-width: 1024px) {
  .p-flow-step {
    padding-bottom: 5.1282051282vw;
  }
}
.p-flow-step:not(:first-of-type) {
  padding-top: 30px;
}
@media screen and (max-width: 1024px) {
  .p-flow-step:not(:first-of-type) {
    padding-top: 5.1282051282vw;
  }
}
.p-flow-step:not(:last-of-type)::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 4px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='4' viewBox='0 0 8 4'%3E%3Cline x1='2' y1='2' x2='6' y2='2' stroke='%23B0D396' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: repeat-x;
  background-size: 4px 4px;
}
@media screen and (max-width: 1024px) {
  .p-flow-step:not(:last-of-type)::after {
    height: 1.0256410256vw;
    background-size: 1.0256410256vw 1.0256410256vw;
  }
}
.p-flow-step__inner {
  display: flex;
  gap: 50px;
  align-items: center;
}
@media screen and (max-width: 1024px) {
  .p-flow-step__inner {
    flex-direction: column;
    gap: 5.1282051282vw;
  }
}
.p-flow-step__content {
  flex: 0 0 68.5%;
}
@media screen and (max-width: 1024px) {
  .p-flow-step__content {
    flex: 0 0 100%;
  }
}
.p-flow-step__label {
  font-size: 24px;
  font-weight: 700;
  color: #30871E;
  letter-spacing: 0.03em;
  line-height: 1.4;
  margin-bottom: 3px;
}
@media screen and (max-width: 1024px) {
  .p-flow-step__label {
    font-size: 5.1282051282vw;
    margin-bottom: 0.7692307692vw;
  }
}
.p-flow-step__title {
  font-size: 24px;
  font-weight: 700;
  position: relative;
  padding-left: 10px;
  line-height: 1.5;
  margin-bottom: 20px;
}
@media screen and (max-width: 1024px) {
  .p-flow-step__title {
    font-size: 5.1282051282vw;
    margin-bottom: 3.8461538462vw;
    padding-left: 2.5641025641vw;
  }
}
.p-flow-step__title::before {
  content: "";
  width: 5px;
  height: 78%;
  background-color: #30871E;
  border-radius: 100vw;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
}
@media screen and (max-width: 1024px) {
  .p-flow-step__title::before {
    width: 1.2820512821vw;
  }
}
.p-flow-step__text {
  line-height: 1.4;
  letter-spacing: 0.03em;
}
@media screen and (max-width: 1024px) {
  .p-flow-step__text {
    font-size: 4.1025641026vw;
  }
}
.p-flow-step__image {
  flex: 0 0 24%;
}
@media screen and (max-width: 1024px) {
  .p-flow-step__image {
    width: 40.5128205128vw;
  }
}
.p-flow-step__image img {
  width: 100%;
}/*# sourceMappingURL=for-first-visitor.css.map */