@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@100;300;400;500;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Prompt:wght@500;600;700&display=swap");
/*! destyle.css v4.0.1 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Reset box-model and set borders */
/* ============================================ */
*,
::before,
::after {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
  min-width: 0;
}

/* 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 {
  margin: 0;
}

/**
 * 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;
  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-top-width: 1px;
  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] {
  -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;
}

/* Replaced content */
/* ============================================ */
/**
 * Prevent vertical alignment issues.
 */
svg,
img,
embed,
object,
iframe {
  vertical-align: bottom;
}

/* Forms */
/* ============================================ */
/**
 * Reset form fields to make them styleable.
 * 1. Make form elements stylable across systems iOS especially.
 * 2. Inherit text-transform from parent.
 */
button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none; /* 1 */
  -moz-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; /* 2 */
}

/**
 * Correct cursors for clickable elements.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
}

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

/**
 * Improve outlines for Firefox and unify style with input elements & buttons.
 */
:-moz-focusring {
  outline: auto;
}

select:disabled {
  opacity: inherit;
}

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

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

legend {
  padding: 0;
}

/**
 * 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;
}

/**
 * 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. Fix font inheritance.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/**
 * Fix appearance for Firefox
 */
[type=number] {
  -moz-appearance: textfield;
}

/**
 * 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]:focus {
  outline: auto;
}

/* Tables */
/* ============================================ */
/**
1. Correct table border color inheritance in all Chrome and Safari.
*/
table {
  border-color: inherit; /* 1 */
  border-collapse: collapse;
}

caption {
  text-align: left;
}

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

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

*, *:before, *:after {
  box-sizing: border-box;
}

html {
  overflow-x: hidden;
  font-size: 62.5%;
  -webkit-text-size-adjust: 100%;
  min-height: 100vh;
  min-width: 320px;
  word-wrap: break-word;
  overflow-wrap: break-word;
  scroll-behavior: smooth;
  background-color: #F5F0E8;
}

body {
  line-height: 1.8;
  width: 100%;
  height: auto;
  min-height: 100vh;
  font-size: 1.6rem;
  font-family: "Zen Kaku Gothic New", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  color: #333333;
  background: #F5F0E8;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  text-rendering: optimizeLegibility;
}
body.is-opening-active {
  overflow: hidden;
  height: 100vh;
}

a {
  color: inherit;
  text-decoration: none;
  transition: color 0.3s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.3s cubic-bezier(0.22, 1, 0.36, 1);
  opacity: 1;
}
a:hover {
  opacity: 0.7;
  text-decoration: none;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(45, 138, 95, 0.24);
}

img {
  max-width: 100%;
  vertical-align: middle;
  height: auto;
}

input {
  margin: 0;
  padding: 0;
}

textarea {
  padding: 0;
  font: inherit;
  color: inherit;
}

button {
  font: inherit;
  padding: 0;
  background-color: transparent;
  border: none;
  color: inherit;
  cursor: pointer;
  transition: transform 0.25s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.25s cubic-bezier(0.22, 1, 0.36, 1), background-color 0.25s cubic-bezier(0.22, 1, 0.36, 1), color 0.25s cubic-bezier(0.22, 1, 0.36, 1);
}

.list-items {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
}
.list-items .list-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
}

@media screen and (max-width: 767px) {
  br.pc {
    display: none !important;
  }
}
@media screen and (min-width: 768px) {
  br.sp {
    display: none !important;
  }
}

.is-visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
  *,
  *::before,
  *::after {
    animation: none !important;
    transition: none !important;
  }
}
:root {
  --color-bg-primary: #F5F0E8;
  --color-green-light: #B8E0C8;
  --color-green-dark: #2B7B61;
  --color-yellow: #F5E642;
  --color-blue: #7EC8E3;
  --color-text: #333333;
  --color-white: #FFFFFF;
}

.l-header {
  z-index: 100;
  position: relative;
  background-color: white;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  height: 70px;
  backdrop-filter: blur(0);
  transition: background-color 0.3s cubic-bezier(0.22, 1, 0.36, 1), backdrop-filter 0.3s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}
@media screen and (min-width: 768px) {
  .l-header {
    height: min(3.6458333333vw, 70px);
  }
}
@media screen and (max-width: 1023px) {
  .l-header {
    display: none;
  }
}
.l-header__inner {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-end;
  width: 100%;
  max-width: 192rem;
  height: 100%;
  padding-right: min(1.0416666667vw, 20px);
}
.l-header__inner h1 {
  display: none;
}
.l-header__menu {
  display: flex;
  flex-flow: row nowrap;
  gap: min(0.5208333333vw, 10px);
}
.l-header__menu .c-button {
  width: min(10.4166666667vw, 200px);
  height: min(2.0833333333vw, 40px);
}
.l-header.is-shadow {
  background-color: rgba(255, 255, 255, 0.78);
  backdrop-filter: blur(8px);
  box-shadow: 0 10px 30px rgba(43, 123, 97, 0.08);
}

.l-sticky-logo {
  z-index: 101;
  position: sticky;
  top: 0;
  width: 100%;
  margin-top: -70px;
  pointer-events: none;
}
@media screen and (min-width: 768px) {
  .l-sticky-logo {
    margin-top: max(-3.6458333333vw, -70px);
  }
}
@media screen and (max-width: 1023px) {
  .l-sticky-logo {
    display: none;
  }
}
.l-sticky-logo__inner {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  max-width: min(100vw, 1920px);
  height: 70px;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .l-sticky-logo__inner {
    height: min(3.6458333333vw, 70px);
  }
}
@media screen and (min-width: 1024px) {
  .l-sticky-logo__inner {
    padding-inline: 24px;
  }
}
.l-sticky-logo .logo {
  pointer-events: auto;
  height: min(1.0416666667vw, 20px);
}
.l-sticky-logo .logo img {
  display: block;
  width: auto;
  max-width: none;
  height: 100%;
}

.l-floating-menu {
  pointer-events: none;
  z-index: 102;
  position: fixed;
  right: 0;
  bottom: min(1.0416666667vw, 20px);
  transform: translateY(min(0.5208333333vw, 10px));
  display: flex;
  flex-direction: column;
  gap: min(0.78125vw, 15px);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s cubic-bezier(0.22, 1, 0.36, 1), visibility 0.3s cubic-bezier(0.22, 1, 0.36, 1), transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}
@media screen and (max-width: 1023px) {
  .l-floating-menu {
    bottom: 0;
    right: auto;
    left: 50%;
    transform: translateX(-50%);
    flex-direction: row;
    justify-content: center;
    gap: 1.5rem;
    width: 100%;
    padding: 0 2rem;
  }
}
.l-floating-menu .c-button {
  pointer-events: auto;
  border-radius: 0;
}
@media screen and (min-width: 1024px) {
  .l-floating-menu .c-button {
    border-top-left-radius: min(1.0416666667vw, 20px);
    border-bottom-left-radius: min(1.0416666667vw, 20px);
    border-right: none;
    width: min(3.125vw, 60px);
    height: min(7.8125vw, 150px);
    padding-right: min(0.6770833333vw, 13px);
  }
}
@media screen and (max-width: 1023px) {
  .l-floating-menu .c-button {
    border-radius: 0;
    border-top-left-radius: 2rem;
    border-top-right-radius: 2rem;
    border-width: 0.2rem;
    border-bottom: none;
    width: 100%;
    max-width: 35rem;
    height: -moz-fit-content;
    height: fit-content;
    padding: 2rem 0;
    box-shadow: none;
  }
}
@media screen and (max-width: 767px) {
  .l-floating-menu .c-button {
    border-width: 0.5333333333vw;
    padding: 3.3333333333vw 0;
  }
}
@media screen and (min-width: 1024px) {
  .l-floating-menu .c-button button {
    font-size: min(0.78125vw, 15px);
    letter-spacing: 0.2em;
    writing-mode: vertical-rl;
  }
}
@media screen and (max-width: 1023px) {
  .l-floating-menu .c-button button {
    font-size: 2.6rem;
    line-height: 1.2;
    letter-spacing: 0.05em;
  }
}
@media screen and (max-width: 767px) {
  .l-floating-menu .c-button button {
    font-size: 3.7333333333vw;
  }
}
.l-floating-menu.is-visible {
  pointer-events: auto;
  visibility: visible;
  opacity: 1;
}
@media screen and (min-width: 1024px) {
  .l-floating-menu.is-visible {
    transform: translateY(0);
  }
}
@media screen and (max-width: 1023px) {
  .l-floating-menu {
    pointer-events: auto;
    visibility: visible;
    transform: translateX(-50%);
    opacity: 1;
  }
}

.l-container {
  height: 100%;
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
}
.l-container__inner {
  background-color: transparent;
  height: 100%;
  width: 100%;
  display: block;
}

.l-main {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  height: 100%;
}
.l-main__inner {
  background-color: transparent;
  height: 100%;
  width: 100%;
}
.l-main__inner section {
  width: 100%;
  max-width: min(100vw, 1920px);
  margin: 0 auto;
}

@keyframes page-to-top-bob {
  0%, 100% {
    translate: 0 0;
  }
  50% {
    translate: 0 max(-0.5208333333vw, -10px);
  }
}
.l-footer {
  position: relative;
  background-color: #FFFFFF;
  background-image: url("../image/bg_footer.svg"), linear-gradient(to bottom, transparent 50%, #EDEBDA 50%);
  background-size: 100% auto;
  background-position: center top;
  background-repeat: no-repeat;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  max-width: min(100vw, 1920px);
  padding: min(13.5416666667vw, 260px) 0 0;
  margin-top: auto;
}
@media screen and (max-width: 1023px) {
  .l-footer {
    padding: 26rem 0 10rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer {
    background-image: url("../image/bg_footer.svg"), linear-gradient(to bottom, transparent 10%, #EDEBDA 10%);
    padding: 34.6666666667vw 0 26.6666666667vw;
  }
}
.l-footer__inner {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  width: 100%;
  height: 100%;
  font-size: min(0.8333333333vw, 16px);
  padding-bottom: min(4.1666666667vw, 80px);
}
.l-footer__background {
  overflow-x: clip;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.l-footer__background .left,
.l-footer__background .right {
  position: absolute;
  inset: 0;
}
.l-footer__background .left figure,
.l-footer__background .right figure {
  position: absolute;
  margin: 0;
}
.l-footer__background .left figure img,
.l-footer__background .right figure img {
  width: 100%;
  max-width: none;
}
.l-footer__background .left .cloud--01 {
  top: 0;
  left: 0;
  width: min(14.375vw, 276px);
  --cloud-drift-x: max(-1.1458333333vw, -22px);
  --cloud-drift-duration: 8s;
}
.l-footer__background .left .cloud--02 {
  top: min(20.8333333333vw, 400px);
  left: 0;
  width: min(10.2604166667vw, 197px);
  --cloud-drift-x: max(-0.9375vw, -18px);
  --cloud-drift-duration: 9.5s;
}
.l-footer__background .left .flake--01 {
  top: min(10.4166666667vw, 200px);
  left: 0;
  width: min(16.3020833333vw, 313px);
}
.l-footer__background .left .flake--02 {
  bottom: min(2.6041666667vw, 50px);
  left: 0;
  width: min(22.5520833333vw, 433px);
}
.l-footer__background .left .pattern--01 {
  top: min(18.2291666667vw, 350px);
  left: min(2.0833333333vw, 40px);
  width: min(10.4166666667vw, 200px);
}
.l-footer__background .left .pattern--02 {
  bottom: min(2.6041666667vw, 50px);
  left: min(10.4166666667vw, 200px);
  width: min(16.6666666667vw, 320px);
}
.l-footer__background .left .object--01 {
  bottom: 0;
  left: 0;
  width: min(32.7604166667vw, 629px);
}
.l-footer__background .right .cloud--01 {
  top: max(-3.125vw, -60px);
  right: 0;
  width: min(14.6354166667vw, 281px);
  --cloud-drift-x: min(1.0416666667vw, 20px);
  --cloud-drift-duration: 8.5s;
}
.l-footer__background .right .cloud--02 {
  top: min(20.8333333333vw, 400px);
  right: 0;
  width: min(7.96875vw, 153px);
  --cloud-drift-x: min(0.8333333333vw, 16px);
  --cloud-drift-duration: 10s;
}
.l-footer__background .right .flake--01 {
  top: min(10.4166666667vw, 200px);
  right: 0;
  width: min(16.875vw, 324px);
}
.l-footer__background .right .flake--02 {
  bottom: min(4.1666666667vw, 80px);
  right: 0;
  width: min(12.6041666667vw, 242px);
}
.l-footer__background .right .pattern--01 {
  top: max(-3.125vw, -60px);
  right: min(20.8333333333vw, 400px);
  width: min(16.6666666667vw, 320px);
}
.l-footer__background .right .pattern--02 {
  bottom: min(20.8333333333vw, 400px);
  right: min(6.25vw, 120px);
  width: min(10.4166666667vw, 200px);
}
.l-footer__background .cloud {
  will-change: translate, transform;
}
@media (prefers-reduced-motion: no-preference) {
  .l-footer__background .cloud {
    transition: translate 1.4s cubic-bezier(0.22, 1, 0.36, 1);
  }
}
@media (prefers-reduced-motion: no-preference) {
  .l-footer__background .cloud.is-cloud-drift {
    animation: cloud-drift var(--cloud-drift-duration, 8s) ease-in-out infinite;
  }
}
.l-footer__background .left .cloud.is-cloud-out {
  transition: none;
  translate: -100vw 0;
}
.l-footer__background .right .cloud.is-cloud-out {
  transition: none;
  translate: 100vw 0;
}
.l-footer__background .flake {
  opacity: 0;
  scale: 0;
  will-change: opacity, scale;
}
@media (prefers-reduced-motion: no-preference) {
  .l-footer__background .flake {
    transition: opacity 0.1s ease-out, scale 0.6s cubic-bezier(0.34, 1.8, 0.64, 1);
  }
}
.l-footer__background .flake.is-flake-in {
  opacity: 1;
  scale: 1;
}
.l-footer .pickup {
  position: relative;
  z-index: 1;
  width: 100%;
  margin-bottom: min(7.8125vw, 150px);
}
@media screen and (max-width: 1023px) {
  .l-footer .pickup {
    margin-bottom: 15rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .pickup {
    margin-bottom: 16vw;
  }
}
.l-footer .pickup__inner {
  width: 100%;
}
.l-footer .pickup__inner > h2 {
  font-family: "Prompt", sans-serif;
  font-size: min(2.6041666667vw, 50px);
  line-height: 1;
  letter-spacing: 0.1em;
  color: #80191E;
  text-align: center;
}
@media screen and (max-width: 1023px) {
  .l-footer .pickup__inner > h2 {
    font-size: 5rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .pickup__inner > h2 {
    font-size: 6.6666666667vw;
  }
}
.l-footer .pickup__inner > p {
  font-weight: 500;
  font-size: min(1.0416666667vw, 20px);
  line-height: 2.2;
  text-align: center;
  margin: min(2.0833333333vw, 40px) 0 min(3.125vw, 60px);
}
@media screen and (max-width: 1023px) {
  .l-footer .pickup__inner > p {
    font-size: 2rem;
    margin: 4rem 0 6rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .pickup__inner > p {
    font-size: 3.2vw;
    margin: 4vw 0 6.6666666667vw;
  }
}
.l-footer .pickup__list {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  gap: min(3.125vw, 60px);
}
@media screen and (max-width: 1023px) {
  .l-footer .pickup__list {
    gap: 4rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .pickup__list {
    flex-flow: column nowrap;
    align-items: center;
    gap: 8vw;
    padding: 0 5.3333333333vw;
  }
}
.l-footer .pickup__list .pickup-item {
  border-radius: min(0.78125vw, 15px);
  border: min(0.1041666667vw, 2px) solid #231815;
  background-color: #F5F0E8;
  display: flex;
  flex-flow: column nowrap;
  width: 100%;
  max-width: min(23.4375vw, 450px);
  height: auto;
  min-height: min(27.0833333333vw, 520px);
  padding: min(1.0416666667vw, 20px) min(1.0416666667vw, 20px) min(2.0833333333vw, 40px);
  box-shadow: min(0.2604166667vw, 5px) min(0.2604166667vw, 5px) 0 0 #C9CACA;
}
@media screen and (max-width: 1023px) {
  .l-footer .pickup__list .pickup-item {
    border-radius: 1.5rem;
    border-width: 0.2rem;
    max-width: 45rem;
    min-height: 52rem;
    padding: 2rem 2rem 4rem;
    box-shadow: 0.5rem 0.5rem 0 0 #C9CACA;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .pickup__list .pickup-item {
    border-radius: 2.6666666667vw;
    border-width: 0.2666666667vw;
    max-width: none;
    min-height: 0;
    padding: 4vw 4vw 6.6666666667vw;
    box-shadow: 0.6666666667vw 0.6666666667vw 0 0 #C9CACA;
  }
}
.l-footer .pickup__list .pickup-item__image {
  width: 100%;
  margin-bottom: min(2.0833333333vw, 40px);
}
@media screen and (max-width: 1023px) {
  .l-footer .pickup__list .pickup-item__image {
    margin-bottom: 4rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .pickup__list .pickup-item__image {
    margin-bottom: 5.3333333333vw;
  }
}
.l-footer .pickup__list .pickup-item__image img {
  width: 100%;
  max-width: none;
}
.l-footer .pickup__list .pickup-item__text p {
  text-align: center;
}
.l-footer .pickup__list .pickup-item__text p:nth-of-type(1) {
  font-weight: 500;
  font-size: min(1.4583333333vw, 28px);
  line-height: 2.2;
}
.l-footer .pickup__list .pickup-item__text p:nth-of-type(1) span {
  display: block;
  font-size: min(0.7291666667vw, 14px);
  line-height: 1.5;
}
@media screen and (max-width: 1023px) {
  .l-footer .pickup__list .pickup-item__text p:nth-of-type(1) {
    font-size: 2.8rem;
  }
  .l-footer .pickup__list .pickup-item__text p:nth-of-type(1) span {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .pickup__list .pickup-item__text p:nth-of-type(1) {
    font-size: 4.8vw;
  }
  .l-footer .pickup__list .pickup-item__text p:nth-of-type(1) span {
    font-size: 2.6666666667vw;
  }
}
.l-footer .pickup__list .pickup-item__text p:nth-of-type(2) {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 2.5lh;
  font-weight: 500;
  font-size: min(0.8333333333vw, 16px);
  line-height: 1.5;
  margin-top: min(0.5208333333vw, 10px);
}
.l-footer .pickup__list .pickup-item__text p:nth-of-type(2) em {
  font-style: normal;
  font-weight: 700;
  font-size: 1.4em;
}
@media screen and (max-width: 1023px) {
  .l-footer .pickup__list .pickup-item__text p:nth-of-type(2) {
    font-size: 1.6rem;
    margin-top: 1rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .pickup__list .pickup-item__text p:nth-of-type(2) {
    font-size: 2.9333333333vw;
    margin-top: 1.3333333333vw;
  }
}
.l-footer .pickup__list .pickup-item .c-button {
  position: relative;
  width: 100%;
  max-width: min(17.7083333333vw, 340px);
  height: min(2.8645833333vw, 55px);
  margin: auto auto 0;
}
@media screen and (max-width: 1023px) {
  .l-footer .pickup__list .pickup-item .c-button {
    max-width: 34rem;
    height: 6rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .pickup__list .pickup-item .c-button {
    max-width: none;
    height: 13.3333333333vw;
    margin-top: 5.3333333333vw;
  }
}
.l-footer .pickup__list .pickup-item .c-button::after {
  content: "";
  position: absolute;
  top: 50%;
  right: min(1.3020833333vw, 25px);
  transform: translateY(-50%);
  background-image: url("../image/common/icon_external-link.svg");
  background-size: 100% auto;
  background-position: center;
  background-repeat: no-repeat;
  display: block;
  width: min(0.625vw, 12px);
  height: min(0.625vw, 12px);
}
@media screen and (max-width: 1023px) {
  .l-footer .pickup__list .pickup-item .c-button::after {
    right: 2.5rem;
    width: 1.2rem;
    height: 1.2rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .pickup__list .pickup-item .c-button::after {
    right: 5.3333333333vw;
    width: 3.2vw;
    height: 3.2vw;
  }
}
.l-footer .pickup__list .pickup-item:hover .c-button {
  transform: translateY(-3px);
}
.l-footer .pickup__list .pickup-item .c-button:hover {
  transform: none;
}
.l-footer .pickup__list .pickup-item:nth-child(2) {
  transition-delay: 0.2s;
}
.l-footer .pickup__list .pickup-item:nth-child(3) {
  transition-delay: 0.4s;
}
.l-footer .page-note {
  width: 100%;
  max-width: 128rem;
  margin-bottom: min(4.1666666667vw, 80px);
}
.l-footer .page-note p {
  font-size: min(0.6770833333vw, 13px);
  line-height: 1.8;
}
@media screen and (max-width: 1023px) {
  .l-footer .page-note {
    margin-bottom: 8rem;
  }
  .l-footer .page-note p {
    font-size: 1.3rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .page-note {
    padding: 0 5.3333333333vw;
    margin-bottom: 16vw;
  }
  .l-footer .page-note p {
    font-size: 2.6666666667vw;
  }
}
.l-footer .company {
  position: relative;
  z-index: 1;
  display: flex;
  flex-flow: row wrap;
  align-items: center;
  justify-content: center;
  gap: min(2.6041666667vw, 50px);
  width: 100%;
  margin-bottom: min(2.6041666667vw, 50px);
}
@media screen and (max-width: 1023px) {
  .l-footer .company {
    gap: 5rem;
    margin-bottom: 5rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .company {
    flex-flow: column nowrap;
    align-items: center;
    gap: 8vw;
    padding: 0 10.6666666667vw;
    margin-bottom: 8vw;
  }
}
.l-footer .company .company-item {
  display: block;
}
.l-footer .company .company-item:nth-of-type(1) {
  width: min(10.4166666667vw, 200px);
}
@media screen and (max-width: 1023px) {
  .l-footer .company .company-item:nth-of-type(1) {
    width: 20rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .company .company-item:nth-of-type(1) {
    width: 100%;
  }
}
.l-footer .company .company-item:nth-of-type(2) {
  width: min(15.625vw, 300px);
}
@media screen and (max-width: 1023px) {
  .l-footer .company .company-item:nth-of-type(2) {
    width: 30rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .company .company-item:nth-of-type(2) {
    width: 100%;
  }
}
.l-footer .company .company-item img {
  width: 100%;
  max-width: none;
}
.l-footer .contact {
  position: relative;
  z-index: 1;
}
.l-footer .contact p {
  text-align: center;
}
.l-footer .contact p:nth-of-type(1) {
  font-weight: 500;
  font-size: min(0.8333333333vw, 16px);
  line-height: 2.2;
}
@media screen and (max-width: 1023px) {
  .l-footer .contact p:nth-of-type(1) {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .contact p:nth-of-type(1) {
    font-size: 4.2666666667vw;
  }
}
.l-footer .contact p:nth-of-type(2) {
  font-size: min(0.625vw, 12px);
  line-height: 1.5;
}
@media screen and (max-width: 1023px) {
  .l-footer .contact p:nth-of-type(2) {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .contact p:nth-of-type(2) {
    font-size: 3.2vw;
  }
}
.l-footer .contact .tel {
  display: flex;
  flex-flow: row nowrap;
  align-items: flex-end;
  justify-content: center;
  gap: min(0.2604166667vw, 5px);
  font-weight: 500;
  font-size: min(1.7708333333vw, 34px);
  line-height: 0.8;
  margin: min(0.5208333333vw, 10px) 0 min(1.0416666667vw, 20px);
}
@media screen and (max-width: 1023px) {
  .l-footer .contact .tel {
    gap: 0.5rem;
    font-size: 3.4rem;
    margin: 1rem 0 2rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .contact .tel {
    gap: 1.3333333333vw;
    font-size: 8.8vw;
    margin: 2.6666666667vw 0 5.3333333333vw;
  }
}
.l-footer .contact .tel::before {
  content: "";
  background-image: url("../image/common/icon_tel.svg");
  background-size: 100% auto;
  background-position: center;
  background-repeat: no-repeat;
  display: block;
  width: min(1.0416666667vw, 20px);
  height: min(1.0416666667vw, 20px);
}
@media screen and (max-width: 1023px) {
  .l-footer .contact .tel::before {
    width: 2rem;
    height: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .contact .tel::before {
    width: 4.8vw;
    height: 4.8vw;
  }
}
.l-footer .copyright {
  position: relative;
  z-index: 1;
  font-family: "Prompt", sans-serif;
  font-size: min(0.625vw, 12px);
  margin-top: min(3.6458333333vw, 70px);
}
@media screen and (max-width: 1023px) {
  .l-footer .copyright {
    font-size: 1.2rem;
    margin-top: 7rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .copyright {
    font-size: 2.6666666667vw;
    margin-top: 16vw;
  }
}
.l-footer .page-to-top {
  position: absolute;
  right: min(4.1666666667vw, 80px);
  bottom: min(2.0833333333vw, 40px);
  z-index: 1;
  width: min(3.2291666667vw, 62px);
  will-change: translate;
}
@media (prefers-reduced-motion: no-preference) {
  .l-footer .page-to-top {
    animation: page-to-top-bob 2s ease-in-out infinite;
  }
}
@media screen and (max-width: 1023px) {
  .l-footer .page-to-top {
    right: 4rem;
    bottom: 4rem;
    width: 6.2rem;
  }
}
@media screen and (max-width: 767px) {
  .l-footer .page-to-top {
    position: static;
    width: 16vw;
    margin-top: 5.3333333333vw;
  }
}
.l-footer .page-to-top img {
  width: 100%;
  max-width: none;
}

@keyframes island-float {
  0%, 100% {
    translate: 0 0;
  }
  50% {
    translate: 0 max(-0.8333333333vw, -16px);
  }
}
@keyframes cloud-drift {
  0%, 100% {
    transform: translateX(0);
  }
  50% {
    transform: translateX(var(--cloud-drift-x, 15px));
  }
}
.visual {
  position: relative;
  background-image: url("../image/bg_visual-pc.png");
  background-image: -webkit-image-set(url("../image/bg_visual-pc.webp") type("image/webp"), url("../image/bg_visual-pc.png") type("image/png"));
  background-image: image-set(url("../image/bg_visual-pc.webp") type("image/webp"), url("../image/bg_visual-pc.png") type("image/png"));
  background-size: auto 100%;
  background-position: center bottom;
  background-repeat: no-repeat;
  width: 100%;
}
@media screen and (max-width: 1279px) {
  .visual {
    background-image: url("../image/bg_visual-sp.png");
    background-image: -webkit-image-set(url("../image/bg_visual-sp.webp") type("image/webp"), url("../image/bg_visual-sp.png") type("image/png"));
    background-image: image-set(url("../image/bg_visual-sp.webp") type("image/webp"), url("../image/bg_visual-sp.png") type("image/png"));
    background-size: 100% auto;
    background-position: center bottom;
  }
}
.visual__bg {
  overflow-x: clip;
  pointer-events: none;
  z-index: 0;
  position: absolute;
  inset: 0;
}
.visual__bg .left,
.visual__bg .right,
.visual__bg .pattern,
.visual__bg .cloud,
.visual__bg .flake,
.visual__bg .object,
.visual__bg .object-item {
  position: absolute;
}
.visual__bg .flake {
  opacity: 0;
  scale: 0;
  will-change: opacity, scale;
}
@media (prefers-reduced-motion: no-preference) {
  .visual__bg .flake {
    transition: opacity 0.1s ease-out, scale 0.6s cubic-bezier(0.34, 1.8, 0.64, 1);
  }
}
.visual__bg .flake.is-flake-in {
  opacity: 1;
  scale: 1;
}
.visual__bg .left,
.visual__bg .right,
.visual__bg .object {
  inset: 0;
  width: 100%;
  height: 100%;
}
.visual__bg .left .pattern--01 {
  top: min(22.9166666667vw, 440px);
  left: max(-5.2083333333vw, -100px);
  width: min(10.4166666667vw, 200px);
}
@media screen and (max-width: 767px) {
  .visual__bg .left .pattern--01 {
    top: 30.6666666667vw;
    left: -6.6666666667vw;
    width: 13.3333333333vw;
  }
}
.visual__bg .left .pattern--02 {
  bottom: min(6.25vw, 120px);
  left: min(11.4583333333vw, 220px);
  width: min(16.6666666667vw, 320px);
}
@media screen and (max-width: 767px) {
  .visual__bg .left .pattern--02 {
    bottom: -1.3333333333vw;
    left: 18.6666666667vw;
    width: 21.3333333333vw;
  }
}
.visual__bg .left .flake--01 {
  top: min(0.5208333333vw, 10px);
  left: 0;
  width: min(22.2916666667vw, 428px);
}
@media screen and (max-width: 767px) {
  .visual__bg .left .flake--01 {
    width: 26.6666666667vw;
  }
}
.visual__bg .left .flake--02 {
  top: min(2.0833333333vw, 40px);
  left: min(19.2708333333vw, 370px);
  width: min(20.0520833333vw, 385px);
}
@media screen and (max-width: 767px) {
  .visual__bg .left .flake--02 {
    width: 26.6666666667vw;
  }
}
.visual__bg .left .flake--03 {
  bottom: min(165.1041666667vw, 3170px);
  left: 0;
  width: min(11.6145833333vw, 223px);
}
@media screen and (max-width: 767px) {
  .visual__bg .left .flake--03 {
    width: 20vw;
  }
}
.visual__bg .left .flake--04 {
  bottom: max(-3.6458333333vw, -70px);
  left: 0;
  width: min(15.15625vw, 291px);
}
@media screen and (max-width: 767px) {
  .visual__bg .left .flake--04 {
    width: 26.6666666667vw;
  }
}
.visual__bg .left .cloud {
  left: 0;
  will-change: translate, transform;
}
@media (prefers-reduced-motion: no-preference) {
  .visual__bg .left .cloud {
    transition: translate 1.4s cubic-bezier(0.22, 1, 0.36, 1);
  }
}
.visual__bg .left .cloud.is-cloud-out {
  transition: none;
  translate: -100vw 0;
}
@media (prefers-reduced-motion: no-preference) {
  .visual__bg .left .cloud.is-cloud-drift {
    animation: cloud-drift var(--cloud-drift-duration, 8s) ease-in-out infinite;
  }
}
.visual__bg .left .cloud--01 {
  top: max(-1.0416666667vw, -20px);
  width: min(14.1666666667vw, 272px);
  --cloud-drift-x: max(-1.1458333333vw, -22px);
  --cloud-drift-duration: 7s;
  transition-delay: 0s;
}
@media screen and (max-width: 767px) {
  .visual__bg .left .cloud--01 {
    top: -1.3333333333vw;
    left: -16.6666666667vw;
    width: 31.2vw;
  }
}
.visual__bg .left .cloud--02 {
  top: min(19.2708333333vw, 370px);
  width: min(12.1354166667vw, 233px);
  --cloud-drift-x: max(-0.8333333333vw, -16px);
  --cloud-drift-duration: 9s;
  transition-delay: 0.15s;
}
@media screen and (max-width: 767px) {
  .visual__bg .left .cloud--02 {
    top: 25.3333333333vw;
    left: -8vw;
    width: 20vw;
  }
}
.visual__bg .left .cloud--03 {
  bottom: min(13.5416666667vw, 260px);
  width: min(12.7083333333vw, 244px);
  --cloud-drift-x: max(-1.3541666667vw, -26px);
  --cloud-drift-duration: 8.5s;
  transition-delay: 0.3s;
}
@media screen and (max-width: 767px) {
  .visual__bg .left .cloud--03 {
    bottom: 6.6666666667vw;
    width: 22.6666666667vw;
  }
}
.visual__bg .left .cloud--04 {
  bottom: min(1.5625vw, 30px);
  width: min(5.7291666667vw, 110px);
  --cloud-drift-x: max(-0.7291666667vw, -14px);
  --cloud-drift-duration: 6.5s;
  transition-delay: 0.45s;
}
@media screen and (max-width: 767px) {
  .visual__bg .left .cloud--04 {
    bottom: -16vw;
    width: 17.3333333333vw;
  }
}
.visual__bg .left .cloud--05 {
  top: min(43.2291666667vw, 830px);
  left: min(17.7083333333vw, 340px);
  width: min(13.3333333333vw, 256px);
  --cloud-drift-x: max(-1.0416666667vw, -20px);
  --cloud-drift-duration: 10s;
  transition-delay: 0.6s;
}
@media screen and (max-width: 767px) {
  .visual__bg .left .cloud--05 {
    top: 366.6666666667vw;
    left: 0;
    width: 26.6666666667vw;
  }
}
.visual__bg .right .pattern--01 {
  bottom: min(28.125vw, 540px);
  right: min(19.7916666667vw, 380px);
  width: min(10.4166666667vw, 200px);
}
@media screen and (max-width: 767px) {
  .visual__bg .right .pattern--01 {
    bottom: auto;
    top: 125.3333333333vw;
    right: 16vw;
    width: 21.3333333333vw;
  }
}
.visual__bg .right .pattern--02 {
  bottom: min(18.75vw, 360px);
  right: max(-6.25vw, -120px);
  width: min(16.6666666667vw, 320px);
}
.visual__bg .right .flake--01 {
  top: min(0.5208333333vw, 10px);
  right: min(15.625vw, 300px);
  width: min(22.3958333333vw, 430px);
}
@media screen and (max-width: 767px) {
  .visual__bg .right .flake--01 {
    width: 32vw;
  }
}
.visual__bg .right .flake--02 {
  top: 0;
  right: 0;
  width: min(12.7083333333vw, 244px);
}
@media screen and (max-width: 767px) {
  .visual__bg .right .flake--02 {
    width: 21.3333333333vw;
  }
}
.visual__bg .right .flake--03 {
  bottom: min(273.4375vw, 5250px);
  left: 0;
  width: min(12.7083333333vw, 244px);
}
@media screen and (max-width: 767px) {
  .visual__bg .right .flake--03 {
    width: 16vw;
  }
}
.visual__bg .right .flake--04 {
  bottom: max(-1.0416666667vw, -20px);
  left: 0;
  width: min(14.8958333333vw, 286px);
}
.visual__bg .right .cloud {
  right: 0;
  will-change: translate, transform;
}
@media (prefers-reduced-motion: no-preference) {
  .visual__bg .right .cloud {
    transition: translate 1.4s cubic-bezier(0.22, 1, 0.36, 1);
  }
}
.visual__bg .right .cloud.is-cloud-out {
  transition: none;
  translate: 100vw 0;
}
@media (prefers-reduced-motion: no-preference) {
  .visual__bg .right .cloud.is-cloud-drift {
    animation: cloud-drift var(--cloud-drift-duration, 8s) ease-in-out infinite;
  }
}
.visual__bg .right .cloud--01 {
  top: max(-4.6875vw, -90px);
  width: min(18.8020833333vw, 361px);
  --cloud-drift-x: min(0.9375vw, 18px);
  --cloud-drift-duration: 8s;
  transition-delay: 0.1s;
}
@media screen and (max-width: 767px) {
  .visual__bg .right .cloud--01 {
    top: 0;
    width: 26.6666666667vw;
  }
}
.visual__bg .right .cloud--02 {
  top: min(8.8541666667vw, 170px);
  width: min(6.40625vw, 123px);
  --cloud-drift-x: min(1.25vw, 24px);
  --cloud-drift-duration: 7.5s;
  transition-delay: 0.25s;
}
@media screen and (max-width: 767px) {
  .visual__bg .right .cloud--02 {
    top: 10.6666666667vw;
  }
}
.visual__bg .right .cloud--03 {
  bottom: min(13.0208333333vw, 250px);
  width: min(14.7916666667vw, 284px);
  --cloud-drift-x: min(1.1458333333vw, 22px);
  --cloud-drift-duration: 9.5s;
  transition-delay: 0.4s;
}
.visual__bg .right .cloud--04 {
  top: min(22.3958333333vw, 430px);
  right: min(8.3333333333vw, 160px);
  width: min(11.6145833333vw, 223px);
  --cloud-drift-x: min(0.8333333333vw, 16px);
  --cloud-drift-duration: 7s;
  transition-delay: 0.55s;
}
@media screen and (max-width: 767px) {
  .visual__bg .right .cloud--04 {
    top: 124vw;
    right: -2.6666666667vw;
    width: 26.6666666667vw;
  }
}
.visual__bg .right .cloud--05 {
  bottom: min(1.5625vw, 30px);
  width: min(10.8854166667vw, 209px);
  --cloud-drift-x: min(1.3541666667vw, 26px);
  --cloud-drift-duration: 10s;
  transition-delay: 0.7s;
}
.visual__bg .object .object-item {
  will-change: transform;
}
@media (prefers-reduced-motion: no-preference) {
  .visual__bg .object .object-item {
    animation: area-object-morph var(--object-morph-duration, 10s) ease-in-out infinite;
    animation-delay: var(--object-morph-delay, 0s);
  }
}
.visual__bg .object .object-item--01 {
  top: min(35.4166666667vw, 680px);
  left: min(6.25vw, 120px);
  width: min(11.09375vw, 213px);
  --object-morph-duration: 9s;
  --object-morph-delay: 0s;
  transform-origin: left center;
}
@media screen and (max-width: 767px) {
  .visual__bg .object .object-item--01 {
    top: auto;
    bottom: 173.3333333333vw;
    left: -2.6666666667vw;
    width: 22.6666666667vw;
  }
}
.visual__bg .object .object-item--02 {
  top: min(31.7708333333vw, 610px);
  right: min(3.125vw, 60px);
  width: min(12.8645833333vw, 247px);
  --object-morph-duration: 11s;
  --object-morph-delay: -3s;
  transform-origin: right center;
}
@media screen and (max-width: 767px) {
  .visual__bg .object .object-item--02 {
    top: auto;
    bottom: 193.3333333333vw;
    right: 2.6666666667vw;
    width: 26.6666666667vw;
  }
}
.visual__bg .object .object-item--03 {
  bottom: max(-3.6458333333vw, -70px);
  left: 0;
  width: min(17.96875vw, 345px);
  --object-morph-duration: 10s;
  --object-morph-delay: -2s;
  transform-origin: left center;
}
@media screen and (max-width: 767px) {
  .visual__bg .object .object-item--03 {
    bottom: -21.3333333333vw;
    left: -13.3333333333vw;
    width: 40vw;
  }
}
.visual__inner {
  position: relative;
  z-index: 1;
  width: 100%;
  padding: min(4.1666666667vw, 80px) 0 min(6.7708333333vw, 130px);
}
@media screen and (max-width: 1023px) {
  .visual__inner {
    padding: 8rem 0 13rem;
  }
}
@media screen and (max-width: 767px) {
  .visual__inner {
    padding: 10.6666666667vw 0 16vw;
  }
}
.visual__text {
  width: min(33.8541666667vw, 650px);
  margin: 0 auto;
}
@media screen and (max-width: 1023px) {
  .visual__text {
    width: calc(100% - 8rem);
    max-width: -moz-fit-content;
    max-width: fit-content;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .visual__text {
    width: 100vw;
    margin-bottom: 4vw;
  }
}
.visual__banner {
  position: absolute;
  top: min(26.0416666667vw, 500px);
  right: min(1.0416666667vw, 20px);
  width: min(16.6666666667vw, 320px);
}
@media screen and (max-width: 1023px) {
  .visual__banner {
    position: static;
    width: 100%;
    padding: 0 4rem;
    margin: 4rem 0;
  }
}
.visual__banner .banner {
  display: block;
  width: 100%;
}
.visual__banner .banner .banner-image {
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
.visual__site-logo {
  width: min(41.6666666667vw, 800px);
  margin: 0 auto min(2.0833333333vw, 40px);
}
@media screen and (max-width: 1023px) {
  .visual__site-logo {
    width: calc(100% - 8rem);
    max-width: -moz-fit-content;
    max-width: fit-content;
    margin: 0 auto 4rem;
  }
}
.visual__site-logo img {
  width: 100%;
  max-width: none;
}
.visual__island-wrapper {
  position: relative;
  width: 100%;
  height: min(33.3333333333vw, 640px);
  margin: 0 auto min(3.6458333333vw, 70px);
}
@media screen and (max-width: 1279px) {
  .visual__island-wrapper {
    width: calc(100% - 8rem);
    max-width: 62rem;
    height: auto;
  }
}
@media screen and (max-width: 767px) {
  .visual__island-wrapper {
    width: calc(100% - 2.6666666667vw);
    max-width: none;
    margin-bottom: 0;
  }
}
.visual__island-wrapper .visual__island {
  position: absolute;
  will-change: translate;
}
@media (prefers-reduced-motion: no-preference) {
  .visual__island-wrapper .visual__island {
    animation: island-float 5s ease-in-out infinite;
  }
}
.visual__island-wrapper .visual__island--main {
  top: 0;
  left: 50%;
  transform: translateX(calc(-50% - min(0.8333333333vw, 16px)));
  width: min(32.2916666667vw, 620px);
  animation-duration: 6s;
  animation-delay: 0s;
}
.visual__island-wrapper .visual__island--01 {
  top: min(5.2083333333vw, 100px);
  left: 50%;
  transform: translateX(calc(-50% - min(22.9166666667vw, 440px)));
  width: min(16.6666666667vw, 320px);
  animation-duration: 5s;
  animation-delay: -1.2s;
}
.visual__island-wrapper .visual__island--02 {
  top: min(17.7083333333vw, 340px);
  left: 50%;
  transform: translateX(calc(-50% - min(14.5833333333vw, 280px)));
  width: min(13.5416666667vw, 260px);
  animation-duration: 4.5s;
  animation-delay: -2s;
}
.visual__island-wrapper .visual__island--03 {
  top: min(22.3958333333vw, 430px);
  left: 50%;
  transform: translateX(-50%);
  width: min(13.5416666667vw, 260px);
  animation-duration: 5.5s;
  animation-delay: -0.8s;
}
.visual__island-wrapper .visual__island--04 {
  top: min(17.7083333333vw, 340px);
  right: 50%;
  transform: translateX(calc(50% + min(14.5833333333vw, 280px)));
  width: min(13.5416666667vw, 260px);
  animation-duration: 4.8s;
  animation-delay: -1.5s;
}
.visual__island-wrapper .visual__island--05 {
  top: min(3.6458333333vw, 70px);
  right: 50%;
  transform: translateX(calc(50% + min(22.9166666667vw, 440px)));
  width: min(16.6666666667vw, 320px);
  animation-duration: 5.2s;
  animation-delay: -0.4s;
}
.visual__island-wrapper .visual__island img {
  width: 100%;
  max-width: none;
}
@media screen and (max-width: 1279px) {
  .visual__island-wrapper .visual__island {
    position: static;
    transform: none;
    width: 100%;
    margin: 0 auto;
  }
  .visual__island-wrapper .visual__island--main {
    width: 100%;
    margin-bottom: 22%;
  }
  .visual__island-wrapper .visual__island--01, .visual__island-wrapper .visual__island--02, .visual__island-wrapper .visual__island--03, .visual__island-wrapper .visual__island--04, .visual__island-wrapper .visual__island--05 {
    width: 50%;
  }
  .visual__island-wrapper .visual__island--03, .visual__island-wrapper .visual__island--05, .visual__island-wrapper .visual__island--01 {
    margin-left: 0;
    margin-right: auto;
    margin-top: -20%;
  }
}
@media screen and (max-width: 1279px) and (max-width: 767px) {
  .visual__island-wrapper .visual__island--03, .visual__island-wrapper .visual__island--05, .visual__island-wrapper .visual__island--01 {
    margin-left: 2vw;
    margin-top: -21.3333333333vw;
  }
}
@media screen and (max-width: 1279px) {
  .visual__island-wrapper .visual__island--02, .visual__island-wrapper .visual__island--04 {
    margin-left: auto;
    margin-right: 0;
    margin-top: -20%;
  }
}
@media screen and (max-width: 1279px) and (max-width: 767px) {
  .visual__island-wrapper .visual__island--02, .visual__island-wrapper .visual__island--04 {
    margin-right: 2vw;
    margin-top: -21.3333333333vw;
  }
}
.visual__info {
  padding: 0 4rem;
}
@media screen and (max-width: 767px) {
  .visual__info {
    padding: 18.6666666667vw 0 0;
  }
}
.visual__info > h2 {
  font-family: "Prompt", sans-serif;
  font-size: min(2.6041666667vw, 50px);
  line-height: 1;
  letter-spacing: 0.1em;
  color: #80191E;
  text-align: center;
  margin-bottom: min(3.125vw, 60px);
}
@media screen and (max-width: 1279px) {
  .visual__info > h2 {
    font-size: 5rem;
    margin-bottom: 6rem;
  }
}
@media screen and (max-width: 767px) {
  .visual__info > h2 {
    font-size: 6.1333333333vw;
    margin-bottom: 6.6666666667vw;
  }
}
.visual__info > p {
  text-align: center;
}
.visual__info > p.bg {
  background-image: url("../image/bg_info-label.svg");
  background-size: 100% auto;
  background-repeat: no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(33.9583333333vw, 652px);
  height: min(2.6041666667vw, 50px);
  font-weight: 500;
  font-size: min(1.25vw, 24px);
  line-height: 1;
  letter-spacing: normal;
  color: #FFFFFF;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .visual__info > p.bg {
    background-image: url("../image/bg_info-label-sp.svg");
    width: 94.9333333333vw;
    height: 8vw;
    font-size: 3.7333333333vw;
  }
}
.visual__info > p:nth-of-type(2) {
  font-weight: 700;
  font-size: min(1.0416666667vw, 20px);
  line-height: 1.6;
  margin: min(2.0833333333vw, 40px) 0 min(2.6041666667vw, 50px);
}
.visual__info > p:nth-of-type(2) .num {
  font-size: 1.7em;
}
.visual__info > p:nth-of-type(2) .day {
  font-size: 1.2em;
}
.visual__info > p:nth-of-type(2) .large {
  font-size: 1.7em;
}
@media screen and (max-width: 767px) {
  .visual__info > p:nth-of-type(2) .large {
    font-size: 1.5em;
  }
}
@media screen and (max-width: 1279px) {
  .visual__info > p:nth-of-type(2) {
    font-size: 2rem;
    margin: 4rem 0 5rem;
  }
}
@media screen and (max-width: 767px) {
  .visual__info > p:nth-of-type(2) {
    font-size: 4.2666666667vw;
    margin: 2.6666666667vw 0 5.3333333333vw;
  }
}
.visual__info > .c-button {
  width: min(17.7083333333vw, 340px);
  height: min(2.6041666667vw, 50px);
  margin: 0 auto min(4.1666666667vw, 80px);
}
@media screen and (max-width: 1279px) {
  .visual__info > .c-button {
    width: 34rem;
    height: 5rem;
    margin-bottom: 8rem;
  }
}
@media screen and (max-width: 767px) {
  .visual__info > .c-button {
    width: 68vw;
    height: 10.6666666667vw;
    margin-bottom: 10.6666666667vw;
  }
}
.visual__info-banner {
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
  align-items: flex-end;
  gap: min(2.0833333333vw, 40px);
}
@media screen and (max-width: 1279px) {
  .visual__info-banner {
    flex-flow: column nowrap;
    gap: 4rem;
  }
}
@media screen and (max-width: 767px) {
  .visual__info-banner {
    gap: 5.3333333333vw;
  }
}
.visual__info-banner .banner-item {
  border: min(0.0520833333vw, 1px) solid #231815;
  border-radius: min(0.78125vw, 15px);
  background-color: #F5F0E8;
  display: flex;
  flex-flow: row nowrap;
  gap: min(2.0833333333vw, 40px);
  width: calc(100% - 4rem);
  height: auto;
  padding: min(1.0416666667vw, 20px);
  box-shadow: min(0.2604166667vw, 5px) min(0.2604166667vw, 5px) 0 0 #C9CACA;
}
@media screen and (min-width: 1280px) {
  .visual__info-banner .banner-item {
    width: min(36.4583333333vw, 700px);
    height: min(15.625vw, 300px);
  }
}
@media screen and (max-width: 1279px) {
  .visual__info-banner .banner-item {
    border-radius: 2rem;
    gap: 4rem;
    padding: 2rem;
    margin: 0 auto;
    box-shadow: 0.5rem 0.5rem 0 0 #C9CACA;
  }
}
@media screen and (max-width: 767px) {
  .visual__info-banner .banner-item {
    border-radius: 2.6666666667vw;
    flex-flow: column nowrap;
    gap: 5.3333333333vw;
    padding: 4vw;
    box-shadow: 0.6666666667vw 0.6666666667vw 0 0 #C9CACA;
  }
}
.visual__info-banner .banner-item:has(.banner-item__full) {
  position: relative;
  border: none;
  background-color: transparent;
  padding: 0;
  box-shadow: none;
}
@media screen and (min-width: 1280px) {
  .visual__info-banner .banner-item:has(.banner-item__full) {
    height: -moz-fit-content;
    height: fit-content;
  }
}
@media screen and (max-width: 767px) {
  .visual__info-banner .banner-item:has(.banner-item__full) {
    background-color: transparent;
  }
}
.visual__info-banner .banner-item__image {
  position: relative;
  flex-shrink: 0;
  width: min(13.5416666667vw, 260px);
}
@media screen and (max-width: 1279px) {
  .visual__info-banner .banner-item__image {
    width: 26rem;
  }
}
@media screen and (max-width: 767px) {
  .visual__info-banner .banner-item__image {
    overflow: hidden;
    border-radius: 1.5rem;
    width: 32vw;
    aspect-ratio: 5/4;
    margin-left: auto;
    margin-bottom: -30.6666666667vw;
  }
}
.visual__info-banner .banner-item__image picture,
.visual__info-banner .banner-item__image img {
  width: 100%;
  max-width: none;
}
.visual__info-banner .banner-item__image figcaption {
  position: absolute;
  bottom: min(0.5208333333vw, 10px);
  right: min(0.5208333333vw, 10px);
  font-size: min(0.625vw, 12px);
  line-height: 1;
  color: #FFFFFF;
}
@media screen and (max-width: 767px) {
  .visual__info-banner .banner-item__image figcaption {
    bottom: 1.3333333333vw;
    right: 1.3333333333vw;
    font-size: 2.6666666667vw;
  }
}
@media screen and (max-width: 767px) {
  .visual__info-banner .banner-item__content {
    padding-top: 5.3333333333vw;
  }
}
.visual__info-banner .banner-item__full {
  width: 100%;
}
.visual__info-banner .banner-item__full img {
  width: 100%;
  max-width: none;
}
.visual__info-banner .banner-item__float {
  position: absolute;
  top: max(-0.5208333333vw, -10px);
  left: max(-0.5208333333vw, -10px);
  width: min(5vw, 96px);
}
@media screen and (max-width: 1279px) {
  .visual__info-banner .banner-item__float {
    top: -1rem;
    left: -1rem;
    width: 10rem;
  }
}
@media screen and (max-width: 767px) {
  .visual__info-banner .banner-item__float {
    display: none;
    top: -1.3333333333vw;
    left: -1.3333333333vw;
    width: 13.3333333333vw;
  }
}
.visual__info-banner .banner-item__content p:nth-of-type(1) {
  font-weight: 500;
  font-size: min(1.5625vw, 30px);
  text-align: center;
}
.visual__info-banner .banner-item__content p:nth-of-type(1) .small {
  display: block;
  font-weight: 700;
  font-size: min(1.0416666667vw, 20px);
}
@media screen and (max-width: 1279px) {
  .visual__info-banner .banner-item__content p:nth-of-type(1) {
    font-size: 3rem;
  }
  .visual__info-banner .banner-item__content p:nth-of-type(1) .small {
    font-size: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .visual__info-banner .banner-item__content p:nth-of-type(1) {
    font-size: 5.3333333333vw;
    text-align: left;
  }
  .visual__info-banner .banner-item__content p:nth-of-type(1) .small {
    font-size: 3.2vw;
  }
}
.visual__info-banner .banner-item__content p:nth-of-type(2) {
  font-weight: 500;
  font-size: min(0.8333333333vw, 16px);
  line-height: 1.5;
  margin: min(1.3020833333vw, 25px) 0 min(1.5625vw, 30px);
}
@media screen and (max-width: 1279px) {
  .visual__info-banner .banner-item__content p:nth-of-type(2) {
    font-size: 1.6rem;
    margin: 2.5rem 0 3rem;
  }
}
@media screen and (max-width: 767px) {
  .visual__info-banner .banner-item__content p:nth-of-type(2) {
    font-size: 3.4666666667vw;
    text-align: left;
    margin: 10.6666666667vw 0 5.3333333333vw;
  }
}
.visual__info-banner .banner-item__content .c-button {
  width: 100%;
}
@media screen and (min-width: 1280px) {
  .visual__info-banner .banner-item__content .c-button {
    max-width: min(17.7083333333vw, 340px);
    min-height: min(2.6041666667vw, 50px);
  }
}
@media screen and (max-width: 1279px) {
  .visual__info-banner .banner-item__content .c-button {
    max-width: 34rem;
    min-height: 6rem;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .visual__info-banner .banner-item__content .c-button {
    max-width: 68vw;
    min-height: 10.6666666667vw;
    margin: 0 auto;
  }
}
.visual__note {
  width: min(72.9166666667vw, 1400px);
  margin: min(2.0833333333vw, 40px) auto 0;
}
.visual__note p {
  font-size: 1rem;
}
@media screen and (max-width: 767px) {
  .visual__note {
    width: 100%;
    padding: 0 2.6666666667vw;
    margin-top: 5.3333333333vw;
  }
}

.info {
  width: 100%;
}
.info__inner {
  overflow-x: clip;
  position: relative;
  width: 100%;
  padding: min(8.3333333333vw, 160px) 0 min(5.2083333333vw, 100px);
}
@media screen and (max-width: 767px) {
  .info__inner {
    padding: 18.6666666667vw 0 0;
  }
}
.info__inner .pattern {
  pointer-events: none;
  position: absolute;
}
.info__inner .pattern--01 {
  top: min(20.8333333333vw, 400px);
  left: max(-5.2083333333vw, -100px);
  width: min(16.6666666667vw, 320px);
}
@media screen and (max-width: 767px) {
  .info__inner .pattern--01 {
    top: 48vw;
    left: 74.6666666667vw;
    width: 21.3333333333vw;
  }
}
.info__inner .pattern--02 {
  top: min(14.0625vw, 270px);
  right: min(6.25vw, 120px);
  width: min(10.4166666667vw, 200px);
}
@media screen and (max-width: 767px) {
  .info__inner .pattern--02 {
    top: 130.6666666667vw;
    right: 86.6666666667vw;
    width: 21.3333333333vw;
  }
}
.info__inner .photo {
  position: absolute;
}
.info__inner .photo--01 {
  bottom: min(2.0833333333vw, 40px);
  left: min(4.1666666667vw, 80px);
  width: 30%;
  max-width: min(27.0833333333vw, 520px);
}
@media screen and (max-width: 1023px) {
  .info__inner .photo--01 {
    display: none;
  }
}
.info__inner .photo--02 {
  bottom: min(3.6458333333vw, 70px);
  right: min(4.1666666667vw, 80px);
  width: 30%;
  max-width: min(23.9583333333vw, 460px);
}
@media screen and (max-width: 1023px) {
  .info__inner .photo--02 {
    display: none;
  }
}
.info__title .title-image {
  width: min(36.9791666667vw, 710px);
  margin: 0 auto;
}
@media screen and (max-width: 1279px) {
  .info__title .title-image {
    width: 71rem;
  }
}
@media screen and (max-width: 767px) {
  .info__title .title-image {
    width: 87.3333333333vw;
  }
}
.info__title > h3 {
  font-weight: 700;
  font-size: min(1.3541666667vw, 26px);
  line-height: 1;
  letter-spacing: 0.05em;
  text-align: center;
  margin: min(2.0833333333vw, 40px) 0 min(4.1666666667vw, 80px);
}
@media screen and (max-width: 1279px) {
  .info__title > h3 {
    font-size: 2.6rem;
    margin: 4rem 0 8rem;
  }
}
@media screen and (max-width: 767px) {
  .info__title > h3 {
    font-size: 3.7333333333vw;
    margin: 4.6666666667vw 0 13.3333333333vw;
  }
}
.info__text p {
  font-weight: 700;
  font-size: min(0.9375vw, 18px);
  line-height: 2.2;
  text-align: center;
}
.info__text p + p {
  margin-top: min(1.5625vw, 30px);
}
@media screen and (max-width: 1279px) {
  .info__text p {
    font-size: 1.8rem;
  }
  .info__text p + p {
    margin-top: 3rem;
  }
}
@media screen and (max-width: 767px) {
  .info__text p {
    font-size: 3.2vw;
  }
  .info__text p + p {
    margin-top: 4vw;
  }
}
@media screen and (min-width: 1024px) {
  .info__slider {
    display: none;
  }
}
@media screen and (max-width: 1023px) {
  .info__slider {
    width: 100%;
    padding: 0 2rem;
    margin-top: 10rem;
  }
}
@media screen and (max-width: 767px) {
  .info__slider {
    position: relative;
    height: auto;
    aspect-ratio: 2/1;
    padding: 0;
    margin-top: 6.6666666667vw;
  }
  .info__slider .helper {
    position: absolute;
    bottom: -2.6666666667vw;
    right: 2.6666666667vw;
    z-index: 1;
    width: 10.6666666667vw;
    pointer-events: none;
  }
  .info__slider .helper img {
    display: block;
    width: 100%;
    max-width: none;
    height: auto;
  }
  .info__slider .track {
    overflow-x: auto;
    overflow-y: clip;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    scroll-snap-type: x proximity;
    height: 100%;
  }
  .info__slider .track::-webkit-scrollbar {
    display: none;
  }
  .info__slider .image {
    width: -moz-max-content;
    width: max-content;
    height: 100%;
    scroll-snap-align: start;
  }
  .info__slider img {
    display: block;
    width: auto;
    max-width: none;
    height: 100%;
  }
}

.hint {
  position: relative;
  background-image: url("../image/bg_hint-pc.png");
  background-image: -webkit-image-set(url("../image/bg_hint-pc.webp") type("image/webp"), url("../image/bg_hint-pc.png") type("image/png"));
  background-image: image-set(url("../image/bg_hint-pc.webp") type("image/webp"), url("../image/bg_hint-pc.png") type("image/png"));
  background-size: 100% auto;
  background-position: center top;
  background-repeat: no-repeat;
  width: 100%;
  padding: min(15.625vw, 300px) 0 min(29.6875vw, 570px);
}
@media screen and (max-width: 1279px) {
  .hint {
    background-size: auto 100%;
    padding: 30rem 0 50rem;
  }
}
@media screen and (max-width: 767px) {
  .hint {
    padding: 40vw 0 66.6666666667vw;
  }
}
.hint__inner {
  position: relative;
  background-image: url("../image/bg_hint-content.svg");
  background-size: 100% auto;
  background-position: center top;
  background-repeat: no-repeat;
  width: 100%;
  max-width: min(75vw, 1440px);
  padding: min(9.375vw, 180px) 0 min(14.5833333333vw, 280px);
  margin: 0 auto;
}
@media screen and (max-width: 1279px) {
  .hint__inner {
    background-image: url("../image/bg_hint-content.svg");
    max-width: none;
    padding: 18rem 0 0;
  }
}
@media screen and (max-width: 767px) {
  .hint__inner {
    padding: 21.3333333333vw 0 0;
  }
}
.hint__background {
  overflow-x: clip;
  pointer-events: none;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.hint__background .left,
.hint__background .right,
.hint__background .top,
.hint__background .pattern,
.hint__background .cloud,
.hint__background .flake {
  position: absolute;
}
.hint__background .left,
.hint__background .right,
.hint__background .top {
  inset: 0;
  width: 100%;
  height: 100%;
}
.hint__background .left .pattern--01 {
  top: min(45.8333333333vw, 880px);
  left: min(4.6875vw, 90px);
  width: min(16.6666666667vw, 320px);
}
.hint__background .left .pattern--02 {
  bottom: min(22.3958333333vw, 430px);
  left: max(-3.6458333333vw, -70px);
  width: min(10.4166666667vw, 200px);
}
.hint__background .left .cloud--01 {
  bottom: min(46.875vw, 900px);
  left: min(2.6041666667vw, 50px);
  width: min(15.625vw, 300px);
  --cloud-drift-x: max(-1.1458333333vw, -22px);
  --cloud-drift-duration: 8.5s;
}
.hint__background .left .flake--01 {
  top: min(6.25vw, 120px);
  left: 0;
  width: min(18.5416666667vw, 356px);
}
.hint__background .left .flake--02 {
  bottom: min(37.5vw, 720px);
  left: min(5.2083333333vw, 100px);
  width: min(20vw, 384px);
}
.hint__background .right .pattern--01 {
  bottom: min(52.0833333333vw, 1000px);
  right: min(7.2916666667vw, 140px);
  width: min(10.4166666667vw, 200px);
}
.hint__background .right .pattern--02 {
  bottom: min(21.3541666667vw, 410px);
  right: max(-2.0833333333vw, -40px);
  width: min(16.6666666667vw, 320px);
}
.hint__background .right .cloud--01 {
  bottom: min(71.3541666667vw, 1370px);
  right: min(2.6041666667vw, 50px);
  width: min(15.625vw, 300px);
  --cloud-drift-x: min(1.0416666667vw, 20px);
  --cloud-drift-duration: 9s;
}
.hint__background .right .flake--01 {
  top: min(48.9583333333vw, 940px);
  right: min(3.125vw, 60px);
  width: min(22.5520833333vw, 433px);
}
.hint__background .top .cloud--01 {
  top: max(-5.7291666667vw, -110px);
  left: 0;
  width: min(17.5520833333vw, 337px);
  --cloud-drift-x: max(-0.9375vw, -18px);
  --cloud-drift-duration: 7.5s;
}
@media screen and (max-width: 767px) {
  .hint__background .top .cloud--01 {
    top: 8vw;
    width: 26.6666666667vw;
  }
}
.hint__background .top .cloud--02 {
  top: max(-6.25vw, -120px);
  right: 0;
  width: min(15.8854166667vw, 305px);
  --cloud-drift-x: min(1.25vw, 24px);
  --cloud-drift-duration: 10s;
}
@media screen and (max-width: 767px) {
  .hint__background .top .cloud--02 {
    top: 8vw;
    width: 32vw;
  }
}
.hint__background .top .flake--01 {
  top: min(6.7708333333vw, 130px);
  right: max(-2.6041666667vw, -50px);
  width: min(32.5vw, 624px);
}
@media screen and (max-width: 767px) {
  .hint__background .top .flake--01 {
    width: 40vw;
  }
}
.hint__background .cloud {
  will-change: translate, transform;
}
@media (prefers-reduced-motion: no-preference) {
  .hint__background .cloud {
    transition: translate 1.4s cubic-bezier(0.22, 1, 0.36, 1);
  }
}
@media (prefers-reduced-motion: no-preference) {
  .hint__background .cloud.is-cloud-drift {
    animation: cloud-drift var(--cloud-drift-duration, 8s) ease-in-out infinite;
  }
}
.hint__background .left .cloud.is-cloud-out,
.hint__background .top .cloud--01.is-cloud-out {
  transition: none;
  translate: -100vw 0;
}
.hint__background .right .cloud.is-cloud-out,
.hint__background .top .cloud--02.is-cloud-out {
  transition: none;
  translate: 100vw 0;
}
.hint__background .flake {
  opacity: 0;
  scale: 0;
  will-change: opacity, scale;
}
@media (prefers-reduced-motion: no-preference) {
  .hint__background .flake {
    transition: opacity 0.1s ease-out, scale 0.6s cubic-bezier(0.34, 1.8, 0.64, 1);
  }
}
.hint__background .flake.is-flake-in {
  opacity: 1;
  scale: 1;
}
.hint__title {
  position: relative;
  border-bottom: min(0.15625vw, 3px) dotted #2B7B61;
  width: calc(100% - min(8.3333333333vw, 160px));
  padding-bottom: min(3.125vw, 60px);
  margin: 0 auto min(4.6875vw, 90px);
}
@media screen and (max-width: 1279px) {
  .hint__title {
    border-bottom-width: 0.3rem;
    width: calc(100% - 16rem);
    padding-bottom: 6rem;
    margin: 0 auto 9rem;
  }
}
@media screen and (max-width: 767px) {
  .hint__title {
    border-bottom-width: 0.5333333333vw;
    width: calc(100% - 10.6666666667vw);
    padding-bottom: 5.3333333333vw;
    margin: 0 auto 12vw;
  }
}
.hint__title > .text {
  width: min(16.1458333333vw, 310px);
  margin: 0 auto min(2.0833333333vw, 40px);
}
@media screen and (max-width: 1279px) {
  .hint__title > .text {
    width: 31rem;
    margin: 0 auto 4rem;
  }
}
@media screen and (max-width: 767px) {
  .hint__title > .text {
    width: 46.6666666667vw;
    margin: 0 auto 5.3333333333vw;
  }
}
.hint__title > h2 {
  display: flex;
  align-items: center;
  width: -moz-fit-content;
  width: fit-content;
  font-weight: 700;
  font-size: min(2.1875vw, 42px);
  line-height: 1.6;
  letter-spacing: 0.05em;
  color: #2B7B61;
  text-align: center;
  margin: 0 auto;
}
.hint__title > h2 span {
  display: inline-block;
  width: min(9.375vw, 180px);
  margin: 0 min(0.5208333333vw, 10px);
}
@media screen and (max-width: 1279px) {
  .hint__title > h2 {
    font-size: 3.6rem;
  }
  .hint__title > h2 span {
    width: 14rem;
    margin: 0 1rem;
  }
}
@media screen and (max-width: 767px) {
  .hint__title > h2 {
    font-size: 5.6vw;
  }
  .hint__title > h2 span {
    width: 21.3333333333vw;
    margin: 0 1.3333333333vw;
  }
}
.hint__title .illust {
  position: absolute;
  display: flex;
  flex-flow: column nowrap;
}
.hint__title .illust--01 {
  bottom: min(2.0833333333vw, 40px);
  left: max(-2.6041666667vw, -50px);
  align-items: flex-start;
  gap: min(0.78125vw, 15px);
}
.hint__title .illust--01 .text {
  width: min(16.1458333333vw, 310px);
}
.hint__title .illust--01 .image {
  width: min(6.7708333333vw, 130px);
}
@media screen and (max-width: 1279px) {
  .hint__title .illust--01 {
    bottom: 4rem;
    left: -5rem;
    gap: 1.5rem;
  }
  .hint__title .illust--01 .text {
    width: 20rem;
  }
  .hint__title .illust--01 .image {
    width: 14rem;
  }
}
@media screen and (max-width: 767px) {
  .hint__title .illust--01 {
    bottom: 21.3333333333vw;
    left: -2.6666666667vw;
    gap: 2.6666666667vw;
  }
  .hint__title .illust--01 .text {
    width: 42.6666666667vw;
  }
  .hint__title .illust--01 .image {
    width: 13.3333333333vw;
  }
}
.hint__title .illust--02 {
  bottom: min(3.125vw, 60px);
  right: max(-2.6041666667vw, -50px);
  align-items: flex-end;
  gap: min(0.78125vw, 15px);
}
.hint__title .illust--02 .text {
  width: min(13.5416666667vw, 260px);
}
.hint__title .illust--02 .image {
  width: min(8.8541666667vw, 170px);
}
@media screen and (max-width: 1279px) {
  .hint__title .illust--02 {
    bottom: 6rem;
    right: -5rem;
    gap: 1.5rem;
  }
  .hint__title .illust--02 .text {
    width: 20rem;
  }
  .hint__title .illust--02 .image {
    width: 17rem;
  }
}
@media screen and (max-width: 767px) {
  .hint__title .illust--02 {
    bottom: 21.3333333333vw;
    right: -1.3333333333vw;
    gap: 2.6666666667vw;
  }
  .hint__title .illust--02 .text {
    width: 37.3333333333vw;
  }
  .hint__title .illust--02 .image {
    width: 16vw;
  }
}
.hint__title .illust .image.is-fade-target {
  translate: 0 0;
  filter: blur(20px);
  will-change: opacity, filter;
}
@media (prefers-reduced-motion: no-preference) {
  .hint__title .illust .image.is-fade-target {
    transition: opacity 1.1s cubic-bezier(0.22, 1, 0.36, 1), filter 1.1s cubic-bezier(0.22, 1, 0.36, 1);
  }
}
.hint__title .illust .image.is-fade-in {
  filter: blur(0);
}
.hint__content {
  position: relative;
  background-image: url("../image/bg_hint-lifestyle.png");
  background-image: -webkit-image-set(url("../image/bg_hint-lifestyle.webp") type("image/webp"), url("../image/bg_hint-lifestyle.png") type("image/png"));
  background-image: image-set(url("../image/bg_hint-lifestyle.webp") type("image/webp"), url("../image/bg_hint-lifestyle.png") type("image/png"));
  background-size: min(54.6875vw, 1050px) auto;
  background-position: center;
  background-repeat: no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(54.6875vw, 1050px);
  height: auto;
  min-height: min(53.6458333333vw, 1030px);
  margin: 0 auto;
}
@media screen and (max-width: 1279px) {
  .hint__content {
    background-color: #FFFFFF;
    background-image: url("../image/bg_hint-content-sp-top.svg"), url("../image/bg_hint-content-sp-bottom.svg"), linear-gradient(to bottom, transparent 33rem, #FCF3F0 33rem, #FCF3F0 90%, transparent 90%);
    background-size: 100% auto, 100% auto;
    background-position: center top, center calc(100% - 11rem);
    flex-flow: column nowrap;
    gap: 12rem;
    max-width: none;
    max-height: none;
    padding: 25rem 0 40rem;
  }
}
@media screen and (max-width: 767px) {
  .hint__content {
    background-image: url("../image/bg_hint-content-sp-top.svg"), url("../image/bg_hint-content-sp-bottom.svg"), linear-gradient(to bottom, transparent 43.3333333333vw, #FCF3F0 43.3333333333vw, #FCF3F0 calc(100% - 44vw), transparent calc(100% - 44vw));
    background-position: center top, center calc(100% - 14.6666666667vw);
    gap: 0;
    padding: 33.3333333333vw 0 53.3333333333vw;
  }
}
.hint__content .lifestyle {
  color: #DE615E;
}
@media screen and (max-width: 767px) {
  .hint__content .lifestyle {
    margin-bottom: 10.6666666667vw;
  }
}
.hint__content .lifestyle > p {
  text-align: center;
}
.hint__content .lifestyle > p:nth-of-type(1) {
  font-weight: 700;
  font-size: min(1.25vw, 24px);
  line-height: 1.6;
  letter-spacing: 0.05em;
}
.hint__content .lifestyle > p:nth-of-type(2) {
  font-weight: 500;
  font-size: min(0.8333333333vw, 16px);
  line-height: 2;
  margin-top: min(2.0833333333vw, 40px);
}
@media screen and (max-width: 1279px) {
  .hint__content .lifestyle > p:nth-of-type(1) {
    font-size: 2.4rem;
  }
  .hint__content .lifestyle > p:nth-of-type(2) {
    font-size: 1.6rem;
    margin-top: 4rem;
  }
}
@media screen and (max-width: 767px) {
  .hint__content .lifestyle > p:nth-of-type(1) {
    font-size: 3.4666666667vw;
  }
  .hint__content .lifestyle > p:nth-of-type(2) {
    font-size: 3.2vw;
    margin-top: 8vw;
  }
}
.hint__content .lifestyle__title {
  width: min(14.5833333333vw, 280px);
  margin: min(1.5625vw, 30px) auto 0;
}
.hint__content .lifestyle__title figcaption {
  font-weight: 700;
  font-size: min(0.9375vw, 18px);
  line-height: 1.6;
  letter-spacing: 0.05em;
  text-align: center;
  margin-top: 1em;
}
@media screen and (max-width: 1279px) {
  .hint__content .lifestyle__title {
    width: 28rem;
    margin-top: 3rem;
  }
  .hint__content .lifestyle__title figcaption {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  .hint__content .lifestyle__title {
    width: 53.3333333333vw;
    margin-top: 5.3333333333vw;
  }
  .hint__content .lifestyle__title figcaption {
    font-size: 3.4666666667vw;
  }
}
.hint__content .orbit {
  position: absolute;
}
.hint__content .orbit .orbit-text {
  position: absolute;
}
.hint__content .orbit .orbit-text p {
  font-weight: 700;
  font-size: min(0.9375vw, 18px);
  letter-spacing: 0.02em;
  writing-mode: vertical-rl;
}
@media screen and (max-width: 1279px) {
  .hint__content .orbit .orbit-text p {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  .hint__content .orbit .orbit-text p {
    font-size: 3.2vw;
  }
}
.hint__content .orbit .orbit-title {
  position: absolute;
}
@media screen and (max-width: 767px) {
  .hint__content .orbit .orbit-title.pc {
    display: none !important;
  }
}
@media screen and (min-width: 768px) {
  .hint__content .orbit .orbit-title.sp {
    display: none !important;
  }
}
.hint__content .orbit .orbit-image {
  width: 100%;
}
.hint__content .orbit.resort {
  top: min(0.2604166667vw, 5px);
  left: min(2.0833333333vw, 40px);
}
.hint__content .orbit.resort .orbit-image {
  width: min(20.1041666667vw, 386px);
}
.hint__content .orbit.resort .orbit-text {
  top: min(1.5625vw, 30px);
  left: max(-1.5625vw, -30px);
  transform: translateX(-100%);
}
.hint__content .orbit.resort .orbit-text p {
  color: #35729B;
}
.hint__content .orbit.resort .orbit-title {
  top: max(-0.5208333333vw, -10px);
  right: min(2.6041666667vw, 50px);
  width: min(10vw, 192px);
}
@media screen and (max-width: 1279px) {
  .hint__content .orbit.resort {
    flex-flow: row-reverse;
  }
  .hint__content .orbit.resort .orbit-image {
    width: 35rem;
  }
  .hint__content .orbit.resort .orbit-title {
    width: 19.2rem;
  }
}
@media screen and (max-width: 767px) {
  .hint__content .orbit.resort {
    gap: 6.6666666667vw;
    margin-left: 2.6666666667vw;
    margin-right: auto;
  }
  .hint__content .orbit.resort .orbit-image {
    width: 46.6666666667vw;
  }
  .hint__content .orbit.resort .orbit-title {
    width: 25.6vw;
  }
}
.hint__content .orbit.botanical {
  bottom: min(7.2916666667vw, 140px);
  left: max(-3.6458333333vw, -70px);
}
.hint__content .orbit.botanical .orbit-image {
  width: min(16.5625vw, 318px);
}
.hint__content .orbit.botanical .orbit-text {
  top: min(8.8541666667vw, 170px);
  left: max(-2.0833333333vw, -40px);
}
.hint__content .orbit.botanical .orbit-text p {
  color: #298948;
}
.hint__content .orbit.botanical .orbit-title {
  bottom: max(-1.0416666667vw, -20px);
  left: min(3.125vw, 60px);
  transform: translateY(100%);
  width: min(7.6041666667vw, 146px);
}
@media screen and (max-width: 1279px) {
  .hint__content .orbit.botanical {
    flex-flow: row-reverse nowrap;
  }
  .hint__content .orbit.botanical .orbit-image {
    width: 28.5rem;
  }
  .hint__content .orbit.botanical .orbit-title {
    width: 14.6rem;
  }
}
@media screen and (max-width: 767px) {
  .hint__content .orbit.botanical {
    gap: 6.6666666667vw;
    margin-left: 2.6666666667vw;
    margin-right: 4vw;
  }
  .hint__content .orbit.botanical .orbit-image {
    width: 38vw;
  }
  .hint__content .orbit.botanical .orbit-title {
    width: 19.4666666667vw;
  }
}
.hint__content .orbit.party {
  bottom: max(-9.375vw, -180px);
  left: min(16.6666666667vw, 320px);
}
.hint__content .orbit.party .orbit-image {
  width: min(19.7916666667vw, 380px);
}
.hint__content .orbit.party .orbit-text {
  top: min(2.0833333333vw, 40px);
  right: max(-1.0416666667vw, -20px);
  transform: translateX(100%);
}
.hint__content .orbit.party .orbit-text p {
  color: #C02947;
}
.hint__content .orbit.party .orbit-title {
  bottom: min(0.78125vw, 15px);
  left: max(-1.0416666667vw, -20px);
  width: min(7.65625vw, 147px);
}
@media screen and (max-width: 1279px) {
  .hint__content .orbit.party {
    flex-flow: row-reverse nowrap;
  }
  .hint__content .orbit.party .orbit-image {
    width: 34rem;
  }
  .hint__content .orbit.party .orbit-title {
    width: 14.7rem;
  }
}
@media screen and (max-width: 767px) {
  .hint__content .orbit.party {
    gap: 6.6666666667vw;
    margin: 0 2.6666666667vw;
  }
  .hint__content .orbit.party .orbit-image {
    width: 41.3333333333vw;
  }
  .hint__content .orbit.party .orbit-title {
    width: 19.6vw;
  }
}
.hint__content .orbit.outdoor {
  bottom: min(8.3333333333vw, 160px);
  right: max(-5.2083333333vw, -100px);
}
.hint__content .orbit.outdoor .orbit-image {
  width: min(17.5520833333vw, 337px);
}
.hint__content .orbit.outdoor .orbit-text {
  top: min(10.4166666667vw, 200px);
  right: max(-1.5625vw, -30px);
}
.hint__content .orbit.outdoor .orbit-text p {
  color: #A89851;
}
.hint__content .orbit.outdoor .orbit-title {
  bottom: max(-1.0416666667vw, -20px);
  left: min(5.2083333333vw, 100px);
  transform: translateY(100%);
  width: min(9.6875vw, 186px);
}
@media screen and (max-width: 1279px) {
  .hint__content .orbit.outdoor .orbit-image {
    width: 30.3rem;
  }
  .hint__content .orbit.outdoor .orbit-title {
    width: 18.6rem;
  }
}
@media screen and (max-width: 767px) {
  .hint__content .orbit.outdoor {
    margin-left: auto;
    margin-right: 4vw;
  }
  .hint__content .orbit.outdoor .orbit-image {
    width: 40.4vw;
  }
  .hint__content .orbit.outdoor .orbit-title {
    width: 24.8vw;
  }
}
.hint__content .orbit.pet {
  top: min(0.2604166667vw, 5px);
  right: min(4.1666666667vw, 80px);
}
.hint__content .orbit.pet .orbit-image {
  width: min(19.53125vw, 375px);
}
.hint__content .orbit.pet .orbit-text {
  top: min(1.0416666667vw, 20px);
  right: max(-1.8229166667vw, -35px);
  transform: translateX(100%);
}
.hint__content .orbit.pet .orbit-text p {
  color: #A89851;
}
.hint__content .orbit.pet .orbit-title {
  top: min(0.1041666667vw, 2px);
  right: min(0.1041666667vw, 2px);
  width: min(6.5625vw, 126px);
}
@media screen and (max-width: 1279px) {
  .hint__content .orbit.pet .orbit-image {
    width: 33rem;
  }
  .hint__content .orbit.pet .orbit-title {
    width: 12.6rem;
  }
}
@media screen and (max-width: 767px) {
  .hint__content .orbit.pet {
    gap: 4.6666666667vw;
    margin-left: auto;
    margin-right: 2.6666666667vw;
    margin-bottom: -5.3333333333vw;
  }
  .hint__content .orbit.pet .orbit-image {
    width: 44vw;
  }
  .hint__content .orbit.pet .orbit-title {
    width: 16.8vw;
  }
}
@media screen and (max-width: 1279px) {
  .hint__content .orbit {
    position: relative;
    top: 0 !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    transform: none;
    display: flex;
    align-items: center;
    gap: 3.5rem;
    width: -moz-fit-content;
    width: fit-content;
  }
  .hint__content .orbit .orbit-title {
    position: static;
    transform: none !important;
    margin-bottom: 4rem;
  }
  .hint__content .orbit .orbit-text {
    position: static;
    transform: none !important;
  }
  .hint__content .orbit .orbit-text p {
    writing-mode: horizontal-tb !important;
  }
  .hint__content .orbit .orbit-image {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .hint__content .orbit {
    gap: 0;
  }
  .hint__content .orbit .orbit-title {
    margin-bottom: 5.3333333333vw;
  }
  .hint__content .orbit .orbit-text {
    margin-bottom: 5.3333333333vw;
  }
  .hint__content .orbit .orbit-image {
    width: 100%;
  }
}
.hint__content.is-fade-target {
  opacity: 1;
  translate: 0 0;
}
.hint__content .lifestyle {
  opacity: 0;
  translate: 0 min(2.0833333333vw, 40px);
  will-change: opacity, translate;
}
@media (prefers-reduced-motion: no-preference) {
  .hint__content .lifestyle {
    transition: opacity 0.6s cubic-bezier(0.22, 1, 0.36, 1), translate 0.6s cubic-bezier(0.22, 1, 0.36, 1);
  }
}
.hint__content .orbit {
  opacity: 0;
  scale: 0.6;
  will-change: opacity, scale;
}
@media (prefers-reduced-motion: no-preference) {
  .hint__content .orbit {
    transition: opacity 0.5s cubic-bezier(0.22, 1, 0.36, 1), scale 0.7s cubic-bezier(0.34, 1.56, 0.64, 1);
  }
}
.hint__content.is-fade-in .lifestyle {
  opacity: 1;
  translate: 0 0;
}
.hint__content.is-fade-in .orbit {
  opacity: 1;
  scale: 1;
}
.hint__content.is-fade-in .orbit:nth-of-type(2) {
  transition-delay: 0.5s;
}
.hint__content.is-fade-in .orbit:nth-of-type(3) {
  transition-delay: 0.65s;
}
.hint__content.is-fade-in .orbit:nth-of-type(4) {
  transition-delay: 0.8s;
}
.hint__content.is-fade-in .orbit:nth-of-type(5) {
  transition-delay: 0.95s;
}
.hint__content.is-fade-in .orbit:nth-of-type(6) {
  transition-delay: 1.1s;
}

@keyframes area-building-cloud-drift {
  0%, 100% {
    translate: 0 0;
  }
  50% {
    translate: var(--cloud-drift-x, 15px) 0;
  }
}
@keyframes area-object-morph {
  0%, 100% {
    transform: skewX(0) skewY(0) rotate(0deg) scale(1);
  }
  25% {
    transform: skewX(3deg) skewY(-1.5deg) rotate(1.5deg) scale(1.03, 0.97);
  }
  50% {
    transform: skewX(-2deg) skewY(3deg) rotate(-1.5deg) scale(0.97, 1.03);
  }
  75% {
    transform: skewX(1.5deg) skewY(1.5deg) rotate(0.8deg) scale(1.02, 1.01);
  }
}
.area {
  position: relative;
  background-color: #72ceda;
  background-image: url("../image/bg_area.png");
  background-image: -webkit-image-set(url("../image/bg_area.webp") type("image/webp"), url("../image/bg_area.png") type("image/png"));
  background-image: image-set(url("../image/bg_area.webp") type("image/webp"), url("../image/bg_area.png") type("image/png"));
  background-size: 100% auto;
  background-position: center top;
  background-repeat: no-repeat;
  width: 100%;
}
.area__inner {
  overflow-x: clip;
  z-index: 1;
  position: relative;
  width: 100%;
  padding: min(7.2916666667vw, 140px) min(2.0833333333vw, 40px) 0;
}
@media screen and (max-width: 1279px) {
  .area__inner {
    padding: 14rem 4rem 0;
  }
}
@media screen and (max-width: 767px) {
  .area__inner {
    padding: 18.6666666667vw 5.3333333333vw 0;
  }
}
.area__background {
  overflow: hidden;
  position: absolute;
  inset: 0;
  background-image: linear-gradient(to bottom, transparent 50%, #D5E8B7 50%);
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 1279px) {
  .area__background {
    background-image: linear-gradient(to bottom, transparent 10%, #D5E8B7 20%);
  }
}
.area__background .left,
.area__background .right {
  position: absolute;
  inset: 0;
}
.area__background .left figure,
.area__background .right figure {
  position: absolute;
  margin: 0;
}
.area__background .left figure img,
.area__background .right figure img {
  width: 100%;
  max-width: none;
}
.area__background .left .pattern--01 {
  top: min(10.4166666667vw, 200px);
  left: max(-4.6875vw, -90px);
  width: min(16.6666666667vw, 320px);
}
.area__background .left .pattern--02 {
  top: min(62.5vw, 1200px);
  left: min(3.125vw, 60px);
  width: min(10.4166666667vw, 200px);
}
.area__background .left .pattern--03 {
  top: min(132.8125vw, 2550px);
  left: min(5.2083333333vw, 100px);
  width: min(10.4166666667vw, 200px);
}
.area__background .left .cloud--01 {
  top: min(14.0625vw, 270px);
  left: 0;
  width: min(15.3125vw, 294px);
  --cloud-drift-x: max(-1.1458333333vw, -22px);
  --cloud-drift-duration: 8s;
}
.area__background .left .cloud--02 {
  top: min(28.6458333333vw, 550px);
  left: 0;
  width: min(8.3333333333vw, 160px);
  --cloud-drift-x: max(-0.8333333333vw, -16px);
  --cloud-drift-duration: 9.5s;
}
.area__background .left .flake--01 {
  top: min(15.1041666667vw, 290px);
  left: 0;
  width: min(9.53125vw, 183px);
}
.area__background .left .object--01 {
  top: min(67.7083333333vw, 1300px);
  left: 0;
  width: min(13.125vw, 252px);
  --object-morph-duration: 9s;
  --object-morph-delay: 0s;
}
.area__background .left .object--02 {
  top: min(139.0625vw, 2670px);
  left: 0;
  width: min(11.3541666667vw, 218px);
  --object-morph-duration: 11s;
  --object-morph-delay: -3s;
}
.area__background .right .pattern--01 {
  top: min(25vw, 480px);
  right: 0;
  width: min(10.4166666667vw, 200px);
}
.area__background .right .pattern--02 {
  top: min(84.375vw, 1620px);
  right: min(3.125vw, 60px);
  width: min(16.6666666667vw, 320px);
}
.area__background .right .pattern--03 {
  top: min(146.875vw, 2820px);
  right: max(-3.90625vw, -75px);
  width: min(10.4166666667vw, 200px);
}
.area__background .right .cloud--01 {
  top: min(13.0208333333vw, 250px);
  right: 0;
  width: min(15.3125vw, 294px);
  --cloud-drift-x: min(1.0416666667vw, 20px);
  --cloud-drift-duration: 8.5s;
}
.area__background .right .cloud--02 {
  top: min(28.6458333333vw, 550px);
  right: 0;
  width: min(7.7604166667vw, 149px);
  --cloud-drift-x: min(0.9375vw, 18px);
  --cloud-drift-duration: 10s;
}
.area__background .right .flake--01 {
  top: min(25vw, 480px);
  right: 0;
  width: min(11.0416666667vw, 212px);
}
.area__background .right .object--01 {
  top: min(47.9166666667vw, 920px);
  right: 0;
  width: min(10.4166666667vw, 200px);
  --object-morph-duration: 10s;
  --object-morph-delay: -2s;
}
.area__background .right .object--02 {
  top: min(119.7916666667vw, 2300px);
  right: min(2.6041666667vw, 50px);
  width: min(16.71875vw, 321px);
  --object-morph-duration: 12s;
  --object-morph-delay: -5s;
}
.area__background .object {
  will-change: transform;
}
@media (prefers-reduced-motion: no-preference) {
  .area__background .object {
    animation: area-object-morph var(--object-morph-duration, 10s) ease-in-out infinite;
    animation-delay: var(--object-morph-delay, 0s);
  }
}
.area__background .left .object {
  transform-origin: left center;
}
.area__background .right .object {
  transform-origin: right center;
}
.area__background .cloud {
  will-change: translate, transform;
}
@media (prefers-reduced-motion: no-preference) {
  .area__background .cloud {
    transition: translate 1.4s cubic-bezier(0.22, 1, 0.36, 1);
  }
}
@media (prefers-reduced-motion: no-preference) {
  .area__background .cloud.is-cloud-drift {
    animation: cloud-drift var(--cloud-drift-duration, 8s) ease-in-out infinite;
  }
}
.area__background .left .cloud.is-cloud-out {
  transition: none;
  translate: -100vw 0;
}
.area__background .right .cloud.is-cloud-out {
  transition: none;
  translate: 100vw 0;
}
.area__background .flake {
  opacity: 0;
  scale: 0;
  will-change: opacity, scale;
}
@media (prefers-reduced-motion: no-preference) {
  .area__background .flake {
    transition: opacity 0.1s ease-out, scale 0.6s cubic-bezier(0.34, 1.8, 0.64, 1);
  }
}
.area__background .flake.is-flake-in {
  opacity: 1;
  scale: 1;
}
.area__building {
  overflow-x: clip;
  position: absolute;
  top: 0;
  left: 0;
  transform: translateY(calc(-100% + min(4.1666666667vw, 80px)));
  width: 100%;
}
.area__building .photo,
.area__building .cloud,
.area__building .flake {
  position: absolute;
  transform: translateX(-50%);
}
.area__building .photo--01 {
  top: min(11.4583333333vw, 220px);
  left: calc(50% - 36.9010416667%);
  width: min(12.65625vw, 243px);
}
@media screen and (max-width: 767px) {
  .area__building .photo--01 {
    top: -2vw;
    left: 0vw;
    width: 32.4vw;
  }
}
.area__building .photo--02 {
  top: min(6.25vw, 120px);
  left: calc(50% - 19.7395833333%);
  width: min(15.7291666667vw, 302px);
}
@media screen and (max-width: 767px) {
  .area__building .photo--02 {
    top: -24vw;
    left: 26.6666666667vw;
    width: 40.2666666667vw;
  }
}
.area__building .photo--03 {
  top: min(4.1666666667vw, 80px);
  left: calc(50% + 9.765625%);
  width: min(14.84375vw, 285px);
}
@media screen and (max-width: 767px) {
  .area__building .photo--03 {
    top: -16.6666666667vw;
    left: auto;
    right: 7.3333333333vw;
    transform: none;
    width: 38vw;
  }
}
.area__building .photo--04 {
  top: min(6.7708333333vw, 130px);
  left: calc(50% + 39.375%);
  width: min(12.9166666667vw, 248px);
}
@media screen and (max-width: 767px) {
  .area__building .photo--04 {
    top: -2.6666666667vw;
    left: auto;
    right: 1.3333333333vw;
    transform: translate(50%);
    width: 33.0666666667vw;
  }
}
.area__building .cloud--01 {
  bottom: min(4.1666666667vw, 80px);
  left: calc(50% - 44.8697916667%);
  width: min(10.2604166667vw, 197px);
  --cloud-drift-x: max(-1.1458333333vw, -22px);
  --cloud-drift-duration: 8s;
}
.area__building .cloud--01.is-cloud-out {
  transition: none;
  translate: -100vw 0;
}
.area__building .cloud--02 {
  bottom: min(4.1666666667vw, 80px);
  left: calc(50% + 46.015625%);
  width: min(7.96875vw, 153px);
  --cloud-drift-x: min(1.0416666667vw, 20px);
  --cloud-drift-duration: 9s;
}
.area__building .cloud--02.is-cloud-out {
  transition: none;
  translate: 100vw 0;
}
@media screen and (max-width: 1279px) {
  .area__building .cloud--01 {
    bottom: 8rem;
    left: calc(50% - 86.15rem);
    width: 19.7rem;
  }
  .area__building .cloud--02 {
    bottom: 8rem;
    left: calc(50% + 88.35rem);
    width: 15.3rem;
  }
}
@media screen and (max-width: 767px) {
  .area__building .cloud--01 {
    bottom: 10.6666666667vw;
    left: calc(50% - 114.8666666667vw);
    width: 26.2666666667vw;
  }
  .area__building .cloud--02 {
    bottom: 10.6666666667vw;
    left: calc(50% + 117.8vw);
    width: 20.4vw;
  }
}
.area__building .flake--01 {
  bottom: min(4.1666666667vw, 80px);
  left: calc(50% - 41.8489583333%);
  width: min(16.3020833333vw, 313px);
}
.area__building .flake--02 {
  bottom: min(4.1666666667vw, 80px);
  left: calc(50% + 41.5625%);
  width: min(16.875vw, 324px);
}
@media screen and (max-width: 1279px) {
  .area__building .flake--01 {
    bottom: 8rem;
    left: calc(50% - 80.35rem);
    width: 31.3rem;
  }
  .area__building .flake--02 {
    bottom: 8rem;
    left: calc(50% + 79.8rem);
    width: 32.4rem;
  }
}
@media screen and (max-width: 767px) {
  .area__building .flake--01 {
    bottom: 10.6666666667vw;
    left: calc(50% - 107.1333333333vw);
    width: 41.7333333333vw;
  }
  .area__building .flake--02 {
    bottom: 10.6666666667vw;
    left: calc(50% + 106.4vw);
    width: 43.2vw;
  }
}
.area__building .main-image {
  position: relative;
  width: 100%;
  max-width: min(78.125vw, 1500px);
  margin: 0 auto;
}
@media screen and (max-width: 1279px) {
  .area__building .main-image {
    max-width: 150rem;
  }
}
@media screen and (max-width: 767px) {
  .area__building .main-image {
    max-width: 200vw;
  }
}
.area__building .cloud {
  will-change: translate;
}
@media (prefers-reduced-motion: no-preference) {
  .area__building .cloud {
    transition: translate 1.4s cubic-bezier(0.22, 1, 0.36, 1);
  }
}
@media (prefers-reduced-motion: no-preference) {
  .area__building .cloud.is-cloud-drift {
    animation: area-building-cloud-drift var(--cloud-drift-duration, 8s) ease-in-out infinite;
  }
}
.area__building .flake {
  opacity: 0;
  scale: 0;
  will-change: opacity, scale;
}
@media (prefers-reduced-motion: no-preference) {
  .area__building .flake {
    transition: opacity 0.1s ease-out, scale 0.6s cubic-bezier(0.34, 1.8, 0.64, 1);
  }
}
.area__building .flake.is-flake-in {
  opacity: 1;
  scale: 1;
}
.area__building .photo.is-fade-target,
.area__building .main-image.is-fade-target {
  translate: 0 0;
  filter: blur(20px);
  will-change: opacity, filter;
}
@media (prefers-reduced-motion: no-preference) {
  .area__building .photo.is-fade-target,
  .area__building .main-image.is-fade-target {
    transition: opacity 1.1s cubic-bezier(0.22, 1, 0.36, 1), filter 1.1s cubic-bezier(0.22, 1, 0.36, 1);
  }
}
.area__building .photo.is-fade-in,
.area__building .main-image.is-fade-in {
  filter: blur(0);
}
.area__building .main-image.is-fade-target {
  transition-delay: 1.1s;
}
.area__title {
  position: relative;
  width: 100%;
  margin: 0 0 min(4.1666666667vw, 80px);
}
@media screen and (max-width: 1279px) {
  .area__title {
    margin-bottom: 8rem;
  }
}
@media screen and (max-width: 767px) {
  .area__title {
    margin-bottom: 10.6666666667vw;
  }
}
.area__title .image {
  width: calc(100% - min(6.25vw, 120px));
  max-width: min(55.7291666667vw, 1070px);
  padding-top: min(4.1666666667vw, 80px);
  margin: 0 auto max(-2.0833333333vw, -40px);
}
@media screen and (max-width: 1279px) {
  .area__title .image {
    width: calc(100% - 12rem);
    max-width: 107rem;
    padding-top: 8rem;
    margin-bottom: -4rem;
  }
}
@media screen and (max-width: 767px) {
  .area__title .image {
    width: 100%;
    max-width: 142.6666666667vw;
    padding-top: 8vw;
    margin-bottom: 1.3333333333vw;
  }
}
.area__title p {
  font-weight: 700;
  font-size: min(1.25vw, 24px);
  line-height: 2.2;
  text-align: center;
}
.area__title p span {
  display: inline-block;
  font-size: min(1.5625vw, 30px);
  margin: 0 0.1em;
}
@media screen and (max-width: 1279px) {
  .area__title p {
    font-size: 2.4rem;
  }
  .area__title p span {
    font-size: 3rem;
  }
}
@media screen and (max-width: 767px) {
  .area__title p {
    font-size: 3.2vw;
  }
  .area__title p span {
    font-size: 4vw;
  }
}
.area__title p .blue {
  color: #0B7194;
}
.area__title p .green {
  color: #148F3B;
}
.area__title p .orange {
  color: #E47C23;
}
.area__title p .indigo {
  color: #30569E;
}
.area__title .illust {
  position: absolute;
}
.area__title .illust--01 {
  top: min(1.3020833333vw, 25px);
  left: calc(50% - 32.2916666667%);
  width: min(3.90625vw, 75px);
}
@media screen and (max-width: 767px) {
  .area__title .illust--01 {
    top: -6.6666666667vw;
    left: 2.6666666667vw;
    width: 10vw;
  }
}
.area__title .illust--02 {
  top: max(-0.78125vw, -15px);
  left: calc(50% - 28.6458333333%);
  width: min(4.53125vw, 87px);
}
@media screen and (max-width: 767px) {
  .area__title .illust--02 {
    top: -14.6666666667vw;
    left: 12.6666666667vw;
    width: 11.6vw;
  }
}
.area__title .illust--03 {
  top: max(-4.1666666667vw, -80px);
  left: calc(50% + 26.5625%);
  width: min(5.8333333333vw, 112px);
}
@media screen and (max-width: 767px) {
  .area__title .illust--03 {
    top: -16vw;
    left: auto;
    right: 14.6666666667vw;
    width: 14.9333333333vw;
  }
}
.area__title .illust--04 {
  top: min(2.34375vw, 45px);
  left: calc(50% + 33.3333333333%);
  width: min(6.3541666667vw, 122px);
}
@media screen and (max-width: 767px) {
  .area__title .illust--04 {
    top: -10.6666666667vw;
    left: auto;
    right: 1.3333333333vw;
    width: 16.2666666667vw;
  }
}
.area__title .illust.is-fade-target {
  translate: 0 0;
  filter: blur(20px);
  will-change: opacity, filter;
}
@media (prefers-reduced-motion: no-preference) {
  .area__title .illust.is-fade-target {
    transition: opacity 1.1s cubic-bezier(0.22, 1, 0.36, 1), filter 1.1s cubic-bezier(0.22, 1, 0.36, 1);
  }
}
.area__title .illust.is-fade-in {
  filter: blur(0);
}
.area__content {
  width: 100%;
  max-width: min(75vw, 1440px);
  margin: 0 auto;
}
@media screen and (max-width: 1279px) {
  .area__content {
    max-width: 144rem;
  }
}
@media screen and (max-width: 767px) {
  .area__content {
    max-width: 192vw;
  }
}
.area__content .area-card.blue {
  --color-card-accent: #0B7194;
  --color-float: #D2DAE4;
}
.area__content .area-card.green {
  --color-card-accent: #298948;
  --color-float: #DEE6D7;
}
.area__content .area-card.yellow {
  --color-card-accent: #E47800;
  --color-float: #FCEEDA;
}
.area__content .area-card.indigo {
  --color-card-accent: #37599F;
  --color-float: #CED3E9;
}
.area__content .area-card.red {
  --color-card-accent: #C7307C;
  --color-float: #F5E1EA;
}
.area__content .area-card {
  position: relative;
  border-radius: min(1.0416666667vw, 20px);
  border: min(0.1041666667vw, 2px) solid var(--color-card-accent);
  background-color: #FFFFFF;
  width: 100%;
  height: -moz-fit-content;
  height: fit-content;
  padding: min(3.6458333333vw, 70px) min(3.125vw, 60px) min(2.0833333333vw, 40px);
}
@media screen and (max-width: 1279px) {
  .area__content .area-card {
    border-radius: 2rem;
    border-width: 0.2rem;
    padding: 7rem 6rem 4rem;
  }
}
@media screen and (max-width: 767px) {
  .area__content .area-card {
    border-radius: 2.6666666667vw;
    border-width: 0.2666666667vw;
    padding: 12vw 0 5.3333333333vw;
  }
}
.area__content .area-card .float {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: min(0.2604166667vw, 5px);
  border: min(0.1041666667vw, 2px) solid var(--color-card-accent);
  background-color: var(--color-float);
  display: flex;
  align-items: center;
  justify-content: center;
  width: -moz-fit-content;
  width: fit-content;
  min-width: min(18.2291666667vw, 350px);
  height: min(2.6041666667vw, 50px);
  padding: 0 min(1.0416666667vw, 20px);
  box-shadow: min(0.15625vw, 3px) min(0.15625vw, 3px) 0 0 #C9CACA;
}
.area__content .area-card .float::before, .area__content .area-card .float::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
}
.area__content .area-card .float::before {
  bottom: max(-0.7291666667vw, -14px);
  z-index: 1;
  border-left: min(0.7291666667vw, 14px) solid transparent;
  border-right: min(0.7291666667vw, 14px) solid transparent;
  border-top: min(0.78125vw, 15px) solid var(--color-float);
}
.area__content .area-card .float::after {
  bottom: max(-0.8333333333vw, -16px);
  border-left: min(0.8333333333vw, 16px) solid transparent;
  border-right: min(0.8333333333vw, 16px) solid transparent;
  border-top: min(0.8333333333vw, 16px) solid var(--color-card-accent);
}
.area__content .area-card .float p {
  font-weight: 700;
  font-size: min(0.9375vw, 18px);
  line-height: 2.2;
  text-align: center;
  color: var(--color-card-accent);
}
@media screen and (max-width: 1279px) {
  .area__content .area-card .float {
    border-radius: 0.5rem;
    border-width: 0.2rem;
    min-width: 35rem;
    height: 5rem;
    padding: 0 2rem;
    box-shadow: 0.3rem 0.3rem 0 0 #C9CACA;
  }
  .area__content .area-card .float::before {
    bottom: -1.2rem;
    border-left-width: 1.4rem;
    border-right-width: 1.4rem;
    border-top-width: 1.4rem;
  }
  .area__content .area-card .float::after {
    bottom: -1.6rem;
    border-left-width: 1.6rem;
    border-right-width: 1.6rem;
    border-top-width: 1.6rem;
  }
  .area__content .area-card .float p {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  .area__content .area-card .float {
    border-radius: 1.3333333333vw;
    border-width: 0.2666666667vw;
    min-width: 70.6666666667vw;
    height: 10.6666666667vw;
    padding: 0 2.6666666667vw;
    box-shadow: 0.4vw 0.4vw 0 0 #C9CACA;
  }
  .area__content .area-card .float::before {
    bottom: -1.8666666667vw;
    border-left-width: 1.8666666667vw;
    border-right-width: 1.8666666667vw;
    border-top-width: 1.8666666667vw;
  }
  .area__content .area-card .float::after {
    bottom: -2.1333333333vw;
    border-left-width: 2.1333333333vw;
    border-right-width: 2.1333333333vw;
    border-top-width: 2.1333333333vw;
  }
  .area__content .area-card .float p {
    font-size: 3.7333333333vw;
    white-space: nowrap;
  }
}
.area__content .area-card .image {
  z-index: 1;
  position: relative;
  width: 100%;
  max-width: min(22.9166666667vw, 440px);
  margin: 0 auto min(3.6458333333vw, 70px);
}
.area__content .area-card .image::before {
  content: "";
  z-index: -1;
  position: absolute;
  bottom: 0;
  left: 0;
  border-radius: 50%;
  background-color: #C8C9CA;
  display: block;
  width: 100%;
  height: min(11.4583333333vw, 220px);
  filter: blur(30px);
}
.area__content .area-card .image img {
  width: 100%;
  max-width: none;
}
@media screen and (max-width: 1279px) {
  .area__content .area-card .image {
    max-width: 44rem;
    margin-bottom: 7rem;
  }
  .area__content .area-card .image::before {
    height: 22rem;
  }
}
@media screen and (max-width: 767px) {
  .area__content .area-card .image {
    max-width: 59.3333333333vw;
    margin-bottom: 9.3333333333vw;
  }
  .area__content .area-card .image::before {
    height: 29.3333333333vw;
  }
}
.area__content .area-card .text {
  position: relative;
}
.area__content .area-card .text .title {
  border-bottom: min(0.15625vw, 3px) dotted #231815;
  margin-bottom: min(1.3020833333vw, 25px);
}
.area__content .area-card .text .title p:nth-of-type(1) {
  font-weight: 700;
  font-size: min(0.9375vw, 18px);
  line-height: 2.2;
}
.area__content .area-card .text .title p:nth-of-type(2) {
  font-weight: 700;
  font-size: min(1.5625vw, 30px);
  line-height: 1.5;
  color: var(--color-card-accent);
  margin-bottom: min(0.78125vw, 15px);
}
.area__content .area-card .text .title p:nth-of-type(2) span {
  display: inline-block;
  font-size: min(1.0416666667vw, 20px);
  margin-left: min(1.0416666667vw, 20px);
}
@media screen and (max-width: 1279px) {
  .area__content .area-card .text .title {
    border-bottom-width: 0.3rem;
    margin-bottom: 2.5rem;
  }
  .area__content .area-card .text .title p:nth-of-type(1) {
    font-size: 1.8rem;
  }
  .area__content .area-card .text .title p:nth-of-type(2) {
    font-size: 3rem;
    margin-bottom: 1.5rem;
  }
  .area__content .area-card .text .title p:nth-of-type(2) span {
    font-size: 2rem;
    margin-left: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .area__content .area-card .text .title {
    border-bottom-width: 0.4vw;
    margin: 0 8vw 3.3333333333vw;
  }
  .area__content .area-card .text .title p {
    white-space: nowrap;
  }
  .area__content .area-card .text .title p:nth-of-type(1) {
    font-size: 3.7333333333vw;
  }
  .area__content .area-card .text .title p:nth-of-type(2) {
    font-size: 5.8666666667vw;
    margin-bottom: 2vw;
  }
  .area__content .area-card .text .title p:nth-of-type(2) span {
    font-size: 4vw;
    margin-left: 2.6666666667vw;
  }
}
.area__content .area-card .text .detail {
  width: min(18.75vw, 360px);
}
.area__content .area-card .text .detail p {
  font-weight: 500;
  font-size: min(0.8333333333vw, 16px);
  line-height: 1.7;
}
@media screen and (max-width: 1279px) {
  .area__content .area-card .text .detail {
    width: 36rem;
  }
  .area__content .area-card .text .detail p {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 767px) {
  .area__content .area-card .text .detail {
    width: 100%;
    padding: 0 8vw;
  }
  .area__content .area-card .text .detail p {
    font-size: 3.2vw;
  }
}
.area__content .area-card .text .float-image {
  position: absolute;
  top: max(-3.6458333333vw, -70px);
  right: max(-5.2083333333vw, -100px);
  max-width: min(13.5416666667vw, 260px);
}
@media screen and (max-width: 1279px) {
  .area__content .area-card .text .float-image {
    top: -7rem;
    right: -10rem;
  }
}
@media screen and (max-width: 767px) {
  .area__content .area-card .text .float-image {
    position: static;
    width: 100%;
    max-width: none;
  }
}
.area__content .area-card.full {
  display: flex;
  flex-flow: row nowrap;
  gap: min(7.8125vw, 150px);
  padding: min(5.2083333333vw, 100px) min(3.125vw, 60px) min(3.125vw, 60px) min(4.1666666667vw, 80px);
}
.area__content .area-card.full .image {
  flex-shrink: 0;
  width: min(23.1770833333vw, 445px);
  height: -moz-fit-content;
  height: fit-content;
  margin: 0;
}
.area__content .area-card.full .card-wrapper {
  display: flex;
  flex-flow: column nowrap;
  justify-content: space-between;
  gap: min(6.1458333333vw, 118px);
}
.area__content .area-card.full .card-wrapper .text .detail {
  width: min(19.7916666667vw, 380px);
}
.area__content .area-card.full .card-wrapper .text .float-image {
  top: 0;
  right: max(-0.5208333333vw, -10px);
  width: min(15.2083333333vw, 292px);
  max-width: none;
}
.area__content .area-card.full .additional {
  position: relative;
  display: flex;
  flex-flow: row nowrap;
  gap: min(2.0833333333vw, 40px);
}
.area__content .area-card.full .additional .add-image {
  flex-shrink: 0;
  width: min(15.625vw, 300px);
}
.area__content .area-card.full .additional .text p:nth-of-type(1) {
  font-weight: 700;
  font-size: min(1.0416666667vw, 20px);
  line-height: 1.5;
  color: var(--color-card-accent);
}
.area__content .area-card.full .additional .text p:nth-of-type(2) {
  font-weight: 500;
  font-size: min(0.8333333333vw, 16px);
  margin-top: min(1.0416666667vw, 20px);
}
.area__content .area-card.full .additional .float-image {
  z-index: 1;
  position: absolute;
  top: max(-1.0416666667vw, -20px);
  left: min(2.0833333333vw, 40px);
  transform: translateX(-100%);
  display: flex;
  flex-flow: row nowrap;
}
.area__content .area-card.full .additional .float-image .illust {
  width: min(3.6458333333vw, 70px);
  margin-top: min(5.7291666667vw, 110px);
  margin-right: max(-2.0833333333vw, -40px);
}
.area__content .area-card.full .additional .float-image .text {
  width: min(10.4166666667vw, 200px);
}
@media screen and (max-width: 1439px) {
  .area__content .area-card.full {
    display: block;
    padding: min(3.6458333333vw, 70px) min(3.125vw, 60px) min(2.0833333333vw, 40px);
  }
  .area__content .area-card.full .image {
    width: 44.5rem;
  }
  .area__content .area-card.full .card-wrapper {
    justify-content: flex-start;
    gap: 11.8rem;
  }
  .area__content .area-card.full .card-wrapper .text .detail {
    width: min(18.75vw, 360px);
  }
  .area__content .area-card.full .card-wrapper .text .float-image {
    width: 29.2rem;
    max-width: none;
  }
  .area__content .area-card.full .additional {
    flex-flow: column nowrap;
    gap: 4rem;
  }
  .area__content .area-card.full .additional .add-image {
    flex-shrink: 0;
    width: 100%;
  }
  .area__content .area-card.full .additional .add-image img {
    width: 100%;
    max-width: none;
  }
  .area__content .area-card.full .additional .text p:nth-of-type(1) {
    font-weight: 700;
    font-size: 2rem;
    line-height: 1.5;
    color: var(--color-card-accent);
  }
  .area__content .area-card.full .additional .text p:nth-of-type(2) {
    font-weight: 500;
    font-size: 1.6rem;
    margin-top: 2rem;
  }
  .area__content .area-card.full .additional .float-image {
    z-index: 1;
    position: absolute;
    top: -2rem;
    left: -5rem;
    display: flex;
    flex-flow: row nowrap;
  }
  .area__content .area-card.full .additional .float-image .illust {
    width: 7rem;
    margin-top: 11rem;
    margin-right: -4rem;
  }
  .area__content .area-card.full .additional .float-image .text {
    width: 16rem;
  }
}
@media screen and (max-width: 1279px) {
  .area__content .area-card.full {
    padding: 7rem 6rem 4rem;
  }
  .area__content .area-card.full .card-wrapper .text .detail {
    width: 38rem;
  }
  .area__content .area-card.full .additional .add-image {
    width: 30rem;
  }
  .area__content .area-card.full .additional .float-image .illust {
    width: 7rem;
  }
  .area__content .area-card.full .additional .float-image .text {
    width: 38rem;
  }
}
@media screen and (max-width: 767px) {
  .area__content .area-card.full {
    padding: 9.3333333333vw 6.6666666667vw 5.3333333333vw;
  }
  .area__content .area-card.full .image {
    width: 100%;
    max-width: none;
  }
  .area__content .area-card.full .image picture {
    width: 100%;
  }
  .area__content .area-card.full .card-wrapper {
    gap: 16vw;
    margin-top: 5.3333333333vw;
  }
  .area__content .area-card.full .card-wrapper .text .title {
    margin: 0;
  }
  .area__content .area-card.full .card-wrapper .text .detail {
    width: 100%;
    padding: 0;
  }
  .area__content .area-card.full .card-wrapper .text .float-image {
    width: 80%;
    margin: 4vw auto 0;
  }
  .area__content .area-card.full .additional {
    gap: 5.3333333333vw;
  }
  .area__content .area-card.full .additional .add-image {
    width: 60vw;
    margin: 0 auto;
  }
  .area__content .area-card.full .additional .text p:nth-of-type(1) {
    font-size: 4.2666666667vw;
  }
  .area__content .area-card.full .additional .text p:nth-of-type(2) {
    font-size: 3.2vw;
  }
  .area__content .area-card.full .additional .float-image {
    top: -18.6666666667vw;
    left: -1.3333333333vw;
    transform: none;
  }
  .area__content .area-card.full .additional .float-image .illust {
    width: 14vw;
    margin-top: 33.3333333333vw;
    margin-right: -13.3333333333vw;
  }
  .area__content .area-card.full .additional .float-image .text {
    width: 40vw;
  }
}
.area__content .content-wrapper {
  display: flex;
  flex-flow: row nowrap;
  gap: 8rem;
  width: 100%;
}
.area__content .content-wrapper + .content-wrapper {
  margin: 7.5rem 0 13rem;
}
@media screen and (max-width: 1279px) {
  .area__content .content-wrapper {
    gap: 8rem;
  }
  .area__content .content-wrapper + .content-wrapper {
    margin: 7.5rem 0 13rem;
  }
}
@media screen and (max-width: 767px) {
  .area__content .content-wrapper {
    gap: 10.6666666667vw;
  }
  .area__content .content-wrapper + .content-wrapper {
    margin: 10vw 0 17.3333333333vw;
  }
}
@media screen and (min-width: 1440px) {
  .area__content .content-wrapper .area-card:last-of-type {
    margin-top: 10rem;
  }
}
@media screen and (max-width: 1439px) {
  .area__content .content-wrapper {
    flex-flow: column nowrap;
  }
}

.guide {
  background-color: #D5E8B7;
  width: 100%;
  padding: min(18.2291666667vw, 350px) 0 0;
}
@media screen and (max-width: 767px) {
  .guide {
    background-image: linear-gradient(to bottom, transparent 20%, #FFFFFF 20%);
    padding: 32vw 0 0;
  }
}
.guide__inner {
  position: relative;
  background-image: url("../image/bg_guide.svg");
  background-size: 100% auto;
  background-position: center top;
  background-repeat: no-repeat;
  width: 100%;
  padding: min(9.6354166667vw, 185px) 0 min(5.2083333333vw, 100px);
}
@media screen and (max-width: 767px) {
  .guide__inner {
    padding: 21.3333333333vw 0 16vw;
  }
}
.guide__background {
  overflow-x: clip;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.guide__background .left,
.guide__background .right {
  position: absolute;
  inset: 0;
}
.guide__background .left figure,
.guide__background .right figure {
  position: absolute;
  margin: 0;
}
.guide__background .left figure img,
.guide__background .right figure img {
  width: 100%;
  max-width: none;
}
.guide__background .left .cloud--01 {
  top: max(-9.375vw, -180px);
  left: min(4.6875vw, 90px);
  width: min(13.3854166667vw, 257px);
  --cloud-drift-x: max(-1.0416666667vw, -20px);
  --cloud-drift-duration: 8s;
}
.guide__background .left .cloud--02 {
  top: max(-4.1666666667vw, -80px);
  left: 0;
  width: min(14.7916666667vw, 284px);
  --cloud-drift-x: max(-1.25vw, -24px);
  --cloud-drift-duration: 9s;
}
.guide__background .left .object--01 {
  top: max(-23.4375vw, -450px);
  left: 0;
  width: min(12.1875vw, 234px);
  --object-morph-duration: 9s;
  --object-morph-delay: 0s;
}
.guide__background .left .object--02 {
  top: max(-15.625vw, -300px);
  left: 0;
  width: min(20.9375vw, 402px);
  --object-morph-duration: 11s;
  --object-morph-delay: -3s;
}
.guide__background .left .flake--01 {
  top: max(-10.4166666667vw, -200px);
  left: 0;
  width: min(13.8020833333vw, 265px);
}
.guide__background .left .pattern--01 {
  top: max(-15.625vw, -300px);
  left: min(5.2083333333vw, 100px);
  width: min(10.4166666667vw, 200px);
}
.guide__background .left .pattern--02 {
  top: min(32.2916666667vw, 620px);
  left: max(-4.1666666667vw, -80px);
  width: min(16.6666666667vw, 320px);
}
.guide__background .right .cloud--01 {
  top: max(-8.3333333333vw, -160px);
  right: min(2.0833333333vw, 40px);
  width: min(13.3333333333vw, 256px);
  --cloud-drift-x: min(1.1458333333vw, 22px);
  --cloud-drift-duration: 8.5s;
}
.guide__background .right .cloud--02 {
  top: 0;
  right: 0;
  width: min(7.7083333333vw, 148px);
  --cloud-drift-x: min(0.9375vw, 18px);
  --cloud-drift-duration: 10s;
}
.guide__background .right .object--01 {
  top: max(-17.7083333333vw, -340px);
  right: 0;
  width: min(13.125vw, 252px);
  --object-morph-duration: 10s;
  --object-morph-delay: -2s;
}
.guide__background .right .object--02 {
  top: max(-9.375vw, -180px);
  right: 0;
  width: min(21.9270833333vw, 421px);
  --object-morph-duration: 12s;
  --object-morph-delay: -5s;
}
.guide__background .right .flake--01 {
  top: max(-5.2083333333vw, -100px);
  right: 0;
  width: min(12.5vw, 240px);
}
.guide__background .right .pattern--01 {
  top: max(-14.5833333333vw, -280px);
  right: max(-8.3333333333vw, -160px);
  width: min(16.6666666667vw, 320px);
}
.guide__background .right .pattern--02 {
  top: 0;
  right: min(8.3333333333vw, 160px);
  width: min(10.4166666667vw, 200px);
}
.guide__background .right .pattern--03 {
  top: min(38.5416666667vw, 740px);
  right: max(-4.1666666667vw, -80px);
  width: min(10.4166666667vw, 200px);
}
.guide__background .cloud {
  will-change: translate, transform;
}
@media (prefers-reduced-motion: no-preference) {
  .guide__background .cloud {
    transition: translate 1.4s cubic-bezier(0.22, 1, 0.36, 1);
  }
}
@media (prefers-reduced-motion: no-preference) {
  .guide__background .cloud.is-cloud-drift {
    animation: cloud-drift var(--cloud-drift-duration, 8s) ease-in-out infinite;
  }
}
.guide__background .left .cloud.is-cloud-out {
  transition: none;
  translate: -100vw 0;
}
.guide__background .right .cloud.is-cloud-out {
  transition: none;
  translate: 100vw 0;
}
.guide__background .flake {
  opacity: 0;
  scale: 0;
  will-change: opacity, scale;
}
@media (prefers-reduced-motion: no-preference) {
  .guide__background .flake {
    transition: opacity 0.1s ease-out, scale 0.6s cubic-bezier(0.34, 1.8, 0.64, 1);
  }
}
.guide__background .flake.is-flake-in {
  opacity: 1;
  scale: 1;
}
.guide__background .object {
  will-change: transform;
}
@media (prefers-reduced-motion: no-preference) {
  .guide__background .object {
    animation: area-object-morph var(--object-morph-duration, 10s) ease-in-out infinite;
    animation-delay: var(--object-morph-delay, 0s);
  }
}
.guide__background .left .object {
  transform-origin: left center;
}
.guide__background .right .object {
  transform-origin: right center;
}
.guide__title {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  width: calc(100% - min(6.25vw, 120px));
  max-width: min(60.4166666667vw, 1160px);
}
@media screen and (max-width: 767px) {
  .guide__title {
    width: calc(100% - 10.6666666667vw);
    max-width: none;
  }
}
.guide__map {
  position: relative;
  background-image: url("../image/bg_guide-content.svg");
  background-size: min(52.0833333333vw, 1000px) auto;
  background-position: center;
  background-repeat: no-repeat;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .guide__map {
    background-size: auto 100%;
  }
}
.guide__map .map-image {
  width: calc(100% - min(6.25vw, 120px));
  max-width: min(62.5vw, 1200px);
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .guide__map .map-image {
    width: calc(100% - 5.3333333333vw);
    max-width: none;
    margin-left: 5.3333333333vw;
  }
}
.guide__map .illust {
  position: absolute;
  transform: translateX(-50%);
}
.guide__map .illust--01 {
  top: min(38.0208333333vw, 730px);
  left: calc(50% - min(36.1197916667vw, 693.5px));
  width: min(6.9270833333vw, 133px);
}
@media screen and (max-width: 767px) {
  .guide__map .illust--01 {
    top: 56vw;
    left: 10.6666666667vw;
    width: 17.7333333333vw;
  }
}
.guide__map .illust--02 {
  top: min(29.6875vw, 570px);
  left: calc(50% + min(31.6927083333vw, 608.5px));
  width: min(8.4895833333vw, 163px);
}
@media screen and (max-width: 767px) {
  .guide__map .illust--02 {
    top: 56vw;
    left: auto;
    right: 10.6666666667vw;
    width: 21.7333333333vw;
  }
}
.guide__map .illust--03 {
  top: min(12.5vw, 240px);
  left: calc(50% + min(34.6875vw, 666px));
  width: min(4.5833333333vw, 88px);
}
@media screen and (max-width: 767px) {
  .guide__map .illust--03 {
    top: 32vw;
    left: auto;
    right: 1.3333333333vw;
    width: 11.7333333333vw;
  }
}
.guide__map .illust.is-fade-target {
  translate: 0 0;
  filter: blur(20px);
  will-change: opacity, filter;
}
@media (prefers-reduced-motion: no-preference) {
  .guide__map .illust.is-fade-target {
    transition: opacity 1.1s cubic-bezier(0.22, 1, 0.36, 1), filter 1.1s cubic-bezier(0.22, 1, 0.36, 1);
  }
}
.guide__map .illust.is-fade-in {
  filter: blur(0);
}

.c-button {
  border: min(0.1041666667vw, 2px) solid #231815;
  border-radius: 100vw;
  background-color: #4995A8;
  display: flex;
  align-items: center;
  justify-content: center;
  width: -moz-fit-content;
  width: fit-content;
  font-weight: 700;
  font-size: min(0.8854166667vw, 17px);
  color: #FFFFFF;
  padding: 0 min(1.0416666667vw, 20px);
  box-shadow: min(0.0520833333vw, 1px) min(0.1041666667vw, 2px) 0 0 #231815;
}
@media screen and (max-width: 1279px) {
  .c-button {
    font-size: 1.7rem;
    padding: 0 2rem;
    box-shadow: 0.1rem 0.2rem 0 0 #231815;
  }
}
@media screen and (max-width: 767px) {
  .c-button {
    font-size: 3.7333333333vw;
    padding: 0 2.6666666667vw;
    box-shadow: 0.1333333333vw 0.2666666667vw 0 0 #231815;
  }
}
.c-button {
  opacity: 1;
  transition: transform 0.25s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.25s cubic-bezier(0.22, 1, 0.36, 1), background-color 0.25s cubic-bezier(0.22, 1, 0.36, 1);
}
.c-button.header {
  background-color: #F5F0E8;
  font-size: min(0.7291666667vw, 14px);
  color: #231815;
}
@media screen and (max-width: 1023px) {
  .c-button.header {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 767px) {
  .c-button.header {
    font-size: 3.2vw;
  }
}
.c-button.entry {
  background-color: #C0A62E;
  color: #FFFFFF;
}
.c-button:hover {
  transform: translateY(-3px);
}

.c-opening {
  z-index: 1000;
  position: fixed;
  inset: 0;
  background-color: #F5F0E8;
  width: 100vw;
  height: 100vh;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition: opacity 1.8s cubic-bezier(0.22, 1, 0.36, 1), visibility 1.8s cubic-bezier(0.22, 1, 0.36, 1);
}
.c-opening.is-complete {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.c-opening__inner {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}
.c-opening .background {
  overflow: hidden;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.c-opening .background .object,
.c-opening .background .pattern {
  opacity: 0;
  transition: opacity 0.6s ease;
}
.c-opening .background .object.is-visible,
.c-opening .background .pattern.is-visible {
  opacity: 1;
}
.c-opening .background .object {
  pointer-events: none;
  position: absolute;
}
.c-opening .background .object--01 {
  top: -2.7777777778%;
  left: -6.7708333333%;
  width: min(21.875vw, 420px);
}
@media screen and (max-width: 767px) {
  .c-opening .background .object--01 {
    top: -4vw;
    left: -17.3333333333vw;
    width: 44.8vw;
  }
}
.c-opening .background .object--02 {
  top: -17.5925925926%;
  left: 18.2291666667%;
  width: min(22.9166666667vw, 440px);
}
@media screen and (max-width: 767px) {
  .c-opening .background .object--02 {
    top: -25.3333333333vw;
    left: 46.6666666667vw;
    width: 46.9333333333vw;
  }
}
.c-opening .background .object--03 {
  top: -21.2962962963%;
  right: 13.0208333333%;
  width: min(25.5208333333vw, 490px);
}
@media screen and (max-width: 767px) {
  .c-opening .background .object--03 {
    top: -30.6666666667vw;
    right: 33.3333333333vw;
    width: 52.2666666667vw;
  }
}
.c-opening .background .object--04 {
  bottom: -16.6666666667%;
  left: 36.9791666667%;
  width: min(20.3125vw, 390px);
}
@media screen and (max-width: 767px) {
  .c-opening .background .object--04 {
    bottom: -24vw;
    left: 94.6666666667vw;
    width: 41.6vw;
  }
}
.c-opening .background .object--05 {
  bottom: -8.3333333333%;
  right: 5.2083333333%;
  width: min(23.9583333333vw, 460px);
}
@media screen and (max-width: 767px) {
  .c-opening .background .object--05 {
    bottom: -12vw;
    right: 13.3333333333vw;
    width: 49.0666666667vw;
  }
}
.c-opening .background .object--red {
  bottom: -11.1111111111%;
  left: -8.3333333333%;
  width: min(21.875vw, 420px);
}
@media screen and (max-width: 767px) {
  .c-opening .background .object--red {
    bottom: -16vw;
    left: -21.3333333333vw;
    width: 44.8vw;
  }
}
.c-opening .background .object--blue {
  bottom: 12.962962963%;
  left: 10.4166666667%;
  width: min(20.8333333333vw, 400px);
}
@media screen and (max-width: 767px) {
  .c-opening .background .object--blue {
    bottom: 18.6666666667vw;
    left: 26.6666666667vw;
    width: 42.6666666667vw;
  }
}
.c-opening .background .object--yellow {
  top: 25%;
  right: 7.2916666667%;
  width: min(18.2291666667vw, 350px);
}
@media screen and (max-width: 767px) {
  .c-opening .background .object--yellow {
    top: 36vw;
    right: 18.6666666667vw;
    width: 37.3333333333vw;
  }
}
.c-opening .background .object--orange {
  top: 24.0740740741%;
  right: -16.1458333333%;
  width: min(22.9166666667vw, 440px);
}
@media screen and (max-width: 767px) {
  .c-opening .background .object--orange {
    top: 34.6666666667vw;
    right: -41.3333333333vw;
    width: 46.9333333333vw;
  }
}
.c-opening .background .object--green {
  top: -2.7777777778%;
  right: -3.125%;
  width: min(16.1458333333vw, 310px);
}
@media screen and (max-width: 767px) {
  .c-opening .background .object--green {
    top: -4vw;
    right: -8vw;
    width: 33.0666666667vw;
  }
}
.c-opening .background .pattern {
  pointer-events: none;
  position: absolute;
  width: min(14.0625vw, 270px);
}
@media screen and (max-width: 767px) {
  .c-opening .background .pattern {
    width: 28.8vw;
  }
}
.c-opening .background .pattern--01 {
  top: 16.6666666667%;
  left: -5.2083333333%;
}
@media screen and (max-width: 767px) {
  .c-opening .background .pattern--01 {
    top: 24vw;
    left: -13.3333333333vw;
  }
}
.c-opening .background .pattern--02 {
  top: 18.5185185185%;
  left: 28.125%;
}
@media screen and (max-width: 767px) {
  .c-opening .background .pattern--02 {
    top: 26.6666666667vw;
    left: 72vw;
  }
}
.c-opening .background .pattern--03 {
  top: -18.5185185185%;
  left: 43.75%;
}
@media screen and (max-width: 767px) {
  .c-opening .background .pattern--03 {
    top: -26.6666666667vw;
    left: 112vw;
  }
}
.c-opening .background .pattern--04 {
  top: -8.3333333333%;
  right: 16.6666666667%;
}
@media screen and (max-width: 767px) {
  .c-opening .background .pattern--04 {
    top: -12vw;
    right: 42.6666666667vw;
  }
}
.c-opening .background .pattern--05 {
  top: -9.2592592593%;
  right: -5.7291666667%;
}
@media screen and (max-width: 767px) {
  .c-opening .background .pattern--05 {
    top: -13.3333333333vw;
    right: -14.6666666667vw;
  }
}
.c-opening .background .pattern--06 {
  bottom: -11.1111111111%;
  left: 7.8125%;
}
@media screen and (max-width: 767px) {
  .c-opening .background .pattern--06 {
    bottom: -16vw;
    left: 20vw;
  }
}
.c-opening .background .pattern--07 {
  bottom: 3.7037037037%;
  right: 19.2708333333%;
}
@media screen and (max-width: 767px) {
  .c-opening .background .pattern--07 {
    bottom: 5.3333333333vw;
    right: 49.3333333333vw;
  }
}
.c-opening .background .pattern--08 {
  bottom: 24.0740740741%;
  right: -8.8541666667%;
}
@media screen and (max-width: 767px) {
  .c-opening .background .pattern--08 {
    bottom: 34.6666666667vw;
    right: -22.6666666667vw;
  }
}
.c-opening .content {
  z-index: 1;
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
}
.c-opening .content > * {
  opacity: 0;
  transition: opacity 0.8s ease;
}
.c-opening .content > *.is-visible {
  opacity: 1;
}
.c-opening .content .image {
  width: min(35.4166666667vw, 680px);
  margin: 0 auto min(3.125vw, 60px);
}
@media screen and (max-width: 1279px) {
  .c-opening .content .image {
    width: 68rem;
    margin-bottom: 6rem;
  }
}
@media screen and (max-width: 767px) {
  .c-opening .content .image {
    width: 90.6666666667vw;
    margin-bottom: 8vw;
  }
}
.c-opening .content .text {
  width: min(47.3958333333vw, 910px);
  margin: 0 auto min(4.6875vw, 90px);
}
@media screen and (max-width: 1279px) {
  .c-opening .content .text {
    width: 91rem;
    margin-bottom: 9rem;
  }
}
@media screen and (max-width: 767px) {
  .c-opening .content .text {
    width: 69.3333333333vw;
    margin-bottom: 12vw;
  }
}
.c-opening .content .logo {
  width: min(25vw, 480px);
  margin: 0 auto;
}
@media screen and (max-width: 1279px) {
  .c-opening .content .logo {
    width: 48rem;
  }
}
@media screen and (max-width: 767px) {
  .c-opening .content .logo {
    width: 64vw;
  }
}

.map-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  background-color: rgba(0, 0, 0, 0.7);
  display: flex;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  overflow-y: auto;
  padding: min(2.0833333333vw, 40px) min(1.0416666667vw, 20px);
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
@media screen and (max-width: 767px) {
  .map-modal {
    padding: 5.3333333333vw 2.6666666667vw;
  }
}
.map-modal.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.map-modal.is-visible .map-modal__inner {
  transform: scale(1);
}
.map-modal__inner {
  position: relative;
  margin: auto;
  border-radius: min(1.0416666667vw, 20px);
  background-color: #F5F0E8;
  background-image: url("../image/bg_map-modal-top.webp"), url("../image/bg_map-modal-bottom.webp");
  background-size: min(22.9166666667vw, 440px) auto, min(18.75vw, 360px) auto;
  background-position: right top, left bottom;
  background-repeat: no-repeat;
  width: min(72.3958333333vw, 1390px);
  padding: min(5.7291666667vw, 110px) min(4.1666666667vw, 80px) min(3.6458333333vw, 70px);
  transform: scale(0.95);
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
@media screen and (max-width: 767px) {
  .map-modal__inner {
    border-radius: 2.6666666667vw;
    background-size: 40vw auto, 34.6666666667vw auto;
    width: 100%;
    padding: 20vw 1.3333333333vw 14.6666666667vw;
  }
}
.map-modal__close {
  position: absolute;
  top: min(1.0416666667vw, 20px);
  right: min(1.0416666667vw, 20px);
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  width: min(2.0833333333vw, 40px);
  height: min(2.0833333333vw, 40px);
  z-index: 10;
  transition: opacity 0.3s;
}
.map-modal__close:hover {
  opacity: 0.7;
}
.map-modal__close img {
  width: 100%;
  height: 100%;
  display: block;
}
@media screen and (max-width: 767px) {
  .map-modal__close {
    top: 2.6666666667vw;
    right: 2.6666666667vw;
    width: 10.6666666667vw;
    height: 10.6666666667vw;
  }
}
.map-modal__title {
  width: -moz-fit-content;
  width: fit-content;
  padding: 0 min(6.7708333333vw, 130px);
  margin-left: auto;
  margin-bottom: max(-2.6041666667vw, -50px);
}
@media screen and (max-width: 767px) {
  .map-modal__title {
    padding: 0;
    margin: 0 auto 10.6666666667vw;
  }
}
.map-modal__title p {
  font-weight: 700;
  font-size: min(1.5625vw, 30px);
  line-height: 1;
  letter-spacing: 0.08em;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .map-modal__title p {
    font-size: 5.3333333333vw;
  }
}
.map-modal__note {
  margin-top: min(1.0416666667vw, 20px);
}
.map-modal__note p {
  font-weight: 400;
  font-size: min(0.6770833333vw, 13px);
  line-height: 1.8;
  text-align: right;
}
@media screen and (max-width: 767px) {
  .map-modal__note {
    margin-top: 2.6666666667vw;
  }
  .map-modal__note p {
    font-size: 2.6666666667vw;
    text-align: center;
  }
}
.map-modal .wrapper {
  display: flex;
  flex-flow: row nowrap;
  align-items: flex-end;
  gap: min(1.5625vw, 30px);
}
@media screen and (max-width: 767px) {
  .map-modal .wrapper {
    flex-flow: column nowrap;
    gap: 9.3333333333vw;
  }
}
.map-modal .wrapper figure {
  position: relative;
}
.map-modal .wrapper figure .float {
  position: absolute;
  top: 0;
  left: min(1.0416666667vw, 20px);
  transform: translateY(-50%);
  border-radius: 100vw;
  border: min(0.1041666667vw, 2px) solid #231815;
  background-color: #E4C852;
  display: flex;
  align-items: center;
  justify-content: center;
  width: -moz-fit-content;
  width: fit-content;
  min-width: min(7.2916666667vw, 140px);
  height: min(1.8229166667vw, 35px);
}
.map-modal .wrapper figure .float span {
  display: block;
  font-weight: 500;
  font-size: min(0.8854166667vw, 17px);
  line-height: 1.2;
}
@media screen and (max-width: 767px) {
  .map-modal .wrapper figure .float {
    left: 4vw;
    border-width: 0.4vw;
    min-width: 24vw;
    height: 6vw;
  }
  .map-modal .wrapper figure .float span {
    font-size: 2.9333333333vw;
  }
}
.map-modal .wrapper .map-image {
  flex-shrink: 0;
  width: min(36.4583333333vw, 700px);
}
@media screen and (max-width: 767px) {
  .map-modal .wrapper .map-image {
    width: 100%;
  }
}
.map-modal .wrapper .map-zoom {
  position: relative;
  border-radius: min(0.78125vw, 15px);
  background-color: #E4C852;
  width: 100%;
  padding: min(0.5208333333vw, 10px) min(0.5208333333vw, 10px) min(1.3020833333vw, 25px);
}
@media screen and (max-width: 767px) {
  .map-modal .wrapper .map-zoom {
    border-radius: 2vw;
    width: 84vw;
    padding: 1.3333333333vw 1.3333333333vw 4vw;
    margin: 0 auto;
  }
}
.map-modal .wrapper .map-zoom::after {
  content: "";
  position: absolute;
  top: min(7.8645833333vw, 151px);
  left: min(0.5208333333vw, 10px);
  transform: translateX(-100%);
  display: block;
  background-image: url("../image/path_map-modal-zoom.svg");
  background-size: 100% auto;
  background-position: center;
  background-repeat: no-repeat;
  width: min(16.6666666667vw, 320px);
  height: min(1.3802083333vw, 26.5px);
}
@media screen and (max-width: 767px) {
  .map-modal .wrapper .map-zoom::after {
    top: 0;
    left: 46vw;
    transform: translateY(-100%);
    background-image: url("../image/path_map-modal-zoom-sp.svg");
    background-position: center bottom;
    width: 3.4666666667vw;
    height: 49.7333333333vw;
  }
}
.map-modal .wrapper .map-zoom__image {
  width: 100%;
  margin-bottom: min(1.8229166667vw, 35px);
}
@media screen and (max-width: 767px) {
  .map-modal .wrapper .map-zoom__image {
    margin-bottom: 4.6666666667vw;
  }
}
.map-modal .wrapper .map-zoom__address {
  font-weight: 500;
  font-size: min(0.9375vw, 18px);
  line-height: 1;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .map-modal .wrapper .map-zoom__address {
    font-size: 3.2vw;
  }
}
.map-modal .wrapper .map-zoom > .c-button {
  width: min(11.9791666667vw, 230px);
  height: min(2.8645833333vw, 55px);
  margin: min(1.5625vw, 30px) auto 0;
}
@media screen and (max-width: 767px) {
  .map-modal .wrapper .map-zoom > .c-button {
    width: 46.6666666667vw;
    height: 11.3333333333vw;
    margin-top: 4.6666666667vw;
  }
}
.map-modal .wrapper .map-zoom > .c-button button {
  font-size: min(0.8854166667vw, 17px);
}
@media screen and (max-width: 767px) {
  .map-modal .wrapper .map-zoom > .c-button button {
    font-size: 3.4vw;
  }
}
.map-modal .wrapper .map-zoom > .c-button button:before {
  content: "";
  background-image: url("../image/common/icon_map.svg");
  background-size: 100% auto;
  background-position: center;
  background-repeat: no-repeat;
  display: inline-block;
  width: min(0.5208333333vw, 10px);
  aspect-ratio: 5/6;
  margin-right: min(0.5208333333vw, 10px);
}
@media screen and (max-width: 767px) {
  .map-modal .wrapper .map-zoom > .c-button button:before {
    width: 2vw;
    margin-right: 2vw;
  }
}

.u-container {
  width: min(100%, 1440px);
  margin-inline: auto;
  padding-inline: 16px;
}
@media screen and (min-width: 1024px) {
  .u-container {
    padding-inline: 24px;
  }
}

.u-grid-responsive {
  display: grid;
  gap: 24px;
  grid-template-columns: 1fr;
}
@media screen and (min-width: 768px) {
  .u-grid-responsive {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.u-hover-card {
  transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}
.u-hover-card:hover, .u-hover-card:focus-within {
  transform: scale(1.03);
  box-shadow: 0 20px 40px rgba(43, 123, 97, 0.12);
}

.u-section-spacing {
  padding-block: clamp(48px, 8vw, 120px);
}

.is-fade-target {
  opacity: 0;
  translate: 0 24px;
  will-change: opacity, translate;
}
@media (prefers-reduced-motion: no-preference) {
  .is-fade-target {
    transition: opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1), translate 0.8s cubic-bezier(0.22, 1, 0.36, 1);
  }
}
.is-fade-target.is-fade-in {
  opacity: 1;
  translate: 0 0;
}/*# sourceMappingURL=style.css.map */