@charset "UTF-8";
@font-face {
  font-family: "Garamond";
  src: url("../fonts/GARA.TTF") format("truetype");
}
/* =========================================================
 base
========================================================= */
/* reset
------------------------------------- */
/*!
 * ress.css • v3.0.1
 * MIT License
 * github.com/filipelinhares/ress
 */
html {
  box-sizing: border-box;
  -webkit-text-size-adjust: 100%;
  word-break: normal;
  -moz-tab-size: 4;
  -o-tab-size: 4;
     tab-size: 4;
}

*, :after, :before {
  background-repeat: no-repeat;
  box-sizing: inherit;
}

:after, :before {
  text-decoration: inherit;
  vertical-align: inherit;
}

* {
  padding: 0;
  margin: 0;
}

hr {
  overflow: visible;
  height: 0;
}

details, main {
  display: block;
}

summary {
  display: list-item;
}

small {
  font-size: 80%;
}

[hidden] {
  display: none;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

a {
  background-color: transparent;
}

a:active, a:hover {
  outline-width: 0;
}

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

pre {
  font-size: 1em;
}

b, strong {
  font-weight: bolder;
}

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

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

input {
  border-radius: 0;
}

[disabled] {
  cursor: default;
}

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

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

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

textarea {
  overflow: auto;
  resize: vertical;
}

button, input, optgroup, select, textarea {
  font: inherit;
}

optgroup {
  font-weight: 700;
}

button {
  overflow: visible;
}

button, select {
  text-transform: none;
}

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

[type=button]::-moz-focus-inner, [type=reset]::-moz-focus-inner, [type=submit]::-moz-focus-inner, button::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

[type=button]::-moz-focus-inner, [type=reset]::-moz-focus-inner, [type=submit]::-moz-focus-inner, button:-moz-focusring {
  outline: 1px dotted ButtonText;
}

[type=reset], [type=submit], button, html [type=button] {
  -webkit-appearance: button;
}

button, input, select, textarea {
  background-color: transparent;
  border-style: none;
}

select {
  -moz-appearance: none;
  -webkit-appearance: none;
}

select::-ms-expand {
  display: none;
}

select::-ms-value {
  color: currentColor;
}

legend {
  border: 0;
  color: inherit;
  display: table;
  white-space: normal;
  max-width: 100%;
}

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

img {
  border-style: none;
}

progress {
  vertical-align: baseline;
}

@media screen {
  [hidden~=screen] {
    display: inherit;
  }
  [hidden~=screen]:not(:active):not(:focus):not(:target) {
    position: absolute !important;
    clip: rect(0 0 0 0) !important;
  }
}
[aria-busy=true] {
  cursor: progress;
}

[aria-controls] {
  cursor: pointer;
}

[aria-disabled] {
  cursor: default;
}

ul, dl, figure {
  margin: 0;
  padding: 0;
}

dt {
  font-weight: normal;
}

ul, li {
  list-style: none;
}

ol {
  padding-left: 1.5em;
}
ol > li {
  list-style: decimal;
}
ol > li + li {
  margin-top: 0.3em;
}

img, iframe {
  vertical-align: bottom;
  max-width: 100%;
}

img {
  height: auto;
}

button {
  outline: none;
  cursor: pointer;
}

table {
  border-collapse: collapse;
}

h1, h2, h3, h4, h5, h6 {
  line-height: 1.4;
}

body {
  height: 100%;
  font-family: "Noto Sans JP", "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Meiryo UI", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 300;
  line-height: 1.7;
  color: #000;
  font-feature-settings: "palt";
  background-color: #f2efdc;
  font-size: 13px;
  font-size: 0.8125rem;
}
@media (min-width: 1024px) {
  body {
    font-size: 14px;
    font-size: 0.875rem;
  }
}

b, strong {
  font-family: "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Meiryo UI", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

a {
  text-decoration: none;
  color: #000;
}

@media (min-width: 768px) {
  a[href*="tel:"]:not(.l-header__contact.u-hidden-large) {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
  }
}
.material-symbols-outlined {
  font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;
}

_:lang(x)::-internal-media-controls-overlay-cast-button, img {
  image-rendering: -webkit-optimize-contrast;
}

/*
@media screen and (-webkit-min-device-pixel-ratio: 0) and (min-resolution: .001dpcm) {
}
*/
.is-fadeIn {
  opacity: 0;
}

/* =========================================================
 component
========================================================= */
/* inner
-------------------------------------- */
.c-inner {
  width: 92%;
  margin-right: auto;
  margin-left: auto;
}
@media (min-width: 1024px) {
  .c-inner {
    width: 88%;
    max-width: 1200px;
  }
}

/* section
-------------------------------------- */
/* img
-------------------------------------- */
.c-img {
  position: relative;
  border-radius: 20px;
}

.c-sharpImg img {
  image-rendering: -webkit-optimize-contrast;
}

/* list
-------------------------------------- */
.c-list > li {
  position: relative;
  padding-left: 1em;
}
.c-list > li:before {
  position: absolute;
  left: 0;
  content: "・";
}
.c-list > li + li {
  margin-top: 0.3em;
}
.c-list ul {
  margin-top: 0.3em;
}
.c-list--square > li::before {
  content: "■" !important;
}
.c-list--disc > li::before {
  content: "●" !important;
}
.c-list--att > li::before {
  content: "※" !important;
}
.c-list--row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6em 1.5em;
}
.c-list--row > li + li {
  margin-top: 0;
}

/* title
-------------------------------------- */
/* lead
-------------------------------------- */
/* btn
-------------------------------------- */
.c-primaryBtn {
  display: inline-flex;
  align-items: center;
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
  align-items: center;
  padding: 0.8em 2em 0.8em 0;
  border-bottom: 1px solid;
  transition: padding 0.5s;
  color: #000;
}
@media (min-width: 1024px) {
  .c-primaryBtn {
    font-size: 18px;
    font-size: 1.125rem;
  }
}
.c-primaryBtn::before, .c-primaryBtn::after {
  position: absolute;
  width: 5px;
  height: 5px;
  border-radius: 5px;
  background: #000;
  content: "";
  transition: transform 0.5s;
}
.c-primaryBtn::before {
  left: 0;
  transform: scale(0);
}
.c-primaryBtn::after {
  right: 1em;
}
@media (any-hover: hover) {
  .c-primaryBtn:hover {
    padding-inline: 1em;
  }
  .c-primaryBtn:hover::before {
    transform: scale(1);
  }
  .c-primaryBtn:hover::after {
    transform: scale(0);
  }
}
.c-primaryBtn--greige {
  color: #000000;
}
.c-primaryBtn--greige::before, .c-primaryBtn--greige::after {
  background: #000000;
}
.c-primaryBtn--reverse {
  padding-inline: 2em 0;
}
.c-primaryBtn--reverse::before {
  left: calc(1em - 2.5px);
  transform: scale(1);
}
.c-primaryBtn--reverse::after {
  right: 1em;
  transform: scale(0);
}
@media (any-hover: hover) {
  .c-primaryBtn--reverse:hover {
    padding-inline: 0 2em;
  }
  .c-primaryBtn--reverse:hover::before {
    transform: scale(0);
  }
  .c-primaryBtn--reverse:hover::after {
    transform: scale(1);
  }
}

/* link
-------------------------------------- */
.c-link--color {
  color: #036EA9;
}
@media (any-hover: hover) {
  .c-link--color {
    transition: 0.5s opacity;
  }
  .c-link--color:hover {
    opacity: 0.7;
  }
}
.c-link--external {
  display: inline-flex;
  justify-content: flex-start !important;
  align-items: center;
  gap: 0.4em;
}
.c-link--external::after {
  width: 0.8em;
  aspect-ratio: 1/1;
  background: url(../img/common/icon_external.svg) no-repeat center/contain;
  content: "";
}
@media (any-hover: hover) {
  .c-link--external {
    transition: 0.5s color;
  }
  .c-link--external:hover {
    color: #000000;
  }
  .c-link--external:hover::after {
    background-image: url(../img/common/icon_external_primary.svg);
  }
}

/* img
-------------------------------------- */
/* =========================================================
 utility
========================================================= */
/* テキスト
-------------------------------------- */
.u-text-left {
  text-align: left !important;
}

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

@media (min-width: 1024px) {
  .u-text-center-large {
    text-align: center !important;
  }
}

.u-text-right {
  text-align: right !important;
}

.u-fs-medium {
  font-size: 18px;
  font-size: 1.125rem;
}

.u-fs-large {
  font-size: 20px;
  font-size: 1.25rem;
}

.u-color-primary {
  color: #000000;
}

.u-bg-gray {
  background: #f0f0f0;
}

/* 表示・非表示
----------------------------------------------- */
.u-hidden {
  display: none !important;
}

@media (min-width: 376px) {
  .u-hidden-xSmall {
    display: none !important;
  }
}

@media (min-width: 521px) {
  .u-hidden-small {
    display: none !important;
  }
}

@media (min-width: 768px) {
  .u-hidden-medium {
    display: none !important;
  }
}

@media (min-width: 1024px) {
  .u-hidden-large {
    display: none !important;
  }
}

@media (min-width: 1366px) {
  .u-hidden-xLarge {
    display: none !important;
  }
}

@media (min-width: 1441px) {
  .u-hidden-xxLarge {
    display: none !important;
  }
}

@media (min-width: 2000px) {
  .u-hidden-xxxLarge {
    display: none !important;
  }
}

@media (max-width: 520px) {
  .u-visible-small {
    display: none !important;
  }
}

@media (max-width: 767px) {
  .u-visible-medium {
    display: none !important;
  }
}

@media (max-width: 1023px) {
  .u-visible-large {
    display: none !important;
  }
}

@media (max-width: 1365px) {
  .u-visible-xLarge {
    display: none !important;
  }
}

@media (max-width: 1440px) {
  .u-visible-xxLarge {
    display: none !important;
  }
}

@media (max-width: 1919px) {
  .u-visible-xxxLarge {
    display: none !important;
  }
}

/* マージン調整
-------------------------------------- */
.u-mt-xxSmall {
  margin-top: 15px !important;
}
@media (min-width: 1024px) {
  .u-mt-xxSmall {
    margin-top: 20px !important;
  }
}

.u-mt-xSmall {
  margin-top: 20px !important;
}
@media (min-width: 1024px) {
  .u-mt-xSmall {
    margin-top: 35px !important;
  }
}

.u-mt-small {
  margin-top: 30px !important;
}
@media (min-width: 1024px) {
  .u-mt-small {
    margin-top: 40px !important;
  }
}

.u-mt-medium {
  margin-top: 45px !important;
}
@media (min-width: 1024px) {
  .u-mt-medium {
    margin-top: 60px !important;
  }
}

.u-mt-large {
  margin-top: 60px !important;
}
@media (min-width: 1024px) {
  .u-mt-large {
    margin-top: 80px !important;
  }
}

.u-mt-xLarge {
  margin-top: 80px !important;
}
@media (min-width: 1366px) {
  .u-mt-xLarge {
    margin-top: 100px !important;
  }
}

.u-mt-xxLarge {
  margin-top: 100px !important;
}
@media (min-width: 1441px) {
  .u-mt-xxLarge {
    margin-top: 170px !important;
  }
}

.u-mb-xxSmall {
  margin-bottom: 15px !important;
}
@media (min-width: 1024px) {
  .u-mb-xxSmall {
    margin-bottom: 20px !important;
  }
}

.u-mb-xSmall {
  margin-bottom: 20px !important;
}
@media (min-width: 1024px) {
  .u-mb-xSmall {
    margin-bottom: 35px !important;
  }
}

.u-mb-small {
  margin-bottom: 30px !important;
}
@media (min-width: 1024px) {
  .u-mb-small {
    margin-bottom: 40px !important;
  }
}

.u-mb-medium {
  margin-bottom: 45px !important;
}
@media (min-width: 1024px) {
  .u-mb-medium {
    margin-bottom: 60px !important;
  }
}

.u-mb-large {
  margin-bottom: 60px !important;
}
@media (min-width: 1024px) {
  .u-mb-large {
    margin-bottom: 80px !important;
  }
}

.u-mb-xLarge {
  margin-bottom: 80px !important;
}
@media (min-width: 1366px) {
  .u-mb-xLarge {
    margin-bottom: 100px !important;
  }
}

.u-mb-xxLarge {
  margin-bottom: 100px !important;
}
@media (min-width: 1441px) {
  .u-mb-xxLarge {
    margin-bottom: 170px !important;
  }
}

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

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

.u-pt-xxSmall {
  padding-top: 15px !important;
}
@media (min-width: 1024px) {
  .u-pt-xxSmall {
    padding-top: 20px !important;
  }
}

.u-pt-xSmall {
  padding-top: 20px !important;
}
@media (min-width: 1024px) {
  .u-pt-xSmall {
    padding-top: 35px !important;
  }
}

.u-pt-small {
  padding-top: 30px !important;
}
@media (min-width: 1024px) {
  .u-pt-small {
    padding-top: 40px !important;
  }
}

.u-pt-medium {
  padding-top: 45px !important;
}
@media (min-width: 1024px) {
  .u-pt-medium {
    padding-top: 60px !important;
  }
}

.u-pt-large {
  padding-top: 60px !important;
}
@media (min-width: 1024px) {
  .u-pt-large {
    padding-top: 80px !important;
  }
}

.u-pt-xLarge {
  padding-top: 80px !important;
}
@media (min-width: 1366px) {
  .u-pt-xLarge {
    padding-top: 100px !important;
  }
}

.u-pt-xxLarge {
  padding-top: 100px !important;
}
@media (min-width: 1441px) {
  .u-pt-xxLarge {
    padding-top: 170px !important;
  }
}

.u-pb-xxSmall {
  padding-bottom: 15px !important;
}
@media (min-width: 1024px) {
  .u-pb-xxSmall {
    padding-bottom: 20px !important;
  }
}

.u-pb-xSmall {
  padding-bottom: 20px !important;
}
@media (min-width: 1024px) {
  .u-pb-xSmall {
    padding-bottom: 35px !important;
  }
}

.u-pb-small {
  padding-bottom: 30px !important;
}
@media (min-width: 1024px) {
  .u-pb-small {
    padding-bottom: 40px !important;
  }
}

.u-pb-medium {
  padding-bottom: 45px !important;
}
@media (min-width: 1024px) {
  .u-pb-medium {
    padding-bottom: 60px !important;
  }
}

.u-pb-large {
  padding-bottom: 60px !important;
}
@media (min-width: 1024px) {
  .u-pb-large {
    padding-bottom: 80px !important;
  }
}

.u-pb-xLarge {
  padding-bottom: 80px !important;
}
@media (min-width: 1366px) {
  .u-pb-xLarge {
    padding-bottom: 100px !important;
  }
}

.u-pb-xxLarge {
  padding-bottom: 100px !important;
}
@media (min-width: 1441px) {
  .u-pb-xxLarge {
    padding-bottom: 170px !important;
  }
}

.u-pt-0 {
  padding-top: 0 !important;
}

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

/* 寄せ
-------------------------------------- */
.u-align-right {
  margin-left: auto;
}

.u-align-center {
  margin-right: auto;
  margin-left: auto;
}

/* 明度変更
-------------------------------------- */
.u-brightness-105 {
  filter: brightness(105%);
}

.u-brightness-110 {
  filter: brightness(110%);
}

.u-brightness-111 {
  filter: brightness(111%);
}

.u-brightness-112 {
  filter: brightness(112%);
}

.u-brightness-113 {
  filter: brightness(113%);
}

.u-brightness-114 {
  filter: brightness(114%);
}

.u-brightness-115 {
  filter: brightness(115%);
}

.u-brightness-116 {
  filter: brightness(116%);
}

.u-brightness-117 {
  filter: brightness(117%);
}

.u-brightness-118 {
  filter: brightness(118%);
}

.u-brightness-119 {
  filter: brightness(119%);
}

.u-brightness-120 {
  filter: brightness(120%);
}

/* =========================================================
 header
========================================================= */
body.is-drawerOpen {
  overflow: hidden;
}
body.is-drawerOpen .is-header--show {
  -webkit-backdrop-filter: none !important;
          backdrop-filter: none !important;
}

.is-header {
  pointer-events: none;
}
.is-header::before {
  transition: opacity 1s, filter 1s;
  opacity: 0;
}
.is-header::after {
  transition: opacity 1s, filter 1s;
  opacity: 0;
}
.is-header--show {
  background-color: rgba(242, 239, 220, 0.4);
  background: linear-gradient(to top, rgba(242, 239, 220, 0) 0%, rgba(242, 239, 220, 0.3) 30%, rgba(242, 239, 220, 0.6) 100%);
  position: relative;
  pointer-events: initial;
  opacity: 1;
}
.is-header--show::before {
  opacity: 1;
  position: absolute;
  z-index: -1;
  inset: 0;
  content: "";
  -webkit-backdrop-filter: blur(4px);
          backdrop-filter: blur(4px);
  will-change: backdrop-filter;
  -webkit-mask-image: linear-gradient(to top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.049) 7.75%, rgba(0, 0, 0, 0.104) 11.25%, rgba(0, 0, 0, 0.45) 23.55%, rgba(0, 0, 0, 0.55) 26.45%, rgba(0, 0, 0, 0.896) 38.75%, rgba(0, 0, 0, 0.951) 42.25%, rgb(0, 0, 0) 50%);
          mask-image: linear-gradient(to top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.049) 7.75%, rgba(0, 0, 0, 0.104) 11.25%, rgba(0, 0, 0, 0.45) 23.55%, rgba(0, 0, 0, 0.55) 26.45%, rgba(0, 0, 0, 0.896) 38.75%, rgba(0, 0, 0, 0.951) 42.25%, rgb(0, 0, 0) 50%);
}
.is-header--show::after {
  opacity: 1;
  position: absolute;
  z-index: -1;
  inset: 0;
  content: "";
  -webkit-backdrop-filter: blur(6px);
          backdrop-filter: blur(6px);
  will-change: filter;
  bottom: 25%;
  -webkit-mask-image: linear-gradient(to top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.049) 15.5%, rgba(0, 0, 0, 0.104) 22.5%, rgba(0, 0, 0, 0.45) 47.1%, rgba(0, 0, 0, 0.55) 52.9%, rgba(0, 0, 0, 0.896) 77.5%, rgba(0, 0, 0, 0.951) 91.9%, rgb(0, 0, 0) 100%);
          mask-image: linear-gradient(to top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.049) 15.5%, rgba(0, 0, 0, 0.104) 22.5%, rgba(0, 0, 0, 0.45) 47.1%, rgba(0, 0, 0, 0.55) 52.9%, rgba(0, 0, 0, 0.896) 77.5%, rgba(0, 0, 0, 0.951) 91.9%, rgb(0, 0, 0) 100%);
}

.l-header {
  display: flex;
  align-items: center;
  position: fixed;
  gap: 20px;
  top: 0;
  right: 0;
  left: 0;
  z-index: 10;
  height: 70px;
}
@media (min-width: 1024px) {
  .l-header {
    height: min(7vw, 140px);
    gap: min(4.9vw, 98px);
  }
}

.l-header__logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  width: 55px;
  margin-right: 20px;
  font-size: 10px;
  font-size: 0.625rem;
}
@media (min-width: 1024px) {
  .l-header__logo {
    width: max(min(4.35vw, 87px), 60px);
  }
}
@media (any-hover: hover) {
  .l-header__logo a {
    transition: 0.5s opacity;
  }
  .l-header__logo a:hover {
    opacity: 0.7;
  }
}

.l-header__nav {
  display: flex;
  align-items: center;
  gap: 20px;
  height: 100%;
  margin-left: auto;
}
@media (min-width: 1024px) {
  .l-header__nav {
    gap: min(4.5vw, 90px);
  }
}

.l-header__drawerBtn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  right: 0px;
  z-index: 5;
  width: 50px;
}
@media (any-hover: hover) {
  .l-header__drawerBtn {
    transition: 0.5s opacity;
  }
  .l-header__drawerBtn:hover {
    opacity: 0.7;
  }
}
@media (min-width: 1024px) {
  .l-header__drawerBtn {
    width: min(6.5vw, 130px);
  }
}
.l-header__drawerBtn .icon {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  aspect-ratio: 130/24;
  width: 100%;
}
.l-header__drawerBtn .icon > span {
  position: absolute;
  width: 100%;
  height: 1px;
  background: rgba(0, 0, 0, 0.65);
  transition: 0.5s;
  content: "";
}
@media (min-width: 1024px) {
  .l-header__drawerBtn .icon > span {
    height: 2px;
  }
}
.l-header__drawerBtn .icon > span:nth-child(1) {
  top: 0;
}
body.is-drawerOpen .l-header__drawerBtn .icon > span:nth-child(1) {
  top: auto;
  transform: rotate(15deg);
}
body.is-drawerOpen .l-header__drawerBtn .icon > span:nth-child(2) {
  opacity: 0;
}
.l-header__drawerBtn .icon > span:nth-child(3) {
  bottom: 0;
}
body.is-drawerOpen .l-header__drawerBtn .icon > span:nth-child(3) {
  bottom: auto;
  transform: rotate(-15deg);
}

.l-header__search {
  display: flex;
  align-items: center;
  gap: 5px;
  width: 100px;
}
@media (min-width: 1024px) {
  .l-header__search {
    width: min(12vw, 240px);
    gap: min(0.8vw, 16px);
  }
}
.l-header__search .text {
  font-size: max(min(1vw, 20px), 14px);
}
.l-header__search .line {
  flex: 1;
  position: relative;
  height: 1px;
  background: rgba(0, 0, 0, 0.65);
}
.l-header__search .line::before {
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 100%;
  height: 2px;
  background: #000;
  transform-origin: right 0;
  transform: scale(0, 1);
  transition: transform 0.5s;
  content: "";
}
@media (any-hover: hover) {
  .l-header__search:hover .line::before {
    transform-origin: left 0;
    transform: scale(1, 1);
  }
}

/* =========================================================
 header
========================================================= */
.l-header .l-header__drawerBtn {
  opacity: 0;
  transition: opacity 1s;
}
.l-header .l-header__logo {
  opacity: 0;
  transition: opacity 1s;
}
.l-header .l-header__nav {
  opacity: 0;
  transition: opacity 1s;
}
.l-header.is-header--show .l-header__drawerBtn {
  opacity: 1;
}
.l-header.is-header--show .l-header__logo {
  opacity: 1;
}
.l-header.is-header--show .l-header__nav {
  opacity: 1;
}

/* =========================================================
 gnav
========================================================= */
.l-gnav {
  display: flex;
  gap: min(2.2222222222vw, 32px);
}
@media (min-width: 1366px) {
  .l-gnav {
    gap: min(4.1666666667vw, 60px);
  }
}
@media (min-width: 1441px) {
  .l-gnav {
    gap: min(4.5vw, 90px);
  }
}
.l-gnav__link {
  position: relative;
  padding-top: 0.2em;
  font-size: max(min(0.9vw, 18px), 13px);
}
@media (any-hover: hover) {
  .l-gnav__link {
    transition: 0.5s opacity;
  }
  .l-gnav__link:hover {
    opacity: 0.7;
  }
}
.l-gnav__link--active {
  opacity: 0.7;
}

/* =========================================================
 drawer
========================================================= */
.l-drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: #f2efdc;
  overflow: auto;
  pointer-events: none;
  transition: 0.5s opacity;
  opacity: 0;
}
body.is-drawerOpen .l-drawer {
  opacity: 1;
  pointer-events: initial;
}
body.is-drawerOpen .l-drawer .l-drawer {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  /* iOSでスムーズスクロール */
  z-index: 9999;
  overscroll-behavior: contain;
}

.l-drawer__inner {
  padding-bottom: 40px;
}
@media (min-width: 1024px) {
  .l-drawer__inner {
    padding-bottom: 70px;
  }
}

.l-drawer__head {
  display: grid;
  grid-template-areas: ". logo language";
  grid-template-columns: 1fr 55px 1fr;
  height: 70px;
}
@media (min-width: 1024px) {
  .l-drawer__head {
    grid-template-columns: 1fr 87px 1fr;
    height: min(10vw, 200px);
  }
}
.l-drawer__head .logo {
  margin: auto;
  grid-area: logo;
}
@media (any-hover: hover) {
  .l-drawer__head .logo a {
    transition: 0.5s opacity;
  }
  .l-drawer__head .logo a:hover {
    opacity: 0.7;
  }
}
.l-drawer__head .language {
  margin-left: auto;
  grid-area: language;
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
  font-weight: 500;
}

@media (max-width: 1023px) {
  .l-drawer__nav {
    padding-left: 30px;
    padding-right: 30px;
  }
}

.l-drawer__sns {
  display: flex;
  justify-content: flex-end;
  gap: 16px;
  margin-top: 20px;
}
@media (max-width: 1023px) {
  .l-drawer__sns {
    margin-left: 30px;
    margin-right: 30px;
  }
}
@media (min-width: 1024px) {
  .l-drawer__sns {
    margin-top: 30px;
  }
}
.l-drawer__sns a {
  width: 37px;
}
@media (any-hover: hover) {
  .l-drawer__sns a {
    transition: 0.5s opacity;
  }
  .l-drawer__sns a:hover {
    opacity: 0.7;
  }
}

.l-drawer__reservation {
  margin-top: 20px;
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
  font-weight: 500;
}
@media (max-width: 1023px) {
  .l-drawer__reservation {
    margin-left: 30px;
    margin-right: 30px;
  }
}
@media (min-width: 1024px) {
  .l-drawer__reservation {
    margin-top: 40px;
  }
}

.l-drawer__reservationBtn {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.3em;
  border: 1px solid;
  font-size: 18px;
  font-size: 1.125rem;
}
@media (any-hover: hover) {
  .l-drawer__reservationBtn {
    transition: 0.5s opacity;
  }
  .l-drawer__reservationBtn:hover {
    opacity: 0.7;
  }
}
@media (min-width: 1024px) {
  .l-drawer__reservationBtn {
    font-size: 30px;
    font-size: 1.875rem;
  }
}

.l-drawer__reservationNav {
  display: flex;
  justify-content: center;
  margin-top: 25px;
}
@media (min-width: 1024px) {
  .l-drawer__reservationNav {
    margin-top: 40px;
  }
}
.l-drawer__reservationNav li + li {
  display: flex;
  align-items: center;
}
.l-drawer__reservationNav li + li::before {
  width: 1px;
  margin-inline: 1.8em;
  height: 1.25em;
  background: #000;
  content: "";
}
@media (any-hover: hover) {
  .l-drawer__reservationNav a {
    transition: 0.5s opacity;
  }
  .l-drawer__reservationNav a:hover {
    opacity: 0.7;
  }
}

/* =========================================================
 対策
========================================================= */
/* CSS部分の修正 */
.l-drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: #f2efdc;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  pointer-events: none;
  transition: 0.3s opacity;
  opacity: 0;
  z-index: 30;
}
body.is-drawerOpen .l-drawer {
  opacity: 1;
  pointer-events: initial;
}

/* bodyが固定された時のスタイル調整 */
body.is-drawerOpen {
  /* touchイベントも無効にする */
  -webkit-overflow-scrolling: auto;
}

/* iOS Safari対応のためのビューポート高さ調整 */
@supports (-webkit-touch-callout: none) {
  .l-drawer {
    /* iOS Safari用の高さ調整 */
    height: 100vh;
    height: 100dvh;
  }
}
/* ドロワー内のスクロール領域を明確にする */
.l-drawer__inner {
  min-height: 100%;
  padding-bottom: 40px;
  /* 安全領域を考慮 */
  padding-bottom: calc(40px + env(safe-area-inset-bottom));
}
@media (min-width: 1024px) {
  .l-drawer__inner {
    padding-bottom: 70px;
    padding-bottom: calc(70px + env(safe-area-inset-bottom));
  }
}

/* タッチデバイス用の追加スタイル */
@media (hover: none) and (pointer: coarse) {
  .l-drawer {
    /* モバイル端末でのスクロール最適化 */
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-y: contain;
  }
  /* ドロワーが開いている時のbody固定をより強固にする */
}
.is-drawerOpen .l-header {
  opacity: 1;
  z-index: 50;
}
.is-drawerOpen .l-header .l-header__drawerBtn {
  z-index: 50;
  pointer-events: auto;
  opacity: 1;
}
.is-drawerOpen .l-header .l-header__logo {
  display: none;
}
.is-drawerOpen .l-header .l-header__nav {
  display: none;
}

/* =========================================================
 footer
========================================================= */
.l-footer {
  position: relative;
  z-index: 2;
  background: #152626;
  color: #FFF;
}

.l-footer__lead {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  aspect-ratio: 2000/730;
}
@media (min-width: 2000px) {
  .l-footer__lead {
    aspect-ratio: unset;
    height: 730px;
  }
}
.l-footer__lead .text {
  position: relative;
  z-index: 2;
  margin-top: 3%;
  color: #FFF;
  font-family: "Garamond", "EB Garamond", serif;
  font-size: 35px;
  font-size: 2.1875rem;
}
@media (min-width: 376px) {
  .l-footer__lead .text {
    font-size: 40px;
    font-size: 2.5rem;
  }
}
@media (min-width: 1024px) {
  .l-footer__lead .text {
    margin-top: 5%;
    font-size: 60px;
    font-size: 3.75rem;
  }
}
.l-footer__lead .bg {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.l-footer__lead .bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.l-footer__inner {
  padding-block: 50px;
}
@media (min-width: 1024px) {
  .l-footer__inner {
    padding-block: 80px;
  }
}

.l-footer__nav a {
  color: #FFF;
}

.l-footer__bottom {
  display: grid;
  gap: 24px;
  margin-top: 40px;
}
@media (max-width: 767px) {
  .l-footer__bottom {
    text-align: center;
  }
}
@media (min-width: 768px) {
  .l-footer__bottom {
    grid-template-areas: "info logo sns" "info logo copy";
    grid-template-columns: 1fr 125px 1fr;
    gap: 16px 0;
  }
}
@media (min-width: 1024px) {
  .l-footer__bottom {
    margin-top: 80px;
  }
}

.l-footer__logo {
  width: 125px;
}
@media (max-width: 767px) {
  .l-footer__logo {
    margin-inline: auto;
  }
}
@media (min-width: 768px) {
  .l-footer__logo {
    grid-area: logo;
  }
}
@media (any-hover: hover) {
  .l-footer__logo a {
    transition: 0.5s opacity;
  }
  .l-footer__logo a:hover {
    opacity: 0.7;
  }
}

.l-footer__info {
  line-height: 2.16;
  font-size: 12px;
  font-size: 0.75rem;
}
@media (min-width: 768px) {
  .l-footer__info {
    grid-area: info;
    margin-top: auto;
  }
}

.l-footer__sns {
  display: flex;
  gap: 16px;
}
@media (max-width: 767px) {
  .l-footer__sns {
    justify-content: center;
  }
}
@media (min-width: 768px) {
  .l-footer__sns {
    justify-content: flex-end;
    grid-area: sns;
    margin-top: auto;
  }
}
.l-footer__sns a {
  width: 37px;
}
@media (any-hover: hover) {
  .l-footer__sns a {
    transition: 0.5s opacity;
  }
  .l-footer__sns a:hover {
    opacity: 0.7;
  }
}

.l-footer__copy {
  font-size: 12px;
  font-size: 0.75rem;
}
@media (min-width: 768px) {
  .l-footer__copy {
    grid-area: copy;
    text-align: right;
  }
}

/* =========================================================
 main
========================================================= */
.l-main {
  position: relative;
  z-index: 2;
  overflow: clip;
}
/* =========================================================
 container
========================================================= */
.l-container {
  display: grid;
  gap: 60px 40px;
  width: 92%;
  margin-right: auto;
  margin-left: auto;
  padding-bottom: 20px;
}
@media (min-width: 1024px) {
  .l-container {
    gap: min(5.3333333333vw, 80px);
    width: 88%;
    max-width: 1200px;
  }
}
@media (min-width: 1024px) {
  .l-container:has(.l-sidebar) {
    grid-template-columns: 1fr max(240px, 25%);
  }
}
.l-container .l-contents {
  margin: 0;
  width: auto;
  max-width: none;
}

/* =========================================================
 contents
========================================================= */
.l-contents {
  width: 92%;
  margin-right: auto;
  margin-left: auto;
}
@media (min-width: 1024px) {
  .l-contents {
    width: 88%;
    max-width: 1200px;
  }
}
/* =========================================================
 sidebar
========================================================= */
.l-sidebar > ul {
  display: flex;
  flex-direction: column;
  gap: 40px;
}
@media (min-width: 521px) {
  .l-sidebar > ul {
    gap: 50px;
  }
}

.l-sidebar__title {
  margin-bottom: 1em;
  padding: 0 0 0.5em;
  border-bottom: 3px solid #000000;
  font-family: "Noto Sans JP", "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Meiryo UI", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 600;
  color: #000000;
  font-size: 20px;
  font-size: 1.25rem;
}

.l-sidebar__entryList li {
  display: flex;
  flex-direction: column-reverse;
  padding: 0.8em 0.4em;
  border-bottom: 1px dotted rgba(187, 188, 190, 0.5);
}
.l-sidebar__entryList li:first-child {
  padding-top: 0;
}
.l-sidebar__entryList .wp-block-latest-posts__post-date {
  display: block;
  color: #f2efdc;
  font-size: 14px;
  font-size: 0.875rem;
}
@media (any-hover: hover) {
  .l-sidebar__entryList a {
    transition: 0.5s opacity;
  }
  .l-sidebar__entryList a:hover {
    opacity: 0.7;
  }
}

.l-sidebar__category > li {
  display: flex;
  flex-wrap: wrap;
  gap: 0.2em;
}
.l-sidebar__category > li::before {
  content: "・";
}
.l-sidebar__category li + li {
  margin-top: 0.5em;
}
.l-sidebar__category li .children {
  width: 100%;
  margin-top: 0.5em;
}
.l-sidebar__category li .children li {
  display: flex;
  gap: 0.2em;
  margin-left: 1em;
}
.l-sidebar__category li .children li::before {
  content: "-";
}
@media (any-hover: hover) {
  .l-sidebar__category a {
    transition: 0.5s color;
  }
  .l-sidebar__category a:hover {
    color: #000000;
  }
}

.l-sidebar__archive {
  position: relative;
  background: #FFF;
  font-size: 16px;
  font-size: 1rem;
}
.l-sidebar__archive::after {
  position: absolute;
  right: 1em;
  top: 50%;
  transform: translateY(-50%);
  background: #000;
  height: 0.5em;
  width: 0.8em;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  content: "";
}
.l-sidebar__archive select {
  width: 100%;
  border: 1px solid;
  padding: 0.5em 2em 0.5em 1em;
  border-color: #bbbcbe;
  color: #000;
  cursor: pointer;
}

/* =========================================================
 検索パネル
========================================================= */
.p-homeSearch__inner {
  padding-block: 50px;
}
@media (min-width: 1024px) {
  .p-homeSearch__inner {
    padding-block: 70px;
  }
}

.p-homeSearch__title {
  color: #92937e;
}

.p-homeSearch__menu {
  display: flex;
  justify-content: center;
  margin-top: 25px;
}
@media (min-width: 1024px) {
  .p-homeSearch__menu {
    margin-top: 40px;
  }
}
.p-homeSearch__menu li + li {
  display: flex;
  align-items: center;
}
.p-homeSearch__menu li + li::before {
  width: 1px;
  margin-inline: 1.8em;
  height: 1.25em;
  background: #000;
  content: "";
}
@media (any-hover: hover) {
  .p-homeSearch__menu a {
    transition: 0.5s opacity;
  }
  .p-homeSearch__menu a:hover {
    opacity: 0.7;
  }
}

.p-homeSearch__wrapper {
  display: grid;
  grid-template-areas: "date date date" "nights rooms numbers" "submit submit submit";
  gap: 20px 0;
}
@media (min-width: 768px) {
  .p-homeSearch__wrapper {
    grid-template-areas: "date nights rooms numbers" "submit submit submit submit";
    grid-template-columns: 1fr 0.72fr 0.72fr 0.72fr;
    gap: 26px;
  }
}
@media (min-width: 1024px) {
  .p-homeSearch__wrapper {
    grid-template-areas: "date nights rooms numbers submit";
    grid-template-columns: 1fr 0.72fr 0.72fr 0.72fr 1fr;
    gap: 0;
  }
}

.p-homeSearch__date {
  grid-area: date;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
  font-size: 22px;
  font-size: 1.375rem;
}
@media (min-width: 768px) {
  .p-homeSearch__date {
    border-left: 1px solid;
  }
}
@media (min-width: 1024px) {
  .p-homeSearch__date {
    height: min(5.7142857143vw, 80px);
    font-size: min(2.1428571429vw, 30px);
  }
}
.p-homeSearch__date input {
  width: 7em;
  text-align: center;
  font-size: inherit;
}

.p-homeSearch__nights {
  grid-area: nights;
  border-left: 1px solid;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-size: 1.375rem;
}
@media (min-width: 1024px) {
  .p-homeSearch__nights {
    font-size: min(2.1428571429vw, 30px);
  }
}
.p-homeSearch__nights .wrapper {
  display: flex;
  align-items: center;
  position: relative;
  width: 3.8em;
}
.p-homeSearch__nights .wrapper::after {
  position: absolute;
  right: 0.1em;
  margin-top: -0.1em;
  width: 0.3em;
  transform: rotate(45deg);
  border-right: 1px solid;
  border-bottom: 1px solid;
  aspect-ratio: 1;
  pointer-events: none;
  content: "";
}
.p-homeSearch__nights select {
  width: 100%;
  padding-left: 0.4em;
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
  font-size: inherit;
  color: #000;
  cursor: pointer;
}
.p-homeSearch__nights .suffix {
  position: absolute;
  left: 2.8em;
  color: #92937e;
  font-size: 60%;
  pointer-events: none;
}

.p-homeSearch__rooms {
  grid-area: rooms;
  border-left: 1px solid;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-size: 1.375rem;
}
@media (min-width: 1024px) {
  .p-homeSearch__rooms {
    font-size: min(2.1428571429vw, 30px);
  }
}
.p-homeSearch__rooms .wrapper {
  display: flex;
  align-items: center;
  position: relative;
  width: 3.8em;
}
.p-homeSearch__rooms .wrapper::after {
  position: absolute;
  right: 0.1em;
  margin-top: -0.1em;
  width: 0.3em;
  transform: rotate(45deg);
  border-right: 1px solid;
  border-bottom: 1px solid;
  aspect-ratio: 1;
  pointer-events: none;
  content: "";
}
.p-homeSearch__rooms select {
  width: 100%;
  padding-left: 0.4em;
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
  font-size: inherit;
  color: #000;
  cursor: pointer;
}
.p-homeSearch__rooms .suffix {
  position: absolute;
  left: 2.8em;
  color: #92937e;
  font-size: 60%;
  pointer-events: none;
}

.p-homeSearch__numbers {
  grid-area: numbers;
  border-inline: 1px solid;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-size: 1.375rem;
}
@media (min-width: 1024px) {
  .p-homeSearch__numbers {
    font-size: min(2.1428571429vw, 30px);
  }
}
.p-homeSearch__numbers .wrapper {
  display: flex;
  align-items: center;
  position: relative;
  width: 3.8em;
}
.p-homeSearch__numbers .wrapper::after {
  position: absolute;
  right: 0.1em;
  margin-top: -0.1em;
  width: 0.3em;
  transform: rotate(45deg);
  border-right: 1px solid;
  border-bottom: 1px solid;
  aspect-ratio: 1;
  pointer-events: none;
  content: "";
}
.p-homeSearch__numbers select {
  width: 100%;
  padding-left: 0.4em;
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
  font-size: inherit;
  color: #000;
  cursor: pointer;
}
.p-homeSearch__numbers .suffix {
  position: absolute;
  left: 2.8em;
  color: #92937e;
  font-size: 60%;
  pointer-events: none;
}

.p-homeSearch__submit {
  grid-area: submit;
}
@media (min-width: 1024px) {
  .p-homeSearch__submit {
    height: min(5.7142857143vw, 80px);
    border-right: 1px solid;
  }
}
.p-homeSearch__submit button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1em;
  padding-left: 1em;
  cursor: pointer;
  font-size: 17px;
  font-size: 1.0625rem;
}
@media (any-hover: hover) {
  .p-homeSearch__submit button {
    transition: 0.5s opacity;
  }
  .p-homeSearch__submit button:hover {
    opacity: 0.7;
  }
}
@media (max-width: 1023px) {
  .p-homeSearch__submit button {
    width: 100%;
    max-width: 400px;
    height: 3em;
    margin-inline: auto;
    border: 1px solid;
  }
}
@media (min-width: 1024px) {
  .p-homeSearch__submit button {
    gap: 2em;
    width: 100%;
    height: 100%;
    padding-left: 2em;
    letter-spacing: 0.05em;
    font-size: min(1.4285714286vw, 20px);
  }
}
.p-homeSearch__submit button::after {
  width: 1em;
  aspect-ratio: 1;
  background: url(../img/home/search_arrow.png) no-repeat center/contain;
  content: "";
}

/* データピッカー
----------------------------------------------- */
.ui-datepicker-inline {
  width: 100% !important;
  border: none !important;
  font-family: "Noto Sans JP", "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Meiryo UI", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.ui-datepicker-header {
  background: transparent !important;
  border: none !important;
}

.ui-datepicker-next {
  border: none !important;
  background: none !important;
  text-align: center;
  font-weight: bold !important;
  cursor: pointer;
}
.ui-datepicker-next.ui-state-disabled {
  cursor: default;
}
.ui-datepicker-next::after {
  content: ">";
}
.ui-datepicker-next span {
  display: none !important;
}
.ui-datepicker-prev {
  border: none !important;
  background: none !important;
  text-align: center;
  font-weight: bold !important;
  cursor: pointer;
}
.ui-datepicker-prev.ui-state-disabled {
  cursor: default;
}
.ui-datepicker-prev::after {
  content: "<";
}
.ui-datepicker-prev span {
  display: none !important;
}
.ui-datepicker td {
  padding: 0 !important;
}
.ui-datepicker td a {
  color: #000 !important;
}

.ui-state-default {
  text-align: center !important;
  border-color: transparent !important;
  background: transparent !important;
}
.ui-state-default.ui-state-selected {
  background: #eee !important;
}
.ui-state-default.ui-state-active {
  background: #d5d5d5 !important;
  border-color: #000 !important;
}

.ui-datepicker-current-day .ui-state-highlight {
  background: #d5d5d5 !important;
}

.kt-unselectable {
  pointer-events: none;
}

/* =========================================================
 project
========================================================= */
.p-subcontents {
  margin-bottom: 100px;
}
@media (min-width: 1024px) {
  .p-subcontents {
    margin-bottom: 170px;
  }
}

/* kv 
-------------------------------------- */
.p-kv {
  position: relative;
}
@media (max-width: 1023px) {
  .p-kv {
    aspect-ratio: 4/3;
  }
}
@media (min-width: 1024px) {
  .p-kv {
    height: 40vw;
    min-height: 650px;
    max-height: 800px;
  }
}
.p-kv.full-mainvisual {
  height: 100vh;
  height: 100svh;
  max-height: 100%;
  min-height: auto;
  aspect-ratio: auto;
}
.p-kv.full-mainvisual .p-kv__inner {
  display: flex;
  align-items: flex-end;
  position: relative;
  z-index: 2;
  height: 100%;
  max-width: 1700px;
  width: 92%;
  margin-left: auto;
  margin-right: auto;
  padding-bottom: 100px;
}
.p-kv.full-mainvisual .p-kv__inner .p-kv__title {
  display: flex;
  flex-direction: column;
  color: #FFF;
  font-weight: normal;
}
.p-kv.full-mainvisual .p-kv__inner .p-kv__title .sub {
  line-height: 1.2;
  font-family: "Garamond", "EB Garamond", serif;
  font-size: 60px;
  font-size: 3.75rem;
}
@media (min-width: 768px) {
  .p-kv.full-mainvisual .p-kv__inner .p-kv__title .sub {
    font-size: 80px;
    font-size: 5rem;
  }
}
@media (min-width: 1366px) {
  .p-kv.full-mainvisual .p-kv__inner .p-kv__title .sub {
    font-size: 120px;
    font-size: 7.5rem;
  }
}
.p-kv.full-mainvisual .p-kv__inner .p-kv__title .main {
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
  font-size: 20px;
  font-size: 1.25rem;
}
@media (min-width: 768px) {
  .p-kv.full-mainvisual .p-kv__inner .p-kv__title .main {
    font-size: 25px;
    font-size: 1.5625rem;
  }
}
@media (min-width: 1366px) {
  .p-kv.full-mainvisual .p-kv__inner .p-kv__title .main {
    font-size: 30px;
    font-size: 1.875rem;
  }
}

.topics-title {
  padding-top: 100px;
}
.topics-title .p-homeEssence__title {
  margin-bottom: 0 !important;
}
.topics-title .p-kv__inner {
  display: flex;
  position: relative;
  z-index: 2;
  height: 100%;
  max-width: 1700px;
  width: 92%;
  margin-left: auto;
  margin-right: auto;
  align-items: center;
  justify-content: center;
}
.topics-title .p-kv__inner .p-kv__title {
  display: flex;
  flex-direction: column;
  color: #FFF;
  font-weight: normal;
}
.topics-title .p-kv__inner .p-kv__title .sub {
  line-height: 1.2;
  font-family: "Garamond", "EB Garamond", serif;
  font-size: 60px;
  font-size: 3.75rem;
}
@media (min-width: 768px) {
  .topics-title .p-kv__inner .p-kv__title .sub {
    font-size: 80px;
    font-size: 5rem;
  }
}
@media (min-width: 1366px) {
  .topics-title .p-kv__inner .p-kv__title .sub {
    font-size: 120px;
    font-size: 7.5rem;
  }
}
.topics-title .p-kv__inner .p-kv__title .main {
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
  font-size: 20px;
  font-size: 1.25rem;
}
@media (min-width: 768px) {
  .topics-title .p-kv__inner .p-kv__title .main {
    font-size: 25px;
    font-size: 1.5625rem;
  }
}
@media (min-width: 1366px) {
  .topics-title .p-kv__inner .p-kv__title .main {
    font-size: 30px;
    font-size: 1.875rem;
  }
}

.p-kv__bg {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
.p-kv__bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

/* breadcrumb
-------------------------------------- */
/* postHead
-------------------------------------- */
/* postBody
-------------------------------------- */
.p-postBody {
  /* =========================================================
   Editor
  ========================================================= */
}
.p-postBody h1:not(.c-sectionSubtitle), .p-postBody h2:not(.c-sectionSubtitle), .p-postBody h3:not(.c-sectionSubtitle), .p-postBody h4:not(.c-sectionSubtitle), .p-postBody h5:not(.c-sectionSubtitle), .p-postBody h6:not(.c-sectionSubtitle) {
  font-weight: normal;
  font-family: "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Meiryo UI", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 16px;
  font-size: 1rem;
}
.p-postBody h1:not(.c-sectionSubtitle) + *, .p-postBody h2:not(.c-sectionSubtitle) + *, .p-postBody h3:not(.c-sectionSubtitle) + *, .p-postBody h4:not(.c-sectionSubtitle) + *, .p-postBody h5:not(.c-sectionSubtitle) + *, .p-postBody h6:not(.c-sectionSubtitle) + * {
  margin-top: 0.8em;
}
.p-postBody a:not(.wp-block-button__link) {
  text-decoration: underline;
  color: #036EA9;
}
@media (any-hover: hover) {
  .p-postBody a:not(.wp-block-button__link):hover {
    text-decoration: none;
  }
}
.p-postBody > * + * {
  margin-top: 2em;
}
.p-postBody p strong {
  color: #000000;
}
.p-postBody * + h2,
.p-postBody * + h3,
.p-postBody * + h4,
.p-postBody * + h5,
.p-postBody * + h6 {
  margin-top: 2em;
}
.p-postBody ul li {
  display: flex;
  position: relative;
}
.p-postBody li + li {
  margin-top: 0.5em;
}
.p-postBody ul:not(.blocks-gallery-grid) li {
  display: list-item;
  padding-left: 1em;
}
.p-postBody ul:not(.blocks-gallery-grid) li:before {
  position: absolute;
  left: 0;
  content: "・";
}
.p-postBody ol {
  padding-left: 1.5em;
}
.p-postBody iframe {
  max-width: 100%;
}
.p-postBody pre {
  white-space: pre-wrap;
}
.p-postBody .alignleft {
  float: left;
  margin: 0 1em 1em 0;
}
.p-postBody .alignright {
  float: right;
  margin: 0 0 1em 1em;
}
.p-postBody .aligncenter {
  margin-right: auto;
  margin-left: auto;
}
.p-postBody figure {
  max-width: 1000px;
  margin: 30px auto;
}
@media (min-width: 1024px) {
  .p-postBody figure {
    margin: 50px auto;
  }
}
.p-postBody figure figcaption {
  margin-top: 1em;
  text-align: center;
}
.p-postBody .wp-block-button__link {
  background: #000000;
}
.p-postBody .wp-block-columns > * > * + * {
  margin-top: 2em;
}

/* entryList
-------------------------------------- */
/* pager
-------------------------------------- */
.p-pager {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media (max-width: 767px) {
  .p-pager {
    gap: 10px;
    flex-direction: column;
  }
}
.p-pager:has(a) {
  margin-top: 40px;
}
@media (min-width: 521px) {
  .p-pager:has(a) {
    margin-top: 80px;
  }
}
@media (min-width: 768px) {
  .p-pager > * {
    width: 48%;
  }
}
.p-pager a {
  color: #000000;
  display: inline-flex !important;
  align-items: center;
  gap: 0.8em;
}
.p-pager a span {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  overflow: hidden;
}
.p-pager a:before {
  flex-shrink: 0;
  background: #000000;
  color: #FFF;
  letter-spacing: 0.06em;
  font-family: "Noto Sans JP", "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Meiryo UI", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  text-decoration: none;
  font-size: 14px;
  font-size: 0.875rem;
}
@media (any-hover: hover) {
  .p-pager a {
    transition: 0.5s opacity;
  }
  .p-pager a:hover {
    opacity: 0.7;
  }
}

.p-pager__next {
  text-align: right;
}
@media (max-width: 767px) {
  .p-pager__next {
    margin-left: auto;
  }
}
.p-pager__next a {
  flex-direction: row-reverse;
}
.p-pager__next a:before {
  padding: 0.2em 0.6em 0.2em 0.8em;
  content: "NEXT >";
}

@media (max-width: 767px) {
  .p-pager__prev {
    margin-right: auto;
  }
}
.p-pager__prev a:before {
  padding: 0.2em 0.8em 0.2em 0.6em;
  content: "< PREV";
}

/* pagination {
-------------------------------------- */
.p-pagination {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.8em;
  margin-top: 50px;
  font-weight: bold;
  font-family: "Noto Sans JP", "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Meiryo UI", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 14px;
  font-size: 0.875rem;
}
@media (min-width: 1024px) {
  .p-pagination {
    margin-top: 100px;
    font-size: 20px;
    font-size: 1.25rem;
  }
}
.p-pagination > * {
  min-width: 2em;
  padding: 0.2em 0.5em;
  border-radius: 100%;
  text-align: center;
}
@media (any-hover: hover) {
  .p-pagination a {
    transition: 0.5s color;
  }
  .p-pagination a:hover {
    color: #000000;
  }
}
.p-pagination .prev,
.p-pagination .next {
  position: relative;
}
.p-pagination .prev::before, .p-pagination .prev::after,
.p-pagination .next::before,
.p-pagination .next::after {
  position: absolute;
  aspect-ratio: 1/1;
  width: 2em;
  border-radius: 100%;
  content: "";
}
.p-pagination .prev::before,
.p-pagination .next::before {
  background: #000;
}
.p-pagination .prev::after,
.p-pagination .next::after {
  background: #FFF;
  clip-path: polygon(40% 35%, 65% 50%, 40% 65%);
}
.p-pagination .prev::before, .p-pagination .prev::after,
.p-pagination .next::before,
.p-pagination .next::after {
  top: 0;
  left: 0;
  transition: 0.5s background-color;
}
@media (any-hover: hover) {
  .p-pagination .prev:hover::before,
  .p-pagination .next:hover::before {
    background: #000000;
  }
}
.p-pagination .prev::after {
  transform: scale(-1, 1);
}
.p-pagination .current {
  border-color: transparent !important;
  color: #FFF;
  background: #000000 !important;
  border-radius: 100%;
}

/* language
-------------------------------------- */
.p-language {
  display: flex;
  align-items: center;
  font-size: max(min(0.9vw, 18px), 14px);
}
.p-language li + li::before {
  margin-inline: 0.4em;
  border-left: 1px solid;
  content: "";
}

@media (any-hover: hover) {
  .p-language__link {
    transition: 0.5s opacity;
  }
  .p-language__link:hover {
    opacity: 0.7;
  }
}
.p-language__link--active {
  color: #b9b9b9;
}

/* menu（drawer/footer）
-------------------------------------- */
.p-menu {
  display: grid;
  gap: 0.8em 0;
}
@media (min-width: 1024px) {
  .p-menu {
    grid-template-columns: 0.65fr 1fr 0.65fr 0.65fr;
  }
}
@media (any-hover: hover) {
  .p-menu a {
    transition: 0.5s opacity;
  }
  .p-menu a:hover {
    opacity: 0.7;
  }
}

.p-menu__list {
  display: grid;
  gap: 1em;
  align-self: start;
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
  font-weight: 500;
}

.p-menu__listChild {
  display: grid;
  gap: 0.5em;
  margin-top: 0.4em;
  font-size: 12px;
  font-size: 0.75rem;
}
@media (min-width: 768px) {
  .p-menu__listChild {
    grid-template-columns: 1fr 1fr;
  }
}
@media (min-width: 1024px) {
  .p-menu__listChild {
    grid-template-columns: 1fr;
  }
}
.p-menu__listChild a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.p-menu__listChild a::before {
  width: 10px;
  height: 0;
  border-top: 1px solid;
  content: "";
}

/* parallaxImg
-------------------------------------- */
.is-parallaxImg {
  position: relative;
  overflow: hidden; /* マスク */
}
.is-parallaxImg .img {
  position: absolute;
  inset: 0;
}
.is-parallaxImg .img img {
  inset: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  will-change: transform;
  transform: translateY(0);
}

/* subcontents
-------------------------------------- */
.p-subcontents {
  position: relative;
  background-color: #f2efdc;
}

/* lead
-------------------------------------- */
.p-lead__inner {
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
}

.p-lead__title {
  line-height: 1.2;
  font-family: "Garamond", "EB Garamond", serif;
  text-align: center;
  color: #92937e;
  font-weight: 400;
  font-size: 60px;
  font-size: 3.75rem;
}
@media (min-width: 768px) {
  .p-lead__title {
    font-size: 80px;
    font-size: 5rem;
  }
}
@media (min-width: 1366px) {
  .p-lead__title {
    font-size: 120px;
    font-size: 7.5rem;
  }
}

.p-lead__sub {
  line-height: 1.2;
  text-align: center;
  color: #92937e;
  font-weight: 500;
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
  font-size: 25px;
  font-size: 1.5625rem;
}
@media (min-width: 1366px) {
  .p-lead__sub {
    font-size: 30px;
    font-size: 1.875rem;
  }
}

.p-lead__text {
  color: #92937e;
}
@media (min-width: 1024px) {
  .p-lead__text {
    line-height: 2;
  }
}

/* localNav
-------------------------------------- */
.p-localNav {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 20px;
}
@media (min-width: 768px) {
  .p-localNav {
    justify-content: center;
    gap: 10px 40px;
  }
}
@media (min-width: 1024px) {
  .p-localNav {
    gap: 10px 75px;
  }
}
.p-localNav li {
  width: 100%;
}
@media (min-width: 768px) {
  .p-localNav li {
    width: calc((100% - 160px) / 5);
  }
}
@media (min-width: 1024px) {
  .p-localNav li {
    width: calc((100% - 300px) / 5);
  }
}

@media (max-width: 1400px) {
  .nav-br-hidden {
    display: none;
  }
}

.p-localNav__link .nav-border {
  display: flex;
  align-items: flex-end;
  gap: 5px;
  padding-bottom: 12px;
  margin-bottom: 10px;
  border-bottom: 1px solid #92937e;
  position: relative;
}
.p-localNav__link .nav-border::before {
  position: absolute;
  left: 0;
  content: "";
  width: 100%;
  height: 2px;
  background: #000000;
  bottom: -1px;
  transform: scale(0, 1);
  transform-origin: right top;
  transition: transform 0.5s;
  z-index: 10;
}
@media (min-width: 768px) {
  .p-localNav__link .nav-border {
    align-items: center;
    flex-direction: column;
    gap: 0;
  }
}
.p-localNav__link .nav-border .nav-text {
  line-height: 1.2;
  transition: 0.6s;
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
  font-size: 16px;
  font-size: 1rem;
}
@media (min-width: 1024px) {
  .p-localNav__link .nav-border .nav-text {
    font-size: 18px;
    font-size: 1.125rem;
  }
}
.p-localNav__link .nav-border .number-box {
  display: flex;
  gap: 5px;
  transition: 0.6s;
}
@media (min-width: 768px) {
  .p-localNav__link .nav-border .number-box {
    flex-direction: column;
    gap: 0px;
  }
}
.p-localNav__link .nav-border .number-box .nav-index {
  text-align: center;
  position: relative;
  color: #92937e;
  font-size: 18px;
  font-family: "Garamond", "EB Garamond", serif;
  line-height: 1;
}
@media (min-width: 768px) {
  .p-localNav__link .nav-border .number-box .nav-index {
    font-size: 20px;
    text-align: center;
  }
}
@media (min-width: 768px) {
  .p-localNav__link .nav-border .number-box .nav-index::after {
    content: "";
    width: 24px;
    height: 1px;
    background-color: #92937e;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
  }
}
.p-localNav__link .nav-border .number-box .nav-number {
  color: #92937e;
  font-size: 18px;
  font-family: "Garamond", "EB Garamond", serif;
  line-height: 1;
}
@media (min-width: 768px) {
  .p-localNav__link .nav-border .number-box .nav-number {
    font-size: 60px;
    text-align: center;
  }
}
.p-localNav__link .nav-text-en {
  color: #92937e;
  font-size: 12px;
  font-family: "Garamond", "EB Garamond", serif;
  letter-spacing: 0.02em;
  display: block;
  transition: 0.6s;
}
@media (min-width: 768px) {
  .p-localNav__link .nav-text-en {
    text-align: center;
  }
}
.p-localNav__link .main {
  flex-shrink: 0;
  margin-right: 0.8em;
  font-family: "Garamond", "EB Garamond", serif;
  font-size: 18px;
  font-size: 1.125rem;
}
@media (min-width: 768px) {
  .p-localNav__link .main {
    font-size: 20px;
    font-size: 1.25rem;
  }
}
.p-localNav__link .sub {
  flex: 1;
  font-size: 11px;
  font-size: 0.6875rem;
}
@media (min-width: 768px) {
  .p-localNav__link .sub {
    font-size: 12px;
    font-size: 0.75rem;
  }
}
@media (any-hover: hover) {
  .p-localNav__link:hover .number-box {
    opacity: 0.3;
  }
  .p-localNav__link:hover .nav-text {
    opacity: 0.3;
  }
  .p-localNav__link:hover .nav-text-en {
    opacity: 0.3;
  }
  .p-localNav__link:hover .nav-border:before {
    transform: scale(1, 1);
    transform-origin: left top;
  }
}

/* slider
-------------------------------------- */
.p-slider {
  position: relative;
}
.p-slider--wide .swiper {
  margin-inline: calc(50% - 50vw);
}
.p-slider .swiper-slide img {
  width: 100%;
}
.p-slider .swiper-button-next,
.p-slider .swiper-button-prev {
  width: 35px;
  height: 35px;
  margin-top: -17px;
}
@media (min-width: 768px) {
  .p-slider .swiper-button-next,
  .p-slider .swiper-button-prev {
    width: 50px;
    height: 50px;
    margin-top: -25px;
  }
}
.p-slider .swiper-button-next::after,
.p-slider .swiper-button-prev::after {
  width: 100%;
  height: 100%;
  content: "";
  background: url(../img/common/slider_arrow.svg) no-repeat center/contain;
}
.p-slider .swiper-button-next {
  right: 5px;
}
@media (min-width: 768px) {
  .p-slider .swiper-button-next {
    right: 20px;
  }
}
.p-slider .swiper-button-prev {
  left: 5px;
}
@media (min-width: 768px) {
  .p-slider .swiper-button-prev {
    left: 20px;
  }
}
.p-slider .swiper-button-prev::after {
  transform: scale(-1, 1);
}
.p-slider .swiper-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  position: absolute;
  bottom: -20px !important;
  right: 10px;
  left: 10px;
}
@media (min-width: 768px) {
  .p-slider .swiper-pagination {
    bottom: -20px !important;
    right: 20px;
    left: 20px;
  }
}
.p-slider .swiper-pagination-bullet {
  margin: 0 !important;
  width: 8px;
  height: 8px;
  background: #bdbdbd;
  opacity: 0.6;
  transition: 0.5s opacity, 0.5s background-color;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.p-slider .swiper-pagination-bullet-active {
  background: #000000;
  opacity: 1;
}

/* 道順用スライダー
-------------------------------------- */
/* カスタムスワイパー専用 */
.p-slider-custom {
  position: relative;
  /* ページャー */
  /* 上の現在/合計 */
}
.p-slider-custom .swiper-slide img {
  width: 100%;
  display: block;
}
.p-slider-custom .swiper-slide .access-text {
  margin-top: 40px;
}
.p-slider-custom .swiper-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
  margin-top: 15px;
  width: auto !important;
  left: 50% !important;
  bottom: 30px !important;
  transform: translateX(-50%);
}
.p-slider-custom .swiper-pagination .swiper-pagination-bullet {
  flex: 1;
  border-radius: 50%;
  opacity: 1;
  position: relative;
  color: transparent; /* 数字は非表示 */
  font-size: 0;
  width: 8px;
  height: 8px;
  background: #bdbdbd;
}
.p-slider-custom .swiper-pagination .swiper-pagination-bullet-active {
  background: none;
  height: 20px;
  width: 20px;
  min-width: 20px;
  border-radius: 50%;
  background-color: #92937e;
  color: #fff;
  font-size: 12px;
  line-height: 20px;
  text-align: center;
  font-weight: bold;
}
.p-slider-custom .slide-counter {
  position: absolute;
  z-index: 10;
  top: 15px;
  right: 15px;
  background: #92937e;
  color: #fff;
  padding: 5px 10px;
  border-radius: 50%;
  font-size: 14px;
  font-weight: bold;
}
.p-slider-custom .slide-counter span.total {
  font-size: 12px;
}

.btn {
  display: inline-flex;
  align-items: center;
  position: relative;
}
.btn::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  height: 1px;
  width: 100%;
  background: #000000;
  transition: background 0.3s ease;
}
.btn .circle-button {
  display: inline-flex;
  align-items: center;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  color: #000;
  text-decoration: none;
  position: relative;
  overflow: hidden;
}
@media (min-width: 1024px) {
  .btn .circle-button {
    font-size: 18px;
  }
}
.btn .circle-button::before, .btn .circle-button::after {
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background-color: #000000;
  position: absolute;
  font-size: 0.5em;
  line-height: 1;
  color: #000;
  transition: opacity 0.1s ease, transform 0.5s ease;
  top: 50%;
  transform: translateY(calc(-50% - 4px)) scale(0); /* 最初は縮小 */
}
.btn .circle-button::after {
  right: 10px;
  transform: translateY(calc(-50% - 4px)) scale(1);
}
.btn .circle-button::before {
  opacity: 0;
  left: 10px;
  color: #92937e;
  background-color: #92937e;
}
.btn .circle-button .text {
  white-space: nowrap;
  position: relative;
  transition: margin 0.5s ease;
  padding-right: 30px;
  padding-left: 30px;
  margin-left: -30px;
  padding-bottom: 10px;
  overflow-x: hidden;
  font-weight: 400;
  font-size: 14px;
  font-size: 0.875rem;
}
@media (min-width: 1024px) {
  .btn .circle-button .text {
    font-size: 16px;
    font-size: 1rem;
  }
}
.btn:hover::after {
  background: #92937e;
}
.btn:hover .circle-button {
  color: #92937e;
}
.btn:hover .circle-button::before {
  opacity: 1;
  transform: translateY(calc(-50% - 4px)) scale(1);
}
.btn:hover .circle-button::after {
  opacity: 0;
  transform: translateY(calc(-50% - 4px)) scale(0);
}
.btn:hover .circle-button .text {
  padding-left: 30px;
  padding-right: 30px;
  margin-left: 0;
  margin-right: -30px;
  transition: margin 0.5s ease;
}

/* ページリンク
-------------------------------------- */
.small-link-sec {
  overflow: visible;
}
.small-link-sec .p-small-link-block {
  position: relative;
  display: flex;
}
.small-link-sec .p-small-link-block img {
  transition: 0.6s;
}
@media (max-width: 1023px) {
  .small-link-sec .p-small-link-block img {
    width: 100%;
  }
}
@media (max-width: 1023px) {
  .small-link-sec .p-small-link-block {
    flex-direction: column;
    gap: 40px;
  }
}
@media (min-width: 1024px) {
  .small-link-sec .p-small-link-block {
    gap: 60px;
    align-items: flex-start;
  }
}
.small-link-sec .p-small-link-block .p-small-link-text .main-title01 {
  transition: 0.6s;
}
@media (max-width: 1023px) {
  .small-link-sec .p-small-link-block .p-small-link-text {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: flex-start;
  }
}
@media (min-width: 1024px) {
  .small-link-sec .p-small-link-block .p-small-link-text {
    position: sticky;
    top: 8vw;
    left: 0;
    width: 300px;
  }
  .small-link-sec .p-small-link-block .p-small-link-text .main-title01 {
    margin-bottom: 20px;
  }
}
.small-link-sec .p-small-link-block .p-small-link-text .caption-text {
  margin-bottom: 20px;
}
@media (min-width: 1024px) {
  .small-link-sec .p-small-link-block .p-small-link-text .caption-text {
    margin-bottom: 30px;
  }
}
.small-link-sec .p-small-link-block .p-small-link-img {
  display: grid;
  gap: 40px 20px;
}
@media (min-width: 521px) {
  .small-link-sec .p-small-link-block .p-small-link-img {
    grid-template-columns: 1fr 1fr;
  }
}
@media (min-width: 1024px) {
  .small-link-sec .p-small-link-block .p-small-link-img {
    gap: 40px;
  }
}
.small-link-sec .p-small-link-block .p-small-link-img .p-small-link-btn-block {
  margin-top: 20px;
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: flex-start;
}
@media (min-width: 1024px) {
  .small-link-sec .p-small-link-block .p-small-link-img .p-small-link-btn-block {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    margin-top: 20px;
  }
}
.small-link-sec .p-small-link-block .p-small-link-img .p-small-link-btn-block .btn {
  margin-top: 0px;
}
@media (min-width: 1024px) {
  .small-link-sec .p-small-link-block .p-small-link-img .p-small-link-btn-block .btn {
    margin-top: 0;
  }
}
.small-link-sec .p-small-link-block .p-small-link-img .p-small-link-btn-block .btn .circle-button {
  white-space: nowrap;
}
@media (min-width: 1024px) {
  .small-link-sec .p-small-link-block .p-small-link-img .link-img-block-btn {
    max-width: 400px;
  }
}
@media (max-width: 767px) {
  .small-link-sec .p-small-link-block .p-small-link-img .link-img-block-btn img {
    width: 100%;
  }
}
.small-link-sec .p-small-link-block .p-small-link-img .link-img-block-btn:hover img {
  opacity: 0.3;
}
.small-link-sec .p-small-link-block .p-small-link-img .link-img-block-btn:hover .main-title03 {
  opacity: 0.3;
}
.small-link-sec .p-small-link-block .p-small-link-img .link-img-block-btn:hover .btn::after {
  background: #92937e;
}
.small-link-sec .p-small-link-block .p-small-link-img .link-img-block-btn:hover .btn .circle-button {
  color: #92937e;
}
.small-link-sec .p-small-link-block .p-small-link-img .link-img-block-btn:hover .btn .circle-button::before {
  opacity: 1;
  transform: translateY(calc(-50% - 4px)) scale(1);
}
.small-link-sec .p-small-link-block .p-small-link-img .link-img-block-btn:hover .btn .circle-button::after {
  opacity: 0;
  transform: translateY(calc(-50% - 4px)) scale(0);
}
.small-link-sec .p-small-link-block .p-small-link-img .link-img-block-btn:hover .btn .circle-button .text {
  padding-left: 30px;
  padding-right: 30px;
  margin-left: 0;
  margin-right: -30px;
  transition: margin 0.5s ease;
}

/* ページリンク
-------------------------------------- */
.content-link-sec {
  overflow: visible;
}
.content-link-sec .p-content-link + .p-content-link .p-content-link-block {
  padding-top: 45px;
}
@media (min-width: 1024px) {
  .content-link-sec .p-content-link + .p-content-link .p-content-link-block {
    padding-top: 60px;
  }
}
.content-link-sec .p-content-link {
  padding-bottom: 45px;
}
@media (min-width: 1024px) {
  .content-link-sec .p-content-link {
    padding-bottom: 60px;
  }
}
.content-link-sec .p-content-link .p-content-link-block {
  position: relative;
  display: flex;
}
@media (max-width: 1023px) {
  .content-link-sec .p-content-link .p-content-link-block {
    flex-direction: column;
    gap: 40px;
  }
}
@media (min-width: 1024px) {
  .content-link-sec .p-content-link .p-content-link-block {
    gap: 60px;
    align-items: flex-start;
  }
}
@media (min-width: 1024px) {
  .content-link-sec .p-content-link .p-content-link-block .p-content-link-text {
    position: sticky;
    top: 8vw;
    left: 0;
    width: 400px;
  }
}
.content-link-sec .p-content-link .p-content-link-block .p-content-link-text .caption-text {
  margin-bottom: 20px;
}
@media (min-width: 1024px) {
  .content-link-sec .p-content-link .p-content-link-block .p-content-link-text .caption-text {
    margin-bottom: 30px;
  }
}
.content-link-sec .p-content-link .p-content-link-block .p-content-link-img .link-img-block + .link-img-block {
  margin-top: 45px;
}
@media (min-width: 1024px) {
  .content-link-sec .p-content-link .p-content-link-block .p-content-link-img .link-img-block + .link-img-block {
    margin-top: 60px;
  }
}
@media (min-width: 1024px) {
  .content-link-sec .p-content-link .p-content-link-block .p-content-link-img .link-img-block {
    max-width: 740px;
  }
}
.content-link-sec .p-content-link .p-content-link-block .p-content-link-img .link-img-block img {
  width: 100%;
}
.content-link-sec .p-content-link .p-content-link-block .p-content-link-img .p-content-link-btn-block {
  margin-top: 20px;
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: flex-start;
}
@media (min-width: 1024px) {
  .content-link-sec .p-content-link .p-content-link-block .p-content-link-img .p-content-link-btn-block {
    margin-top: 30px;
  }
}
.content-link-sec .p-content-link .p-content-link-block .p-content-link-img .p-content-link-btn-block .btn {
  margin-top: 0px;
}
@media (min-width: 1024px) {
  .content-link-sec .p-content-link .p-content-link-block .p-content-link-img .p-content-link-btn-block .btn {
    margin-top: 0;
  }
}

/* usp-content
-------------------------------------- */
.usp-content .usp-main {
  position: relative;
  height: 100vh;
  height: 100svh;
  max-height: 100%;
  min-height: auto;
  aspect-ratio: auto;
}
.usp-content .usp-main .p-usp__inner {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-direction: column;
  position: relative;
  z-index: 2;
  height: 100%;
  max-width: 1700px;
  width: 92%;
  margin-left: auto;
  margin-right: auto;
  padding-top: 100px;
  padding-bottom: 100px;
}
.usp-content .usp-main .p-usp__inner .usp-title-box .usp-number {
  display: inline-block;
  border-bottom: 1px solid #fff;
  text-shadow: 0 0 8px rgba(0, 0, 0, 0.35);
}
.usp-content .usp-main .p-usp__inner .usp-title-box .usp-number .usp-index {
  line-height: 1;
}
.usp-content .usp-main .p-usp__inner .usp-title-box .usp-number .usp-num {
  line-height: 1;
}
.usp-content .usp-main .p-usp__inner .usp-title-box .p-usp__title {
  text-shadow: 0 0 8px rgba(0, 0, 0, 0.35);
}
.usp-content .usp-main .p-usp__inner .usp-title-box .usp-title-cap {
  font-family: "Garamond", "EB Garamond", serif;
  color: #fff;
  letter-spacing: 0.02em;
  text-shadow: 0 0 8px rgba(0, 0, 0, 0.35);
}
.usp-content .usp-main .p-usp__inner .usp-text-bpx {
  margin-left: auto;
  margin-top: auto;
  color: #fff;
  font-weight: 200;
  text-align: right;
  text-shadow: 0 0 8px rgba(0, 0, 0, 0.45);
}

.is-parallaxImg02 {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  overflow: hidden; /* マスク */
}
.is-parallaxImg02 img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.is-parallaxImg02 .p-usp__bg {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  inset: 0;
}
.is-parallaxImg02 .p-usp__bg img {
  inset: 0;
  width: 100%;
  height: 135%; /* 動かしても隙間が出ないよう少し大きく */
  -o-object-fit: cover;
     object-fit: cover;
  will-change: transform;
  transform: translateY(0);
}

/* concept-content
-------------------------------------- */
.concept-content .concept-content-box01 {
  max-width: 1700px;
  width: 92%;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  gap: 110px;
  gap: min(10.7142857143vw, 150px);
  align-items: center;
  margin-top: 70px;
}
@media (min-width: 1024px) {
  .concept-content .concept-content-box01 .concept-img01 {
    width: 50%;
  }
}
.concept-content .concept-content-box01 p {
  flex: 1;
}
@media (max-width: 1023px) {
  .concept-content .concept-content-box01 {
    align-items: flex-start;
    flex-direction: column;
    margin-top: 60px;
  }
  .concept-content .concept-content-box01 .concept-img01 img {
    width: 49.853372434vw;
    height: 57.6735092864vw;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
.concept-content .concept-content-box01 p {
  font-weight: 300;
  flex: 1;
}
.concept-content .concept-content-box02 {
  max-width: 1600px;
  width: 92%;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-direction: row-reverse;
  gap: 260px;
  align-items: center;
  margin-top: 70px;
}
@media (min-width: 1024px) {
  .concept-content .concept-content-box02 .concept-img02 {
    width: 34.8837209302%;
    margin-left: auto;
  }
}
.concept-content .concept-content-box02 p {
  margin-left: auto;
}
@media (min-width: 1024px) {
  .concept-content .concept-content-box02 p {
    width: 50%;
  }
}
@media (max-width: 1023px) {
  .concept-content .concept-content-box02 {
    flex-direction: column;
    align-items: flex-end;
    gap: 60px;
    margin-top: 60px;
  }
  .concept-content .concept-content-box02 .concept-img02 img {
    width: 43.9882697947vw;
    height: 51.8084066471vw;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .concept-content .concept-content-box02 p {
    text-align: right;
  }
}
.concept-content .concept-content-box02 p {
  font-weight: 200;
}
.concept-content .concept-content-box03 {
  max-width: 1080px;
  width: 80%;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  margin-top: 70px;
}
@media (max-width: 1023px) {
  .concept-content .concept-content-box03 {
    flex-direction: column;
    align-items: flex-start;
    gap: 60px;
    margin-top: 60px;
  }
  .concept-content .concept-content-box03 .concept-img03 img {
    width: 38.1231671554vw;
    height: 45.9433040078vw;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .concept-content .concept-content-box03 p {
    text-align: right;
  }
}

/* 汎用box
-------------------------------------- */
.p-box--floormap {
  display: flex;
}
@media (max-width: 1023px) {
  .p-box--floormap {
    flex-direction: column;
    gap: 30px;
  }
}
@media (min-width: 1024px) {
  .p-box--floormap {
    gap: 70px;
  }
}
@media (min-width: 1024px) {
  .p-box--floormap .p-box__main {
    flex: 1;
  }
}
.p-box--floormap .p-box__img {
  text-align: center;
}
@media (min-width: 1024px) {
  .p-box--floormap .p-box__img {
    width: 34.1666666667%;
    padding-inline: 30px;
  }
}
.p-box--floormap .p-box__img img {
  width: auto;
}
.p-box--text .main-title02 {
  margin-bottom: 20px;
}
.p-box--text .p-box__main + .p-box__main {
  margin-top: 40px;
}
@media (max-width: 1023px) {
  .p-box--text .p-box__main + .p-box__main {
    margin-top: 20px;
  }
}
.p-box--text .p-box__main.list-two {
  display: flex;
}
@media (max-width: 1023px) {
  .p-box--text .p-box__main.list-two {
    flex-direction: column;
  }
}
@media (min-width: 1024px) {
  .p-box--text .p-box__main.list-two {
    align-items: flex-start;
  }
}
.p-box--text .p-box__main.text-spec {
  display: flex;
  flex-direction: column;
}
@media (min-width: 1024px) {
  .p-box--text .p-box__main.text-spec {
    flex-direction: initial;
  }
}
.p-box--text .p-box__main.text-spec .p-box__text {
  width: 100%;
}
.p-box--text .p-box__main.text-spec .p-box__list {
  width: 100%;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid #000;
}
@media (min-width: 1024px) {
  .p-box--text .p-box__main.text-spec .p-box__list {
    width: 400px;
    margin-top: 0px;
    padding-top: 0px;
    border-top: none;
  }
}
.p-box--text .p-box__main.text-spec .p-box__list > div {
  display: flex;
  flex-direction: initial;
}
.p-box--text .p-box__main.text-spec .p-box__list > div dt {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}
.p-box--text .p-box__main.text-spec .p-box__list > div + div {
  margin-top: 10px;
}
.p-box--text .list-two .p-box__list {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}
@media (min-width: 1024px) {
  .p-box--text .list-two .p-box__list {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 35px;
  }
}
.p-box--text .list-two .p-box__list > div {
  flex-direction: column;
}
.p-box--text .list-two .p-box__list > div + div {
  margin-top: 20px;
}
@media (min-width: 1024px) {
  .p-box--text .list-two .p-box__list > div + div {
    margin-top: 0;
  }
}
.p-box--text .list-two .p-box__list > div dt {
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid #000;
}
@media (min-width: 1024px) {
  .p-box--text .list-two .p-box__list > div dt {
    margin-bottom: 20px;
    padding-bottom: 20px;
  }
}
.p-box--text .p-box__list {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}
.p-box--text .p-box__list > div {
  flex-direction: column;
}
.p-box--text .p-box__list > div + div {
  margin-top: 20px;
}
.p-box--text .p-box__list > div dt {
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid #000;
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
}
@media (min-width: 1024px) {
  .p-box--text .p-box__list > div dt {
    margin-bottom: 20px;
    padding-bottom: 20px;
  }
}
.p-box--split {
  display: flex;
}
@media (max-width: 1023px) {
  .p-box--split {
    flex-direction: column;
    gap: 20px;
  }
}
@media (min-width: 1024px) {
  .p-box--split {
    align-items: center;
    gap: 60px;
  }
  .p-box--splitReverse {
    flex-direction: row-reverse;
  }
}
@media (min-width: 1024px) {
  .p-box--split .p-box__img {
    width: 50%;
  }
}
@media (min-width: 1024px) {
  .p-box--split .p-box__main {
    flex: 1;
  }
}
.p-box--split .p-box__main .main-title02 {
  margin-bottom: 30px;
}
@media (max-width: 1023px) {
  .p-box--split .p-box__main .main-title02 {
    margin-bottom: 20px;
  }
}

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

.p-box__list {
  line-height: 1.5;
}
@media (max-width: 1023px) {
  .p-box__list {
    margin-top: 1em;
    padding-top: 1em;
    border-top: 1px solid;
  }
}
.p-box__list > div {
  display: flex;
}
.p-box__list > div + div {
  margin-top: 0.6em;
}
.p-box__list dd {
  flex: 1;
}
.p-box__list dd.list-content .list-two-grid {
  display: grid;
  gap: 5px 20px;
}
@media (min-width: 768px) {
  .p-box__list dd.list-content .list-two-grid {
    grid-template-columns: 1fr 1fr;
  }
}
.p-box__list dd.list-content .list-two-grid li {
  position: relative;
  padding-left: 0.8em; /* 黒丸の分だけ余白を作る */
  list-style: none;
}
.p-box__list dd.list-content .list-two-grid li::before {
  content: "●";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 0.3em;
  color: #000000; /* 黒色 */
}
.p-box__list--bordertop {
  margin-top: 1.3em;
  padding-top: 1.5em;
  border-top: 1px solid;
}
.p-box__list--bordertop dt {
  width: 6.25em;
}
@media (min-width: 1024px) {
  .p-box__list--borderleft {
    margin-left: 1.5em;
    padding-left: 1.5em;
    border-left: 1px solid;
  }
}
.p-box__list--borderleft dt {
  width: 4.7em;
}

.p-box__notice {
  font-size: 12px;
  font-size: 0.75rem;
}
* + .p-box__notice {
  margin-top: 20px;
}

/* 汎用boxを入れるグリッド
-------------------------------------- */
.p-boxGrid {
  display: grid;
  gap: 40px;
}
@media (min-width: 1024px) {
  .p-boxGrid--col2 {
    grid-template-columns: 1fr 1fr;
    gap: 60px;
  }
}
.p-boxGrid--col2 .p-box__img {
  margin-bottom: 20px;
}
.p-boxGrid--col2 .main-title02 {
  margin-bottom: 20px;
}
@media (min-width: 1024px) {
  .p-boxGrid--col3 {
    grid-template-columns: 1fr 1fr 1fr;
    gap: 45px;
  }
}
.p-boxGrid--col3 .p-box__img {
  margin-bottom: 20px;
}
.p-boxGrid--col3 .main-title02 {
  margin-bottom: 20px;
}

/* bg-color-section
-------------------------------------- */
.bg-color-section {
  background-color: #dfddc9;
  padding: 60px;
}
@media (max-width: 1023px) {
  .bg-color-section {
    padding: 45px;
  }
}
.bg-color-section .p-consent__inner {
  display: flex;
  gap: 30px;
}
@media (max-width: 1023px) {
  .bg-color-section .p-consent__inner {
    flex-direction: column-reverse;
  }
}
@media (min-width: 1024px) {
  .bg-color-section .p-consent__inner {
    gap: 30px 60px;
    flex-wrap: wrap;
    align-items: center;
  }
}
@media (min-width: 1024px) {
  .bg-color-section .p-consent__main {
    flex: 1;
  }
}
.bg-color-section .p-consent__main .main-title02 {
  margin-bottom: 30px;
}
@media (min-width: 1024px) {
  .bg-color-section .p-consent__img {
    width: 30.3%;
  }
}
.bg-color-section .p-consent__img img {
  width: 100%;
}

/* sectionHead
-------------------------------------- */
.p-sectionHead {
  display: flex;
}
@media (max-width: 1023px) {
  .p-sectionHead {
    flex-direction: column;
    gap: 16px;
  }
}
@media (min-width: 1024px) {
  .p-sectionHead {
    gap: 50px;
  }
}

@media (max-width: 1023px) {
  .p-sectionHead__title {
    text-align: center;
  }
}
@media (min-width: 1024px) {
  .p-sectionHead__title {
    flex-shrink: 0;
  }
}

.p-sectionHead__text {
  line-height: 1.8;
}
@media (min-width: 1024px) {
  .p-sectionHead__text {
    flex: 1;
    margin-top: 1em;
    line-height: 2.25;
  }
}

/* roomList
-------------------------------------- */
.p-roomList {
  position: relative;
}

.p-roomList__slider {
  margin-right: calc(50% - 50vw) !important;
}

.p-roomList__slide {
  width: 180px !important;
}
@media (min-width: 768px) {
  .p-roomList__slide {
    width: 280px !important;
  }
}
.p-roomList__slide .link {
  display: block;
}
@media (any-hover: hover) {
  .p-roomList__slide .link:hover .img {
    box-shadow: none;
  }
  .p-roomList__slide .link:hover .img::before {
    opacity: 1;
  }
}
.p-roomList__slide .img {
  position: relative;
  aspect-ratio: 280/400;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.25);
  transition: 0.5s box-shadow;
}
.p-roomList__slide .img::before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.2);
  content: "";
  opacity: 0;
  transition: 0.5s opacity;
}
.p-roomList__slide .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-roomList__slide .title {
  margin-top: 10px;
  font-weight: normal;
}
.p-roomList__slide .title .sub {
  display: block;
  font-family: "Garamond", "EB Garamond", serif;
  font-size: 22px;
  font-size: 1.375rem;
}
@media (min-width: 768px) {
  .p-roomList__slide .title .sub {
    font-size: 30px;
    font-size: 1.875rem;
  }
}
.p-roomList__slide .title .main {
  display: block;
  font-size: 13px;
  font-size: 0.8125rem;
}
@media (min-width: 768px) {
  .p-roomList__slide .title .main {
    font-size: 16px;
    font-size: 1rem;
  }
}

.p-roomList__controlls {
  display: flex;
  gap: 28px;
  align-items: center;
  position: relative;
  margin-top: 35px;
}
@media (min-width: 1024px) {
  .p-roomList__controlls {
    margin-top: 56px;
  }
}
.p-roomList__controlls .swiper-pagination {
  position: relative;
  flex: 1;
  width: auto !important;
  height: 2px !important;
  background: #c9c9c9;
}
.p-roomList__controlls .swiper-pagination-progressbar-fill {
  background: #000000 !important;
}
.p-roomList__controlls .swiper-button-next,
.p-roomList__controlls .swiper-button-prev {
  position: relative;
  width: 14px;
  height: 24px;
  margin-top: 0;
  right: auto;
  left: auto;
}
.p-roomList__controlls .swiper-button-next::after,
.p-roomList__controlls .swiper-button-prev::after {
  width: 100%;
  height: 100%;
  content: "";
  background: url(../img/common/roomlist_arrow.svg) no-repeat center/contain;
}
@media (any-hover: hover) {
  .p-roomList__controlls .swiper-button-next,
  .p-roomList__controlls .swiper-button-prev {
    transition: 0.5s opacity;
  }
  .p-roomList__controlls .swiper-button-next:hover,
  .p-roomList__controlls .swiper-button-prev:hover {
    opacity: 0.7;
  }
}
.p-roomList__controlls .swiper-button-prev::after {
  transform: scale(-1, 1);
}

/* infoBox(今回フォーマットなし)
-------------------------------------- */
.p-infoBox {
  display: flex;
}
@media (max-width: 1023px) {
  .p-infoBox {
    flex-direction: column;
    gap: 1em;
  }
}
@media (min-width: 1024px) {
  .p-infoBox {
    gap: 40px;
  }
}

.p-infoBox__title {
  font-weight: normal;
}
@media (max-width: 1023px) {
  .p-infoBox__title {
    text-align: center;
    padding-bottom: 0.6em;
    border-bottom: 1px solid;
    font-size: 18px;
    font-size: 1.125rem;
  }
}
@media (min-width: 1024px) {
  .p-infoBox__title {
    display: flex;
    align-items: center;
    width: 145px;
    padding-right: 1em;
    border-right: 1px solid;
    font-size: 16px;
    font-size: 1rem;
  }
}

@media (min-width: 1024px) {
  .p-infoBox__main {
    flex: 1;
  }
}
.p-infoBox__main--col3 {
  display: grid;
  gap: 10px;
}
@media (min-width: 768px) {
  .p-infoBox__main--col3 {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px 20px;
  }
}
@media (min-width: 1024px) {
  .p-infoBox__main--col3 {
    grid-template-columns: repeat(3, 1fr);
    gap: 10px 30px;
  }
}
.p-infoBox__main--col5 {
  display: grid;
  gap: 10px;
}
@media (min-width: 768px) {
  .p-infoBox__main--col5 {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px 20px;
  }
}
@media (min-width: 1024px) {
  .p-infoBox__main--col5 {
    grid-template-columns: repeat(5, 1fr);
    gap: 10px 30px;
  }
}

.p-infoBox__notice {
  font-size: 12px;
  font-size: 0.75rem;
  margin-top: 1em;
}

.p-infoBox__dl dt {
  margin-bottom: 0.5em;
  padding-bottom: 0.5em;
  border-bottom: 1px solid;
}
@media (min-width: 1024px) {
  .p-infoBox__dl dt {
    margin-bottom: 1em;
  }
}
.p-infoBox__dl dd {
  margin-top: 10px;
}
@media (max-width: 767px) {
  .p-infoBox__dl + .p-infoBox__dl {
    margin-top: 1em;
  }
}

/*　FAQ
-------------------------------------- */
/* relations
-------------------------------------- */
.p-homeRelations {
  padding-block: 50px;
  background: #dfddc9;
}
@media (min-width: 1024px) {
  .p-homeRelations {
    padding-block: 60px 70px;
  }
}

.p-homeRelations__list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px 20px;
}
@media (min-width: 768px) {
  .p-homeRelations__list {
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
  }
}
@media (min-width: 1366px) {
  .p-homeRelations__list {
    grid-template-columns: repeat(5, 1fr);
    gap: min(5vw, 70px);
  }
}
.p-homeRelations__list > div a dt {
  position: relative;
}
.p-homeRelations__list > div a dt span {
  transition: 0.6s;
}
.p-homeRelations__list > div a dt::before {
  position: absolute;
  left: 0;
  content: "";
  width: 100%;
  height: 2px;
  background: #000000;
  bottom: -1px;
  transform: scale(0, 1);
  transform-origin: right top;
  transition: transform 0.5s;
  z-index: 10;
}
.p-homeRelations__list > div a dd {
  transition: 0.6s;
}
@media (any-hover: hover) {
  .p-homeRelations__list > div a:hover dt::before {
    opacity: 1;
    transform: scale(1, 1);
    transform-origin: left top;
  }
  .p-homeRelations__list > div a:hover dt span {
    opacity: 0.3;
  }
  .p-homeRelations__list > div a:hover dd {
    opacity: 0.3;
  }
}
.p-homeRelations__list dt {
  margin-bottom: 0.5em;
  padding-bottom: 0.5em;
  border-bottom: 1px solid #adad99;
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
  text-align: center;
  font-weight: 500;
  font-size: 16px;
  font-size: 1rem;
}
@media (min-width: 1024px) {
  .p-homeRelations__list dt {
    font-size: 18px;
    font-size: 1.125rem;
  }
}
.p-homeRelations__list dd {
  font-size: 13px;
  font-size: 0.8125rem;
}
@media (min-width: 1024px) {
  .p-homeRelations__list dd {
    font-size: 14px;
    font-size: 0.875rem;
  }
}

.p-homeRelations__btn {
  margin-top: 30px;
  text-align: right;
}
@media (min-width: 1024px) {
  .p-homeRelations__btn {
    margin-top: 40px;
  }
}

/* ナビアコーディオン
-------------------------------------- */
.accodion-nav .accodion-nav-toggle {
  cursor: pointer;
  position: relative;
}
.accodion-nav .accodion-nav-toggle::before, .accodion-nav .accodion-nav-toggle::after {
  width: 10px;
  height: 1px;
  background: #000000;
  content: "";
  right: 0;
  position: absolute;
  top: 10px;
}
.accodion-nav .accodion-nav-toggle::after {
  transform: rotate(90deg);
  transition: 0.5s transform;
}
.accodion-nav .accodion-nav-toggle.active::after {
  transform: rotate(360deg);
}
.accodion-nav .accodion-nav-toggle.white-toggle::before, .accodion-nav .accodion-nav-toggle.white-toggle::after {
  background: #fff;
}
@media (max-width: 767px) {
  .accodion-nav .p-menu__listChild {
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: max-height 0.4s ease, opacity 0.4s ease;
  }
  .accodion-nav .p-menu__listChild.open {
    max-height: 500px;
    opacity: 1;
  }
}
@media (min-width: 768px) {
  .accodion-nav .p-menu__listChild {
    max-height: none;
    opacity: 1;
    overflow: visible;
    transition: none;
  }
}

/* margin
-------------------------------------- */
/* テキストサイズ
-------------------------------------- */
.main-title01 {
  font-family: "Garamond", "EB Garamond", serif;
  font-weight: 400;
  color: #92937e;
  font-size: 30px;
  font-size: 1.875rem;
}
@media (min-width: 1024px) {
  .main-title01 {
    font-size: 40px;
    font-size: 2.5rem;
  }
}

.main-title02 {
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
  font-weight: 500;
  font-size: 22px;
  font-size: 1.375rem;
}
@media (min-width: 1024px) {
  .main-title02 {
    font-size: 30px;
    font-size: 1.875rem;
  }
}

.main-title03 {
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
  font-weight: 500;
  font-size: 18px;
  font-size: 1.125rem;
}
@media (min-width: 1024px) {
  .main-title03 {
    font-size: 20px;
    font-size: 1.25rem;
  }
}

.caption-text {
  font-family: "Garamond", "EB Garamond", serif;
  font-weight: 400;
  color: #92937e;
  font-size: 16px;
  font-size: 1rem;
}
@media (min-width: 1024px) {
  .caption-text {
    font-size: 18px;
    font-size: 1.125rem;
  }
}

.usp-index {
  font-family: "Garamond", "EB Garamond", serif;
  font-weight: 400;
  color: #fff;
  font-size: 18px;
  font-size: 1.125rem;
}
@media (min-width: 1024px) {
  .usp-index {
    font-size: 20px;
    font-size: 1.25rem;
  }
}

.usp-num {
  font-family: "Garamond", "EB Garamond", serif;
  font-weight: 400;
  color: #fff;
  font-size: 30px;
  font-size: 1.875rem;
}
@media (min-width: 1024px) {
  .usp-num {
    font-size: 35px;
    font-size: 2.1875rem;
  }
}

.p-usp__title {
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
  font-weight: 200;
  color: #fff;
  font-size: 30px;
  font-size: 1.875rem;
}
@media (min-width: 1024px) {
  .p-usp__title {
    font-size: 50px;
    font-size: 3.125rem;
  }
}

.fs18 {
  font-size: 16px;
  font-size: 1rem;
}
@media (min-width: 1024px) {
  .fs18 {
    font-size: 18px;
    font-size: 1.125rem;
  }
}

.fs16 {
  font-size: 14px;
  font-size: 0.875rem;
}
@media (min-width: 1024px) {
  .fs16 {
    font-size: 16px;
    font-size: 1rem;
  }
}

.fs20 {
  font-size: 18px;
  font-size: 1.125rem;
}
@media (min-width: 1024px) {
  .fs20 {
    font-size: 20px;
    font-size: 1.25rem;
  }
}

.f-serif {
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
}

.f-en {
  font-family: "Garamond", "EB Garamond", serif;
}

.f-wt500 {
  font-weight: 500;
}

.f-wt400 {
  font-weight: 400;
}

.f-wt300 {
  font-weight: 300;
}

/* 背景色
-------------------------------------- */
.bg-color01 {
  background-color: rgba(146, 147, 126, 0.2);
}

/* 線
-------------------------------------- */
.border-top01 {
  border-top: 1px solid #92937e;
}

/* =========================================================
 home
========================================================= */
.is-kvLead,
.is-textGradient {
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  line-height: 1;
  height: auto;
  /* 斜め量 */
  --diag: 1em;
  /* 初期：白が全面（左端=0%）→ 右へ押し出して消す */
  --cutTop: -2em;
  --cutBottom: -1em;
  /* 時間・イージング調整 */
  --cut-duration: 2s;
  --cut-ease: cubic-bezier(.2, .8, .2, 1);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.is-kvLead .before,
.is-kvLead .after,
.is-textGradient .before,
.is-textGradient .after {
  inset: 0;
  display: inline-block;
  font: inherit;
  pointer-events: none;
}
.is-kvLead .after,
.is-textGradient .after {
  color: #92937e;
  /* 下地（ゴール） */
  z-index: 1;
}
.is-kvLead .before,
.is-textGradient .before {
  position: absolute;
  color: #ffffff;
  /* 開始色（白） */
  z-index: 2;
  /*
      左端のみ可変：
      (cutTop,0) → (100,0) → (100,100) → (cutBottom,100)
      ＝左辺が var(--cutTop)/var(--cutBottom) で右へスライド（斜めの刃）
  */
  clip-path: polygon(var(--cutTop) 0%, 100% 0%, 100% 100%, var(--cutBottom) 100%);
  transition: clip-path var(--cut-duration) var(--cut-ease);
  will-change: clip-path;
}

.is-textGradient--done {
  --cutTop: 100%;
  --cutBottom: calc(100% + var(--diag));
  /* 斜めを保ったまま境界が画外へ抜ける */
}

/* title
-------------------------------------- */
.p-homeTitleGradient {
  font-family: "Garamond", "EB Garamond", serif;
  line-height: 1;
  text-align: center;
  font-weight: 400;
  font-size: 40px;
  font-size: 2.5rem;
}
@media (min-width: 1024px) {
  .p-homeTitleGradient {
    font-size: max(min(6vw, 120px), 80px);
  }
}

.p-homeTitle {
  margin-bottom: 1em;
  text-align: center;
  font-family: "Garamond", "EB Garamond", serif;
  font-weight: 400;
  font-size: 30px;
  font-size: 1.875rem;
}
@media (min-width: 1024px) {
  .p-homeTitle {
    font-size: 40px;
    font-size: 2.5rem;
  }
}

/* kv
-------------------------------------- */
.p-homeKv {
  position: relative;
  clip-path: inset(0);
}

/* movie
-------------------------------------- */
.p-homeKv__movie {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  height: 100vh;
  z-index: 1;
}
.p-homeKv__movie video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.home-kv-slider .p-slider {
  height: 100vh;
}
.home-kv-slider .p-slider .swiper {
  height: 100vh;
}
.home-kv-slider .p-slider .swiper .swiper-wrapper {
  height: 100vh;
}
.home-kv-slider .p-slider .swiper .swiper-wrapper .swiper-slide {
  height: 100vh;
}
.home-kv-slider .p-slider .swiper img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

/* logoarea
-------------------------------------- */
.p-homeLogoarea {
  position: relative;
  z-index: 3;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100vh;
}

.p-homeLogoarea__logo {
  width: 100px;
  margin-bottom: 250px;
}
@media (min-width: 768px) {
  .p-homeLogoarea__logo {
    width: max(min(6.45vw, 129px), 100px);
    margin-bottom: max(min(20vw, 400px), 280px);
  }
}

.p-homeKv__lead {
  position: sticky;
  z-index: 3;
  bottom: calc(50% - 0.5em);
  right: 0;
  left: 0;
}
@media (max-width: 520px) {
  .p-homeKv__lead {
    bottom: calc(50% - 1em);
  }
}
.p-homeKv__lead.is-stopped {
  position: absolute;
  top: var(--stop-top);
  right: 0;
  left: 0;
  margin-top: 0;
  transform: none;
}

/* textarea
-------------------------------------- */
.p-homeTextarea {
  position: relative;
  z-index: 2;
  background: #f2efdc;
  padding-top: 30px;
}
@media (min-width: 1024px) {
  .p-homeTextarea {
    padding-top: 50px;
  }
}

.p-homeTextarea__gradient {
  position: absolute;
  z-index: 2;
  right: 0;
  left: 0;
  bottom: calc(100% - 1px);
  overflow: hidden;
  height: 100vh;
  pointer-events: none;
}
.p-homeTextarea__gradient .inner {
  width: 100%;
  height: 200%;
  background: linear-gradient(to bottom, rgba(242, 239, 220, 0) 0%, rgba(242, 239, 220, 0) 20%, rgba(242, 239, 220, 0.1) 30%, rgba(242, 239, 220, 0.8) 42%, #f2efdc 52%);
}

.p-homeTextarea__text {
  position: relative;
  z-index: 2;
  max-width: 520px;
  margin-inline: auto;
  color: #92937e;
  line-height: 2;
  font-size: 16px;
  font-size: 1rem;
}
@media (min-width: 1024px) {
  .p-homeTextarea__text {
    font-size: 18px;
    font-size: 1.125rem;
  }
}
.p-homeTextarea__text p + p {
  margin-top: 1.5em;
}

.p-homeTextarea__img {
  position: relative;
  z-index: 2;
}

.p-homeTextarea__img::before {
  position: absolute;
  background: linear-gradient(to bottom, rgba(242, 239, 220, 0) 0%, rgba(242, 239, 220, 0) 20%, rgba(242, 239, 220, 0.1) 30%, rgba(242, 239, 220, 0.8) 42%, #f2efdc 52%);
  width: 100%;
  height: 50px;
}
.p-homeTextarea__img .second-bottom {
  position: absolute;
  z-index: 2;
  right: 0;
  left: 0;
  bottom: 0;
  overflow: hidden;
  height: 13vh;
  pointer-events: none;
}
.p-homeTextarea__img .second-bottom .inner {
  width: 100%;
  height: 200%;
  background: linear-gradient(to bottom, rgba(242, 239, 220, 0) 0%, rgba(242, 239, 220, 0) 20%, rgba(242, 239, 220, 0.1) 30%, rgba(242, 239, 220, 0.8) 42%, #f2efdc 52%);
}
.p-homeTextarea__img .second-top {
  position: absolute;
  z-index: 2;
  right: 0;
  left: 0;
  top: 0;
  overflow: hidden;
  height: 10vh;
  pointer-events: none;
}
@media (min-width: 1024px) {
  .p-homeTextarea__img .second-top {
    height: 30vh;
  }
}
.p-homeTextarea__img .second-top .inner {
  width: 100%;
  height: 200%;
  background: linear-gradient(to bottom, #f2efdc 0%, rgba(242, 239, 220, 0.8) 15%, rgba(242, 239, 220, 0.1) 40%, rgba(242, 239, 220, 0) 100%);
}

/* essence
-------------------------------------- */
.p-homeEssence {
  margin-top: -2px;
  position: relative;
  z-index: 3;
  padding-block: 50px 80px;
  background: #f2efdc;
}
@media (min-width: 1024px) {
  .p-homeEssence {
    padding-block: 100px 160px;
  }
}

.p-homeEssence__title {
  margin-bottom: 30px;
}
@media (min-width: 1024px) {
  .p-homeEssence__title {
    margin-bottom: 60px;
  }
}

.p-homeEssence__text {
  max-width: 520px;
  margin-inline: auto;
  line-height: 2;
  font-size: 16px;
  font-size: 1rem;
}
@media (min-width: 1024px) {
  .p-homeEssence__text {
    font-size: 18px;
    font-size: 1.125rem;
  }
}
.p-homeEssence__text p + p {
  margin-top: 1.5em;
}

.p-homeEssence__nav {
  margin-top: 40px;
}
@media (min-width: 1024px) {
  .p-homeEssence__nav {
    margin-top: 60px;
  }
}

/* essenceTitle
-------------------------------------- */
.p-homeEssenceTitle .number {
  width: -moz-fit-content;
  width: fit-content;
  margin-bottom: 0.2em;
  border-bottom: 1px solid;
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
  font-weight: 500;
  line-height: 1.2;
  text-shadow: 0 0 8px rgba(0, 0, 0, 0.35);
  font-size: 26px;
  font-size: 1.625rem;
}
@media (min-width: 768px) {
  .p-homeEssenceTitle .number {
    font-size: 35px;
    font-size: 2.1875rem;
  }
}
.p-homeEssenceTitle .number span {
  font-family: "Garamond", "EB Garamond", serif;
  font-size: 18px;
  font-size: 1.125rem;
}
@media (min-width: 768px) {
  .p-homeEssenceTitle .number span {
    font-size: 20px;
    font-size: 1.25rem;
  }
}
.p-homeEssenceTitle .title {
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
  font-weight: 500;
  line-height: 1.4;
  text-shadow: 0 0 8px rgba(0, 0, 0, 0.35);
  font-size: 30px;
  font-size: 1.875rem;
}
@media (min-width: 768px) {
  .p-homeEssenceTitle .title {
    font-size: 50px;
    font-size: 3.125rem;
  }
}
.p-homeEssenceTitle .en {
  margin-top: 1em;
  font-family: "Garamond", "EB Garamond", serif;
  font-weight: 500;
  text-shadow: 0 0 8px rgba(0, 0, 0, 0.35);
  font-size: 16px;
  font-size: 1rem;
}
@media (min-width: 768px) {
  .p-homeEssenceTitle .en {
    font-size: 18px;
    font-size: 1.125rem;
  }
}

/* kyoto
-------------------------------------- */
.p-homeKyoto {
  position: relative;
}

.p-homeKyoto__inner {
  display: flex;
  flex-direction: column;
  gap: 80px;
  position: relative;
  z-index: 2;
  max-width: 1700px;
  padding-block: 50px 130px;
  color: #FFF;
}
@media (min-width: 1024px) {
  .p-homeKyoto__inner {
    min-height: 1000px;
    padding-block: 100px;
  }
}

.p-homeKyoto__text {
  margin-top: auto;
  text-align: right;
  text-shadow: 0 0 8px rgba(0, 0, 0, 0.45);
  font-size: 16px;
  font-size: 1rem;
}
@media (min-width: 1024px) {
  .p-homeKyoto__text {
    font-size: 18px;
    font-size: 1.125rem;
  }
}
.p-homeKyoto__text p + p {
  margin-top: 1.5em;
}

.p-homeKyoto__bg {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

.p-homeKyoto__toggleBtn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
  position: absolute;
  bottom: 20px;
  left: calc(50% - 11px);
  z-index: 3;
  width: 22px;
  cursor: pointer;
}
@media (any-hover: hover) {
  .p-homeKyoto__toggleBtn {
    transition: 0.5s opacity;
  }
  .p-homeKyoto__toggleBtn:hover {
    opacity: 0.7;
  }
}
@media (min-width: 1024px) {
  .p-homeKyoto__toggleBtn {
    bottom: 30px;
  }
}
.p-homeKyoto__toggleBtn .line {
  width: 1px;
  height: 50px;
  background: #FFF;
  animation: scroll 1.5s infinite;
}
@media (min-width: 1024px) {
  .p-homeKyoto__toggleBtn .line {
    height: 150px;
  }
}
@keyframes scroll {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  50.1% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}
.p-homeKyoto__toggleBtn .icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  aspect-ratio: 1;
}
.p-homeKyoto__toggleBtn .icon::before, .p-homeKyoto__toggleBtn .icon::after {
  width: 100%;
  height: 2px;
  background: #FFF;
  content: "";
}
.p-homeKyoto__toggleBtn .icon::after {
  position: absolute;
  transform: rotate(90deg);
  transition: 0.5s transform;
}
.p-homeKyoto__toggleBtn.is-toggle__btn--open .icon::after {
  transform: rotate(360deg);
}

/* homeKyotoContents
-------------------------------------- */
.p-homeKyotoContents {
  display: grid;
  grid-template-rows: 0fr;
  opacity: 0;
  transition: 0.5s grid-template-rows ease, 0.5s padding ease, 0.5s opacity ease;
}

.is-toggle__contents--open {
  padding-block: 50px 80px;
  grid-template-rows: 1fr;
  opacity: 1;
}
@media (min-width: 1024px) {
  .is-toggle__contents--open {
    padding-block: 80px 180px;
  }
}

.p-homeKyotoContents__inner {
  display: grid;
  gap: 60px;
  overflow: hidden;
  max-width: 1720px;
}
@media (min-width: 1024px) {
  .p-homeKyotoContents__inner {
    gap: 80px;
  }
}

.p-homeKyotoContents__box {
  display: flex;
}
@media (max-width: 1023px) {
  .p-homeKyotoContents__box {
    flex-direction: column;
    gap: 20px;
  }
}
@media (min-width: 1024px) {
  .p-homeKyotoContents__box {
    align-items: center;
  }
  .p-homeKyotoContents__box:nth-child(2n) {
    flex-direction: row-reverse;
  }
}
.p-homeKyotoContents__box .img img {
  width: 100%;
}
.p-homeKyotoContents__box .text p + p {
  margin-top: 1.5em;
}
.p-homeKyotoContents__box--01 {
  gap: min(10.7142857143vw, 150px);
}
@media (min-width: 1024px) {
  .p-homeKyotoContents__box--01 {
    gap: min(10.7142857143vw, 150px);
  }
}
@media (min-width: 1024px) {
  .p-homeKyotoContents__box--01 .img {
    width: 50%;
  }
}
@media (max-width: 1023px) {
  .p-homeKyotoContents__box--01 .img img {
    width: 49.853372434vw;
    height: 57.6735092864vw;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
@media (min-width: 1024px) {
  .p-homeKyotoContents__box--01 .text {
    flex: 1;
  }
}
@media (max-width: 1023px) {
  .p-homeKyotoContents__box--02 {
    gap: 60px;
  }
}
.p-homeKyotoContents__box--02 .img {
  margin-left: auto;
}
@media (min-width: 1024px) {
  .p-homeKyotoContents__box--02 .img {
    width: 34.8837209302%;
    margin-left: auto;
  }
}
@media (max-width: 1023px) {
  .p-homeKyotoContents__box--02 .img img {
    width: 49.853372434vw;
    height: 57.6735092864vw;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
.p-homeKyotoContents__box--02 .text {
  margin-left: auto;
}
@media (min-width: 1024px) {
  .p-homeKyotoContents__box--02 .text {
    width: 50%;
  }
  .p-homeKyotoContents__box--02 .text p {
    width: -moz-fit-content;
    width: fit-content;
    margin-left: auto;
  }
}
@media (min-width: 1024px) {
  .p-homeKyotoContents__box--03 .img {
    width: 26.1627906977%;
    margin-left: auto;
  }
}
@media (max-width: 1023px) {
  .p-homeKyotoContents__box--03 .img img {
    width: 38.1231671554vw;
    height: 45.9433040078vw;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
@media (min-width: 1024px) {
  .p-homeKyotoContents__box--03 .btn-box {
    width: 50%;
    margin-top: auto;
    padding-left: 27.9069767442%;
  }
}

/* yase
-------------------------------------- */
.p-homeYase {
  position: relative;
}

.p-homeYase__inner {
  position: relative;
  z-index: 2;
  max-width: 1700px;
  padding-block: 50px 70px;
}
@media (min-width: 1024px) {
  .p-homeYase__inner {
    padding-block: 70px 180px;
  }
}

.p-homeYase__bg {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

.p-homeYase__main {
  margin-top: 60px;
}
@media (min-width: 1024px) {
  .p-homeYase__main {
    margin-top: min(21.4285714286vw, 300px);
  }
}
.p-homeYase__main .lead {
  margin-bottom: 0.7em;
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
  font-weight: 500;
  font-size: 22px;
  font-size: 1.375rem;
}
@media (min-width: 1024px) {
  .p-homeYase__main .lead {
    font-size: 36px;
    font-size: 2.25rem;
  }
}
.p-homeYase__main .text {
  line-height: 2;
}
.p-homeYase__main .text p + p {
  margin-top: 1.5em;
}

.p-homeYase__imgText {
  display: flex;
  margin-top: 40px;
}
@media (max-width: 1023px) {
  .p-homeYase__imgText {
    flex-direction: column;
    gap: 20px;
  }
}
@media (min-width: 1024px) {
  .p-homeYase__imgText {
    gap: min(10.7142857143vw, 150px);
    margin-top: 70px;
  }
}
@media (min-width: 1024px) {
  .p-homeYase__imgText .img {
    width: 50%;
  }
}
@media (min-width: 1024px) {
  .p-homeYase__imgText .main {
    display: flex;
    flex-direction: column;
    justify-content: center;
    flex: 1;
    position: relative;
    max-width: 440px;
    padding-block: 60px;
  }
}
.p-homeYase__imgText .text {
  line-height: 2;
}
.p-homeYase__imgText .text p + p {
  margin-top: 1.5em;
}
.p-homeYase__imgText .btn {
  margin-top: 20px;
}
@media (min-width: 1024px) {
  .p-homeYase__imgText .btn {
    position: absolute;
    right: 0;
    bottom: 0;
  }
}

.z10 {
  position: relative;
  z-index: 10;
}

.chu {
  font-size: 12px;
}
@media (max-width: 767px) {
  .chu {
    font-size: 11px;
  }
}

.p-list__inner {
  max-width: 900px;
}
.p-list__inner .u-fs-medium {
  font-weight: normal;
}

.news-contents-btn {
  display: flex;
}
.news-contents-btn .center {
  margin-left: auto;
  margin-right: auto;
}

.hidden-scroll {
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

@media (max-width: 1023px) {
  .hidden-tab {
    display: none;
  }
}

.mt0 {
  margin-top: 0 !important;
}

.mb0 {
  margin-bottom: 0 !important;
}

.mt10 {
  margin-top: 10px;
}

.btn-flex {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}
.btn-flex.large-btn {
  gap: 20px;
}
.btn-flex.large-btn .c-primaryBtn .text--en {
  color: #000;
  font-family: "Garamond", "EB Garamond", serif;
  font-size: 20px;
  font-size: 1.25rem;
  transform: translateY(100%);
}
.btn-flex.large-btn .c-primaryBtn .text--ja {
  transform: translateY(0%);
  font-size: 16px;
  font-size: 1rem;
  color: #FFF;
}
@media (any-hover: hover) {
  .btn-flex.large-btn .c-primaryBtn:hover {
    background: #FFF;
  }
  .btn-flex.large-btn .c-primaryBtn:hover .text--en {
    transform: translateY(0%);
  }
  .btn-flex.large-btn .c-primaryBtn:hover .text--ja {
    transform: translateY(-100%);
  }
  .btn-flex.large-btn .c-primaryBtn:hover .arrow path {
    stroke: #92937e;
  }
}

.border-top {
  border-top: 1px solid #000000;
}

/* =========================================================
 プライバシーポリシー
========================================================= */
.privacy_area .p-box__title {
  margin-bottom: 0.4em;
  padding-bottom: 0.4em;
  border-bottom: 1px solid #92937e;
}
@media (max-width: 959px) {
  .privacy_area .under-line.tit02 {
    padding-left: 0px;
    padding-right: 0px;
  }
}
.privacy_area .list-type {
  list-style: none;
  counter-reset: listNum;
  margin-top: 1.5em;
}
@media (min-width: 1024px) {
  .privacy_area .list-type {
    margin: 1.5rem 0 0 2rem;
  }
}
.privacy_area .list-type li {
  position: relative;
  counter-increment: listNum;
  padding-left: 2.5em;
}
.privacy_area .list-type li::before {
  content: "（" counter(listNum) "）";
  position: absolute;
  left: 0;
  top: 0;
}
.privacy_area .list-type.list-style01 li {
  padding-left: 3.5em;
}
.privacy_area .list-type.list-style01 li::before {
  content: "方針" counter(listNum) ".";
}
.privacy_area .list-type li + li {
  margin-top: 1em;
}
.privacy_area .add-text {
  margin-top: 1em;
}

.list-box {
  margin-top: 3em;
}

/* =========================================================
 宿泊約款
========================================================= */
.terms_content h3 {
  font-size: 20px;
  font-weight: 300;
  line-height: 1.4;
  margin-bottom: 20px;
}
@media screen and (max-width: 479px) {
  .terms_content h3 {
    font-size: 18px;
    margin-bottom: 10px;
  }
}
.terms_content p {
  margin-bottom: 10px;
}
.terms_content div + div {
  margin-top: 40px;
}
@media screen and (max-width: 479px) {
  .terms_content div + div {
    margin-top: 30px;
  }
}
.terms_content .main-num {
  counter-reset: number;
  /*数字をリセット*/
  list-style-type: none !important;
  /*数字を一旦消す*/
  padding-left: 20px;
}
.terms_content .main-num .list01 {
  position: relative;
  padding-left: 10px;
}
.terms_content .inner-num {
  padding-left: 0;
}
.terms_content .inner-num li {
  counter-increment: cnt;
  padding-left: 50px;
  position: relative;
}
.terms_content .inner-num li:before {
  content: "（" counter(cnt) "）";
  position: absolute;
  left: 0;
  width: 50px;
  text-align: center;
}
.terms_content .table01 {
  width: 100%;
  border: 1px solid #e3e3e3;
}
@media screen and (max-width: 479px) {
  .terms_content .table01 {
    font-size: 2.5052192067vw;
  }
}
.terms_content .table01 tr {
  border: 1px solid #e3e3e3;
}
.terms_content .table01 tr .center {
  text-align: center;
  vertical-align: middle;
}
.terms_content .table01 tr th {
  width: 33.3333333333%;
  border: 1px solid #e3e3e3;
  font-weight: 300;
  padding: 10px 20px;
}
@media screen and (max-width: 767px) {
  .terms_content .table01 tr th {
    padding: 0.6518904824vw 1.3037809648vw;
  }
}
.terms_content .table01 tr td {
  border: 1px solid #e3e3e3;
  padding: 10px 20px;
}
@media screen and (max-width: 767px) {
  .terms_content .table01 tr td {
    padding: 0.6518904824vw 1.3037809648vw;
  }
}
.terms_content .table01.column09 tr th {
  width: 11.1111111111%;
  text-align: center;
  vertical-align: middle;
}
.terms_content .table01.column09 tr td {
  text-align: center;
  vertical-align: middle;
}
.terms_content .text_flex {
  margin-top: 30px;
  display: flex;
  align-items: flex-start;
}
.terms_content .text_flex p {
  flex-basis: 35px;
  max-width: 35px;
  margin-bottom: 0;
}
.terms_content .text_flex ol {
  padding-left: 30px;
  flex-basis: calc(100% - 35px);
  max-width: calc(100% - 35px);
}
.terms_content .text_flex ol li {
  list-style: auto;
}
.terms_content .table-content {
  border-collapse: collapse;
}
@media (max-width: 767px) {
  .terms_content .table-content {
    transform: scale(0.5);
    width: 200%;
    transform-origin: top left;
    font-size: 4.1720990874vw;
  }
}
.terms_content .table-content td {
  border: 1px solid #000;
  white-space: nowrap;
}
.terms_content .table-content .table-left {
  width: 28%;
  padding: 5px 10px;
}
.terms_content .table-content .table-center {
  width: 26%;
  padding: 5px 10px;
}
.terms_content .table-content .table-right {
  width: 46%;
  padding: 5px 10px;
}

.n-margin25 {
  margin-top: 10px;
}
@media (max-width: 767px) {
  .n-margin25 {
    margin-top: -20vw;
  }
}

.n-margin40 {
  margin-top: 10px;
}
@media (max-width: 767px) {
  .n-margin40 {
    margin-top: -30vw;
  }
}

.list01 .inner-num li {
  list-style: none;
}

/* =========================================================
 ニュースリストページ
========================================================= */
.p-newsNav {
  margin-block: 0px 70px;
  position: relative;
  z-index: 10;
}
@media (min-width: 768px) {
  .p-newsNav {
    margin-block: 0px 150px;
  }
}
.p-newsNav__inner {
  grid-template-columns: 1fr 1fr 1fr;
  display: grid;
  max-width: 1230px;
}
@media (max-width: 520px) {
  .p-newsNav__inner .p-newsNav__btn {
    letter-spacing: -1.3px;
  }
}

.p-newsNav__btn {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  text-align: center;
  padding: 0.5em 0;
  line-height: 1.45;
  letter-spacing: 0.2em;
  font-size: 12px;
  font-size: 0.75rem;
}
@media (min-width: 521px) {
  .p-newsNav__btn {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}
@media (min-width: 1024px) {
  .p-newsNav__btn {
    font-size: min(1.4084507042vw, 20px);
  }
}
.p-newsNav__btn::before {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 1px;
  background: #d0d0d0;
  content: "";
}
.p-newsNav__btn::after {
  position: absolute;
  width: 0%;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
  height: 2px;
  background: #000000;
  content: "";
  transition: 0.5s width ease-out;
}
.p-newsNav__btn img {
  width: 1.2em;
  margin-left: 0.4em;
}

.is-newsNavBtn--active::after {
  width: 100%;
  transform: translateX(-50%);
}

/* list
-------------------------------------- */
.is-newsDetail {
  visibility: hidden;
  height: 0;
  overflow: hidden;
}
.is-newsDetail--show {
  visibility: visible;
  height: auto;
  overflow: unset;
}

.p-featuresList__archive {
  margin-left: auto;
}

.p-featuresList__list {
  margin-top: 20px;
}
@media (min-width: 1024px) {
  .p-featuresList__list {
    margin-top: 30px;
  }
}
.p-featuresList__list .p-newsNav {
  margin-block: 70px;
  position: relative;
  z-index: 50;
}
@media (min-width: 768px) {
  .p-featuresList__list .p-newsNav {
    margin-block: 100px 80px;
  }
}
.p-featuresList__list li {
  border-bottom: 1px solid #92937e;
}
.p-featuresList__list .link {
  display: flex;
  gap: 0 16px;
  padding: 22px 0;
}
@media (min-width: 1024px) {
  .p-featuresList__list .link {
    gap: 0 40px;
    padding: 30px 0;
  }
}
.p-featuresList__list .img {
  width: 120px;
  height: 80px;
}
@media (max-width: 375px) {
  .p-featuresList__list .img {
    width: 100px;
    height: 60px;
  }
}
.p-featuresList__list .img img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-featuresList__list .main {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  flex: 1;
  -moz-column-gap: 10px;
       column-gap: 10px;
  row-gap: 20px;
}
@media (max-width: 767px) {
  .p-featuresList__list .main {
    -moz-column-gap: 10px;
         column-gap: 10px;
    row-gap: 10px;
  }
}
.p-featuresList__list .date {
  min-width: 5em;
}
@media (min-width: 768px) {
  .p-featuresList__list .date {
    min-width: 5.25em;
  }
}
.p-featuresList__list .category {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin-top: 0.15em;
  padding-right: 10px;
  font-size: 11px;
  font-size: 0.6875rem;
}
.p-featuresList__list .category span {
  min-width: 5.91em;
  padding: 0.1em 0.9em;
  background: #92937e;
  border-radius: 2em;
  color: #FFF;
  text-align: center;
}
.p-featuresList__list .category.category-news span {
  background: #92937e;
}
.p-featuresList__list .category.category-landlady span {
  background: #92937e;
}
.p-featuresList__list .title {
  font-weight: normal;
  font-size: inherit;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  text-overflow: ellipsis;
  overflow: hidden;
}
@media (max-width: 767px) {
  .p-featuresList__list .title {
    width: 100%;
  }
}
@media (min-width: 768px) {
  .p-featuresList__list .title {
    flex: 1;
  }
}
@media (max-width: 767px) {
  .p-featuresList__list .btn {
    text-align: right;
  }
}
@media (min-width: 768px) {
  .p-featuresList__list .btn {
    margin-left: 3em;
  }
}
.p-featuresList__list li .c-img,
.p-featuresList__list li .date,
.p-featuresList__list li .category,
.p-featuresList__list li .blog-title {
  transition: 0.6s;
}
.p-featuresList__list li a:hover .btn::after {
  background: #92937e;
}
.p-featuresList__list li a:hover .btn .circle-button {
  color: #92937e;
}
.p-featuresList__list li a:hover .btn .circle-button::before {
  opacity: 1;
  transform: translateY(calc(-50% - 4px)) scale(1);
}
.p-featuresList__list li a:hover .btn .circle-button::after {
  opacity: 0;
  transform: translateY(calc(-50% - 4px)) scale(0);
}
.p-featuresList__list li a:hover .btn .circle-button .text {
  padding-left: 30px;
  padding-right: 30px;
  margin-left: 0;
  margin-right: -30px;
  transition: margin 0.5s ease;
}
.p-featuresList__list li a:hover .c-img,
.p-featuresList__list li a:hover .date,
.p-featuresList__list li a:hover .category,
.p-featuresList__list li a:hover .blog-title {
  opacity: 0.4;
}

.c-archiveSelect {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  width: 9.375em;
}
.c-archiveSelect::after {
  position: absolute;
  right: 1em;
  width: 6px;
  height: 5px;
  background: #000;
  content: "";
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}
.c-archiveSelect.p-newsList__archive {
  margin: 30px 0 0 auto;
}
@media (min-width: 768px) {
  .c-archiveSelect.p-newsList__archive {
    margin-top: 60px;
  }
}
.c-archiveSelect select {
  width: 100%;
  background: #f0f0f0;
  border-radius: 5px;
  padding: 0.25em 1em;
  cursor: pointer;
  color: #000;
}

.c-secondaryBtn {
  position: relative;
  display: inline-flex;
  align-items: center;
  padding-right: 1.5em;
  font-size: 15px;
  font-size: 0.9375rem;
}
.c-secondaryBtn::before, .c-secondaryBtn::after {
  position: absolute;
  aspect-ratio: 1/1;
  width: 1em;
  border-radius: 100%;
  content: "";
}
.c-secondaryBtn::before {
  background: #000;
}
.c-secondaryBtn::after {
  background: #FFF;
  clip-path: polygon(40% 35%, 65% 50%, 40% 65%);
}
@media (min-width: 1024px) {
  .c-secondaryBtn {
    font-size: 16px;
    font-size: 1rem;
  }
}
.c-secondaryBtn::before, .c-secondaryBtn::after {
  right: 0;
}
@media (any-hover: hover) {
  .c-secondaryBtn {
    transition: 0.5s;
  }
  .c-secondaryBtn::before {
    transition: 0.5s;
  }
  .c-secondaryBtn:hover {
    color: #000000;
  }
  .c-secondaryBtn:hover::before {
    background: #000000;
  }
}

.p-featuresList__inner .p-pagination {
  font-weight: 400;
}
.p-featuresList__inner .p-pagination > * {
  line-height: 1.8;
  padding: 0.2em 0.8em;
}
.p-featuresList__inner .p-pagination .current {
  background: #92937e !important;
}

/* =========================================================
 ニュース詳細ページ
========================================================= */
.news-content .topics-sub-tit {
  display: flex;
  gap: 10px;
  margin-bottom: 20px;
}
.news-content .topics-sub-tit .category {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin-top: 0.15em;
  padding-right: 10px;
  font-size: 11px;
  font-size: 0.6875rem;
}
.news-content .topics-sub-tit .category span {
  min-width: 5.91em;
  padding: 0.1em 0.9em;
  background: #92937e;
  border-radius: 2em;
  color: #FFF;
  text-align: center;
}

.news-contents-box .news-caption {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-top: 0.5em;
}
.news-contents-box .news-caption .news-category {
  background-color: #92937e;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
  margin-top: 0.15em;
  color: #fff;
  border-radius: 2em;
  padding: 0.1em 0.9em;
  padding-right: 10px;
  font-size: 11px;
  font-size: 0.6875rem;
}
.news-contents-box .u-fs-medium {
  font-weight: normal;
}
.news-contents-box .news-contents-btn {
  display: flex;
}
.news-contents-box .news-contents-btn .c-primaryBtn {
  margin-left: auto;
  margin-right: auto;
}
.news-contents-box .img-box img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 2/1;
}
.news-contents-box .p-box__img img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 3/2;
}

/* =========================================================
 faq
========================================================= */
.list-area {
  margin: 0 auto 90px;
}
@media (max-width: 959px) {
  .list-area {
    margin-bottom: clamp(45px, 9.39vw, 90px);
  }
}
.list-area .main-title02 {
  border-bottom: 1px solid #000;
  margin-bottom: 20px;
  padding-bottom: 10px;
}
.list-area.accordion-area {
  list-style: none;
}
.list-area.accordion-area .accordion-trigger {
  cursor: pointer;
  position: relative;
  transition: all 0.5s ease;
  padding-right: 25px;
}
.list-area.accordion-area .accordion-trigger:after {
  content: "";
  position: absolute;
  right: 3%;
  top: 50%;
  width: 14px;
  height: 14px;
  transform: translateY(-50%) rotate(0deg);
  transition: transform 0.4s ease;
  background: linear-gradient(#000, #000) center/100% 1px no-repeat, linear-gradient(#000, #000) center/1px 100% no-repeat;
  /* 縦線 */
}
.list-area.accordion-area .accordion-trigger.open:after {
  background: linear-gradient(#000, #000) center/100% 1px no-repeat;
  /* 横線だけ */
  transform: translateY(-50%) rotate(180deg);
  /* クルッと回転 */
}
.list-area.accordion-area .accordion-box {
  display: none;
}
.list-area .accordion-box {
  display: none;
}
.list-area .accordion-box .list-flex {
  display: flex;
  border-bottom: 1px solid #000;
}
.list-area .accordion-box .list-flex dt {
  flex-basis: 220px;
  max-width: 220px;
  padding: 15px 25px;
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: 0.15em;
  line-height: 2.8125;
}
@media (max-width: 479px) {
  .list-area .accordion-box .list-flex dt {
    flex-basis: 90px;
    max-width: 90px;
    padding: 5px 0px;
    line-height: 1.5;
  }
}
.list-area .accordion-box .list-flex dd {
  flex-basis: calc(100% - 220px);
  max-width: calc(100% - 220px);
  padding: 15px 25px 15px 0;
  display: flex;
  align-items: center;
  letter-spacing: 0.15em;
  line-height: 1.875;
}
@media (max-width: 479px) {
  .list-area .accordion-box .list-flex dd {
    flex-basis: calc(100% - 90px);
    max-width: calc(100% - 90px);
    padding: 5px 0px 5px 10px;
    line-height: 1.5;
  }
}

.space_area .accordion-box {
  padding-left: 32px;
  padding-right: 32px;
  border-bottom: 1px solid #000;
}
@media (max-width: 959px) {
  .space_area .accordion-box {
    padding-left: 0px;
    padding-right: 0px;
  }
}
.space_area .accordion-box dt {
  width: 100%;
  max-width: 100%;
  padding: 35px 0px 20px 40px;
  font-weight: normal;
  letter-spacing: 0.15em;
  line-height: 2.8125;
  display: inline-block;
  position: relative;
}
@media (max-width: 959px) {
  .space_area .accordion-box dt {
    padding: 20px 0px 10px 25px;
    line-height: 1.5;
  }
}
.space_area .accordion-box dt:before {
  content: "Q";
  position: absolute;
  left: 0;
}
.space_area .accordion-box dd {
  width: 100%;
  max-width: 100%;
  padding: 0px 0px 0px 40px;
  font-weight: 400;
  line-height: 1.875;
  letter-spacing: 0.15em;
  margin-inline-start: 0px;
  display: inline-block;
  position: relative;
  word-break: break-all;
}
.space_area .accordion-box dd:last-child {
  padding-bottom: 40px;
}
@media (max-width: 959px) {
  .space_area .accordion-box dd {
    padding: 0px 0px 0px 25px;
    line-height: 1.5;
  }
}
.space_area .accordion-box dd:before {
  content: "A";
  position: absolute;
  left: 0;
}
.space_area .accordion-box li {
  width: 100%;
  max-width: 100%;
  padding-left: 40px;
  font-weight: normal;
  letter-spacing: 0.15em;
  line-height: 2.8125;
  display: inline-block;
  position: relative;
}
.space_area .accordion-box li:first-child {
  padding-top: 20px;
}
.space_area .accordion-box li:last-child {
  padding-bottom: 40px;
}
@media (max-width: 959px) {
  .space_area .accordion-box li {
    padding-left: 20px;
    line-height: 1.5;
  }
}
.space_area .accordion-box li:before {
  content: "■";
  position: absolute;
  left: 0;
}

.under-line {
  border-bottom: 1px solid #92937e;
  transition: 0.4s;
}
.under-line:hover {
  border-bottom: 1px solid transparent;
}

/* =========================================================
 会社概要
========================================================= */
.company-contents > div {
  display: flex;
  border-bottom: 1px solid #92937e;
  padding: 1.5em 0;
  gap: 10px;
}
.company-contents > div:first-child {
  border-top: 1px solid #92937e;
}
@media (max-width: 520px) {
  .company-contents > div {
    flex-direction: column;
    gap: 5px;
  }
}
.company-contents > div dt {
  width: 10em;
}
@media (min-width: 521px) {
  .company-contents > div dt {
    text-align: center;
  }
}
.company-contents > div dd {
  width: 90%;
}
.company-contents > div dd ul li {
  width: 90%;
}
.company-contents > div dd ul li a {
  display: inline-block;
}
.company-contents > div dd ul li + li {
  margin-top: 10px;
  padding-top: 10px;
}

/* =========================================================
 トップページ　
========================================================= */
.bg-news-content {
  position: relative;
  margin-top: -2px;
  background-color: #f2efdc;
}

.home-news-inner .p-news-contents .p-news-box {
  border-bottom: 1px solid #92937e;
}
.home-news-inner .p-news-contents .p-news-box .news-link {
  padding-top: 15px;
  padding-bottom: 15px;
  display: flex;
  gap: 30px;
}
.home-news-inner .p-news-contents .p-news-box .news-link .news-tit {
  font-weight: 300;
  font-size: 13px;
  font-size: 0.8125rem;
}
@media (min-width: 1024px) {
  .home-news-inner .p-news-contents .p-news-box .news-link .news-tit {
    font-size: 14px;
    font-size: 0.875rem;
  }
}

.blog-content .p-box__img {
  aspect-ratio: 570/400;
  overflow: hidden;
}
.blog-content .p-box__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.blog-content .blog-text-box {
  margin-top: 10px;
}
.blog-content .blog-text-box .category {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin-top: 0.15em;
  padding-right: 10px;
  font-size: 11px;
  font-size: 11px;
  font-size: 0.6875rem;
}
.blog-content .blog-text-box .category span {
  min-width: 5.91em;
  padding: 0.1em 0.9em;
  background: #92937e;
  border-radius: 2em;
  color: #FFF;
  text-align: center;
  line-height: 1.7;
}
.blog-content .blog-text-box .blog-title {
  font-family: "Noto Sans JP", "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Meiryo UI", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: normal;
  line-height: 1.7;
  color: #000;
  margin-top: 10px;
  font-weight: 300;
  font-size: 13px;
  font-size: 0.8125rem;
}
@media (min-width: 1024px) {
  .blog-content .blog-text-box .blog-title {
    font-size: 14px;
    font-size: 0.875rem;
  }
}

/* =========================================================
 コンタクト詳細ページ
========================================================= */
#contact button,
#contact input,
#contact select,
#contact textarea {
  background-color: #fff;
  /*border: 1px solid #000;*/
}

#contact .mfp_buttons button {
  padding: 12px 35px;
  border: 1px solid #ddd;
  background-color: #fff;
}
#contact .mfp_buttons button:hover {
  color: #ddd;
}

#contact .home-section__btn a {
  display: flex;
  margin: 0 auto;
}

form#mailformpro dl dt {
  line-height: 15px;
  font-weight: 300;
}
form#mailformpro dl dt .must {
  background-color: #92937e;
}
form#mailformpro .mt10 {
  margin-top: 10px !important;
}
form#mailformpro .mfp_achroma {
  background-color: #f2efdc;
}

/* =========================================================
 コンタクト追加詳細ページ
========================================================= */
form#mailformpro dl .wide-text dt {
  float: none;
  clear: none;
  text-align: left !important;
  width: 100%;
}
form#mailformpro dl .wide-text dd {
  padding-top: 0;
  padding-left: 0;
  border-top: none;
}
form#mailformpro dl .wide-text dd .check-flex {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
}
form#mailformpro .mt10 {
  margin-top: 10px !important;
}

.agreement .gray-area {
  padding: 20px;
  background-color: #f7f7f7;
}
.agreement #terms-box {
  padding-left: 10px;
  padding-right: 10px;
  max-height: 500px;
  overflow-y: scroll;
}
.agreement #terms-box ol {
  list-style-type: decimal;
}
.agreement #terms-box ol li {
  position: relative;
  padding-left: 2em;
  list-style: none;
  counter-increment: item;
}
.agreement #terms-box ol li::before {
  content: counter(item) ". ";
  position: absolute;
  left: 0;
  top: 0;
}
.agreement #terms-box .c-tit {
  margin-bottom: 20px;
}
.agreement .check-flex label {
  color: #999;
  /* 初期はグレー */
  cursor: not-allowed;
}
.agreement .check-flex label.enabled {
  color: #000;
  /* スクロール後は黒 */
  cursor: pointer;
}

@media screen and (max-width: 768px) {
  table#mfp_confirm_table tr th {
    white-space: break-spaces;
    width: 150px;
  }
}
.iframe-wrap {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%;
  /* 16:9比率 (700/1200 ≈ 0.583 → 約56.25%) */
  height: 0;
  overflow: hidden;
}
.iframe-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.tel-area {
  color: #fff;
}

.p-menu__list .gaibu a {
  justify-content: flex-start !important;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: 0.5s;
  gap: 0.4em;
}
.p-menu__list .gaibu a::after {
  width: 0.8em;
  aspect-ratio: 1/1;
  background: url(../img/common/icon_external.svg) no-repeat center/contain;
  content: "";
}

.l-footer__nav .p-menu__list .gaibu a::after {
  background: url(../img/common/icon_external_white.svg) no-repeat center/contain;
}

/* =========================================================
 トップセカンドビュー
========================================================= */
.aerial-bg {
  position: relative;
  margin-top: -2px;
  background-color: #f2efdc;
}

.aerial-bg::before,
.aerial-bg::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 60px;
  /* ぼかしの高さ */
  pointer-events: none;
  /* 上のコンテンツ操作を妨げない */
  z-index: 10;
}

.aerial-bg::before {
  top: 80px;
  background: linear-gradient(to bottom, rgb(242, 239, 220) 0%, rgba(242, 239, 220, 0) 100%);
}
@media (min-width: 1366px) {
  .aerial-bg::before {
    top: 100px;
  }
}

.aerial-bg::after {
  bottom: 0;
  background: linear-gradient(to top, rgb(242, 239, 220) 0%, rgba(242, 239, 220, 0) 100%);
}

.aerial-wrap {
  perspective: 1000px;
  /* 3D効果のための遠近感 */
  overflow: hidden;
  height: 880px;
  width: 100%;
  max-width: 2000px;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 764px) {
  .aerial-wrap {
    height: 500px;
  }
}

.aerial-img {
  width: 100%;
  display: block;
  animation: floatMove 30s linear infinite;
  transform-style: preserve-3d;
  /* 3D効果を維持 */
  height: 100%;
  position: relative;
  width: 2000px;
}
@media (min-width: 1900px) {
  .aerial-img {
    width: 2000px;
  }
}
@media (min-width: 1700px) {
  .aerial-img {
    margin-left: 255px;
  }
}
@media (max-width: 1000px) {
  .aerial-img {
    margin-left: -200px;
  }
}
@media (max-width: 764px) {
  .aerial-img {
    width: 1024px;
    margin-left: -50px;
  }
}
@media (max-width: 500px) {
  .aerial-img {
    margin-left: -150px;
  }
}
.aerial-img .map-img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  scale: 1.3;
  width: 2000px;
}
@media (min-width: 1900px) {
  .aerial-img .map-img {
    width: 2000px;
  }
}
@media (max-width: 764px) {
  .aerial-img .map-img {
    width: 1024px;
  }
}

@keyframes floatMove {
  0% {
    transform: translate(0, 0) rotateX(0deg) rotateY(0deg) scaleY(1) scaleZ(1);
  }
  6.25% {
    transform: translate(-10px, -6px) rotateX(3deg) rotateY(1deg) scaleY(1.01) scaleZ(0.99);
  }
  12.5% {
    transform: translate(-20px, -12px) rotateX(4deg) rotateY(2deg) scaleY(1.02) scaleZ(0.98);
  }
  18.75% {
    transform: translate(-30px, -9px) rotateX(5deg) rotateY(2deg) scaleY(1.02) scaleZ(0.98);
  }
  25% {
    transform: translate(-40px, 0px) rotateX(6deg) rotateY(3deg) scaleY(1.03) scaleZ(0.97);
  }
  31.25% {
    transform: translate(-45px, 10px) rotateX(5deg) rotateY(2deg) scaleY(1.02) scaleZ(0.98);
  }
  37.5% {
    transform: translate(-50px, 20px) rotateX(4deg) rotateY(1deg) scaleY(1.01) scaleZ(0.99);
  }
  43.75% {
    transform: translate(-45px, 30px) rotateX(3deg) rotateY(0deg) scaleY(1.01) scaleZ(0.99);
  }
  50% {
    transform: translate(-40px, 40px) rotateX(-3deg) rotateY(0deg) scaleY(0.99) scaleZ(1.01);
  }
  56.25% {
    transform: translate(-30px, 30px) rotateX(-4deg) rotateY(-1deg) scaleY(0.98) scaleZ(1.02);
  }
  62.5% {
    transform: translate(-20px, 20px) rotateX(-5deg) rotateY(0deg) scaleY(0.97) scaleZ(1.03);
  }
  68.75% {
    transform: translate(-10px, 10px) rotateX(-4deg) rotateY(1deg) scaleY(0.98) scaleZ(1.02);
  }
  75% {
    transform: translate(-5px, 4px) rotateX(3deg) rotateY(2deg) scaleY(1.01) scaleZ(0.99);
  }
  81.25% {
    transform: translate(-3px, 0px) rotateX(2deg) rotateY(1deg) scaleY(1.01) scaleZ(0.99);
  }
  87.5% {
    transform: translate(-2px, -4px) rotateX(2deg) rotateY(1deg) scaleY(1) scaleZ(1);
  }
  93.75% {
    transform: translate(-1px, -2px) rotateX(1deg) rotateY(0.5deg) scaleY(1) scaleZ(1);
  }
  100% {
    transform: translate(0, 0) rotateX(0deg) rotateY(0deg) scaleY(1) scaleZ(1);
  }
}
.place-position li {
  position: absolute;
}
.place-position li.hotel {
  top: 130px;
  left: 770px;
  height: 493px;
}
@media (min-width: 1900px) {
  .place-position li.hotel {
    left: 770px;
    height: 493px;
  }
}
@media (max-width: 764px) {
  .place-position li.hotel {
    top: 150px;
    height: 200px;
    left: 460px;
  }
}
.place-position li.hotel .dashed-line {
  bottom: -410px;
  bottom: 0;
}
@media (max-width: 1023px) {
  .place-position li.hotel .dashed-line {
    bottom: 0;
  }
}
.place-position li.ohara {
  top: 300px;
  left: 29.5833333333vw;
  height: clamp(600px, 37.2222222222vw, 670px);
  height: 150px;
  top: 250px;
  left: 630px;
}
@media (min-width: 1900px) {
  .place-position li.ohara {
    left: 630px;
  }
}
@media (max-width: 764px) {
  .place-position li.ohara {
    top: 108px;
    height: 115px;
    left: 358px;
  }
}
.place-position li.ohara .dashed-line {
  bottom: -410px;
  bottom: 0;
  left: 110%;
}
@media (max-width: 1023px) {
  .place-position li.ohara .dashed-line {
    bottom: 0;
  }
}
.place-position li.ohara .solid-line {
  top: 0%;
  /* テキストの下 */
  top: 0;
  height: 0;
  background: black;
  opacity: 0;
  left: 110%;
}
@keyframes solidLineAnim {
  0% {
    height: 0;
    opacity: 1;
  }
  50% {
    height: 100%;
    opacity: 1;
  }
  100% {
    height: 100%;
    opacity: 0;
  }
}
@keyframes dashedLineAnim {
  0% {
    height: 0;
    opacity: 0;
  }
  100% {
    height: 100%;
    opacity: 1;
  }
}
.place-position li.ruri {
  top: 280px;
  height: 330px;
  left: 850px;
}
@media (max-width: 764px) {
  .place-position li.ruri {
    top: 200px;
    height: 125px;
    left: 533px;
  }
}
.place-position li.ruri .dashed-line {
  bottom: -410px;
  bottom: 0;
  left: -10%;
}
@media (max-width: 1023px) {
  .place-position li.ruri .dashed-line {
    bottom: 0;
  }
}
.place-position li.ruri .solid-line {
  top: 0%;
  /* テキストの下 */
  top: 0;
  height: 0;
  background: black;
  opacity: 0;
  left: -10%;
}
.place-position li.ruri .bl_fv_areaListNumTxt {
  transform: translateY(30px);
}
@keyframes solidLineAnim {
  0% {
    height: 0;
    opacity: 1;
  }
  50% {
    height: 100%;
    opacity: 1;
  }
  100% {
    height: 100%;
    opacity: 0;
  }
}
@keyframes dashedLineAnim {
  0% {
    height: 0;
    opacity: 0;
  }
  100% {
    height: 100%;
    opacity: 1;
  }
}
.place-position li.biwako {
  top: 143px;
  height: 155px;
  left: 1322px;
}
@media (max-width: 764px) {
  .place-position li.biwako {
    top: 80px;
    height: 90px;
    left: 719px;
  }
}
.place-position li.biwako .dashed-line {
  bottom: -410px;
  bottom: 0;
  left: -10%;
}
@media (max-width: 1023px) {
  .place-position li.biwako .dashed-line {
    bottom: 0;
  }
}
.place-position li.biwako .solid-line {
  top: 0%;
  /* テキストの下 */
  top: 0;
  height: 0;
  background: black;
  opacity: 0;
  left: -10%;
}
.place-position li.biwako .bl_fv_areaListNumTxt {
  transform: translateY(10px);
}
@keyframes solidLineAnim {
  0% {
    height: 0;
    opacity: 1;
  }
  50% {
    height: 100%;
    opacity: 1;
  }
  100% {
    height: 100%;
    opacity: 0;
  }
}
@keyframes dashedLineAnim {
  0% {
    height: 0;
    opacity: 0;
  }
  100% {
    height: 100%;
    opacity: 1;
  }
}
.place-position li.hiei {
  top: 290px;
  height: 92px;
  left: 1365px;
}
@media (max-width: 764px) {
  .place-position li.hiei {
    top: 140px;
    height: 88px;
    left: 755px;
  }
}
.place-position li.hiei .dashed-line {
  bottom: -410px;
  bottom: 0;
  left: -10%;
}
@media (max-width: 1023px) {
  .place-position li.hiei .dashed-line {
    bottom: 0;
  }
}
.place-position li.hiei .solid-line {
  top: 0%;
  /* テキストの下 */
  top: 0;
  height: 0;
  background: black;
  opacity: 0;
  left: -10%;
}
.place-position li.hiei .bl_fv_areaListNumTxt {
  transform: translateY(10px);
}
@keyframes solidLineAnim {
  0% {
    height: 0;
    opacity: 1;
  }
  50% {
    height: 100%;
    opacity: 1;
  }
  100% {
    height: 100%;
    opacity: 0;
  }
}
@keyframes dashedLineAnim {
  0% {
    height: 0;
    opacity: 0;
  }
  100% {
    height: 100%;
    opacity: 1;
  }
}
.place-position li.city {
  height: 150px;
  top: 430px;
  left: 134px;
}
@media (max-width: 764px) {
  .place-position li.city {
    top: 215px;
    height: 115px;
    left: 175px;
  }
}
.place-position li.city .dashed-line {
  bottom: -410px;
  bottom: 0;
  left: 110%;
}
@media (max-width: 764px) {
  .place-position li.city .dashed-line {
    left: -10%;
  }
}
@media (max-width: 1023px) {
  .place-position li.city .dashed-line {
    bottom: 0;
  }
}
.place-position li.city .solid-line {
  top: 0%;
  /* テキストの下 */
  top: 0;
  height: 0;
  background: black;
  opacity: 0;
  left: 110%;
}
@media (max-width: 764px) {
  .place-position li.city .solid-line {
    left: -10%;
  }
}
@keyframes solidLineAnim {
  0% {
    height: 0;
    opacity: 1;
  }
  50% {
    height: 100%;
    opacity: 1;
  }
  100% {
    height: 100%;
    opacity: 0;
  }
}
@keyframes dashedLineAnim {
  0% {
    height: 0;
    opacity: 0;
  }
  100% {
    height: 100%;
    opacity: 1;
  }
}

/* キーフレーム */
@keyframes solidLineAnim {
  0% {
    height: 0;
    opacity: 1;
  }
  50% {
    height: 100%;
    opacity: 1;
  }
  100% {
    height: 100%;
    opacity: 0;
  }
}
@keyframes dashedLineAnim {
  0% {
    height: 0;
    opacity: 0;
  }
  100% {
    height: 90%;
    opacity: 1;
  }
}
.bl_fv_areaListNum {
  position: relative;
  display: inline-block;
}

.bl_fv_areaListNumTxt {
  opacity: 0;
  transition: opacity 0.8s ease-in-out;
  font-size: 20px;
  font-weight: 500;
  white-space: nowrap;
}
@media (max-width: 1023px) {
  .bl_fv_areaListNumTxt {
    font-size: 16px;
  }
}

/* 線の基本スタイル */
.map-line {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 0.5px;
}

/* 実線（上→下） */
.solid-line {
  top: 100%;
  /* テキストの下 */
  top: 0;
  height: 0;
  border-left: 1px solid black;
  opacity: 0;
}

/* 点線（下→上） */
.dashed-line {
  height: 0;
  border-left: 1px dashed black;
  opacity: 0;
}

/* アニメーション */
.animate-solid {
  animation: solidLineAnim 0.5s forwards;
}

.animate-dashed {
  animation: dashedLineAnim 0.8s forwards;
}

.animate-text {
  opacity: 1;
}

/* 実線（上→下） */
.solid-line02 {
  top: 100%;
  /* テキストの下 */
  height: 0;
  border-left: 1px solid black;
  opacity: 0;
}

/* 点線（下→上） */
.dashed-line02 {
  bottom: -410px;
  height: 0;
  border-left: 1px dashed black;
  opacity: 0;
}

/* アニメーション */
.animate-solid02 {
  animation: solidLineAnim02 0.5s forwards;
}

.animate-dashed02 {
  animation: dashedLineAnim 0.8s forwards;
}

.animate-text {
  opacity: 1;
}

/* キーフレーム */
@keyframes solidLineAnim02 {
  0% {
    height: 0;
    opacity: 1;
  }
  50% {
    height: 450px;
    opacity: 1;
  }
  100% {
    height: 100px;
    opacity: 0;
  }
}
@keyframes dashedLineAnim02 {
  0% {
    height: 0;
    opacity: 0;
  }
  100% {
    height: 400px;
    opacity: 1;
  }
}
/* localNav
-------------------------------------- */
.p-localNav {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 20px;
}
@media (min-width: 768px) {
  .p-localNav {
    justify-content: center;
    gap: 10px 30px;
  }
}
@media (min-width: 1024px) {
  .p-localNav {
    gap: 10px 50px;
  }
}
.p-localNav li {
  width: 100%;
}
@media (min-width: 768px) {
  .p-localNav li {
    width: calc((100% - 120px) / 5);
  }
}
@media (min-width: 1024px) {
  .p-localNav li {
    width: calc((100% - 200px) / 5);
  }
}
.p-localNav li .p-localNav__link .nav-border .nav-text {
  font-size: 14px;
  font-size: 0.875rem;
}
@media (min-width: 1024px) {
  .p-localNav li .p-localNav__link .nav-border .nav-text {
    font-size: 16px;
    font-size: 1rem;
  }
}

.p-homeSearch__nights .wrapper {
  width: 4.2em;
}
@media (min-width: 1024px) {
  .p-homeSearch__nights .wrapper {
    width: 4.8em;
  }
}
.p-homeSearch__nights .suffix {
  font-style: 56%;
}
.p-homeSearch__rooms .wrapper {
  width: 4.4em;
}
@media (min-width: 1024px) {
  .p-homeSearch__rooms .wrapper {
    width: 4.8em;
  }
}
.p-homeSearch__rooms .suffix {
  font-style: 56%;
}
.p-homeSearch__numbers .wrapper {
  width: 4.4em;
}
@media (min-width: 1024px) {
  .p-homeSearch__numbers .wrapper {
    width: 4.8em;
  }
}
.p-homeSearch__numbers .suffix {
  font-style: 56%;
}

.p-homeRelations__list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px 20px;
}
@media (min-width: 768px) {
  .p-homeRelations__list {
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
  }
}
@media (min-width: 1366px) {
  .p-homeRelations__list {
    grid-template-columns: repeat(5, 1fr);
    gap: min(3.5714285714vw, 50px);
  }
}
.p-homeRelations__list dt {
  margin-bottom: 0.5em;
  padding-bottom: 0.5em;
  border-bottom: 1px solid #adad99;
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
  text-align: center;
  font-weight: 500;
  font-size: 13px;
  font-size: 0.8125rem;
}
@media (min-width: 1024px) {
  .p-homeRelations__list dt {
    font-size: 15px;
    font-size: 0.9375rem;
  }
}

/* 汎用box
-------------------------------------- */
.p-box--floormap {
  display: flex;
}
@media (max-width: 1023px) {
  .p-box--floormap {
    flex-direction: column;
    gap: 30px;
  }
}
@media (min-width: 1024px) {
  .p-box--floormap {
    gap: 70px;
  }
}
@media (min-width: 1024px) {
  .p-box--floormap .p-box__main {
    flex: 1;
  }
}
.p-box--floormap .p-box__img {
  text-align: center;
}
@media (min-width: 1024px) {
  .p-box--floormap .p-box__img {
    width: 34.1666666667%;
    padding-inline: 30px;
  }
}
.p-box--floormap .p-box__img img {
  width: auto;
}
.p-box--text .main-title02 {
  margin-bottom: 20px;
}
.p-box--text .p-box__main + .p-box__main {
  margin-top: 40px;
}
@media (max-width: 1023px) {
  .p-box--text .p-box__main + .p-box__main {
    margin-top: 20px;
  }
}
.p-box--text .p-box__main.list-two {
  display: flex;
}
@media (max-width: 1023px) {
  .p-box--text .p-box__main.list-two {
    flex-direction: column;
  }
}
@media (min-width: 1024px) {
  .p-box--text .p-box__main.list-two {
    align-items: flex-start;
  }
}
.p-box--text .p-box__main.text-spec {
  display: flex;
  flex-direction: column;
}
@media (min-width: 1024px) {
  .p-box--text .p-box__main.text-spec {
    flex-direction: initial;
  }
}
.p-box--text .p-box__main.text-spec .p-box__text {
  width: 100%;
}
.p-box--text .p-box__main.text-spec .p-box__list {
  width: 100%;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid #000;
}
@media (min-width: 1024px) {
  .p-box--text .p-box__main.text-spec .p-box__list {
    width: 500px;
    margin-top: 0px;
    padding-top: 0px;
    border-top: none;
  }
}
.p-box--text .p-box__main.text-spec .p-box__list > div {
  display: flex;
  flex-direction: initial;
}
.p-box--text .p-box__main.text-spec .p-box__list > div dt {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}
.p-box--text .p-box__main.text-spec .p-box__list > div + div {
  margin-top: 10px;
}
.p-box--text .list-two .p-box__list {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}
@media (min-width: 1024px) {
  .p-box--text .list-two .p-box__list {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 35px;
  }
}
.p-box--text .list-two .p-box__list > div {
  flex-direction: column;
}
.p-box--text .list-two .p-box__list > div + div {
  margin-top: 20px;
}
@media (min-width: 1024px) {
  .p-box--text .list-two .p-box__list > div + div {
    margin-top: 0;
  }
}
.p-box--text .list-two .p-box__list > div dt {
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid #000;
}
@media (min-width: 1024px) {
  .p-box--text .list-two .p-box__list > div dt {
    margin-bottom: 20px;
    padding-bottom: 20px;
  }
}
.p-box--text .p-box__list {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}
.p-box--text .p-box__list > div {
  flex-direction: column;
}
.p-box--text .p-box__list > div + div {
  margin-top: 20px;
}
.p-box--text .p-box__list > div dt {
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid #000;
  font-family: "Noto Serif JP", "Times New Roman", Georgia, serif;
}
@media (min-width: 1024px) {
  .p-box--text .p-box__list > div dt {
    margin-bottom: 20px;
    padding-bottom: 20px;
  }
}
.p-box--split {
  display: flex;
}
@media (max-width: 1023px) {
  .p-box--split {
    flex-direction: column;
    gap: 20px;
  }
}
@media (min-width: 1024px) {
  .p-box--split {
    align-items: center;
    gap: 60px;
  }
  .p-box--splitReverse {
    flex-direction: row-reverse;
  }
}
@media (min-width: 1024px) {
  .p-box--split .p-box__img {
    width: 50%;
  }
}
@media (min-width: 1024px) {
  .p-box--split .p-box__main {
    flex: 1;
  }
}
.p-box--split .p-box__main .main-title02 {
  margin-bottom: 30px;
}
@media (max-width: 1023px) {
  .p-box--split .p-box__main .main-title02 {
    margin-bottom: 20px;
  }
}

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

.p-box__list {
  line-height: 1.5;
}
@media (max-width: 1023px) {
  .p-box__list {
    margin-top: 1em;
    padding-top: 1em;
    border-top: 1px solid;
  }
}
.p-box__list > div {
  display: flex;
}
.p-box__list > div + div {
  margin-top: 0.6em;
}
.p-box__list dd {
  flex: 1;
}
.p-box__list dd.list-content .list-two-grid {
  display: grid;
  gap: 5px 20px;
}
@media (min-width: 768px) {
  .p-box__list dd.list-content .list-two-grid {
    grid-template-columns: 1fr 1fr;
  }
}
.p-box__list dd.list-content .list-two-grid li {
  position: relative;
  padding-left: 0.8em; /* 黒丸の分だけ余白を作る */
  list-style: none;
}
.p-box__list dd.list-content .list-two-grid li::before {
  content: "●";
  position: absolute;
  left: 0;
  top: 9px;
  transform: translateY(0%);
  font-size: 0.3em;
  color: #000000; /* 黒色 */
}
.p-box__list--bordertop {
  margin-top: 1.3em;
  padding-top: 1.5em;
  border-top: 1px solid;
}
.p-box__list--bordertop dt {
  width: 6.25em;
}
@media (min-width: 1024px) {
  .p-box__list--borderleft {
    margin-left: 1.5em;
    padding-left: 1.5em;
    border-left: 1px solid;
  }
}
.p-box__list--borderleft dt {
  width: 10em;
}

.p-box__notice {
  font-size: 12px;
  font-size: 0.75rem;
}
* + .p-box__notice {
  margin-top: 20px;
}

/* 汎用boxを入れるグリッド
-------------------------------------- */
.p-boxGrid {
  display: grid;
  gap: 40px;
}
@media (min-width: 1024px) {
  .p-boxGrid--col2 {
    grid-template-columns: 1fr 1fr;
    gap: 60px;
  }
}
.p-boxGrid--col2 .p-box__img {
  margin-bottom: 20px;
}
.p-boxGrid--col2 .main-title02 {
  margin-bottom: 20px;
}
@media (min-width: 1024px) {
  .p-boxGrid--col3 {
    grid-template-columns: 1fr 1fr 1fr;
    gap: 45px;
  }
}
.p-boxGrid--col3 .p-box__img {
  margin-bottom: 20px;
}
.p-boxGrid--col3 .main-title02 {
  margin-bottom: 20px;
}

/* ページリンク
-------------------------------------- */
.content-link-sec {
  overflow: visible;
}
.content-link-sec .p-content-link + .p-content-link .p-content-link-block {
  padding-top: 45px;
}
@media (min-width: 1024px) {
  .content-link-sec .p-content-link + .p-content-link .p-content-link-block {
    padding-top: 60px;
  }
}
.content-link-sec .p-content-link {
  padding-bottom: 45px;
}
@media (min-width: 1024px) {
  .content-link-sec .p-content-link {
    padding-bottom: 60px;
  }
}
.content-link-sec .p-content-link .p-content-link-block {
  position: relative;
  display: flex;
}
@media (max-width: 1023px) {
  .content-link-sec .p-content-link .p-content-link-block {
    flex-direction: column;
    gap: 40px;
  }
}
@media (min-width: 1024px) {
  .content-link-sec .p-content-link .p-content-link-block {
    gap: 60px;
    align-items: flex-start;
  }
}
@media (min-width: 1024px) {
  .content-link-sec .p-content-link .p-content-link-block .p-content-link-text {
    position: sticky;
    top: 8vw;
    left: 0;
    width: 400px;
  }
}
.content-link-sec .p-content-link .p-content-link-block .p-content-link-text .main-title02 {
  margin-bottom: 20px;
}
@media (min-width: 1024px) {
  .content-link-sec .p-content-link .p-content-link-block .p-content-link-text .main-title02 {
    margin-bottom: 30px;
  }
}
.content-link-sec .p-content-link .p-content-link-block .p-content-link-text .caption-text {
  margin-bottom: 20px;
}
@media (min-width: 1024px) {
  .content-link-sec .p-content-link .p-content-link-block .p-content-link-text .caption-text {
    margin-bottom: 30px;
  }
}
.content-link-sec .p-content-link .p-content-link-block .p-content-link-img .link-img-block + .link-img-block {
  margin-top: 45px;
}
@media (min-width: 1024px) {
  .content-link-sec .p-content-link .p-content-link-block .p-content-link-img .link-img-block + .link-img-block {
    margin-top: 60px;
  }
}
@media (min-width: 1024px) {
  .content-link-sec .p-content-link .p-content-link-block .p-content-link-img .link-img-block {
    max-width: 740px;
  }
}
.content-link-sec .p-content-link .p-content-link-block .p-content-link-img .link-img-block img {
  width: 100%;
}
.content-link-sec .p-content-link .p-content-link-block .p-content-link-img .p-content-link-btn-block {
  margin-top: 20px;
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: flex-start;
}
@media (min-width: 1024px) {
  .content-link-sec .p-content-link .p-content-link-block .p-content-link-img .p-content-link-btn-block {
    margin-top: 30px;
  }
}
.content-link-sec .p-content-link .p-content-link-block .p-content-link-img .p-content-link-btn-block .btn {
  margin-top: 0px;
}
@media (min-width: 1024px) {
  .content-link-sec .p-content-link .p-content-link-block .p-content-link-img .p-content-link-btn-block .btn {
    margin-top: 0;
  }
}

@media screen and (max-width: 767px) and (orientation: landscape) {
  .usp-content .usp-main {
    height: 600px;
  }
}
@media (max-width: 1023px) {
  .usp-content .usp-main .p-usp__inner {
    padding-top: 50px;
    padding-bottom: 50px;
  }
}

form#mailformpro dl dt {
  line-height: 1.7 !important;
}
@media (min-width: 769px) {
  form#mailformpro dl dt {
    line-height: 1.5;
    width: 200px;
    padding-top: 22px;
  }
}
@media (min-width: 769px) {
  form#mailformpro dl dd {
    padding: 20px 5px 20px 220px;
    line-height: 1.7;
  }
}

/* ドロワーが開いている時 */
body.is-drawerOpen {
  width: 100% !important;
  -webkit-overflow-scrolling: auto; /* iOS対策 */
}

/* 通常時 */
body {
  -webkit-overflow-scrolling: touch;
}/*# sourceMappingURL=styles.css.map */