@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Zen+Maru+Gothic:wght@300;400;500;700;900&display=swap");
.u-pdt0 {
  padding-top: 0 !important;
}

.u-pdt8 {
  padding-top: 8px !important;
}

.u-pdt16 {
  padding-top: 16px !important;
}

.u-pdt24 {
  padding-top: 24px !important;
}

.u-pdt32 {
  padding-top: 32px !important;
}

.u-pdt40 {
  padding-top: 40px !important;
}

.u-pdt50 {
  padding-top: 50px !important;
}

.u-pdb0 {
  padding-bottom: 0 !important;
}

.u-pdb8 {
  padding-bottom: 8px !important;
}

.u-pdb16 {
  padding-bottom: 16px !important;
}

.u-pdb24 {
  padding-bottom: 24px !important;
}

.u-pdb32 {
  padding-bottom: 32px !important;
}

.u-pdb40 {
  padding-bottom: 40px !important;
}

.u-pdb50 {
  padding-bottom: 50px !important;
}

.u-mgt0 {
  margin-top: 0 !important;
}

.u-mgt8 {
  margin-top: 8px !important;
}

.u-mgt16 {
  margin-top: 16px !important;
}

.u-mgt24 {
  margin-top: 24px !important;
}

.u-mgt32 {
  margin-top: 32px !important;
}

.u-mgt40 {
  margin-top: 40px !important;
}

.u-mgt50 {
  margin-top: 50px !important;
}

.u-mgb0 {
  margin-bottom: 0 !important;
}

.u-mgb8 {
  margin-bottom: 8px !important;
}

.u-mgb16 {
  margin-bottom: 16px !important;
}

.u-mgb20 {
  margin-bottom: 20px !important;
}

.u-mgb30 {
  margin-bottom: 30px !important;
}

.u-mgb40 {
  margin-bottom: 40px !important;
}

.u-mgb50 {
  margin-bottom: 50px !important;
}

.u-hr {
  height: 1px;
  border: none;
  background-color: #CCCCCC;
}

.u-txt-bold {
  font-weight: bold;
}

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

.u-txt-right {
  text-align: right;
}

.u-txt-red {
  color: #FF5757;
}

.u-txt-caution {
  display: block;
  color: #E60000;
}

.u-color-main {
  color: #00923C;
}

.u-vertical-center {
  place-content: center;
}

.u-nowrap {
  white-space: nowrap;
}

.u-border {
  border: 1px solid #D6D6D6;
  padding: 16px;
}

.u-break-word {
  word-break: break-word;
}

.u-caution {
  margin-top: 16px;
  display: flex;
  gap: 4px;
  font-size: clamp(12px,calc(12px + (2) * ((100vw - 375px) / (1065))), 14px);
}

@media screen and (min-width: 1024px) {
  .u-pc-none {
    display: none;
  }
}

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

.u-border-dot {
  width: 94%;
  padding-bottom: 20px;
  margin-top: 60px;
  height: 3px;
  position: relative;
  margin-inline: auto;
  display: block;
  background-image: radial-gradient(circle, #000000 2px, transparent 2px);
  background-position: left top;
  background-repeat: repeat-x;
  background-size: 8px 4px;
}
@media screen and (min-width: 1025px) {
  .u-border-dot {
    margin-top: 120px;
    padding-bottom: 40px;
  }
}

.u-fadein {
  opacity: 0;
  visibility: hidden;
  /*追加*/
  transition: all 1s;
  transform: translateY(80px);
}
@media screen and (min-width: 1025px) {
  .u-fadein {
    transform: translateY(150px);
  }
}
.u-fadein.is-active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.c-sec__inner {
  width: 100%;
  max-width: 1240px;
  padding: 0 20px;
  margin-inline: auto;
}

.c-sec__ttl {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.c-sec__ttl-ico {
  max-width: 60px;
}
@media screen and (min-width: 1025px) {
  .c-sec__ttl-ico {
    max-width: 100px;
  }
}

.c-sec__ttl-main {
  font-size: clamp(38px,calc(38px + (24) * ((100vw - 375px) / (1065))), 62px);
  color: #00923C;
  font-weight: 600;
}

.c-sec__ttl-sub {
  font-size: clamp(22px,calc(22px + (12) * ((100vw - 375px) / (1065))), 34px);
  font-weight: 600;
  margin-top: 18px;
  text-align: center;
}

.c-btn {
  margin-inline: auto;
  margin-top: 30px;
  max-width: 720px;
}
@media screen and (min-width: 1025px) {
  .c-btn {
    margin-top: 80px;
  }
}
.c-btn a {
  font-size: clamp(18px,calc(18px + (20) * ((100vw - 375px) / (1065))), 38px);
  background: #C4D600;
  border: 2px solid #262626;
  border-radius: 80px;
  font-weight: 600;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 40px;
  padding: 16px 10px;
  transition: all 0.3s;
}
@media screen and (min-width: 1025px) {
  .c-btn a {
    border: 3px solid #262626;
    padding: 26px 10px;
  }
}
.c-btn a svg {
  width: 10px;
  transition: all 0.3s;
}
@media screen and (min-width: 1025px) {
  .c-btn a svg {
    width: 20px;
  }
}
@media (any-hover: hover) {
  .c-btn a:hover svg {
    transform: translateX(3px);
    animation: fuwafuwayoko 1s linear infinite;
  }
  @keyframes fuwafuwayoko {
    0% {
      transform: translateX(0);
    }
    50% {
      transform: translateX(8px);
    }
    100% {
      transform: translateX(0);
    }
  }
}
.c-btn.small {
  width: 100%;
  max-width: 280px;
  margin-inline: 0;
  margin-top: 0;
}
.c-btn.small a {
  padding: 5px 10px 10px;
  border: 1px solid #262626;
}
@media screen and (min-width: 1025px) {
  .c-btn.small a {
    border: 2px solid #262626;
    padding: 5px 10px 10px;
  }
}
@media (any-hover: hover) {
  .c-btn.small a:hover {
    letter-spacing: 0.06em;
    background: #b0c000;
  }
}

.c-page-top {
  position: fixed;
  bottom: 5px;
  right: 5px;
  z-index: 100;
  width: 90%;
  max-width: 60px;
}
@media screen and (min-width: 1025px) {
  .c-page-top {
    bottom: 20px;
    right: 20px;
    width: 90%;
    max-width: 130px;
  }
}
.c-page-top a {
  display: block;
  width: 100%;
}
.c-page-top img {
  display: block;
  width: 100%;
}

.c-list-indent {
  margin-top: 16px;
}
@media screen and (min-width: 769px) {
  .c-list-indent {
    margin-top: 24px;
  }
}
.c-list-indent li {
  margin-top: 4px;
  display: flex;
  flex-wrap: nowrap;
}
.c-list-indent li span {
  margin-right: 8px;
}
.c-list-indent li p {
  width: 100%;
}
.c-list-indent.disc li {
  position: relative;
  padding-left: 16px;
}
@media screen and (min-width: 1025px) {
  .c-list-indent.disc li {
    padding-left: 22px;
  }
}
.c-list-indent.disc li::before {
  content: "";
  background: #000;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  position: absolute;
  top: 8px;
  left: 0;
}
@media screen and (min-width: 1025px) {
  .c-list-indent.disc li::before {
    width: 14px;
    height: 14px;
  }
}

.c-list-caution {
  margin-top: 16px;
  display: inline-block;
  margin: 16px auto 0;
}
@media screen and (min-width: 769px) {
  .c-list-caution {
    margin-top: 24px;
  }
}
.c-list-caution p {
  display: flex;
  font-size: clamp(11px,calc(11px + (2) * ((100vw - 375px) / (1065))), 13px);
}
.c-list-caution p .c-list-caution__head {
  margin-right: 10px;
}
.c-list-caution.center {
  width: 100%;
}
.c-list-caution.center li {
  justify-content: center;
}

.l-main__body {
  padding-bottom: 0;
  position: relative;
}

.l-main__contents {
  font-family: "Zen Maru Gothic", sans-serif;
  display: block;
  color: #212121;
  /* 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.
  */
  /* Vertical rhythm */
  /* ============================================ */
  /* Headings */
  /* ============================================ */
  /* Lists (enumeration) */
  /* ============================================ */
  /* Lists (definition) */
  /* ============================================ */
  /* Grouping content */
  /* ============================================ */
  /**
  * 1. Add the correct box sizing in Firefox.
  * 2. Show the overflow in Edge and IE.
  */
  /**
  * 1. Correct the inheritance and scaling of font size in all browsers.
  * 2. Correct the odd `em` font sizing in all browsers.
  */
  /* Text-level semantics */
  /* ============================================ */
  /**
  * Remove the gray background on active links in IE 10.
  */
  /**
  * 1. Remove the bottom border in Chrome 57-
  * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
  */
  /**
  * Add the correct font weight in Chrome, Edge, and Safari.
  */
  /**
  * 1. Correct the inheritance and scaling of font size in all browsers.
  * 2. Correct the odd `em` font sizing in all browsers.
  */
  /**
  * Add the correct font size in all browsers.
  */
  /**
  * Prevent `sub` and `sup` elements from affecting the line height in
  * all browsers.
  */
  /* Replaced content */
  /* ============================================ */
  /**
  * Prevent vertical alignment issues.
  */
  /* Forms */
  /* ============================================ */
  /**
  * Reset form fields to make them styleable.
  * 1. Make form elements stylable across systems iOS especially.
  * 2. Inherit text-transform from parent.
  */
  /**
  * Correct cursors for clickable elements.
  */
  /**
  * Improve outlines for Firefox and unify style with input elements & buttons.
  */
  /**
  * Remove padding
  */
  /**
  * Reset to invisible
  */
  /**
  * Add the correct vertical alignment in Chrome, Firefox, and Opera.
  */
  /**
  * Remove the default vertical scrollbar in IE 10+.
  */
  /**
  * Correct the cursor style of increment and decrement buttons in Chrome.
  */
  /**
  * Correct the outline style in Safari.
  */
  /**
  * Remove the inner padding in Chrome and Safari on macOS.
  */
  /**
  * 1. Correct the inability to style clickable types in iOS and Safari.
  * 2. Fix font inheritance.
  */
  /**
  * Fix appearance for Firefox
  */
  /**
  * Clickable labels
  */
  /* Interactive */
  /* ============================================ */
  /*
  * Add the correct display in Edge, IE 10+, and Firefox.
  */
  /*
  * Add the correct display in all browsers.
  */
  /*
  * Remove outline for editable content.
  */
  /* Tables */
  /* ============================================ */
  /**
  1. Correct table border color inheritance in all Chrome and Safari.
  */
}
.l-main__contents *,
.l-main__contents ::before,
.l-main__contents ::after {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
}
.l-main__contents p,
.l-main__contents table,
.l-main__contents blockquote,
.l-main__contents address,
.l-main__contents pre,
.l-main__contents iframe,
.l-main__contents form,
.l-main__contents figure,
.l-main__contents dl {
  margin: 0;
}
.l-main__contents h1,
.l-main__contents h2,
.l-main__contents h3,
.l-main__contents h4,
.l-main__contents h5,
.l-main__contents h6 {
  margin: 0;
}
.l-main__contents ul,
.l-main__contents ol {
  margin: 0;
  padding: 0;
  list-style: none;
}
.l-main__contents dt {
  font-weight: bold;
}
.l-main__contents dd {
  margin-left: 0;
}
.l-main__contents hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit;
}
.l-main__contents pre {
  font-family: monospace, monospace; /* 1 */
  font-size: inherit; /* 2 */
}
.l-main__contents address {
  font-style: inherit;
}
.l-main__contents a,
.l-main__contents a:link,
.l-main__contents a[href=""],
.l-main__contents a:visited,
.l-main__contents a:visited:hover {
  text-decoration: none;
  color: inherit;
}
.l-main__contents abbr[title] {
  text-decoration: underline dotted; /* 2 */
}
.l-main__contents b,
.l-main__contents strong {
  font-weight: bolder;
}
.l-main__contents code,
.l-main__contents kbd,
.l-main__contents samp {
  font-family: monospace, monospace; /* 1 */
  font-size: inherit; /* 2 */
}
.l-main__contents small {
  font-size: 80%;
}
.l-main__contents sub,
.l-main__contents sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
.l-main__contents sub {
  bottom: -0.25em;
}
.l-main__contents sup {
  top: -0.5em;
}
.l-main__contents svg,
.l-main__contents img,
.l-main__contents embed,
.l-main__contents object,
.l-main__contents iframe {
  vertical-align: bottom;
}
.l-main__contents button,
.l-main__contents input,
.l-main__contents optgroup,
.l-main__contents select,
.l-main__contents textarea {
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  border-radius: 0;
  text-align: inherit;
  text-transform: inherit; /* 2 */
}
.l-main__contents button,
.l-main__contents [type=button],
.l-main__contents [type=reset],
.l-main__contents [type=submit] {
  cursor: pointer;
}
.l-main__contents button:disabled,
.l-main__contents [type=button]:disabled,
.l-main__contents [type=reset]:disabled,
.l-main__contents [type=submit]:disabled {
  cursor: default;
}
.l-main__contents :-moz-focusring {
  outline: auto;
}
.l-main__contents select:disabled {
  opacity: inherit;
}
.l-main__contents option {
  padding: 0;
}
.l-main__contents fieldset {
  margin: 0;
  padding: 0;
  min-width: 0;
}
.l-main__contents legend {
  padding: 0;
}
.l-main__contents progress {
  vertical-align: baseline;
}
.l-main__contents textarea {
  overflow: auto;
}
.l-main__contents [type=number]::-webkit-inner-spin-button,
.l-main__contents [type=number]::-webkit-outer-spin-button {
  height: auto;
}
.l-main__contents [type=search] {
  outline-offset: -2px; /* 1 */
}
.l-main__contents [type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}
.l-main__contents ::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}
.l-main__contents [type=number] {
  -moz-appearance: textfield;
}
.l-main__contents label[for] {
  cursor: pointer;
}
.l-main__contents details {
  display: block;
}
.l-main__contents summary {
  display: list-item;
}
.l-main__contents [contenteditable]:focus {
  outline: auto;
}
.l-main__contents table {
  border-color: inherit; /* 1 */
  border-collapse: collapse;
}
.l-main__contents caption {
  text-align: left;
}
.l-main__contents td,
.l-main__contents th {
  vertical-align: top;
  padding: 0;
}
.l-main__contents th {
  text-align: left;
  font-weight: bold;
}

.p-mv img {
  width: 100%;
}

.p-anc {
  margin-top: 30px;
}
@media screen and (min-width: 1025px) {
  .p-anc {
    margin-top: 40px;
  }
}
.p-anc .p-anc__list {
  display: flex;
  justify-content: center;
  align-items: center;
  list-style: none;
  flex-direction: column;
  gap: 10px;
  padding: 0;
}
@media screen and (min-width: 1025px) {
  .p-anc .p-anc__list {
    gap: 40px;
    flex-direction: row;
  }
}
.p-anc .p-anc__btn {
  width: 100%;
}
@media screen and (min-width: 1025px) {
  .p-anc .p-anc__btn {
    width: 50%;
  }
}
.p-anc .p-anc__btn a {
  width: 100%;
  border: 2px solid #676767;
  border-radius: 20px;
  color: #00923C;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 15px;
  padding: 15px 10px;
  font-size: clamp(24px,calc(24px + (8) * ((100vw - 375px) / (1065))), 32px);
  font-weight: 600;
  transition: all 0.3s;
}
@media screen and (min-width: 1025px) {
  .p-anc .p-anc__btn a {
    border: 3px solid #676767;
    padding: 30px 10px;
    border-radius: 20px 20px 0 0;
    border-bottom: 0;
    min-width: 510px;
  }
}
.p-anc .p-anc__btn a svg {
  width: 14px;
  transition: all 0.8s;
}
@media screen and (min-width: 1025px) {
  .p-anc .p-anc__btn a svg {
    width: 18px;
  }
}
@media (any-hover: hover) {
  .p-anc .p-anc__btn a:hover {
    color: #00923C;
  }
  .p-anc .p-anc__btn a:hover svg {
    animation: fuwafuwatate 1s linear infinite;
  }
  @keyframes fuwafuwatate {
    0% {
      transform: translateY(3px);
    }
    25% {
      transform: translateY(0px);
    }
    50% {
      transform: translateY(-3px);
    }
    75% {
      transform: translateY(0px);
    }
    100% {
      transform: translateY(3px);
    }
  }
}

.p-hotel {
  background: #F0F7D0;
  padding: 30px 0 60px;
  margin-top: 30px;
}
@media screen and (min-width: 1025px) {
  .p-hotel {
    padding: 60px 0 100px;
    margin-top: 0;
  }
}
.p-hotel .p-hotel__info {
  width: 100%;
  margin-top: 16px;
}
@media screen and (min-width: 1025px) {
  .p-hotel .p-hotel__info {
    margin-top: 28px;
  }
}
.p-hotel .p-hotel__info img {
  width: 100%;
}
.p-hotel .p-hotel__map {
  background: #fff;
  border-radius: 28px;
  padding: 20px 15px;
  margin-top: 30px;
  position: relative;
}
@media screen and (min-width: 1025px) {
  .p-hotel .p-hotel__map {
    border-radius: 36px;
    padding: 35px 20px;
    margin-top: 70px;
  }
}
.p-hotel .p-hotel__map-ttl {
  font-size: clamp(22px,calc(22px + (18) * ((100vw - 375px) / (1065))), 40px);
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}
@media screen and (min-width: 1025px) {
  .p-hotel .p-hotel__map-ttl {
    gap: 20px;
    position: absolute;
    top: 36px;
    left: 50%;
    transform: translateX(-50%);
  }
}
.p-hotel .p-hotel__map-ttl svg {
  width: 16px;
}
@media screen and (min-width: 1025px) {
  .p-hotel .p-hotel__map-ttl svg {
    width: 20px;
  }
}
.p-hotel .p-hotel__map-wrap {
  position: relative;
}
@media screen and (min-width: 1025px) {
  .p-hotel .p-hotel__map-wrap .p-hotel__map-img {
    max-width: 1040px;
    margin-inline: auto;
  }
}
.p-hotel .p-hotel__map-wrap .p-hotel__map-btn-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 15px;
}
@media screen and (min-width: 1025px) {
  .p-hotel .p-hotel__map-wrap .p-hotel__map-btn-list {
    margin-top: 0;
  }
}
.p-hotel .p-hotel__map-wrap .p-hotel__map-btn {
  width: calc(50% - 4px);
}
@media screen and (min-width: 1025px) {
  .p-hotel .p-hotel__map-wrap .p-hotel__map-btn {
    width: fit-content;
    min-width: 120px;
    position: absolute;
  }
}
.p-hotel .p-hotel__map-wrap .p-hotel__map-btn a {
  width: 100%;
  font-size: clamp(14px,calc(14px + (8) * ((100vw - 375px) / (1065))), 22px);
  font-weight: bold;
  font-family: "Noto Sans JP", sans-serif;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: #fff;
  border: 2px solid #707070;
  border-radius: 50px;
  padding: 5px 15px 6px;
  transition: all 0.3s;
}
@media screen and (min-width: 1025px) {
  .p-hotel .p-hotel__map-wrap .p-hotel__map-btn a {
    padding: 2px 18px 3px;
  }
}
.p-hotel .p-hotel__map-wrap .p-hotel__map-btn a svg {
  width: 16px;
  transition: all 0.3s;
}
@media (any-hover: hover) {
  .p-hotel .p-hotel__map-wrap .p-hotel__map-btn a:hover svg {
    transform: translateX(3px);
    animation: fuwafuwayoko 1s linear infinite;
  }
  @keyframes fuwafuwayoko {
    0% {
      transform: translateX(0);
    }
    50% {
      transform: translateX(5px);
    }
    100% {
      transform: translateX(0);
    }
  }
}
.p-hotel .p-hotel__map-wrap .p-hotel__map-btn.btn-01 {
  top: 42%;
  left: 77%;
}
.p-hotel .p-hotel__map-wrap .p-hotel__map-btn.btn-02 {
  top: 57.6%;
  left: 68.6%;
}
.p-hotel .p-hotel__map-wrap .p-hotel__map-btn.btn-03 {
  top: 44%;
  left: 56%;
}
.p-hotel .p-hotel__map-wrap .p-hotel__map-btn.btn-04 {
  top: 59%;
  left: 51%;
}
.p-hotel .p-hotel__map-wrap .p-hotel__map-btn.btn-05 {
  top: 67.4%;
  left: 45%;
}
.p-hotel .p-hotel__map-wrap .p-hotel__map-btn.btn-06 {
  top: 76%;
  left: 50.4%;
}
.p-hotel .p-hotel__map-wrap .p-hotel__map-btn.btn-07 {
  top: 48%;
  left: 33%;
}
.p-hotel .p-hotel__map-wrap .p-hotel__map-btn.btn-08 {
  top: 58%;
  left: 28%;
}
.p-hotel .p-hotel__map-wrap .p-hotel__map-btn.btn-09 {
  top: 76%;
  left: 32.6%;
}
.p-hotel .p-hotel__map-wrap .p-hotel__map-btn.btn-10 {
  top: 57%;
  left: 7.6%;
}
.p-hotel .p-hotel__map-wrap .p-hotel__map-btn.btn-11 {
  top: 81%;
  left: 9.6%;
}
.p-hotel .p-hotel__category-ttl {
  font-size: clamp(20px,calc(20px + (16) * ((100vw - 375px) / (1065))), 36px);
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-top: 60px;
}
@media screen and (min-width: 1025px) {
  .p-hotel .p-hotel__category-ttl {
    gap: 20px;
    margin-top: 100px;
  }
}
.p-hotel .p-hotel__category-ttl svg {
  width: 18px;
}
@media screen and (min-width: 1025px) {
  .p-hotel .p-hotel__category-ttl svg {
    width: 20px;
  }
}
.p-hotel .p-hotel__category-swiper {
  overflow: hidden;
  position: relative;
  margin-top: 20px;
  padding-bottom: 40px;
  /* 前への矢印カスタマイズ */
  /* 次への矢印カスタマイズ */
  /* 画像サイズ調整 */
}
@media screen and (min-width: 1025px) {
  .p-hotel .p-hotel__category-swiper {
    margin-top: 60px;
    padding-bottom: 50px;
  }
}
.p-hotel .p-hotel__category-swiper .swiper-wrapper .swiper-slide a {
  display: block;
}
.p-hotel .p-hotel__category-swiper .swiper-wrapper .swiper-slide a img {
  display: block;
  width: 100%;
}
.p-hotel .p-hotel__category-swiper .swiper-button-prev,
.p-hotel .p-hotel__category-swiper .swiper-button-next {
  margin: 0;
  width: 32px;
  height: 60px;
  top: 34%;
}
.p-hotel .p-hotel__category-swiper .swiper-button-prev svg,
.p-hotel .p-hotel__category-swiper .swiper-button-next svg {
  display: none;
}
.p-hotel .p-hotel__category-swiper .swiper-button-prev {
  left: 0;
}
.p-hotel .p-hotel__category-swiper .swiper-button-next {
  right: 0;
}
.p-hotel .p-hotel__category-swiper .swiper-button-prev::after,
.p-hotel .p-hotel__category-swiper .swiper-button-next::after {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 100%;
  height: 100%;
  display: block;
}
.p-hotel .p-hotel__category-swiper .swiper-button-prev::after {
  background: url(../img/ico_swiper_prev.svg);
  background-size: contain;
}
.p-hotel .p-hotel__category-swiper .swiper-button-next::after {
  background: url(../img/ico_swiper_next.svg);
  background-size: contain;
}
.p-hotel .p-hotel__category-swiper .swiper-slide img {
  height: auto;
  width: 100%;
}
.p-hotel .p-hotel__category-swiper .swiper-pagination-bullet {
  width: 10px;
  height: 10px;
}
.p-hotel .p-hotel__category-swiper .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background: #00923C;
}

.p-rentacar {
  padding: 60px 0 80px;
}
@media screen and (min-width: 1025px) {
  .p-rentacar {
    padding: 110px 0 180px;
  }
}
.p-rentacar .p-rentcar__top-anc {
  display: flex;
  justify-content: center;
  align-items: center;
  list-style: none;
  flex-direction: column;
  gap: 10px;
  padding: 0;
  margin-top: 15px;
}
@media screen and (min-width: 1025px) {
  .p-rentacar .p-rentcar__top-anc {
    margin-top: 30px;
    flex-direction: row;
  }
}
.p-rentacar .p-rentcar__top-anc li {
  width: 100%;
}
.p-rentacar .p-rentcar__top-anc li a {
  font-size: clamp(16px,calc(16px + (12) * ((100vw - 375px) / (1065))), 28px);
  color: #00923C;
  font-weight: 600;
  border: 2px solid #00923C;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  border-radius: 20px;
  padding: 10px;
  transition: all 0.3s;
}
@media screen and (min-width: 1025px) {
  .p-rentacar .p-rentcar__top-anc li a {
    border: 3px solid #00923C;
    border-radius: 30px;
    padding: 15px 20px;
  }
}
.p-rentacar .p-rentcar__top-anc li a img {
  width: 100%;
  max-width: 410px;
}
.p-rentacar .p-rentcar__top-anc li a > span {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}
.p-rentacar .p-rentcar__top-anc li a svg {
  width: 10px;
  transition: all 0.3s;
}
@media screen and (min-width: 1025px) {
  .p-rentacar .p-rentcar__top-anc li a svg {
    width: 20px;
  }
}
@media (any-hover: hover) {
  .p-rentacar .p-rentcar__top-anc li a:hover {
    color: #00923C;
  }
  .p-rentacar .p-rentcar__top-anc li a:hover svg {
    animation: fuwafuwatate 1s linear infinite;
  }
  @keyframes fuwafuwatate {
    0% {
      transform: translateY(3px);
    }
    25% {
      transform: translateY(0px);
    }
    50% {
      transform: translateY(-3px);
    }
    75% {
      transform: translateY(0px);
    }
    100% {
      transform: translateY(3px);
    }
  }
}
.p-rentacar .c-sec__ttl-sub {
  margin-top: 20px;
}
@media screen and (min-width: 1025px) {
  .p-rentacar .c-sec__ttl-sub {
    margin-top: 50px;
  }
}
.p-rentacar .p-rentacar__img {
  margin-top: 15px;
}
@media screen and (min-width: 1025px) {
  .p-rentacar .p-rentacar__img {
    margin-top: 30px;
  }
}
.p-rentacar .p-rentacar__img img {
  width: 100%;
}
.p-rentacar .p-rentacar__ribon-ttl {
  background: #F07600;
  width: 88%;
  max-width: 890px;
  font-size: clamp(20px,calc(20px + (10) * ((100vw - 375px) / (1065))), 30px);
  text-align: center;
  color: #fff;
  margin-inline: auto;
  padding: 10px 10px;
  position: relative;
  margin-top: 30px;
}
@media screen and (min-width: 1025px) {
  .p-rentacar .p-rentacar__ribon-ttl {
    width: 100%;
    padding: 10px 50px;
    margin-top: 60px;
  }
}
.p-rentacar .p-rentacar__ribon-ttl::before {
  content: "";
  background: url(../img/ico_rentacar_ribon_01.svg) no-repeat left;
  background-size: cover;
  height: 100%;
  width: 30px;
  position: absolute;
  left: -27px;
  top: 0;
}
@media screen and (min-width: 1025px) {
  .p-rentacar .p-rentacar__ribon-ttl::before {
    background: url(../img/ico_rentacar_ribon_01.svg) no-repeat left;
    background-size: contain;
    left: -22px;
  }
}
.p-rentacar .p-rentacar__ribon-ttl::after {
  content: "";
  background: url(../img/ico_rentacar_ribon_02.svg) no-repeat right;
  background-size: cover;
  height: 100%;
  width: 30px;
  position: absolute;
  right: -27px;
  top: 0;
}
@media screen and (min-width: 1025px) {
  .p-rentacar .p-rentacar__ribon-ttl::after {
    background: url(../img/ico_rentacar_ribon_02.svg) no-repeat right;
    background-size: contain;
    right: -22px;
  }
}
.p-rentacar .p-rentacar__book-ttl {
  text-align: center;
  font-size: 34px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  font-size: clamp(22px,calc(22px + (23) * ((100vw - 375px) / (1065))), 45px);
  color: #00923C;
  margin-top: 15px;
}
@media screen and (min-width: 1025px) {
  .p-rentacar .p-rentacar__book-ttl {
    gap: 20px;
    margin-top: 30px;
  }
}
.p-rentacar .p-rentacar__book-ttl > span > span {
  font-size: clamp(32px,calc(32px + (26) * ((100vw - 375px) / (1065))), 58px);
}
.p-rentacar .p-rentacar__book-ttl img {
  width: 30px;
}
@media screen and (min-width: 1025px) {
  .p-rentacar .p-rentacar__book-ttl img {
    width: 90px;
  }
}
.p-rentacar .p-rentacar__book-box-txt {
  font-size: clamp(20px,calc(20px + (10) * ((100vw - 375px) / (1065))), 30px);
  font-weight: 600;
  text-align: center;
  border: 2px solid #000;
  max-width: 900px;
  padding: 10px;
  box-shadow: 8px 8px 0px #C4D600;
  margin: 20px 0 5px;
  margin-inline: auto;
}
.p-rentacar .p-rentacar__box {
  border: 2px solid #1A1A1A;
  box-shadow: 4px 4px 0px #000;
  font-family: "Noto Sans JP", sans-serif;
  margin-top: 25px;
  padding: 15px;
}
@media screen and (min-width: 1025px) {
  .p-rentacar .p-rentacar__box {
    padding: 30px 40px;
  }
}
@media screen and (min-width: 1025px) {
  .p-rentacar .p-rentacar__box {
    margin-top: 50px;
  }
}
.p-rentacar .p-rentacar__box .p-rentacar__box-topimg {
  width: 100%;
  max-width: 730px;
}
.p-rentacar .p-rentacar__box .p-rentacar__box-ttl {
  font-size: clamp(20px,calc(20px + (15) * ((100vw - 375px) / (1065))), 35px);
  color: #00923C;
  font-weight: 500;
}
.p-rentacar .p-rentacar__box .p-rentacar__box-flex {
  display: flex;
  flex-direction: column;
  gap: 6px;
  border-bottom: 1px solid #707070;
  padding-bottom: 8px;
}
@media screen and (min-width: 1025px) {
  .p-rentacar .p-rentacar__box .p-rentacar__box-flex {
    align-items: flex-end;
    flex-direction: row;
    justify-content: space-between;
  }
}
.p-rentacar .p-rentacar__box .p-rentacar__box-flex .p-rentacar__box-flex-txt {
  font-size: clamp(16px,calc(16px + (8) * ((100vw - 375px) / (1065))), 24px);
  margin-top: 5px;
}
@media screen and (min-width: 1025px) {
  .p-rentacar .p-rentacar__box .p-rentacar__box-flex .p-rentacar__box-flex-txt {
    width: 70%;
    margin-top: 10px;
  }
}
.p-rentacar .p-rentacar__box .p-rentacar__box-flex .p-rentacar__box-flex-price {
  font-size: clamp(14px,calc(14px + (6) * ((100vw - 375px) / (1065))), 20px);
  width: fit-content;
  margin-left: auto;
}
@media screen and (min-width: 1025px) {
  .p-rentacar .p-rentacar__box .p-rentacar__box-flex .p-rentacar__box-flex-price {
    margin-left: 0;
  }
}
.p-rentacar .p-rentacar__box .p-rentacar__box-flex .p-rentacar__box-flex-price > strong {
  color: #E60000;
  font-size: clamp(24px,calc(24px + (14) * ((100vw - 375px) / (1065))), 38px);
  display: inline-block;
  line-height: 1;
}
.p-rentacar .p-rentacar__box .p-rentacar__box-flex .p-rentacar__box-flex-price > strong span {
  font-size: clamp(30px,calc(30px + (18) * ((100vw - 375px) / (1065))), 48px);
}
@media screen and (min-width: 1025px) {
  .p-rentacar .p-rentacar__box .p-rentacar__box-flex.no-flex .p-rentacar__box-flex-txt {
    width: 100%;
    margin-top: 10px;
  }
}
.p-rentacar .p-rentacar__box .p-rentacar__box-btm {
  display: flex;
  align-items: center;
  flex-direction: column;
  margin-top: 15px;
  gap: 10px;
}
@media screen and (min-width: 1025px) {
  .p-rentacar .p-rentacar__box .p-rentacar__box-btm {
    align-items: flex-end;
    flex-direction: row;
    justify-content: space-between;
    margin-top: 30px;
    gap: 0;
  }
}
@media screen and (min-width: 1025px) {
  .p-rentacar .p-rentacar__box .p-rentacar__box-btm ul {
    width: 70%;
  }
}
.p-rentacar .p-rentacar__box .p-rentacar__box-btm ul li {
  text-indent: -4em;
  padding-left: 4em;
  font-size: clamp(13px,calc(13px + (7) * ((100vw - 375px) / (1065))), 20px);
}
.p-rentacar .p-rentacar__box.price {
  padding: 0 15px 15px;
}
@media screen and (min-width: 1025px) {
  .p-rentacar .p-rentacar__box.price {
    padding: 0 40px 30px;
  }
}
.p-rentacar .p-rentacar__box.price .p-rentacar__box-ttl {
  margin-top: 10px;
}

.bpr-searchbox {
  margin-top: 20px !important;
}
@media screen and (min-width: 1025px) {
  .bpr-searchbox {
    margin-top: 40px !important;
  }
}

.p-place-search {
  background: #C4D600;
  padding: 60px 0;
}
@media screen and (min-width: 1025px) {
  .p-place-search {
    padding: 130px 0;
  }
}
.p-place-search .p-place-search__ttl {
  font-size: clamp(22px,calc(22px + (18) * ((100vw - 375px) / (1065))), 40px);
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  text-align: center;
}
@media screen and (min-width: 1025px) {
  .p-place-search .p-place-search__ttl {
    gap: 20px;
  }
}
.p-place-search .p-place-search__ttl svg {
  width: 16px;
}
@media screen and (min-width: 1025px) {
  .p-place-search .p-place-search__ttl svg {
    width: 20px;
  }
}
.p-place-search .p-place-search__list {
  display: flex;
  flex-wrap: wrap;
  gap: 20px 15px;
  margin-top: 30px;
}
@media screen and (min-width: 1025px) {
  .p-place-search .p-place-search__list {
    margin-top: 80px;
    gap: 40px 30px;
  }
}
.p-place-search .p-place-search__list li {
  width: 100%;
}
@media screen and (min-width: 1025px) {
  .p-place-search .p-place-search__list li {
    width: calc(33.3333333333% - 20px);
  }
}
.p-place-search .p-place-search__list li a {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: 18px;
  transition: all 0.3s;
}
@media screen and (min-width: 1025px) {
  .p-place-search .p-place-search__list li a {
    min-height: 220px;
  }
}
.p-place-search .p-place-search__list li a .p-place-search__list-ttl {
  font-size: clamp(22px,calc(22px + (10) * ((100vw - 375px) / (1065))), 32px);
  font-weight: 600;
  background: rgba(255, 255, 255, 0.8);
  min-height: 40px;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 0;
  z-index: 2;
}
@media screen and (min-width: 1025px) {
  .p-place-search .p-place-search__list li a .p-place-search__list-ttl {
    min-height: 60px;
  }
}
.p-place-search .p-place-search__list li a .p-place-search__list-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: all 0.3s;
}
.p-place-search .p-place-search__list li a .p-place-search__list-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  background: #fff;
  border-radius: 50%;
  position: absolute;
  bottom: 10px;
  right: 10px;
}
@media screen and (min-width: 1025px) {
  .p-place-search .p-place-search__list li a .p-place-search__list-icon {
    width: 54px;
    height: 54px;
  }
}
.p-place-search .p-place-search__list li a .p-place-search__list-icon svg {
  width: 8px;
}
@media screen and (min-width: 1025px) {
  .p-place-search .p-place-search__list li a .p-place-search__list-icon svg {
    width: 13px;
  }
}
@media (any-hover: hover) {
  .p-place-search .p-place-search__list li a:hover .p-place-search__list-img {
    scale: 1.1;
  }
}
