@charset "UTF-8";
/* Break point
---------------------------------------------------------- */
@import url("https://fonts.googleapis.com/css2?family=Marcellus&family=Noto+Sans+JP:wght@400;500;600&family=Sofia+Sans+Extra+Condensed&display=swap");
/* ==========================================================================//
//
//　変数
//
// ========================================================================== */
:root {
  /* Color
  ---------------------------------------------------------- */
  --color-font: #333333;
  --color-main: #005425;
  --color-sub: #812B1F;
  --color-back: #F6F5F4;
  --color-btn: #E9E9E9;
  --color-line: #D4D0CC;
  --color-font_gray: #8E8E8F;
  --color-link: #2C71D6;
  --color-visited:#17236E;
  /* Font
  ---------------------------------------------------------- */
  --font-jp: "Noto Sans JP", sans-serif;
  --font-en: "Marcellus", serif;
  --font-en2: "Sofia Sans Extra Condensed", sans-serif;
  --font-m: 500;
  --font-b: 700;
  --font11: 0.7rem;
  --font12: 0.79rem;
  --font13: 0.81rem;
  --font14: 0.88rem;
  --font16: 1rem;
  --font17: 1.06rem;
  --font18: 1.12rem;
  --font19: 1.19rem;
  --font20: 1.25rem;
  --font22: 1.42rem;
  --font25: 1.6rem;
  --font28: 1.8rem;
  --font30: 1.875rem;
  --font32: 2rem;
  --font35: 2.18rem;
  --font36: 2.28rem;
  --font41: 2.56rem;
  --font43: 2.68rem;
  --font44: 2.75rem;
  --font46: 2.88rem;
  --font48: 3rem;
  --font60: 3.75rem;
  /* Skew
  ---------------------------------------------------------- */
  --bezier: cubic-bezier(0.970, 0.000, 0.395, 0.995);
  /* Radius
  ---------------------------------------------------------- */
  --radius_s: 5px;
  --radius_m: 10px;
  --radius_l: 20px;
  /* Padding
  ---------------------------------------------------------- */
  --secPad: 80px;
  /* hight
  ---------------------------------------------------------- */
  --headerH: 60px;
  --translateH: 56px;
}

/* Placeholder
---------------------------------------------------------- */
/* ==========================================================================//
//
//　About
//
// ========================================================================== */
.p-about_sec_top .image_back {
  position: relative;
  height: 730px;
}
@media screen and (min-width: 768px) {
  .p-about_sec_top .image_back {
    height: 700px;
  }
}
.p-about_sec_top .image_back .image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.p-about_sec_top .image_back .image img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: bottom;
     object-position: bottom;
  width: 100%;
  height: 100%;
}
@media screen and (min-width: 1024px) {
  .p-about_sec_top .image_back .image.image01 img, .p-about_sec_top .image_back .image.image02 img {
    -o-object-position: 70%;
       object-position: 70%;
  }
}
@media screen and (min-width: 768px) {
  .p-about_sec_top .image_back .image.image03 img {
    -o-object-position: top;
       object-position: top;
  }
}
.p-about_sec_top .text {
  color: #fff;
  text-shadow: 0 0 2px rgba(0, 0, 0, 0.8);
  width: 90%;
  margin-right: auto;
  margin-left: auto;
  max-width: 620px;
}

.p-about_sec_identity .splide__arrow {
  --arrowW: 20px;
  width: var(--arrowW);
  height: auto;
  background: transparent !important;
  top: 32vw;
}
@media screen and (min-width: 768px) {
  .p-about_sec_identity .splide__arrow {
    --arrowW: 3vw;
    top: 17vw;
  }
}
.p-about_sec_identity .splide__arrow svg {
  width: var(--arrowW);
  height: var(--arrowW);
}
.p-about_sec_identity .splide__arrow.splide__arrow--prev {
  left: 2%;
}
@media screen and (min-width: 768px) {
  .p-about_sec_identity .splide__arrow.splide__arrow--prev {
    left: 25%;
  }
}
.p-about_sec_identity .splide__arrow.splide__arrow--next {
  right: 2%;
}
@media screen and (min-width: 768px) {
  .p-about_sec_identity .splide__arrow.splide__arrow--next {
    right: 25%;
  }
}
.p-about_sec_identity .splide__pagination {
  bottom: auto;
  top: 0;
}
.p-about_sec_identity .splide__pagination__page {
  opacity: 1;
  width: 6px;
  height: 6px;
  margin: 4px;
}
.p-about_sec_identity .splide__pagination__page.is-active {
  background-color: var(--color-main);
}
.p-about_sec_identity .splide__track {
  padding-top: 40px;
}
.p-about_sec_identity .splide__track .splide__list figure {
  max-width: 600px;
  margin: 0 auto;
}
.p-about_sec_identity .caption_slider h3 {
  padding: 0.8em 0 0.5em;
}
.p-about_sec_identity .caption_slider p {
  line-height: 2;
}

.p-about_sec_history {
  background-color: rgba(255, 255, 255, 0.7);
}
@media screen and (min-width: 768px) {
  .p-about_sec_history .block_history {
    display: grid;
    grid-template-columns: 45% 1fr;
    gap: 2.5em;
  }
}
.p-about_sec_history .block_mini {
  border-radius: var(--radius_l);
}
@media screen and (min-width: 768px) {
  .p-about_sec_history .block_mini {
    display: grid;
    grid-template-columns: 45% 1fr;
    gap: 2.5em;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    padding-left: 5vw;
    padding-right: 5vw;
  }
}
.p-about_sec_history .block_leaflet {
  border-radius: var(--radius_l);
}
@media screen and (min-width: 768px) {
  .p-about_sec_history .block_leaflet {
    padding-left: 5vw;
    padding-right: 5vw;
  }
}
@media screen and (min-width: 768px) {
  .p-about_sec_history .block_leaflet .content {
    display: grid;
    grid-template-columns: auto minmax(420px, 1fr);
    gap: 3em;
  }
}
.p-about_sec_history .block_leaflet .image_leaflet {
  border-radius: var(--radius_s);
  -webkit-box-shadow: 3px 3px 0 rgba(0, 0, 0, 0.16);
          box-shadow: 3px 3px 0 rgba(0, 0, 0, 0.16);
}
.p-about_sec_history .block_leaflet .list_btn {
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(100px, 230px);
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (min-width: 768px) {
  .p-about_sec_history .block_leaflet .list_btn {
    grid-template-columns: auto auto;
    -webkit-box-pack: stretch;
    -webkit-justify-content: stretch;
        -ms-flex-pack: stretch;
            justify-content: stretch;
  }
}
.p-about_sec_history .block_history_bottom {
  border-radius: 50px 50px 0 0;
}
@media screen and (min-width: 768px) {
  .p-about_sec_history .block_history_bottom .inner_history_bottom {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5em;
  }
}
.p-about_sec_history .block_history_bottom .content .list_data {
  display: grid;
  grid-template-columns: auto auto;
  gap: 0.5em 2em;
}

.p-about_image_back {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: -1;
}
.p-about_image_back img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

/* ==========================================================================//
//
//　Rental space
//
// ========================================================================== */
@media screen and (min-width: 768px) {
  .p-reserve_sec_nav .floors {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
  }
}

.p-reserve_icon_tel {
  display: inline-block;
  width: 1.5em;
  height: 1.5em;
  background-color: var(--color-main);
  border-radius: 50%;
  position: relative;
}
.p-reserve_icon_tel svg {
  fill: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

@media screen and (min-width: 768px) {
  .p-reserve_sec_floor .item_floor .block_image {
    display: grid;
    grid-template-columns: 55% 1fr;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 3em;
  }
}

.p-reserve_slider .splide__pagination {
  position: static;
  margin-top: 5px;
}
.p-reserve_slider .splide__arrow {
  background-color: #fff;
}
.p-reserve_slider .splide__arrow--next {
  right: 0.5em;
}
.p-reserve_slider .splide__arrow--prev {
  left: 0.5em;
}

/* ==========================================================================//
//
//　Information
//
// ========================================================================== */
.p-info_map {
  height: 400px;
}
@media screen and (min-width: 768px) {
  .p-info_map {
    height: 500px;
  }
}
.p-info_map iframe {
  width: 100%;
  height: 100%;
}

/* ==========================================================================//
//
//  Location
//
// ========================================================================== */
.p-location_window .block {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3vw;
}
.p-location_window .item_window {
  border-radius: 50vw 50vw 0 0;
  overflow: hidden;
}

.p-location_block_info {
  padding-left: 5vw;
  padding-right: 5vw;
  border-radius: var(--radius_l);
}

.p-location_list {
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 30px;
}
.p-location_list > li {
  overflow: hidden;
}
@media screen and (min-width: 1024px) {
  .p-location_list > li > a:hover .link-name {
    opacity: 0.8;
  }
  .p-location_list > li > a:hover .link-text {
    opacity: 1;
    visibility: visible;
    bottom: 0;
  }
  .p-location_list > li > a:focus .link-name {
    opacity: 0.8;
  }
  .p-location_list > li > a:focus .link-text {
    opacity: 1;
    visibility: visible;
    bottom: 0;
  }
}
.p-location_list .link-image {
  overflow: hidden;
}
.p-location_list .link-text {
  color: #fff;
  padding: 5px 10px;
  top: 5px;
  right: 5px;
  background-color: var(--color-main);
  border-radius: 4em;
  max-width: -webkit-max-content;
  max-width: -moz-max-content;
  max-width: max-content;
}
@media screen and (min-width: 1024px) {
  .p-location_list .link-text {
    padding: 10px;
    top: auto;
    right: 0;
    bottom: -1em;
    border-radius: 0 0 var(--radius_l) var(--radius_l);
    max-width: 100%;
    opacity: 0;
    visibility: hidden;
    -webkit-transition: opacity 0.2s, visibility 0.2s, bottom 0.2s;
    transition: opacity 0.2s, visibility 0.2s, bottom 0.2s;
  }
}
.p-location_list .link-text svg {
  fill: #fff;
}