@charset "UTF-8";
.bl__lupuraCta__contact a:hover,
.bl__lupuraFaq .bl__lupuraCta__contact a:hover {
  text-decoration: underline
}
.bl__lupuraHero {
  position: relative;
  width: 100%;
  aspect-ratio: 1920/1080;
  overflow: hidden
}
.bl__lupuraHero__bg,
.lupura__coverImg {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block
}
.bl__lupuraWave {
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 100%;
  line-height: 0;
  z-index: 2
}
.bl__lupuraWave svg {
  display: block;
  width: 100%;
  height: auto
}
.lupura {
  font-family: "Sawarabi Gothic",sans-serif;
  color: #4a5560;
  line-height: 1.85
}
.lupura__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .4em;
  padding: .85em 2em;
  border-radius: 40px;
  color: #fff;
  font-weight: 700;
  text-decoration: none;
  line-height: 1.4;
  transition: opacity .3s
}
.lupura__eyebrow,
.lupura__ttl {
  color: #147ab8;
  font-weight: 700
}
.lupura__btn:hover {
  opacity: .85
}
.lupura__btn--pink {
  background: #ee7aa5
}
.lupura__btn--teal {
  background: #2db1bd
}
.lupura__btn--blue {
  background: #147ab8
}
.lupura__btn--navy {
  background: #1a5f8f
}
.lupura__btn--purple {
  background: #6f63a3
}
.lupura__btn--block {
  display: flex;
  max-width: 560px
}
.lupura__eyebrow {
  font-size: .75rem;
  letter-spacing: .18em;
  text-align: center;
  margin-bottom: .3em
}
.lupura__ttl {
  position: relative;
  display: inline-block;
  font-size: 1.5rem;
  letter-spacing: .04em;
  margin-bottom: 1.6rem
}
.lupura__ttl::after {
  content: "";
  position: absolute;
  left: 8%;
  right: 8%;
  bottom: -2px;
  height: 10px;
  background: rgba(120,200,240,.4);
  z-index: -1;
  border-radius: 4px
}
.lupura__ttlWrap {
  text-align: center
}
.bl__lupuraFeature {
  position: relative;
  width: 100%;
  padding: 60px 40px 90px;
  background: linear-gradient(to bottom,#e8f4fb 0,#f4faff 60%,#fff 100%);
  overflow: hidden;
  box-sizing: border-box
}
.bl__lupuraFeature__fish {
  position: absolute;
  top: 40px;
  left: 80px;
  width: 150px;
  z-index: 1
}
.bl__lupuraFeature__bubble {
  position: absolute;
  z-index: 0
}
.bl__lupuraFeature__bubble--left {
  left: 80px;
  bottom: 0;
  width: 140px
}
.bl__lupuraFeature__bubble--right {
  right: 28px;
  bottom: 0;
  width: 100px
}
.bl__lupuraFeature__title {
  position: relative;
  z-index: 2;
  text-align: center;
  color: #2f6fd6;
  font-size: 28px;
  font-weight: 700;
  letter-spacing: .02em;
  margin: 0 0 40px
}
.bl__lupuraFeature__title span {
  color: #2f6fd6
}
.bl__lupuraFeature__list {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: center;
  gap: 32px;
  list-style: none;
  margin: 0;
  padding: 0;
  flex-wrap: wrap
}
.bl__lupuraFeature__item {
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  box-sizing: border-box;
  border: 4px solid transparent
}
.bl__lupuraFeature__item--blue {
  border-color: #7fa8e0
}
.bl__lupuraFeature__item--blue .bl__lupuraFeature__text {
  color: #4d7fce
}
.bl__lupuraFeature__item--green {
  border-color: #7fc07f
}
.bl__lupuraFeature__item--green .bl__lupuraFeature__text {
  color: #5aa85a
}
.bl__lupuraFeature__item--purple {
  border-color: #b47fc0
}
.bl__lupuraFeature__item--purple .bl__lupuraFeature__text {
  color: #a15cae
}
.bl__lupuraFeature__item--gold {
  border-color: #b8a04a
}
.bl__lupuraFeature__item--gold .bl__lupuraFeature__text {
  color: #a08a3c
}
.bl__lupuraFeature__icon {
  width: 70px;
  height: 70px;
  display: flex;
  align-items: center;
  justify-content: center
}
.bl__lupuraFeature__icon img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain
}
.bl__lupuraFeature__text {
  margin: 0;
  text-align: center;
  font-weight: 700;
  line-height: 1.4;
  font-size: 25px
}
.bl__lupuraIntro {
  position: relative;
  background: #fff;
  padding-bottom: 60px;
  overflow: hidden
}
.bl__lupuraIntro__row {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 460px
}
.bl__lupuraIntro__imgWrap {
  flex: 0 0 55%;
  height: 460px;
  overflow: hidden;
  position: relative;
  z-index: 1
}
.bl__lupuraIntro__img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block
}
.bl__lupuraIntro__row--01 .bl__lupuraIntro__imgWrap {
  border-radius: 0 230px 230px 0
}
@media (max-width:768px) {
  .bl__lupuraFeature__fish {
    top: 126px;
    left: 16px;
    width: 100px
  }
  .bl__lupuraFeature__title {
    font-size: 20px
  }
  .bl__lupuraFeature__list {
    gap: 16px
  }
  .bl__lupuraFeature__item {
    width: 150px;
    height: 150px;
    gap: 8px
  }
  .bl__lupuraFeature__icon {
    width: 40px;
    height: 40px
  }
  .bl__lupuraFeature__text {
    font-size: 14px
  }
  .bl__lupuraIntro__row {
    flex-direction: column;
    min-height: auto
  }
  .bl__lupuraIntro__imgWrap {
    flex: none;
    width: 100%;
    height: 240px
  }
  .bl__lupuraIntro__row--01 .bl__lupuraIntro__imgWrap {
    border-radius: 0
  }
}
.bl__lupuraIntro__row--02 .bl__lupuraIntro__imgWrap {
  order: 2;
  border-radius: 230px 0 0 230px
}
.bl__lupuraIntro__row--02 .bl__lupuraIntro__textWrap {
  order: 1
}
.bl__lupuraIntro__textWrap {
  flex: 0 0 45%;
  padding: 40px 60px;
  box-sizing: border-box;
  z-index: 2
}
.bl__lupuraIntro__heading {
  color: #2f6fd6;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.5;
  margin: 0 0 24px
}
.bl__lupuraIntro__text {
  font-size: 15px;
  line-height: 2;
  color: #333;
  margin: 0
}
.bl__lupuraIntro__fish {
  position: absolute;
  width: 140px;
  z-index: 3;
  pointer-events: none
}
.bl__lupuraIntro__fish--01 {
  right: 6%;
  bottom: -40px
}
@media (max-width:768px) {
  .bl__lupuraIntro__row--02 .bl__lupuraIntro__imgWrap {
    order: 1;
    border-radius: 0
  }
  .bl__lupuraIntro__row--02 .bl__lupuraIntro__textWrap {
    order: 2
  }
  .bl__lupuraIntro__row--02 {
    flex-direction: column;
    min-height: auto
  }
  .bl__lupuraIntro__textWrap {
    flex: none;
    width: 100%;
    padding: 32px 24px 60px
  }
  .bl__lupuraIntro__heading {
    font-size: 19px;
    margin-bottom: 16px
  }
  .bl__lupuraIntro__text {
    font-size: 14px;
    line-height: 1.9
  }
  .bl__lupuraIntro__fish--01 {
    right: 4%;
    bottom: -20px
  }
}
.bl__lupuraIntro__fish--02 {
  left: 5%;
  bottom: -40px
}
.bl__lupuraIntro__fishSchool {
  position: absolute;
  width: 220px;
  z-index: 3;
  pointer-events: none
}
.bl__lupuraIntro__fishSchool--01 {
  right: 4%;
  bottom: -60px
}
.bl__lupuraIntro__ctaHeading {
  text-align: center;
  margin-top: 100px
}
.bl__lupuraIntro__ctaHeading h2 {
  display: inline-block;
  position: relative;
  color: #2f6fd6;
  font-size: 32px;
  font-weight: 800;
  padding-bottom: 16px
}
.bl__lupuraIntro__ctaHeading h2::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 6px;
  background: #dcecfa;
  z-index: -1
}
.bl__lupuraCta {
  position: relative;
  padding: 60px 24px 80px;
  box-sizing: border-box;
  background: linear-gradient(to bottom,#fff 0,#cde9fc 35%,#cde9fc 65%,#fff 100%)
}
@media (max-width:768px) {
  .bl__lupuraIntro__fish--02 {
    left: 4%;
    bottom: -20px
  }
  .bl__lupuraIntro__fish {
    width: 80px
  }
  .bl__lupuraIntro__fishSchool--01 {
    right: 3%;
    bottom: -66px
  }
  .bl__lupuraIntro__fishSchool {
    width: 110px
  }
  .bl__lupuraIntro__ctaHeading h2 {
    font-size: 24px
  }
  .bl__lupuraIntro__ctaHeading {
    margin-top: 60px
  }
  .bl__lupuraCta {
    padding: 40px 16px 60px
  }
}
@media (max-width:480px) {
  .bl__lupuraCta {
    padding: 32px 12px 48px
  }
}
.bl__lupuraCta--plain {
  background: #ecf7fd
}
.bl__lupuraCta--last {
  background: #fff;
  overflow: hidden;
  padding-bottom: 180px
}
.bl__lupuraCta .wrapper {
  max-width: 1080px;
  margin: 0 auto
}
.bl__lupuraCta .lupura__ttlWrap {
  text-align: center;
  margin-bottom: -10px
}
.bl__lupuraCta .lupura__ttlWrap--sub {
  margin-top: 56px
}
.bl__lupuraCta .lupura__ttl {
  display: inline-block;
  position: relative;
  color: #2f6fd6;
  font-size: 32px;
  font-weight: 800;
  line-height: 1.5;
  padding-bottom: 14px
}
.bl__lupuraCta .lupura__ttl::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 6px;
  background: #fff;
  z-index: -1
}
.bl__lupuraCta__photo {
  position: relative;
  width: 100%;
  aspect-ratio: 4.5/1;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0,60,120,.15)
}
.bl__lupuraCta__photo .lupura__coverImg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block
}
@media (max-width:768px) {
  .bl__lupuraCta--last {
    padding-bottom: 100px
  }
  .bl__lupuraCta .lupura__ttlWrap--sub {
    margin-top: 44px
  }
  .bl__lupuraCta .lupura__ttl {
    font-size: 22px
  }
  .bl__lupuraCta__photo {
    border-radius: 16px;
    aspect-ratio: 3/1.3
  }
}
.bl__lupuraCta__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom,rgba(0,30,60,.5) 0,rgba(0,30,60,.15) 40%,rgba(0,30,60,.4) 100%);
  pointer-events: none;
  z-index: 1
}
.bl__lupuraCta__inner {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 6px 16px;
  box-sizing: border-box;
  overflow: hidden
}
.bl__lupuraCta__copy {
  margin: 0;
  text-align: center;
  color: #fff;
  font-size: clamp(11px,1.4vw,20px);
  font-weight: 800;
  letter-spacing: .02em;
  line-height: 1.3;
  text-shadow: 0 2px 10px rgba(0,0,0,.4);
  flex-shrink: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%
}
@media (max-width:768px) {
  .bl__lupuraCta__inner {
    gap: 4px;
    padding: 20px 10px
  }
  .bl__lupuraCta__copy {
    font-size: 18px;
    line-height: 2.25
  }
}
.bl__lupuraCta .lupura__btn {
  position: static;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 88%;
  max-width: 800px;
  min-height: 32px;
  padding: 30px 20px;
  border-radius: 999px;
  text-align: center;
  font-size: clamp(11px,1.1vw,20px);
  font-weight: 800;
  line-height: 1.2;
  text-decoration: none;
  box-sizing: border-box;
  box-shadow: 0 4px 12px rgba(0,0,0,.2);
  transition: transform .2s,box-shadow .2s;
  flex-shrink: 0;
  white-space: nowrap
}
.bl__lupuraCta .lupura__btn::after {
  content: "";
  width: 6px;
  height: 6px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: rotate(45deg);
  flex-shrink: 0
}
.bl__lupuraCta .lupura__btn--pink {
  background: #e3628f;
  color: #fff;
  border: 4px solid #fff
}
.bl__lupuraCta .lupura__btn--pink:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 16px rgba(0,0,0,.25);
  background: #d1507e
}
.bl__lupuraCta .lupura__btn--purple {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 480px;
  margin: 24px auto 0;
  padding: 16px 24px;
  background: #5b4b9e;
  color: #fff;
  box-shadow: 0 6px 14px rgba(0,0,0,.15)
}
.bl__lupuraCta .lupura__btn--purple:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 20px rgba(0,0,0,.2)
}
@media (max-width:768px) {
  .bl__lupuraCta .lupura__btn {
    min-height: 28px;
    padding: 30px 14px;
    font-size: 18px
  }
}
.bl__lupuraCta__insta {
  position: relative;
  margin-top: 0
}
.bl__lupuraCta__instaImg {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 24px;
  box-shadow: 0 10px 30px rgba(0,60,120,.1)
}
.bl__lupuraCta__handle {
  position: relative;
  z-index: 1;
  display: block;
  max-width: 620px;
  margin: 30px auto 0;
  text-align: center;
  background: #fff;
  color: #2f6fd6;
  font-weight: 800;
  font-size: 24px;
  letter-spacing: .03em;
  padding: 18px;
  border-radius: 999px;
  box-shadow: 0 6px 16px rgba(0,60,120,.12)
}
.bl__lupuraCta__note {
  max-width: 900px;
  margin: 48px auto 0;
  text-align: center;
  font-size: 13px;
  line-height: 1.9;
  color: #444
}
.bl__lupuraCta__contactWrap {
  margin-top: 12px
}
.bl__lupuraCta__contact {
  text-align: center;
  font-size: 14px;
  color: #333;
  margin: 4px 0
}
.bl__lupuraCta__contact a {
  color: #333;
  text-decoration: none
}
.bl__lupuraCta__weed {
  position: absolute;
  bottom: 0;
  width: 180px;
  height: auto;
  z-index: 0;
  pointer-events: none
}
.bl__lupuraCta__weed--l {
  left: 100px
}
.bl__lupuraCta__weed--r {
  right: 100px;
  transform: scaleX(-1)
}
@media (max-width:768px) {
  .bl__lupuraCta__instaImg {
    border-radius: 20px
  }
  .bl__lupuraCta__note {
    margin-top: 32px;
    font-size: 12px
  }
  .bl__lupuraCta__contact {
    font-size: 13px
  }
  .bl__lupuraCta__weed {
    width: 100px
  }
  .bl__lupuraCta__weed--l {
    left: 8px
  }
  .bl__lupuraCta__weed--r {
    right: 8px
  }
}
.bl__lupuraCta__fishWrap {
  position: relative;
  height: 0
}
.bl__lupuraCta__fish {
  position: absolute;
  left: 6%;
  bottom: 10px;
  width: 130px;
  z-index: 1;
  pointer-events: none
}
.bl__lupuraReason {
  position: relative;
  padding: 70px 24px 90px;
  background: #cde9f7;
  box-sizing: border-box;
  overflow: hidden
}
.bl__lupuraReason .wrapper {
  max-width: 1080px;
  margin: 0 auto;
  position: relative;
  z-index: 1
}
.bl__lupuraReason .lupura__eyebrow {
  display: inline-block;
  margin: 0 0 16px;
  padding: 10px 28px;
  background: #fff;
  color: #2f6fd6;
  font-size: 16px;
  font-weight: 800;
  letter-spacing: .08em;
  border-radius: 999px;
  box-shadow: 0 4px 10px rgba(0,60,120,.1)
}
.bl__lupuraReason .lupura__ttlWrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  margin-bottom: 48px
}
.bl__lupuraReason .lupura__ttl {
  display: inline-block;
  position: relative;
  color: #2f6fd6;
  font-size: 40px;
  font-weight: 800;
  line-height: 1.5;
  padding-bottom: 14px
}
.bl__lupuraReason .lupura__ttl::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 8px;
  background: #fff;
  z-index: -1
}
.bl__lupuraReason__grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 32px 28px
}
@media (max-width:1024px) {
  .bl__lupuraReason__grid {
    grid-template-columns: repeat(2,1fr)
  }
}
.bl__lupuraReason__item {
  display: flex;
  flex-direction: column;
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 8px 20px rgba(0,60,120,.1);
  transition: transform .2s,box-shadow .2s
}
.bl__lupuraReason__item:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 28px rgba(0,60,120,.16)
}
.bl__lupuraReason__img {
  width: 100%;
  aspect-ratio: 4/3;
  overflow: hidden
}
.bl__lupuraReason__img picture {
  display: block;
  width: 100%;
  height: 100%
}
.bl__lupuraReason__img .lupura__coverImg {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
  display: block
}
.bl__lupuraReason__body {
  padding: 20px 20px 24px
}
.bl__lupuraReason__ttl {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 12px;
  font-size: 17px;
  font-weight: 800;
  color: #1a4fa0;
  line-height: 1.5
}
.bl__lupuraReason__ttl .num {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: #2f6fd6;
  color: #fff;
  font-size: 16px;
  font-weight: 800
}
.bl__lupuraReason__desc {
  margin: 0;
  font-size: 16px;
  line-height: 1.9;
  color: #444
}
.bl__lupuraBigMenu,
.bl__lupuraMenu {
  position: relative;
  padding: 70px 24px 140px;
  background: #fff;
  box-sizing: border-box;
  overflow: hidden
}
.bl__lupuraMenu .wrapper {
  max-width: 1080px;
  margin: 0 auto
}
.bl__lupuraMenu .lupura__ttlWrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  margin-bottom: 56px
}
.bl__lupuraMenu .lupura__eyebrow {
  display: inline-block;
  margin: 0 0 12px;
  padding: 8px 24px;
  background: #eaf5fc;
  color: #2f6fd6;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .08em;
  border-radius: 999px
}
.bl__lupuraMenu .lupura__ttl {
  display: inline-block;
  position: relative;
  color: #2f6fd6;
  font-size: 32px;
  font-weight: 800;
  padding-bottom: 12px;
  margin: 0
}
.bl__lupuraMenu .lupura__ttl::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 8px;
  background: #2f6fd6;
  opacity: .25
}
.bl__lupuraMenu__card {
  position: relative;
  display: flex;
  align-items: stretch;
  gap: 40px;
  margin: 0 auto 64px;
  padding: 0 56px 0 0;
  max-width: 980px;
  min-height: 320px;
  border: 3px solid #2ab6a8;
  border-radius: 28px;
  box-sizing: border-box
}
.bl__lupuraMenu__card:last-child {
  margin-bottom: 0
}
.bl__lupuraMenu__card--snork {
  border-color: #2ab6a8
}
.bl__lupuraMenu__card--dive {
  border-color: #e3628f
}
.bl__lupuraMenu__card--whale {
  border-color: #1a4a7a
}
.bl__lupuraMenu__visualWrap {
  position: relative;
  flex: 0 0 340px;
  align-self: stretch
}
.bl__lupuraMenu__visual {
  width: 100%;
  height: 100%;
  border-radius: 25px 0 0 25px;
  overflow: hidden
}
.bl__lupuraMenu__visual .lupura__coverImg {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block
}
.bl__lupuraMenu__badges {
  position: absolute;
  top: -18px;
  left: 16px;
  display: flex;
  gap: 8px;
  z-index: 4
}
.bl__lupuraMenu__badge {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: inherit;
  box-shadow: 0 4px 10px rgba(0,0,0,.18)
}
.bl__lupuraMenu .lupura__btn,
.lupura__btn--block {
  box-shadow: 0 6px 14px rgba(0,0,0,.15);
  transition: transform .2s,box-shadow .2s;
  text-decoration: none
}
.bl__lupuraMenu__creature {
  position: absolute;
  bottom: -20px;
  right: -20px;
  z-index: 3;
  filter: drop-shadow(0 6px 10px rgba(0, 0, 0, .15))
}
.bl__lupuraMenu__creature--turtle {
  width: 108px
}
.bl__lupuraMenu__creature--diver {
  width: 130px;
  transform: rotate(-6deg)
}
.bl__lupuraMenu__creature--whale {
  width: 118px
}
.bl__lupuraMenu__body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 32px 0
}
.bl__lupuraMenu__name {
  margin: 0 0 8px;
  font-size: 22px;
  font-weight: 800
}
.bl__lupuraMenu__card--snork .bl__lupuraMenu__name {
  color: #2ab6a8
}
.bl__lupuraMenu__card--dive .bl__lupuraMenu__name {
  color: #e3628f
}
.bl__lupuraMenu__card--whale .bl__lupuraMenu__name {
  color: #1a4a7a
}
.bl__lupuraMenu__price {
  margin: 0 0 14px;
  font-size: 16px;
  color: #333
}
.bl__lupuraMenu__price b {
  font-size: 20px;
  font-weight: 800;
  margin: 0 2px
}
.bl__lupuraMenu__lead {
  margin: 0 0 20px;
  font-size: 16px;
  line-height: 1.9;
  color: #444
}
.bl__lupuraMenu .lupura__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 420px;
  max-width: 100%;
  padding: 14px 32px;
  border-radius: 999px;
  color: #fff;
  font-size: 16px;
  font-weight: 800;
  line-height: 1.4;
  align-self: flex-start;
  box-sizing: border-box
}
.bl__lupuraMenu .lupura__btn:hover,
.lupura__btn--block:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 20px rgba(0,0,0,.2)
}
.bl__lupuraMenu .lupura__btn--teal {
  background: #2ab6a8
}
.bl__lupuraMenu .lupura__btn--pink {
  background: #e3628f
}
.bl__lupuraMenu .lupura__btn--navy {
  background: #1a4a7a
}
@media (max-width:900px) {
  .bl__lupuraMenu__card {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 0;
    margin-bottom: 48px
  }
  .bl__lupuraMenu__visualWrap {
    flex: none;
    width: 100%
  }
  .bl__lupuraMenu__visual {
    width: 100%;
    aspect-ratio: 4/3;
    border-radius: 25px 25px 0 0
  }
  .bl__lupuraMenu__badges {
    top: -16px;
    left: 12px
  }
  .bl__lupuraMenu__badge {
    width: 68px;
    height: 68px;
    font-size: 10px
  }
  .bl__lupuraMenu__badge b {
    font-size: 12px
  }
  .bl__lupuraMenu__creature {
    bottom: -24px;
    right: -12px
  }
  .bl__lupuraMenu__creature--turtle {
    width: 100px
  }
  .bl__lupuraMenu__creature--diver {
    width: 150px
  }
  .bl__lupuraMenu__creature--whale {
    width: 130px
  }
  .bl__lupuraMenu__body {
    padding: 24px 24px 28px
  }
  .bl__lupuraMenu .lupura__btn {
    width: 100%;
    align-self: stretch;
    padding: 14px 24px;
    font-size: 20px
  }
}
@media (max-width:480px) {
  .bl__lupuraCta__photo {
    aspect-ratio: 2/1.2
  }
  .bl__lupuraCta__copy {
    font-size: 13px
  }
  .bl__lupuraCta .lupura__btn {
    font-size: 13px;
    padding: 26px 15px;
    min-height: 26px
  }
  .bl__lupuraCta__handle {
    font-size: 17px;
    margin-top: 16px;
    padding: 12px;
    max-width: 90%
  }
  .bl__lupuraCta__weed {
    width: 120px
  }
  .bl__lupuraMenu {
    padding: 48px 16px 60px
  }
  .bl__lupuraMenu .lupura__ttl {
    font-size: 22px
  }
  .bl__lupuraMenu__card {
    border-radius: 20px
  }
  .bl__lupuraMenu__badge {
    width: 56px;
    height: 56px;
    font-size: 9px
  }
  .bl__lupuraMenu__badge b {
    font-size: 10px
  }
  .bl__lupuraMenu__creature--turtle {
    width: 60px
  }
  .bl__lupuraMenu__creature--diver {
    width: 50px
  }
  .bl__lupuraMenu__creature--whale {
    width: 64px
  }
  .bl__lupuraMenu__body {
    padding: 20px
  }
  .bl__lupuraMenu__name {
    font-size: 18px
  }
  .bl__lupuraMenu__price {
    font-size: 14px
  }
  .bl__lupuraMenu__price b {
    font-size: 17px
  }
  .bl__lupuraMenu__lead {
    font-size: 13px
  }
  .bl__lupuraMenu .lupura__btn {
    padding: 12px 20px;
    font-size: 1px
  }
}
.bl__lupuraMenu__fishSchool {
  position: absolute;
  top: 24px;
  right: 28%;
  width: 200px;
  z-index: 2;
  pointer-events: none
}
.bl__lupuraMenu__weed {
  position: absolute;
  bottom: 0;
  width: 160px;
  height: auto;
  z-index: 1;
  pointer-events: none
}
.bl__lupuraMenu__weed--l {
  left: 100px
}
.bl__lupuraMenu__weed--r {
  right: 100px;
  transform: scaleX(-1)
}
.bl__lupuraVoice {
  padding: 70px 24px 90px;
  background: #fff;
  box-sizing: border-box
}
.bl__lupuraVoice .wrapper {
  max-width: 1080px;
  margin: 0 auto
}
.bl__lupuraVoice .lupura__ttlWrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center
}
.bl__lupuraVoice .lupura__eyebrow {
  display: inline-block;
  margin: 0 0 12px;
  padding: 8px 24px;
  background: #eaf5fc;
  color: #2f6fd6;
  font-size: 18px;
  font-weight: 800;
  letter-spacing: .08em;
  border-radius: 999px
}
.bl__lupuraVoice .lupura__ttl {
  display: inline-block;
  position: relative;
  color: #2f6fd6;
  font-size: 50px;
  font-weight: 800;
  padding-bottom: 12px
}
.bl__lupuraVoice .lupura__ttl::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 10px;
  background: #eaf5fc;
  z-index: -1
}
.bl__lupuraVoice__sub {
  margin: 20px 0 44px;
  text-align: center;
  font-size: 17px;
  font-weight: 500;
  color: #333
}
.bl__lupuraVoice__grid {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 24px
}
.bl__lupuraVoice__card {
  background: #fff;
  border: 1px solid #cfe6f7;
  border-radius: 20px;
  padding: 28px 28px 24px
}
.bl__lupuraVoice__stars {
  margin: 0 0 16px;
  color: #cda43c;
  font-size: 22px;
  letter-spacing: 4px
}
.bl__lupuraVoice__ttl {
  margin: 0 0 14px;
  font-size: 22px;
  font-weight: 800;
  color: #1a1a1a
}
.bl__lupuraVoice__txt {
  margin: 0 0 20px;
  font-size: 16px;
  line-height: 1.9;
  color: #444
}
.bl__lupuraVoice__who {
  margin: 0;
  text-align: right;
  font-size: 14px;
  font-weight: 800;
  color: #1a1a1a
}
.bl__lupuraSafe {
  background: #f7f2e6;
  padding: 2.8rem 0 3rem;
  text-align: center
}
.bl__lupuraSafe .wrapper {
  padding: 0 24px;
  box-sizing: border-box
}
.bl__lupuraSafe__ttl {
  color: #5a6068;
  font-size: 2.4rem;
  font-weight: 700;
  margin-bottom: 1.4em
}
.bl__lupuraSafe__list {
  display: grid;
  grid-template-columns: 1fr;
  gap: .3em 2rem;
  max-width: 990px;
  margin: 0 auto 1.6em;
  padding: 110px 30px;
  background: #fff;
  border-radius: 10px;
  text-align: left;
  list-style: none
}
@media (min-width:641px) {
  .lupura__ttl {
    font-size: 1.9rem
  }
  .bl__lupuraSafe__list {
    grid-template-columns: 1fr 1fr
  }
}
.bl__lupuraSafe__list li {
  position: relative;
  padding-left: 1em;
  font-size: 16px;
  line-height: 1.7
}
.bl__lupuraSafe__list li::before {
  content: "・";
  position: absolute;
  left: 0;
  color: #6f63a3
}
@media (max-width:640px) {
  .bl__lupuraHero {
    aspect-ratio: auto;
    height: auto
  }
  .bl__lupuraCta__copy {
    white-space: normal
  }
  .bl__lupuraReason {
    padding: 48px 16px 60px
  }
  .bl__lupuraReason .lupura__eyebrow {
    font-size: 12px;
    padding: 8px 20px
  }
  .bl__lupuraReason .lupura__ttlWrap {
    margin-bottom: 32px
  }
  .bl__lupuraReason .lupura__ttl {
    font-size: 24px
  }
  .bl__lupuraReason__grid {
    grid-template-columns: 1fr;
    gap: 20px
  }
  .bl__lupuraReason__img {
    aspect-ratio: 16/10
  }
  .bl__lupuraReason__body {
    padding: 16px 18px 20px
  }
  .bl__lupuraReason__ttl .num {
    width: 28px;
    height: 28px;
    font-size: 14px
  }
  .bl__lupuraReason__ttl {
    font-size: 16px
  }
  .bl__lupuraReason__desc {
    line-height: 1.8
  }
  .bl__lupuraSafe {
    padding: 2rem 0 2.4rem
  }
  .bl__lupuraSafe .wrapper {
    padding: 0 16px
  }
  .bl__lupuraSafe__ttl {
    font-size: 1.8rem;
    margin-bottom: 1em
  }
  .bl__lupuraSafe__list {
    margin: 0 8px 1.4em;
    padding: 40px 24px;
    border-radius: 16px
  }
  .bl__lupuraSafe__list li {
    font-size: 15px;
    line-height: 1.8
  }
}
.bl__lupuraBigMenu .wrapper {
  max-width: 1080px;
  margin: 0 auto
}
.bl__lupuraBigMenu .lupura__ttlWrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  margin-bottom: 48px
}
.bl__lupuraBigMenu .lupura__eyebrow {
  display: inline-block;
  margin: 0 0 12px;
  padding: 8px 24px;
  background: #eaf5fc;
  color: #2f6fd6;
  font-size: 17px;
  font-weight: 800;
  letter-spacing: .08em;
  border-radius: 999px
}
.bl__lupuraBigMenu .lupura__ttl {
  display: inline-block;
  position: relative;
  color: #2f6fd6;
  font-size: 50px;
  font-weight: 800;
  padding-bottom: 12px
}
.bl__lupuraBigMenu .lupura__ttl::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 10px;
  background: #eaf5fc;
  z-index: 0
}
.bl__lupuraBigMenu__block {
  position: relative;
  margin: 0 auto 72px;
  max-width: 900px
}
.bl__lupuraBigMenu__block:last-child {
  margin-bottom: 0
}
.bl__lupuraBigMenu__block--snork {
  --ribbon-color: #2ab6a8
}
.bl__lupuraBigMenu__block--dive {
  --ribbon-color: #e3628f
}
.bl__lupuraBigMenu__block--whale {
  --ribbon-color: #1a4a7a
}
.bl__lupuraBigMenu__banner {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 20px;
  overflow: hidden
}
.bl__lupuraBigMenu__badges {
  position: relative;
  z-index: 2;
  display: flex;
  gap: 8px;
  margin-bottom: -70px;
  padding: 16px 0 0 16px
}
.bl__lupuraBigMenu__ribbonWrap {
  position: relative;
  margin-top: 24px
}
.bl__lupuraBigMenu__ribbon {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  padding: 12px 40px;
  background: var(--ribbon-color);
  color: #fff;
  font-size: 20px;
  font-weight: 800;
  letter-spacing: .02em;
  border-radius: 999px
}
.bl__lupuraBigMenu__price {
  margin: 28px 0 20px;
  text-align: center;
  font-size: 18px;
  font-weight: 800;
  color: #1a1a1a
}
.bl__lupuraBigMenu__desc {
  margin: 0 0 32px;
  font-size: 16px;
  line-height: 2;
  color: #333;
  text-align: justify
}
.bl__lupuraBigMenu__creature {
  position: absolute;
  top: -40%;
  right: -30px;
  transform: translateY(-30%);
  z-index: 2;
  filter: drop-shadow(0 6px 10px rgba(0, 0, 0, .15))
}
.bl__lupuraBigMenu__block--snork .bl__lupuraBigMenu__creature {
  width: 150px
}
@media (max-width:768px) {
  .bl__lupuraCta__fish {
    left: auto;
    right: -20px;
    bottom: -35px;
    width: 110px
  }
  .bl__lupuraMenu__fishSchool {
    top: 12px;
    right: -2%;
    width: 150px
  }
  .bl__lupuraMenu__weed {
    width: 120px
  }
  .bl__lupuraMenu__weed--l {
    left: 8px
  }
  .bl__lupuraMenu__weed--r {
    right: 8px
  }
  .bl__lupuraVoice {
    padding: 48px 16px 60px
  }
  .bl__lupuraVoice .lupura__ttl {
    font-size: 22px
  }
  .bl__lupuraVoice__sub {
    font-size: 13px;
    margin: 14px 0 32px
  }
  .bl__lupuraVoice__grid {
    grid-template-columns: 1fr;
    gap: 18px
  }
  .bl__lupuraVoice__card {
    padding: 24px 20px 20px
  }
  .bl__lupuraVoice__stars {
    font-size: 18px;
    margin-bottom: 12px
  }
  .bl__lupuraVoice__ttl {
    font-size: 15px
  }
  .bl__lupuraVoice__txt,
  .bl__lupuraVoice__who {
    font-size: 13px
  }
  .bl__lupuraBigMenu {
    padding: 48px 16px 100px
  }
  .bl__lupuraBigMenu .lupura__ttlWrap {
    margin-bottom: 32px
  }
  .bl__lupuraBigMenu .lupura__eyebrow {
    font-size: 13px;
    padding: 6px 18px
  }
  .bl__lupuraBigMenu .lupura__ttl {
    font-size: 26px;
    padding-bottom: 8px
  }
  .bl__lupuraBigMenu .lupura__ttl::after {
    height: 6px
  }
  .bl__lupuraBigMenu__creature {
    right: 12px;
    transform: translateY(-30%)
  }
  .bl__lupuraBigMenu__block--snork .bl__lupuraBigMenu__creature {
    width: 100px
  }
}
.bl__lupuraBigMenu__block--dive .bl__lupuraBigMenu__creature {
  width: 250px
}
.bl__lupuraBigMenu__block--whale .bl__lupuraBigMenu__creature {
  width: 150px
}
.bl__lupuraBigMenu__fishSchool {
  position: absolute;
  top: 54px;
  right: 6%;
  width: 250px;
  z-index: 0;
  pointer-events: none
}
@media (max-width:768px) {
  .bl__lupuraBigMenu__block--dive .bl__lupuraBigMenu__creature {
    width: 150px
  }
  .bl__lupuraBigMenu__block--whale .bl__lupuraBigMenu__creature {
    width: 100px
  }
  .bl__lupuraBigMenu__fishSchool {
    top: 162px;
    right: -16%;
    width: 180px
  }
}
@media (max-width:375px) {
  .bl__lupuraBigMenu__fishSchool {
    width: 70px
  }
}
.bl__lupuraBigMenu__btnRow {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center
}
.bl__lupuraBigMenu__fishSchoolSmall {
  position: absolute;
  left: calc(50% + 260px);
  top: 50%;
  transform: translateY(-50%);
  width: 180px;
  z-index: 2;
  pointer-events: none
}
.lupura__btn--block {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 480px;
  margin: 0 auto;
  padding: 16px 24px;
  border-radius: 999px;
  background: #4a5b9a;
  color: #fff;
  font-size: 16px;
  font-weight: 800
}
.bl__lupuraMenu__badge {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 90px;
  height: 90px;
  border-radius: 50%;
  background: #fff;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.3;
  text-align: center;
  box-shadow: 0 4px 10px rgba(0,0,0,.18)
}
.bl__lupuraMenu__badge b {
  font-size: 13px;
  font-weight: 800
}
.bl__lupuraMenu__badge--teal {
  color: #2ab6a8;
  border: 2px solid #2ab6a8
}
.bl__lupuraMenu__badge--pink {
  color: #e3628f;
  border: 2px solid #e3628f
}
.bl__lupuraMenu__badge--blue {
  color: #1a4a7a;
  border: 2px solid #1a4a7a
}
.bl__lupuraFaq {
  position: relative;
  padding: 70px 24px 90px;
  background: #e5e0f5;
  box-sizing: border-box
}
.bl__lupuraFaq__card,
.bl__lupuraFaq__contactCard {
  background: #fff;
  box-shadow: 0 8px 20px rgba(80,60,130,.1)
}
.bl__lupuraFaq .wrapper {
  max-width: 900px;
  margin: 0 auto
}
.bl__lupuraFaq .lupura__ttlWrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center
}
.bl__lupuraFaq .lupura__ttl {
  display: inline-block;
  position: relative;
  color: #5b4b9e;
  font-size: 30px;
  font-weight: 800;
  line-height: 1.5;
  padding-bottom: 12px
}
.bl__lupuraFaq__a::before,
.bl__lupuraFaq__q::before {
  left: 0;
  display: flex;
  border-radius: 50%;
  color: #fff;
  font-weight: 800
}
.bl__lupuraFaq .lupura__ttl::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 8px;
  background: #cfc3ea;
  z-index: -1
}
.bl__lupuraFaq__sub {
  margin: 24px 0 48px;
  text-align: center;
  font-size: 15px;
  line-height: 1.9;
  color: #4a4460
}
.bl__lupuraFaq__card {
  border-radius: 20px;
  overflow: hidden
}
.bl__lupuraFaq__qa {
  padding: 28px 32px;
  border-bottom: 1px solid #ece6f7
}
.bl__lupuraFaq__qa:last-child {
  border-bottom: none
}
.bl__lupuraFaq__q {
  position: relative;
  margin: 0 0 12px;
  padding-left: 40px;
  font-size: 17px;
  font-weight: 800;
  line-height: 1.6;
  color: #5b4b9e
}
.bl__lupuraFaq__q::before {
  content: "Q";
  position: absolute;
  top: -2px;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  background: #6c5ce7;
  font-size: 15px
}
.bl__lupuraFaq__a {
  position: relative;
  margin: 0;
  padding-left: 40px;
  font-size: 16px;
  line-height: 1.9;
  color: #333
}
.bl__lupuraFaq__a::before {
  content: "A";
  position: absolute;
  top: 0;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  background: #ffb648;
  font-size: 15px
}
.bl__lupuraFaq__contactCard {
  margin-top: 32px;
  padding: 28px 32px;
  border-radius: 20px
}
.bl__lupuraFaq .bl__lupuraCta__note {
  max-width: 100%;
  margin: 0;
  text-align: center;
  font-size: 13px;
  line-height: 1.9;
  color: #444
}
.bl__lupuraFaq .bl__lupuraCta__contactWrap {
  margin-top: 16px
}
.bl__lupuraFaq .bl__lupuraCta__contact {
  text-align: center;
  font-size: 14px;
  color: #333;
  margin: 4px 0
}
.bl__lupuraFaq .bl__lupuraCta__contact a {
  color: #333;
  text-decoration: none
}
.bl__lupuraFaq__fishTop {
  position: absolute;
  left: 10%;
  top: -30px;
  width: 180px;
  z-index: 3;
  pointer-events: none
}
@media (max-width:768px) {
  .bl__lupuraBigMenu__btnRow {
    flex-direction: column;
    gap: 12px
  }
  .bl__lupuraBigMenu__fishSchoolSmall {
    display: none
  }
  .bl__lupuraFaq {
    padding: 48px 16px 60px
  }
  .bl__lupuraFaq .lupura__ttl {
    font-size: 21px
  }
  .bl__lupuraFaq__sub {
    font-size: 13px;
    margin: 18px 0 32px;
    text-align: left
  }
  .bl__lupuraFaq__card {
    border-radius: 16px
  }
  .bl__lupuraFaq__qa {
    padding: 20px
  }
  .bl__lupuraFaq__q {
    font-size: 15px;
    padding-left: 34px
  }
  .bl__lupuraFaq__q::before {
    width: 24px;
    height: 24px;
    font-size: 13px
  }
  .bl__lupuraFaq__a {
    font-size: 14px;
    padding-left: 34px
  }
  .bl__lupuraFaq__a::before {
    width: 24px;
    height: 24px;
    font-size: 13px
  }
  .bl__lupuraFaq__contactCard {
    margin-top: 24px;
    padding: 20px;
    border-radius: 16px
  }
  .bl__lupuraFaq .bl__lupuraCta__note {
    font-size: 12px;
    line-height: 1.8
  }
  .bl__lupuraFaq .bl__lupuraCta__contactWrap {
    margin-top: 12px
  }
  .bl__lupuraFaq .bl__lupuraCta__contact {
    font-size: 13px
  }
  .bl__lupuraFaq__fishTop {
    width: 160px;
    top: -44px;
    left: 4%
  }
}
.lupura__fish {
  display: inline-block;
  vertical-align: middle
}
.lupura__fish--head {
  height: 24px;
  margin-right: 6px
}