@charset "UTF-8";
/*============================================
responsive
============================================*/
.shoplist {
  padding: 90px 0; }
  @media screen and (max-width: 897px) {
    .shoplist {
      padding: 30px 0; } }
  .shoplist__headline h2 {
    margin: 0 0 60px 0;
    padding: 0 0 15px 0;
    position: relative;
    font-weight: 700;
    font-size: 1.5rem;
    text-align: center; }
    @media screen and (max-width: 897px) {
      .shoplist__headline h2 {
        font-size: 18px; } }
    .shoplist__headline h2::after {
      position: absolute;
      content: "";
      left: 50%;
      transform: translateX(-50%);
      bottom: 0;
      width: 100px;
      height: 3px;
      background: #B2393C; }
      @media screen and (max-width: 897px) {
        .shoplist__headline h2::after {
          left: 50%;
          transform: translateX(-50%);
          width: 60px; } }
  .shoplist__box {
    background: #fff;
    box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px; }
    .shoplist__box:not(:last-of-type) {
      margin: 0 0 60px 0; }
      @media screen and (max-width: 897px) {
        .shoplist__box:not(:last-of-type) {
          margin: 0 0 30px 0; } }
    .shoplist__box .inbox {
      display: flex;
      justify-content: space-between; }
      @media screen and (max-width: 897px) {
        .shoplist__box .inbox {
          display: block; } }
      .shoplist__box .inbox .img {
        width: 50%; }
        @media screen and (max-width: 897px) {
          .shoplist__box .inbox .img {
            width: 100%; } }
        .shoplist__box .inbox .img img {
          width: 100%;
          vertical-align: bottom; }
      .shoplist__box .inbox .txt {
        width: 50%;
        padding: 1.5% 2%; }
        @media screen and (max-width: 897px) {
          .shoplist__box .inbox .txt {
            width: 100%;
            padding: 4%; } }
        .shoplist__box .inbox .txt h3 {
          margin: 0;
          padding: 0 0 15px 0;
          position: relative;
          font-weight: 700;
          font-size: 1.5rem; }
          @media screen and (max-width: 897px) {
            .shoplist__box .inbox .txt h3 {
              text-align: center;
              font-size: 18px; } }
          .shoplist__box .inbox .txt h3::after {
            position: absolute;
            content: "";
            left: 0;
            bottom: 0;
            width: 100px;
            height: 3px;
            background: #B2393C; }
            @media screen and (max-width: 897px) {
              .shoplist__box .inbox .txt h3::after {
                left: 50%;
                transform: translateX(-50%);
                width: 60px; } }
        .shoplist__box .inbox .txt .shop-dl div {
          display: flex;
          justify-content: space-between;
          border-bottom: 1px dotted #ccc;
          padding: 0 0 10px 0;
          margin: 0 0 10px 0; }
          @media screen and (max-width: 897px) {
            .shoplist__box .inbox .txt .shop-dl div {
              font-size: 14px; } }
          .shoplist__box .inbox .txt .shop-dl div dt {
            width: 20%;
            padding: 0;
            margin: 0; }
          .shoplist__box .inbox .txt .shop-dl div dd {
            width: 80%;
            padding: 0;
            margin: 0; }
        .shoplist__box .inbox .txt .btn-details {
          display: flex;
          justify-content: space-between; }
          @media screen and (max-width: 897px) {
            .shoplist__box .inbox .txt .btn-details {
              flex-wrap: wrap; } }
          .shoplist__box .inbox .txt .btn-details .details {
            width: 32%;
            text-align: center; }
            @media screen and (max-width: 897px) {
              .shoplist__box .inbox .txt .btn-details .details {
                width: 100%;
                margin: 10px 0 0 0; } }
            .shoplist__box .inbox .txt .btn-details .details a {
              background: #93181B;
              display: block;
              padding: 3% 1.5%;
              color: #fff;
              text-decoration: none;
              border-radius: 5px;
              font-size: 14px;
              position: relative; }
              @media screen and (max-width: 897px) {
                .shoplist__box .inbox .txt .btn-details .details a {
                  padding: 15px 1.5%; } }
              .shoplist__box .inbox .txt .btn-details .details a::after {
                content: '';
                border: 0;
                border-top: solid 2px #fff;
                border-right: solid 2px #fff;
                display: inline-block;
                width: 6px;
                height: 6px;
                position: absolute;
                top: 50%;
                right: 8px;
                transform: translateY(-50%) rotate(45deg); }
          .shoplist__box .inbox .txt .btn-details .reserve {
            width: 32%;
            text-align: center; }
            @media screen and (max-width: 897px) {
              .shoplist__box .inbox .txt .btn-details .reserve {
                width: 48%; } }
            .shoplist__box .inbox .txt .btn-details .reserve a {
              font-size: 14px;
              background: #222;
              display: block;
              padding: 3% 1.5%;
              color: #fff;
              text-decoration: none;
              border-radius: 5px;
              position: relative; }
              @media screen and (max-width: 897px) {
                .shoplist__box .inbox .txt .btn-details .reserve a {
                  padding: 15px 1.5%; } }
              .shoplist__box .inbox .txt .btn-details .reserve a::after {
                content: '';
                border: 0;
                border-top: solid 2px #fff;
                border-right: solid 2px #fff;
                display: inline-block;
                width: 6px;
                height: 6px;
                position: absolute;
                top: 50%;
                right: 8px;
                transform: translateY(-50%) rotate(45deg); }

.shopdetails {
  padding: 90px 0; }
  @media screen and (max-width: 897px) {
    .shopdetails {
      padding: 30px 0; } }
  .shopdetails__headline h2 {
    margin: 0 0 30px 0;
    padding: 0 0 15px 0;
    position: relative;
    font-weight: 700;
    font-size: 1.5rem;
    text-align: center; }
    @media screen and (max-width: 897px) {
      .shopdetails__headline h2 {
        font-size: 18px; } }
    .shopdetails__headline h2::after {
      position: absolute;
      content: "";
      left: 50%;
      transform: translateX(-50%);
      bottom: 0;
      width: 100px;
      height: 3px;
      background: #B2393C; }
      @media screen and (max-width: 897px) {
        .shopdetails__headline h2::after {
          left: 50%;
          transform: translateX(-50%);
          width: 60px; } }
  .shopdetails__img {
    position: relative;
    z-index: 5; }
    .shopdetails__img img {
      vertical-align: bottom; }
  .shopdetails__box {
    position: relative;
    z-index: 10;
    max-width: 1040px;
    margin: -60px auto 60px auto;
    background: #fff;
    box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
    padding: 1.5%;
    display: flex; }
    @media screen and (max-width: 897px) {
      .shopdetails__box {
        margin: 0 0 20px 0;
        display: block;
        padding: 0;
        background: #fff;
        box-shadow: none; } }
    .shopdetails__box .txt {
      width: 50%;
      padding: 0 3% 0 0; }
      @media screen and (max-width: 897px) {
        .shopdetails__box .txt {
          width: 100%;
          font-size: 14px;
          padding: 0; } }
      .shopdetails__box .txt dl div {
        display: flex;
        justify-content: space-between;
        border-bottom: 1px dotted #ccc;
        padding: 0 0 6px 0;
        margin: 0 0 6px 0; }
        .shopdetails__box .txt dl div dt {
          padding: 0;
          margin: 0;
          width: 18%; }
        .shopdetails__box .txt dl div dd {
          padding: 0;
          margin: 0;
          width: 82%; }
      .shopdetails__box .txt p {
        margin: 0;
        padding: 3px;
        border: 1px solid #e4e4e4;
        font-size: 14px;
        background: #f7f7f7; }
    .shopdetails__box .map {
      width: 50%; }
      @media screen and (max-width: 897px) {
        .shopdetails__box .map {
          width: 100%; } }
      .shopdetails__box .map .gmap {
        height: 0;
        overflow: hidden;
        padding-bottom: 56.25%;
        position: relative; }
      .shopdetails__box .map .gmap iframe {
        position: absolute;
        left: 0;
        top: 0;
        height: 100%;
        width: 100%; }
      .shopdetails__box .map p {
        margin: 0;
        padding: 10px 0 0 0;
        text-align: center;
        font-size: 14px; }
  .shopdetails__btn ul {
    margin: 0;
    display: flex;
    justify-content: space-between; }
    @media screen and (max-width: 897px) {
      .shopdetails__btn ul {
        display: block; } }
    .shopdetails__btn ul li {
      list-style-type: none;
      padding: 0;
      margin: 0;
      width: 48%; }
      @media screen and (max-width: 897px) {
        .shopdetails__btn ul li {
          width: 100%; } }
      .shopdetails__btn ul li img {
        width: 100%; }
      @media screen and (max-width: 897px) {
        .shopdetails__btn ul li:last-of-type {
          margin: 15px 0 0 0; } }

.facilitylist {
  padding: 90px 0;
  max-width: 1080px;
  margin: auto; }
  @media screen and (max-width: 897px) {
    .facilitylist {
      padding: 30px 20px; } }
  .facilitylist__headline h2 {
    margin: 0 0 30px 0;
    padding: 0 0 15px 0;
    position: relative;
    font-weight: 700;
    font-size: 1.5rem;
    text-align: center; }
    @media screen and (max-width: 897px) {
      .facilitylist__headline h2 {
        font-size: 18px; } }
    .facilitylist__headline h2::after {
      position: absolute;
      content: "";
      left: 50%;
      transform: translateX(-50%);
      bottom: 0;
      width: 100px;
      height: 3px;
      background: #B2393C; }
      @media screen and (max-width: 897px) {
        .facilitylist__headline h2::after {
          left: 50%;
          transform: translateX(-50%);
          width: 60px; } }
  .facilitylist__box {
    display: flex;
    justify-content: space-between; }
    @media screen and (max-width: 897px) {
      .facilitylist__box {
        display: block; } }
    .facilitylist__box__item {
      box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
      background: #fff;
      width: 48%; }
      @media screen and (max-width: 897px) {
        .facilitylist__box__item {
          width: 100%; } }
      .facilitylist__box__item .img img {
        vertical-align: bottom; }
      .facilitylist__box__item .txt {
        text-align: center; }
        .facilitylist__box__item .txt h3 {
          font-weight: 700;
          position: relative; }
          .facilitylist__box__item .txt h3::after {
            content: '';
            border: 0;
            border-top: solid 2px #222;
            border-right: solid 2px #222;
            display: inline-block;
            width: 10px;
            height: 10px;
            position: absolute;
            top: 50%;
            right: 20px;
            transform: translateY(-50%) rotate(45deg); }
      .facilitylist__box__item a {
        text-decoration: none; }
      @media screen and (max-width: 897px) {
        .facilitylist__box__item:last-of-type {
          margin: 20px 0 0 0; } }

/***************************************/
/* 2023.05.11 layout change　*/
/***************************************/
.shopdetails__headline h2 {
  font-family: source-han-sans-japanese, sans-serif;
  font-weight: 900;
  font-style: normal;
  color: #191919;
  margin-bottom: 60px;
  letter-spacing: 0.05em; }
  @media screen and (min-width: 800px) {
    .shopdetails__headline h2 {
      font-size: 2.7rem; } }
  .shopdetails__headline h2::after {
    width: 40px; }
