header {
  margin-bottom: 120px;
  position: relative;
}
@media screen and (max-width: 768px) {
  header {
    margin-bottom: 80px;
  }
}
@media screen and (max-width: 520px) {
  header {
    margin-bottom: 64px;
  }
}
header .header_summary {
  color: #fff;
  display: flex;
  align-items: center;
  flex-flow: column nowrap;
  justify-content: center;
  height: 100%;
  width: 100%;
  position: absolute;
  z-index: 2;
}
header .header_summary h1 {
  font-size: 3.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
}
header .header_summary h1 em {
  color: #eedf30;
  font-size: 2em;
  font-style: normal;
  font-weight: 600;
  line-height: 1;
}
header .header_summary h1 sup {
  font-size: 1.2rem;
  position: relative;
  top: -1em;
}
@media screen and (max-width: 991px) {
  header .header_summary h1 {
    font-size: 3.232vw;
  }
  header .header_summary h1 sup {
    font-size: 1rem;
    top: -0.5em;
  }
}
@media screen and (max-width: 768px) {
  header .header_summary h1 {
    font-size: 4.166vw;
  }
}
header .header_summary p {
  margin: 24px auto 40px;
  max-width: 696px;
  width: 90%;
}
@media screen and (max-width: 768px) {
  header .header_summary p {
    margin: 16px auto 32px;
  }
}
header .header_summary dl {
  padding: 1.25em 1em 0.5em;
  text-align: right;
  position: absolute;
  right: 1em;
  bottom: 0.25em;
}
@media screen and (max-width: 768px) {
  header .header_summary dl {
    text-align: center;
    position: relative;
    right: auto;
    bottom: auto;
  }
}
header .header_summary dl sup {
  font-size: 1.2rem;
  position: relative;
  top: -0.5em;
}
@media screen and (max-width: 991px) {
  header .header_summary dl sup {
    font-size: 1rem;
    top: -0.5em;
  }
}
header .header_summary dt {
  font-size: 1.4rem;
  line-height: 1.2;
}
@media screen and (max-width: 991px) {
  header .header_summary dt {
    font-size: 1.2rem;
  }
}
header .header_summary dd {
  font-size: 1.6rem;
  margin: 0;
}
header .header_summary dd em {
  font-size: 1.5em;
  font-style: normal;
  line-height: 0;
}
header .header_summary dd span {
  font-size: 1rem;
}
header .header_visual ul {
  display: flex;
  flex-flow: row nowrap;
}
header .header_visual li {
  width: 25%;
}
header .header_visual img {
  height: 480px;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 768px) {
  header .header_visual img {
    height: 48.69vh;
  }
}
@media screen and (max-width: 520px) {
  header .header_visual img {
    height: 28.54vh;
  }
}

.caption {
  margin: 80px auto;
  max-width: 1140px;
  width: 96%;
}
.caption p {
  font-size: 1.2rem;
  line-height: 1.2;
  margin-bottom: 8px;
}
@media screen and (max-width: 768px) {
  .caption p {
    font-size: 1rem;
  }
}
@media screen and (max-width: 768px) {
  .caption {
    margin: 64px auto;
  }
}
@media screen and (max-width: 520px) {
  .caption {
    margin: 48px auto;
  }
}

.anchor {
  margin: 0 auto 80px;
  max-width: 1140px;
  width: 96%;
}
@media screen and (max-width: 768px) {
  .anchor {
    margin-bottom: 64px;
  }
}
.anchor h2 {
  font-size: 3.2rem;
  font-weight: normal;
  line-height: 1.8;
  text-align: center;
}
.anchor h2 span {
  color: #7d7d7d;
  display: block;
  font-size: 2rem;
  font-family: "Cormorant Garamond", serif;
}
@media screen and (max-width: 991px) {
  .anchor h2 {
    font-size: 4.166vw;
  }
  .anchor h2 span {
    font-size: 2.604vw;
  }
}
@media screen and (max-width: 768px) {
  .anchor h2 {
    font-size: 6.153vw;
  }
  .anchor h2 span {
    font-size: 3.846vw;
  }
}
.anchor .area_list {
  margin-top: 2em;
}
.anchor .area_list ul {
  background: #fff;
  border-radius: 16px;
  box-shadow: 4px 4px 10px rgba(0, 0, 0, 0.3);
  display: flex;
  flex-flow: row nowrap;
  gap: 24px;
  padding: 8px;
}
@media screen and (max-width: 520px) {
  .anchor .area_list ul {
    flex-wrap: wrap;
    gap: 0 24px;
  }
}
.anchor .area_list li {
  line-height: 64px;
  text-align: center;
  width: calc((100% - 96px) / 5);
}
.anchor .area_list li a {
  background-color: #fff;
  border-radius: 8px;
  display: block;
  font-size: 2rem;
}
.anchor .area_list li a:hover {
  background-color: #163259;
  color: #fff;
}
@media screen and (max-width: 520px) {
  .anchor .area_list li {
    line-height: 40px;
    width: calc((100% - 48px) / 3);
  }
  .anchor .area_list li a {
    font-size: 3.846vw;
  }
}

.officialsearch {
  margin: 0 auto 80px;
  max-width: 1140px;
  width: 96%;
}
@media screen and (max-width: 768px) {
  .officialsearch {
    margin-bottom: 64px;
  }
}
.officialsearch h2 {
  font-size: 3.2rem;
  font-weight: normal;
  line-height: 1.8;
  text-align: center;
}
.officialsearch h2 span {
  color: #7d7d7d;
  display: block;
  font-size: 2rem;
  font-family: "Cormorant Garamond", serif;
}
@media screen and (max-width: 991px) {
  .officialsearch h2 {
    font-size: 4.166vw;
  }
  .officialsearch h2 span {
    font-size: 2.604vw;
  }
}
@media screen and (max-width: 768px) {
  .officialsearch h2 {
    font-size: 6.153vw;
  }
  .officialsearch h2 span {
    font-size: 3.846vw;
  }
}
.officialsearch .search_list ul {
  display: flex;
  flex-flow: row nowrap;
  margin-top: 2em;
  gap: 24px;
  padding: 8px;
}
@media screen and (max-width: 520px) {
  .officialsearch .search_list ul {
    flex-wrap: wrap;
    gap: 16px;
  }
}
.officialsearch .search_list li {
  line-height: 64px;
  text-align: center;
  width: calc((100% - 72px) / 4);
}
.officialsearch .search_list li a {
  background-color: #163259;
  border-radius: 8px;
  color: #fff;
  display: block;
  font-size: 2rem;
}
.officialsearch .search_list li a:hover {
  background-color: #3c71bc;
  color: #fff;
}
@media screen and (max-width: 520px) {
  .officialsearch .search_list li {
    line-height: 48px;
    width: calc((100% - 16px) / 2);
  }
  .officialsearch .search_list li a {
    font-size: 3.846vw;
  }
}

.property_list {
  margin: 0 auto;
  padding: 80px 0 40px;
}
@media screen and (max-width: 768px) {
  .property_list {
    padding: 64px 0 32px;
  }
}
@media screen and (max-width: 520px) {
  .property_list {
    padding: 48px 0 24px;
  }
}
.property_list.bg {
  background-color: #d9dee6;
}
.property_list__inner {
  margin: auto;
  max-width: 1140px;
  width: 96%;
}
.property_list .hdg {
  color: #163259;
  font-size: 2.4rem;
  margin-bottom: 64px;
  text-align: center;
}
.property_list .hdg::after {
  background-color: #163259;
  content: "";
  display: block;
  height: 8px;
  margin: 1em auto 0;
  width: 3em;
}
@media screen and (max-width: 520px) {
  .property_list .hdg {
    font-size: 4.615vw;
    margin-bottom: 40px;
  }
}

.property {
  background: #fff;
  border-radius: 16px;
  box-shadow: 4px 4px 10px rgba(0, 0, 0, 0.3);
  margin-bottom: 80px;
  padding: 40px;
  scroll-margin-top: 40px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .property {
    margin-bottom: 64px;
    padding: 24px;
  }
}
@media screen and (max-width: 520px) {
  .property {
    margin-bottom: 48px;
  }
}
.property_inner {
  display: grid;
  grid-template-columns: 52.83% 43.39%;
  grid-template-rows: repeat(2, auto);
  grid-gap: 40px;
}
@media screen and (max-width: 768px) {
  .property_inner {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    grid-gap: 24px;
  }
}
.property figure {
  grid-area: 1/1/3/2;
}
@media screen and (max-width: 768px) {
  .property figure {
    grid-area: auto;
  }
}
.property_summary {
  grid-area: 1/2/1/2;
}
@media screen and (max-width: 768px) {
  .property_summary {
    grid-area: auto;
  }
}
.property_summary h3 {
  font-size: 2.4rem;
  margin-bottom: 16px;
}
@media screen and (max-width: 520px) {
  .property_summary h3 {
    font-size: 4.615vw;
  }
}
.property_summary .property_address {
  background-color: #978153;
  border-radius: 20px;
  color: #fff;
  line-height: 40px;
  padding: 0 1em;
  position: absolute;
  left: 40px;
  top: -20px;
}
@media screen and (max-width: 768px) {
  .property_summary .property_address {
    border-radius: 16px;
    line-height: 32px;
    top: -16px;
  }
}
.property_summary .property_point {
  color: #978153;
  font-weight: 700;
  line-height: 1.6;
}
.property_summary .property_lead {
  line-height: 1.6;
  margin-top: 0.75em;
}
.property_summary .property_access {
  line-height: 1.6;
  margin-top: 1.5em;
  padding-left: 1.5em;
  position: relative;
}
.property_summary .property_access::before {
  background: url(../images/ic_access.svg) no-repeat;
  background-size: contain;
  content: "";
  display: inline-block;
  height: 24px;
  margin-right: 8px;
  width: 17px;
  position: absolute;
  top: 0;
  left: 0;
}
.property .note {
  font-size: 1rem;
}
.property ul {
  grid-area: 2/2/3/3;
  align-content: end;
  display: flex;
  flex-flow: row wrap;
  gap: 8px;
}
@media screen and (max-width: 768px) {
  .property ul {
    grid-area: auto;
  }
}
.property li {
  text-align: center;
  width: calc((100% - 8px) / 2);
}
.property li.full {
  width: 100%;
}
.property li a {
  border-radius: 8px;
  color: #fff;
  display: block;
  line-height: 48px;
}
.property li.official a {
  background-color: #163259;
}
.property li.request a {
  background-color: #59162e;
}
.property li.reserve a {
  background-color: #978153;
}

.banner {
  margin: 0 auto 120px;
  max-width: 1140px;
  width: 96%;
}
@media screen and (max-width: 768px) {
  .banner {
    margin-bottom: 80px;
  }
}
@media screen and (max-width: 520px) {
  .banner {
    margin-bottom: 64px;
  }
}

.brand {
  background-color: #edeff2;
  padding: 80px 0;
}
@media screen and (max-width: 768px) {
  .brand {
    padding: 64px 0;
  }
}
@media screen and (max-width: 520px) {
  .brand {
    padding: 48px 0;
  }
}
.brand_inner {
  margin: auto;
  max-width: 1140px;
  width: 96%;
}
.brand h2 {
  font-size: 3.2rem;
  font-weight: normal;
  line-height: 1.8;
  text-align: center;
}
.brand h2 span {
  color: #7d7d7d;
  display: block;
  font-size: 2rem;
  font-family: "Cormorant Garamond", serif;
}
@media screen and (max-width: 991px) {
  .brand h2 {
    font-size: 4.166vw;
  }
  .brand h2 span {
    font-size: 2.604vw;
  }
}
@media screen and (max-width: 768px) {
  .brand h2 {
    font-size: 6.153vw;
  }
  .brand h2 span {
    font-size: 3.846vw;
  }
}
.brand h3 {
  color: #978153;
  font-size: 4rem;
  font-weight: 500;
  line-height: 1.6;
  margin: 40px 0;
  text-align: center;
}
@media screen and (max-width: 991px) {
  .brand h3 {
    font-size: 4.04vw;
  }
}
@media screen and (max-width: 768px) {
  .brand h3 {
    font-size: 5.208vw;
  }
}
.brand p {
  line-height: 2;
  margin-bottom: 3em;
  text-align: center;
}
.brand ul {
  display: flex;
  flex-flow: row nowrap;
  gap: 16px;
  justify-content: space-between;
}
@media screen and (max-width: 520px) {
  .brand ul {
    flex-flow: column wrap;
  }
}
@media screen and (max-width: 520px) {
  .brand li {
    margin: auto;
    max-width: 364px;
  }
}
.brand figcaption {
  font-size: 1.2rem;
  line-height: 1.4;
  margin-top: 8px;
  text-align: right;
}
.brand .btn_links {
  background-color: #978153;
  border-radius: 8px;
  color: #fff;
  display: block;
  font-size: 2rem;
  line-height: 64px;
  margin: 40px auto 0;
  max-width: 320px;
  text-align: center;
  width: 100%;
}
@media screen and (max-width: 768px) {
  .brand .btn_links {
    font-size: 1.6rem;
  }
}

.float-banner {
  position: fixed;
  bottom: 96px;
  left: 0;
  z-index: 9;
  transition: opacity 0.4s ease;
  opacity: 0;
  pointer-events: none;
}
.float-banner.is-visible {
  opacity: 1;
  pointer-events: all;
}
.float-banner .banner-space {
  max-width: 320px;
  position: relative;
}

.float-close {
  background-color: #444;
  width: 24px;
  height: 24px;
  display: block;
  position: absolute;
  left: 0;
  top: -24px;
  z-index: 800;
  cursor: pointer;
}
.float-close::before, .float-close::after {
  width: 16px;
  height: 1px;
  position: absolute;
  top: 50%;
  left: 50%;
  content: "";
  background: #fff;
}
.float-close::before {
  transform: translate(-50%, -50%) rotate(45deg);
}
.float-close::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

@media only screen and (max-width: 768px) {
  .float-banner {
    bottom: 0;
    right: 28px;
  }
}
@media only screen and (max-width: 520px) {
  .float-banner {
    right: 0;
  }
  .float-banner .banner-space {
    max-width: 240px;
  }
}/*# sourceMappingURL=style.css.map */