@charset "utf-8";
:root{
  --size-btn-slidearrow: clamp(1.875rem, -0.625rem + 6.67vw, 2.5rem);
}

@media (1024px < width) {
  :root{
    --size-btn-slidearrow: 30px;
  }
}

h4{
  font-weight: var(--font-semibold);
  letter-spacing: .1em;
  margin: 0 0 10px;
  font-size: clamp(1.188rem, 0.688rem + 2vw, 1.625rem);
  line-height: 1.8;
  /*
  position: relative;
  padding: 0 0 30px;
  margin: 0 0 30px;*/
}
/*
h4::after{
  content: "";
  width: 60px;
  height: 3px;
  position: absolute;
  bottom: 0;
  left: 0;
  background-color: var(--color-primary);
}*/

@media (1024px < width) {
  h4{
    font-size: clamp(1.125rem, 0.393rem + 1.14vw, 1.25rem);
    line-height: 1.9;
  }
}

.facility_contents{
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
}

.facility_lists{
  margin: 0 0 min(20.666vw, 155px);
  justify-content: space-between;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(105px, 1fr));
  gap: 30px 10px;
}

.facility_lists a{
    aspect-ratio: 1 / 1;
    display: flex;
    flex-direction: column;
    background-color: #F8F8F7;
    border: 1px solid var(--color-primary);
    transition: opacity var(--hover-animation);
    padding: 0 5px;
}

.facility_lists a:hover{
  opacity: var(--hover-opacity);
}

.icon_cat_img{
  flex-grow: 1;
  display: grid;
  place-content: center;
  padding: 14px 0 0;
  height: 50px;
}

.icon_cat_img svg{
  width: 47%;
  margin: 0 auto;
}

.facility_lists a[href$="#hours"] svg{
  width: 40%;
}

.facility_lists a[href$="#service"] svg{
  width: 30%;
}

.facility_lists a[href$="#information"] svg{
  width: 45%;
}

.facility_lists a[href$="/access/"] svg{
  width: 55%;
}

.facility_lists a[href$="#parking"] svg{
  width: 50%;
}

.facility_lists a[href$="#kids"] svg{
  width: 40%;
}

.facility_lists a[href$="#barrierfree"] svg{
  width: 35%;
}

.facility_lists a[href$="#cash"] svg{
  width: 36%;
}

.facility_lists a[href$="#okeihanpoint"] svg{
  width: 45%;
}

.facility_lists a[href*="recruit"] svg{
  width: 58%;
}

.facility_lists a[href$="#ekenet"] svg{
  width: 49%;
}

.btn_sort_text{
  text-align: center;
  align-self: center;
  display: grid;
  place-content: center;
  line-height: 1.2;
  font-size: clamp(0.813rem, 0.612rem + 0.8vw, 1.125rem);
  letter-spacing: .025em;
  font-weight: var(--font-semibold);
  height: 50px;
}

.section_contents{
  margin: 0 0 min(25vw, 150px);
}

.section_contents h3{
  font-weight: var(--font-semibold);
  letter-spacing: .1em;
  line-height: 1.64;
  position: relative;
  padding: 0 0 30px;
  margin: 0 0 30px;
  font-size: clamp(1.375rem, 0.518rem + 3.43vw, 2.125rem);
}

.section_contents h3::after{
  content: "";
  width: 60px;
  height: 3px;
  position: absolute;
  bottom: 0;
  left: 0;
  background-color: var(--color-border-title);
}

.hours_lists{
  font-weight: var(--font-semibold);
  display: grid;
  grid-template-columns: max-content auto;
  gap: 20px min(10vw, 75px);
  margin: 0 0 40px;
  line-height: 2;
}

.hours_lists dt{
  font-size: clamp(1rem, 0.429rem + 2.29vw, 1.5rem);
}

.hours_lists dd{
  font-size: clamp(0.875rem, 0.304rem + 2.29vw, 1.375rem);
}

.hours_notes{
  font-weight: var(--font-semibold);
  font-size: clamp(0.875rem, 0.83rem + 0.23vw, 1rem);
  text-indent: -1em;
  padding-left: 1em;
}

.hours_notes small{
  font-size: inherit;
}

.hours_notes small::before{
  content: "※";
  margin: 0 .2em 0 0;
}

.hours_notes a, .facility_box a{
  display: inline;
}

.hours_notes a, .facility_box a:not([href*="tel:"]){
  text-decoration: underline;
}

.service_lists{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
  justify-content: space-between;
  gap: min(8vw, 60px) 0;
  margin: 0 0 40px;
}

.service_lists figure{
  display: grid;
  grid-auto-flow: row;
  grid-template-rows: auto 1fr;
  justify-items: center;
  padding: 0 5px;
}

.service_lists img{
  width: 60px;
  height: 60px;
  margin: 0 0 20px 0;
}

.service_lists figcaption{
  text-align: center;
  font-size: clamp(0.75rem, 0.393rem + 1.43vw, 1.063rem);
  font-weight: var(--font-semibold);
  align-self: center;
}

.service_container{
  margin: min(10vw, 60px) 0 0;
}

.aed_container{
  margin: 40px 0 0;
}

.service_container .facility_box:not(:last-of-type){
  margin: 0 0 min(13.333vw, 80px);
}

.caution_lists, .okeihan_excluded{
  font-weight: var(--font-semibold);
  font-size: clamp(0.875rem, 0.589rem + 1.14vw, 1.125rem);
}

.caution_lists li{
  text-indent: calc((1em + .5rem) * -1);
  padding-left: calc(1em + .5rem);
}

.caution_lists li:not(:last-of-type){
  margin: 0 0 .5rem;
}

.caution_lists li::before{
  content: "※";
  margin: 0 .5rem 0 0;
}

.facility_text_lists li{
  text-indent: -1em;
  padding-left: 1em;
}

.facility_text_lists li:not(:last-of-type){
  margin: 0 0 .25rem;
}

.facility_text_lists li::before{
  content: "・";
  margin: 0 .5rem 0 0;
}

.font-smaller{
  font-size: 80%;
}

.payment_container{
  margin: 0 0 min(10.666vw, 80px);
  font-weight: var(--font-semibold);
}

.okeihan_container{
  font-weight: var(--font-semibold);
}

.okeihan_container:not(:last-child){
  margin: 0 0 60px;
}

.cash_card_lists{
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 0 0 40px;
}

.cash_card_lists:last-child{
  justify-content: center;
  margin: 0 0 60px;
}

.touchkessai_lists{
  display: flex;
  border: 2px solid var(--color-primary);
  border-radius: 10px;
  padding: 20px 0;
  margin: 0 0 0 40px;
}

.touchkessai_lists li:first-of-type{
  border-right: 2px solid var(--color-primary);
}

.cash_code_lists{
  display: flex;
  justify-content: center;
  margin: 0 0 40px;
}

.cash_code_lists li{
  width: 25%;
}

.cash_code_lists img{
  width: 85%;
  margin: 0 auto;
}

.payment_container p, .ekenet_text{
  font-size: clamp(1rem, 0.857rem + 0.57vw, 1.125rem);
}

.payment_container p, .ekenet_text, .okeihan_container p{
  line-height: 1.8;
}

.payment_container p, .okeihan_container p{
  margin: 0 0 20px;
}

.lost_text h5{
  font-weight: var(--font-semibold);
  letter-spacing: .1em;
  font-size: clamp(1.25rem, 0.964rem + 1.14vw, 1.5rem);
  line-height: 1.8;
  position: relative;
  padding: 0 0 20px;
  margin: 0 0 20px;
}

.lost_text h5::after, .okeihan_title::after{
  content: "";
  width: 60px;
  height: 3px;
  position: absolute;
  bottom: 0;
  left: 0;
  background-color: var(--color-primary);
}

.lost_text p{
  font-size: clamp(1rem, 0.643rem + 1.43vw, 1.313rem);
}

.ekenet_container{
  font-weight: var(--font-semibold);
}

.ekenet_text{
  margin: 0 0 min(6.666vw, 40px);
}

.ekenetcard_contents{
  display: grid;
  justify-content: space-between;
  gap: 30px;
}

.ekenetcard_contents figure{
  display: grid;
  grid-template-columns: 30% auto;
  grid-template-rows: auto 1fr;
  gap: 5px 14px;
}

.ekenetcard_contents figcaption{
  font-size: clamp(1rem, 0.929rem + 0.29vw, 1.063rem);
  grid-column: 2 / 3;
  grid-row: 1 / 2;
}

.ekenetcard_contents img{
  grid-column: 1 / 2;
  grid-row: 1 / 3;
}

.ekenetcard_contents p{
  font-size: clamp(0.875rem, 0.732rem + 0.57vw, 1rem);
  grid-column: 2 / 3;
  grid-row: 2 / 3;
}

.okeihan_box{
  display: flex;
  align-items: center;
}

.okeihan_box, .okeihan_text_contents{
  margin: 0 0 40px;
}

.okeihan_box img{
  margin: 0 30px 0 0;
  width: 80px;
  height: 80px;
}

.okeihan_box p{
  margin: 0;
  font-size: clamp(1.125rem, 0.839rem + 1.14vw, 1.375rem);
}

.okeihan_box p, .okeihan_text_contents p{
  line-height: 1.8;
}

.okeihan_text_contents p{
  display: grid;
  grid-auto-flow: column;
  grid-template-columns: 1rem auto;
  gap: 0 14px;
  font-size: clamp(1rem, 0.857rem + 0.57vw, 1.125rem);
}

.okeihan_text_contents p:not(:last-of-type){
  margin: 0 0 30px;
}

.okeihan_text_contents p::before{
  content: "・";
  display: inline-block;
  text-align: center;
}

.okeihan_title{
  position: relative;
  padding: 0 0 20px;
  margin: 0 0 20px;
}

.okeihan_container .okeihan_excluded{
  font-size: clamp(0.875rem, 0.589rem + 1.14vw, 1.125rem);
  margin: min(6.666vw, 40px) 0 min(8vw, 60px);
}

.text_lists{
  font-size: clamp(0.875rem, 0.661rem + 0.86vw, 1.063rem);
}

.text_lists li{
  text-indent: -1em;
  padding-left: 1em;
}

.text_lists li:not(:last-of-type){
  margin: 0 0 16px 0;
}

.text_lists li::before{
  content: "・";
  margin: 0 .5rem 0 0;
}

.color_orange{
  color: var(--color-orange);
}

.facility_box{
  font-weight: var(--font-semibold);
}

.facility_box .btn_primary a{
  display: grid;
  text-decoration: none;
}

.facility_flexbox{
  display: grid;
  gap: min(7.5vw, 30px) 0;
}

.slide_facility .splide__pagination{
  position: static;
  height: var(--size-btn-slidearrow);
}

.slide_facility .splide__pagination__page{
  background: var(--color-border);
}

.slide_facility .splide__pagination__page.is-active{
  background: var(--color-orange);
  transform: scale(1);
}

.slide_facility .slide_arrow{
  width: var(--size-btn-slidearrow);
  height: var(--size-btn-slidearrow);
  background-color: rgb(128 120 120 / 100%);
  border-radius: 0;
  transition: opacity var(--hover-animation);
  opacity: 100%;
  top: auto;
  transform: none;
  bottom: 0;
}

.slide_facility .slide_arrow svg{
  fill: none;
  stroke: #fff;
  width: 52%;
  height: 52%;
}

.slide_facility .slide_arrow_prev{
  left: auto;
  right: var(--size-btn-slidearrow);
}

.slide_facility .slide_arrow_next{
  right: 0;
}

.facility_text_detail{
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  padding: 18px 0;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px 50px;
  letter-spacing: .025em;
  margin: 0 0 min(6vw, 24px);
}

.facility_text_detail dt, .facility_text_detail dd{
  font-size: clamp(1rem, 0.571rem + 1.71vw, 1.375rem);
}

.facility_box_text p{
  font-size: clamp(1rem, 0.643rem + 1.43vw, 1.313rem);
}

.ekentet_container{
  padding: 0;
}

.ekentet_container .facility_contents{
  padding: 0 calc(var(--space-side) + var(--space-inner-side));
  max-width: calc(900px + (calc(var(--space-side) + var(--space-inner-side)) * 2));
}

.ekenet_contents{
  margin: 0 0 min(20vw, 80px);
}

.facility_contents--service{
  background-color: #F8F8F7;
  padding: min(8vw, 60px) calc(var(--space-side) + var(--space-inner-side));
  margin-bottom: min(13.333vw, 100px);
}

.facility_contents--service .section_contents{
  max-width: 900px;
  margin: 0 auto;
}

.ekenet_lead-text{
  text-align: center;
  font-size: clamp(1.25rem, 0.964rem + 1.14vw, 1.5rem);
  font-weight: var(--font-semibold);
  line-height: 1.6;
  letter-spacing: .1em;
}

.list_ekenetcard{
  display: grid;
  margin: 0 0 40px;
  gap: 40px 0;
}

.list_ekenetcard figure{
  display: grid;
  grid-template-columns: 30% auto;
  grid-template-rows: auto 1fr;
  gap: 0 20px;
}

.list_ekenetcard figcaption, .list_ekenetcard p{
  grid-column: 2 / 3;
  line-height: 1.5;
}

.list_ekenetcard figcaption{
  font-size: 1rem;
  grid-row: 1 / 2;
  margin-bottom: 10px;
}

.list_ekenetcard img{
  grid-column: 1 / 2;
  grid-row: 1 / 3;
  margin: 0 auto;
  width: 100%;
  max-width: 150px;
  align-self: center;
}

.list_ekenetcard p{
  grid-row: 2 / 3;
  font-size: .875rem;
  margin: 0;
}

.cardservice_container .btn_secondary{
  background-color: #fff;
}

.title_cardservice{
  font-size: clamp(1.125rem, 0.696rem + 1.71vw, 1.5rem);
  margin: 0 0 10px;
}

.title_cardservice:not(:first-of-type){
  margin: min(10vw, 40px) 0 10px;
}

.title_cardservice::before{
  width: 24px;
  height: 24px;
  display: inline-block;
  background-color: var(--color-base);
  color: #fff;
  text-align: center;
  font-size: clamp(1.125rem, 0.696rem + 1.71vw, 1.5rem);
  font-family: var(--font-en);
  line-height: 20px;
  margin-right: 6px;
}

.title_cardservice:nth-of-type(1)::before{
  content: "1";
}

.title_cardservice:nth-of-type(2)::before{
  content: "2";
}

.title_cardservice:nth-of-type(3)::before{
  content: "3";
}

.text_cardservice{
  font-weight: var(--font-semibold);
  font-size: clamp(0.875rem, 0.589rem + 1.14vw, 1.125rem);
  line-height: 1.6;
}

.text_cardservice:nth-of-type(2){
  margin-bottom: 10px;
}

.text_cardservice:last-of-type{
  margin-bottom: min(8vw, 60px);
}

.okeihanstation_container p{
  font-weight: var(--font-semibold);
  font-size: 1rem;
  line-height: 1.6;
  margin: 0 0 20px;
}

.okeihanstation_container p{
  margin: 0 0 min(8vw, 60px);
}


@media (400px <= width) {
  .icon_cat_img{
      height: auto;
  }

  .service_lists{
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  }
}

@media (509px < width) {
  .facility_lists{
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  }
}

@media (600px <= width) {
  .icon_cat_img{
      padding: 10px 0 0;
  }

  .facility_lists{
    grid-template-columns: repeat(auto-fill, minmax(165px, 1fr));
    gap: 40px 5.333vw;
  }

  .facility_lists .btn_sort_text{
      margin: 0 0 5px;
  }

  .section_contents h3{
    padding: 0 0 40px;
    margin: 0 0 40px;
  }

  .section_contents h3::after{
    width: 90px;
  }

  .service_lists{
    grid-template-columns: repeat(auto-fit, minmax(165px, 1fr));
  }

  .service_lists img{
    width: 80px;
    height: 80px;
  }

  .ekenetcard_contents{
    grid-auto-flow: column;
    grid-template-columns: repeat(3, 1fr);
    text-align: center;
    gap: min(5.333vw, 40px);
  }

  .ekenetcard_contents figure{
    display: block;
  }

  .ekenetcard_contents img{
    margin: 5px auto 10px;
  }

  .ekenetcard_contents p{
    text-align: center;
  }

  .okeihan_box img{
    width: 0 40px 0 0;
    width: auto;
    height: auto;
  }
}


@media (1024px < width) {
  .facility_lists{
      margin: 0 0 80px;
      grid-template-columns: repeat(auto-fill, minmax(165px, 1fr));
      gap: 40px 18px;
  }
  
  .icon_cat_img svg{
      width: 38%;
  }

  .facility_lists a[href$="#information"] svg{
      width: 45%;
  }

  .facility_lists a[href$="recruit.html"] svg{
      width: 52%;
  }

  .facility_lists a[href$="#kids"] svg{
      width: 38%;
  }

  .facility_lists .btn_sort_text{
      font-size: .938rem;
  }

  .section_contents{
    margin: 0 0 120px;
  }
  
  .section_contents h3{
    font-size: clamp(1.375rem, 0.643rem + 1.14vw, 1.5rem);
    line-height: 1.8;
    padding: 0 0 30px;
    margin: 0 0 30px;
  }

  .section_contents h3::after{
    width: 60px;
  }

  .hours_lists{
    gap: 24px 108px;
  }

  .hours_lists dt{
    font-size: 1.063rem;
  }
  
  .hours_lists dd{
    font-size: 1rem;
  }

  .service_container .facility_box:not(:last-of-type){
    margin: 0 0 60px;
  }

  .facility_flexbox{
    gap: 0 30px;
    grid-template-columns: 1fr 1fr;
    /*grid-auto-flow: column;*/
  }

  .facility_box_text{
    padding: 0 0 0 30px;
  }

  .facility_box_text p{
    font-size: 1rem;
  }

  .cash_code_lists li{
    margin-right: 60px;
    width: auto;
  }
  
  .cash_code_lists li:nth-of-type(4n), .cash_code_lists li:last-of-type{
    margin-right: 0;
  }

  .cash_code_lists img{
    width: 100%;
  }

  .service_lists figure{
    padding: 0;
  }

  .service_lists figcaption{
    font-size: .938rem;
  }

  .facility_text_detail dt{
    font-size: 1.063rem;
  }
  
  .facility_text_detail dd{
    font-size: 1rem;
  }

  .lost_text{
    margin: min(6.666vw, 40px) 0 0;
  }

  .lost_text h5{
    font-size: 1.188rem;
    line-height: 1.9;
  }

  .text_lists, .lost_text p, .caution_lists, .okeihan_container .okeihan_excluded{
    font-size: 1rem;
  }

  .ekenetcard_contents{
    gap: 60px;
  }

  .okeihan_box p{
    font-size: 1.25rem;
  }
  
  .okeihan_text_contents p{
    font-size: 1.063rem;
  }

  .ekenet_lead-text{
    font-size: 1.625rem;
  }

  .ekenet_contents{
    margin: 0 0 90px;
  }

  .list_ekenetcard{
    grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
    text-align: center;
    gap: 10px;
  }
  
  .list_ekenetcard figure{
    display: grid;
    grid-template-rows: subgrid;
    grid-row: span 3;
    gap: 0;
    grid-template-columns: none;
  }

  .list_ekenetcard figcaption, .list_ekenetcard p, .list_ekenetcard img{
    grid-column: auto;
    grid-row: auto;
  }
  
  .list_ekenetcard figcaption{
    font-size: 1rem;
    margin-bottom: 0;
  }
  
  .list_ekenetcard img{
    margin: 0 auto;
    width: 80%;
    align-self: center;
  }
  
  .list_ekenetcard p{
    text-align: center;
    font-size: .875rem;
    margin: 0;
  }

  .title_cardservice{
    font-size: 1.188rem;
  }

  .title_cardservice:not(:first-of-type){
    margin: 40px 0 10px;
  }

  .title_cardservice::before{
    width: 30px;
    height: 30px;
    font-size: 1.063rem;
    line-height: 30px;
    margin-right: 16px;
  }

  .text_cardservice{
    font-size: 1rem;
  }

  .text_cardservice:last-of-type{
    margin-bottom: 60px;
  }
}

@media (1085px < width) {
    .facility_lists .btn_sort_text{
        height: 40px;
        margin: 0 0 15px;
    }
}