@charset "UTF-8";
/*---------- ▼ cmn-logo ----------*/
.cmn-logo {
  transition: all 0.5s; }
  .cmn-logo:hover {
    opacity: 0.6; }

/*  ▼ cmn-title
------------------------------------- */
.cmn-title {
  width: 100%;
  text-align: center; }
  .cmn-title_ja {
    display: block;
    margin: 0 0 10px; }
  .cmn-title_en {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #41bdcd;
    font-style: italic;
    font-weight: 700;
    text-transform: uppercase; }
    .cmn-title_en::before, .cmn-title_en::after {
      content: '';
      width: 43px;
      height: 1px;
      background-color: #41bdcd; }
  @media screen and (min-width: 768px) {
    .cmn-title {
      margin: 0 0 40px; }
      .cmn-title_en {
        font-size: 1.4rem; } }
  @media screen and (max-width: 767px) {
    .cmn-title {
      margin: 0 0 30px; }
      .cmn-title_en {
        font-size: 1.2rem; } }

/*  ▼ cmn-subtitle
------------------------------------- */
.cmn-subtitle {
  width: 100%;
  color: #41bdcd;
  text-shadow: #fff 2px 0px, #fff -2px 0px,
 #fff 0px -2px, #fff 0px 2px,
 #fff 2px 2px , #fff -2px 2px,
 #fff 2px -2px, #fff -2px -2px,
 #fff 1px 2px,  #fff -1px 2px,
 #fff 1px -2px, #fff -1px -2px,
 #fff 2px 1px,  #fff -2px 1px,
 #fff 2px -1px, #fff -2px -1px;
  background: linear-gradient(to right, #fbeba0, #fbeba0) no-repeat center/calc(100% - 72px) 100%, linear-gradient(to bottom left, #fbeba0 50%, rgba(255, 255, 255, 0) 50%) no-repeat left/36px 100%, linear-gradient(to top right, #fbeba0 50%, rgba(255, 255, 255, 0) 50%) no-repeat right/36px 100%;
  position: relative; }
  .cmn-subtitle::before {
    content: '';
    width: 443px;
    height: 351px;
    margin: auto;
    background: url(../images/cmn-subtitle_shape.png) no-repeat center/contain;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0; }
  @media screen and (min-width: 768px) {
    .cmn-subtitle {
      margin: 0 0 140px;
      font-size: 3rem;
      padding: 25px 36px 26px 86px; }
      .cmn-subtitle_text:first-child {
        margin-right: auto; } }
  @media screen and (max-width: 767px) {
    .cmn-subtitle {
      justify-content: center;
      margin: 185.5px 0 30px;
      padding: 10px;
      background: linear-gradient(to right, #fbeba0, #fbeba0) no-repeat center/calc(100% - 28px) 100%, linear-gradient(to bottom left, #fbeba0 50%, rgba(255, 255, 255, 0) 50%) no-repeat left/14px 100%, linear-gradient(to top right, #fbeba0 50%, rgba(255, 255, 255, 0) 50%) no-repeat right/14px 100%; }
      .cmn-subtitle::before {
        width: 221.5px;
        height: 175.5px;
        top: -175.5px;
        bottom: auto; }
      .cmn-subtitle_text:first-child {
        margin-right: 10px; } }

/*  ▼ cmn-button
------------------------------------- */
.cmn-button {
  width: 175px;
  padding: 4px 0 6px;
  margin: 0 auto;
  color: #fff;
  text-align: center;
  border-radius: 30px;
  background-color: #7ccbd5; }
  .cmn-button:hover {
    background-color: #41bdcd; }

/*  ▼ content-box
------------------------------------- */
.content-box {
  width: 100%;
  font-weight: 400;
  font-family: "Noto Serif JP", serif;
  border-radius: 6px;
  border: 1px solid #41bdcd;
  background-color: #fff; }
  .content-box_price {
    align-items: center;
    justify-content: center;
    padding: 0 0 7px;
    font-weight: 400;
    font-family: "Noto Serif JP", serif;
    line-height: 1;
    color: #41bdcd;
    letter-spacing: 0;
    border-radius: 6px;
    background-color: #fbeba0;
    position: relative; }
    .content-box_price::after {
      content: '';
      width: 100%;
      height: 100%;
      border-radius: inherit;
      border: 1px solid #41bdcd;
      position: absolute;
      top: -4px;
      right: 4px;
      pointer-events: none; }
    .content-box_price_item {
      display: flex;
      flex-flow: row wrap;
      align-items: flex-end; }
      /* .content-box_price_item::after {
        flex: 1;
        align-self: center;
        content: '';
        width: 125px;
        height: 4px;
        margin: 0 10px;
        background: url(../images/border.png) repeat-x left/contain; } */
    .content-box_price_text {
      font-weight: 400; }
    .content-box_price_fot-small {
      letter-spacing: 0.12em; }
  .content-box_list {
    align-items: stretch;
    justify-content: center;
    text-align: center; }
    .content-box_list img {
      display: block; }
    .content-box_list-caption {
      display: inline;
      margin: 5px 0 0;
      line-height: 1.3;
      background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 50%, #fbeba0 50%) no-repeat center; }
  @media screen and (min-width: 768px) {
    .content-box {
      padding: 0 0 30px; }
      .content-box_price {
        width: 996px;
        margin: -31.5px auto 20px; }
        .content-box_price_item {
          font-size: 3.4rem;
          /* padding-left: 125px; */}
        .content-box_price_text {
          font-size: 5.6rem; }
        .content-box_price_fot-medium {
          font-size: 2.8rem; }
        .content-box_price_fot-small {
          font-size: 2.2rem; }
      .content-box_list-item {
        padding: 0 0 20px; }
        .content-box_list-item:not(:last-child) {
          padding-right: 20px;
          margin-right: 20px;
          border-right: 1px solid #41bdcd; }
      .content-box_list-caption {
        font-size: 2rem; } }
  @media screen and (max-width: 767px) {
    .content-box_price {
      flex-direction: column;
      width: 90%;
      padding: 4px 0 9px;
      margin: -29px auto 20px; }
      .content-box_price_item {
        font-size: 2.1rem; }
        .content-box_price_item::after {
          content: normal; }
      .content-box_price_text {
        font-size: 2.4rem; }
      .content-box_price_fot-medium {
        font-size: 1.8rem; }
      .content-box_price_fot-small {
        font-size: 1.4rem; }
    .content-box_list {
      padding: 0 20px 20px; }
      .content-box_list-item {
        width: 48%; }
        .content-box_list-item:nth-child(odd) {
          margin-right: 4%;
          position: relative; }
          .content-box_list-item:nth-child(odd)::before {
            content: '';
            width: 1px;
            height: 100%;
            margin: auto;
            border-right: 1px solid #41bdcd;
            position: absolute;
            top: 0;
            right: calc(-4% - 1px);
            bottom: 0; }
        .content-box_list-item:nth-child(even) {
          border-right: none; }
        .content-box_list-item:not(:nth-last-child(-n+2)) {
          margin-bottom: 30px;
          position: relative; }
          .content-box_list-item:not(:nth-last-child(-n+2))::after {
            content: '';
            width: 100%;
            height: 1px;
            border-top: 1px solid #41bdcd;
            position: absolute;
            bottom: -16px;
            left: 0; }
      .content-box_list img {
        margin: 0 auto 10px; }
      .content-box_list-caption {
        line-height: 1;
        font-size: 1.8rem; } }

/*  ▼ mail_button
------------------------------------- */
.mail_button,
.reservation_button{
  display: flex;
  align-items: center;
  justify-content: center;
  width: 190px;
  height: 42px;
  color: #fff;
  font-size: 1.8rem;
  text-align: center;
  border-radius: 30px;
  background-color: #7ccbd5; }
.mail_button:hover,
.reservation_button:hover {
    background-color: #41bdcd; }
  @media screen and (min-width: 768px) {
    .mail_button::before {
      content: url(../images/icon-mail.png);
      margin: 2px 16px 0 0; } }
  @media screen and (max-width: 767px) {
    .mail_button {
      padding-right: 10px;
      font-size: 1.5rem; }
      .mail_button::before {
        content: '\f0e0';
        margin: 3px 10px 0 0;
        font-weight: 900;
        font-family: "Font Awesome 5 Free"; } }

/*  ▼ cmn-tel
------------------------------------- */
.cmn-tel {
  display: flex;
  align-items: center;
  line-height: 1;
  letter-spacing: 0.1em; }
  .cmn-tel::before {
    margin-right: 5px; }
  @media screen and (min-width: 768px) {
    .cmn-tel {
      font-size: 2.6rem; }
      .cmn-tel::before {
        content: url(../images/icon-tel.png);
        margin-bottom: -2px; } }
  @media screen and (max-width: 767px) {
    .cmn-tel {
      font-size: 2.7rem; }
      .cmn-tel::before {
        content: '\f879';
        margin-top: 7px;
        font-size: 0.7em;
        font-weight: 900;
        font-family: "Font Awesome 5 Free"; } }

/*  ▼ modal
------------------------------------- */
.modal img {
  object-fit: cover; }

.modal-card {
  height: 100%;
  cursor: pointer;
  transition: all 0.5s; }
  .modal-card:hover {
    opacity: 0.7; }

.modal-content {
  display: none;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.8);
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000; }
  .modal-content_column {
    overflow-y: auto;
    background-color: #fff;
    margin: auto;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0; }
  .modal-content_fig {
    height: auto; }

@media screen and (min-width: 768px) {
  .modal-content_column {
    width: 1080px;
    height: 76vh;
    padding: 50px 150px; } }

@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop, .modal img {
    object-fit: none; } }

@media screen and (max-width: 767px) {
  .modal-content_column {
    width: 90%;
    height: 71vh;
    padding: 20px;
    margin: 0 auto;
    position: absolute;
    top: 50%;
    right: 0;
    left: 0;
    transform: translateY(-50%); } }

/*# sourceMappingURL=common.css.map */
