
:root{
  --brown:#F5F2EB;
  --dbrown:#745844;
}
.f_bold{
  font-weight: bold;
}
.f_brown{
  color:var(--brown);
}
.f_dbrown{
  color:var(--dbrown);
}
.bg_brown{
  background:var(--brown);
}
.bg_dbrown{
  background:var(--dbrown);
}
.t_center{
  text-align: center;
}
section.bg_brown{

}
.bg_brown_img{
  /* background:var(--brown);
  background-image:url(/common/img/facilities/yaotome/bg_sec.png);
  background-size: cover;*/
} 
main{
  font-family: "Noto Serif JP";
}
main p{
  margin-block-start: 0em;
    margin-block-end: 0em;
}

main #asahikawa_wrap{
  line-height: 1.6;
  overflow-x: hidden;
}
#asahikawa_wrap .sec_inner{
  max-width:1240px;
  margin: auto;
  font-size: 20px;
}
.mimamorisys_wrap img {
  height: auto;
}
.fl{
	flex-wrap: nowrap;
}
#page_title{
  display: none;
}
.yoa_sec{
  padding:160px 0 100px;
}
.yao_sec_ttl{
  width:fit-content;
  margin:auto;
  margin-bottom:60px;
  font-size: 40px;
  color: var(--dbrown);border-bottom: solid 1px var(--dbrown);
  font-weight: bold;
}
.yao_sec_ttl_02{
  font-size: 26px;
  margin-bottom:35px;
  padding-left:20px;
  position: relative;
  &:before{
    position: absolute;
    content:"";
    top:3px;
    left:0;
    background:var(--dbrown); 
    height: 100%;
    width:5px;
  }
}
.ttl_belt{
  color:#fff;
  font-size: 28px;
  padding:10px 5px;
  padding-right:50px;
  max-width: fit-content;
  margin-bottom:40px;
  background: linear-gradient(270deg, rgba(116, 88, 68, 0.00) 0%, rgba(116, 88, 68, 0.60) 12%, rgba(116, 88, 68, 0.90) 100%);
}
.ico_point{
  position: relative;
}
.ico_point::before{
  content:"";
  position: absolute;
    top: -55px;
    left: -90px;
  width: 120px;
  height: 70px;
}
.txt_asta{
  position: relative;
  font-size: 12px;
  padding-left:15px;
  &:before{
    content:'※';
    position: absolute;
    left:0;
    top:0;
  }
}
@media (max-width: 1024px){
  #asahikawa_wrap .sec_inner{
    font-size: 16px;
  }
  .yoa_sec{
   padding:90px 0 60px;
  }
  .sec_inner{
    padding:0 20px;
  }
  .yao_sec_ttl{
    margin-bottom:30px;
    font-size: 24px;
    border-bottom: solid 2px var(--dbrown);
    width:100%;
    text-align: center;
  }
  .ico_point::before {
    top: -38px;
    left: 0px;
    width: 67px;
    height: 40px;
  }
  .yao_sec_ttl_02{
    font-size: 19px;
    margin-bottom:20px;
    padding-left:15px;
    &:before {
      top: 0;
      bottom: 0;
      left: 0;
      height: 75%;
      margin: auto;
    }
  }
  .ttl_belt {
    color: #fff;
    padding: 5px 5px;
    padding-right:10px;
    font-size: 20px;
    margin-bottom:20px;
  }

}
@media (min-width: 1025px) and (max-width: 1349px) {

}



/* ttl_asahikawa */
#ttl_asahikawa{
  position: relative;
  padding:20px 40px;
  max-width: 1240px;
  width:100%;
  margin: auto;
  font-family: "Noto Serif JP";
  height: 280px;
  margin-bottom:50px;
  background: url(/common/img/facilities/asahikawa/bg_mv.png);
  background-size: contain;

  & .ttl_rib{
    width: 405px;
    height: 73px;
    margin: auto;
    margin-bottom:10px; 
    display: block;
  }
  
  & .ttl_fici_name{
    justify-content: center;
    align-items: center;
    & img{
      width:90px;
      height: 92px;
      margin: 0;
      margin-right: 10px;
    }
    & > .ttl_txt_wrap{
      display: flex;
      align-items: center;
    }
    & h1{
      width:fit-content;
      font-weight: bold;
      position: relative;
    }
    .ttl_line{
      display: block;
      width: fit-content;
      padding:3px 15px;
      border-top:solid 1px var(--dbrown);
      border-bottom:solid 1px var(--dbrown);
      font-size: 14px;
      height: fit-content;
      margin-right:5px;
      line-height: 1.2;
      text-align: center;
      
    }
    &.ttl_kujou {
      & .fl{
        align-items: baseline;
      }
      & h1{
        font-size:44px;
      }
      & p{
        padding-left:10px;
        font-size: 18px;
      }
    }
    &.ttl_sanjou{
      & img{
        width: 70px;
        height: 72px;
      }
      & h1{
        font-size:38px;
      }
    }

  }      
}

@media (max-width: 1024px){
  #ttl_asahikawa{
    height: 325px;
    background: url(/common/img/facilities/asahikawa/mv_sp.png);
    background-size: cover;
    padding: 20px 20px;
    & h1{
      font-size: 18px;
      text-align: center;
      position: absolute;
      bottom:10px;
      right:0;
      left:0;
      margin: auto;
    }
    & .txt_asta{
      color:#000;
      position: absolute;
      right:5px;
      bottom:-20px;
    }
    & .ttl_txt_wrap{
      flex-direction: column;
      & > .fl{
        flex-direction: column;
      }
    }
    & .ttl_fici_name{
      padding-right: 10px;
    }
    & .ttl_fici_name .ttl_line{
      width:100%;
      margin-bottom:20px;
    }
    & .ttl_rib{
      margin-bottom:20px; 
      display: block;
    }


      & .ttl_fici_name.ttl_kujou {
        margin-bottom:20px;
        & .fl{
          align-items: center;
          justify-content: center;
        }
        & img {
            width: 70px;
            height: 70px;
            margin: 0;
            margin-right: 5px;
        }
        & .ttl_txt_wrap h1{
          font-size:28px;
          line-height: 1;
        }
        & .ttl_txt_wrap p{
          padding-left:0px;
          font-size: 18px;
          line-height: 1;
          text-align: center;
        }
      }
      & .ttl_fici_name.ttl_sanjou{
        padding-right: 20px;
        & img{
          width: 60px;
          height: 60px;
        }
        & .ttl_txt_wrap h1{
          font-size:26px;
          line-height: 1;
        }
      }

  }
}
/* ttl_asahikawa end */

/* intro */
#intro{
  padding:40px 0;
  text-align: center;
  font-size: 24px;
  line-height: 2em;
}
/* intro end */


/* faci */
#faci{
  padding-bottom:60px;
}
#faci .fl{
  gap:25px;
  justify-content: center;
}
.faci_box{
  padding:40px;
  padding-bottom:75px;
  max-width: 605px;
  background: var(--brown);
  border-radius: 10px;
  position: relative;
  & h2{
    font-size: 36px;
    margin-bottom:20px;
  }
  & img{
    max-width: 480px;
    margin: auto;
    margin-bottom:20px;
    display: block;
  }
  & p{
    font-size: 20px;
    line-height: 180%;
    margin-bottom:20px;
  }
  & a{
    /* text-decoration: underline; */
    border-bottom: solid 1px var(--dbrown);
    position: relative;
    width: fit-content;
    padding-top: 10px;
    line-height: 1;
    margin: auto;
    display: block;
    font-size: 18px;
    /* padding-right: 20px; */
    right: 20px;
    position: absolute;
    bottom:40px;
    left:0;
    right:20px;
    &:after{
      position: absolute;
      content:"";
      font-size: 18px;
      bottom:0;
      top:7px;
      right: -20px;
      margin: auto;
      width: 8px;
      height: 8px;
      border: 2px solid;
      border-color:  transparent transparent var(--dbrown) var(--dbrown);
      transform: rotate(-45deg);
    }
  } 
}
.faci_btn_adj{
  flex-direction: column;
  justify-content: space-between;
}
@media (max-width: 1024px){
  #faci .fl {
    gap: 25px;
    flex-direction: column;
  }
  .faci_box {
    padding: 20px 10px;
    & h2 {
        font-size: 20px;
        margin-bottom: 20px;
    }
  }
  .faci_box_in{
    display: flex;
    flex-direction: column-reverse;
    gap:20px;
    & > div{
      
    }
    & p{
      font-size: 16px;
      margin-bottom:20px;
    }
    & a{
      line-height: 150%;
      position: relative;
      font-size: 14px;
      right: 10px;
      left: auto;
      bottom: auto;
      padding-top:0;
      text-align: center;
      &:after {
        font-size: 18px;
        bottom: 0;
        top: -4px;
        right: -20px;
        margin: auto;
        width: 5px;
        height: 5px;
      }
    }
    & img{
      margin-bottom:0;
    }
  }
}
/* faci end */


/* asa_nav */
.asa_nav{
  margin-bottom:0px;
}
.nav_ttl{
  background: url(/common/img/facilities/asahikawa/bg_nav.png);
  background-size:cover;
  padding:80px 0 100px;
  margin-bottom:50px;
  & h2{
    line-height: 1;
    color:#fff;
    font-size: 36px;
    text-align: left;
  }
  & span{
    font-size: 60px;
  }
}
.nav_intro{
  text-align: center;
  font-size: 22px;
  line-height: 180%;
  margin-bottom:30px;
}
.asa_nav .fl{
  gap:30px;
}
.asa_nav a{
  box-shadow: 3px 3px 10px 0px rgba(200, 196, 188, 0.40);
  display: block;
  background: var(--brown);
  max-width: 390px;
  width:100%;
  text-align: center;
  color:var(--dbrown);
  font-size: 24px;
  border-radius: 20px;
  font-weight: bold;
  padding:5px 0 40px;
  position: relative;
  & span{

  }
  & img{
    max-width: 47px;
  }
  &:after{
    position: absolute;
    content:"";
    bottom:18px;
    right:0;
    left:0;
    margin: auto;
    width: 10px;
    height: 10px;
    border: 2px solid;
    border-color:  transparent transparent var(--dbrown) var(--dbrown);
    transform: rotate(-45deg);
  }
}
@media (max-width: 1024px){
  .nav_ttl{
    background: url(/common/img/facilities/asahikawa/bg_nav_sp.png);
    background-size:cover;
  }
  .nav_ttl {
    padding:30px 0;
    & h2 {
        font-size: 22px;
      & span {
          font-size: 37px;
      }
    }
  }
  .nav_intro {
    text-align: center;
    font-size: 15px;
  }
  .asa_nav .fl{
    gap:20px 15px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    a {
      padding: 0px 0 25px;
      font-size: 16px;
      & span {
        font-family: 'Helvetica Neue', sans-serif;
        font-size: 12px;
      }
      & img{
         max-width: 35px;
      }
      &:after {
        bottom: 12px;
        width: 6px;
        height: 6px;
        border: 1px solid;
        border-color: transparent transparent var(--dbrown) var(--dbrown);
      }
    }
    a:first-of-type p{
      padding-top:11px;
    }
  }
}
/* yao_nav end */

/* p1 */
#p1{
  padding-top:130px;
}
#p1 .ico_point::before{
  background: url(/common/img/facilities/asahikawa/ico_point_01.svg);
  background-size:cover;
}

.p1_01{
  justify-content: space-between;
  margin-bottom:50px;
}
.p1_01_img{
  max-width: 480px;
  .img_cap{
    text-align: right;
    font-size: 12px;  
  }
}
.p1_01_txt{
  max-width: 700px;
  font-size: 20px;
  & p{
    margin-bottom:10px;
  }

}
.p1_02{
  padding:40px 30px 20px;
  padding-right:0;
  border:solid 3px var(--dbrown);
  border-radius:20px;
  & .fl{
    justify-content: space-between;
  }
  & h4{
    max-width: 565px;
    margin: auto;
    margin-bottom:30px;
  }
  .p1_02_txt{
    & ul{
      margin-bottom:20px;
    }
    & li{
      position: relative;
      padding-left: 30px;
      &:before{
        position: absolute;
        content:"・";
        top:0;
        bottom:0;
        left:3px;
        color: var(--dbrown);
      }
    }
    .txt_asta{
      font-size: 14px;
      margin-top: -3px;
      display: block;
    }
        
  }
  .p1_02_img{
    & img{
      max-width: 450px;
      margin-right: 0;
      margin-left: auto;
      margin-bottom:5px;
      display: block;
    }
    & p{
      padding-right: 40px;
      text-align: right;
      font-size: 12px;
    }
  }
}


@media (max-width: 1024px){
  #p1{
    padding-top:90px;
  }
  .p1_01 {
    gap:20px;
    flex-direction: column-reverse;
  }
  .p1_01_txt {

    font-size: 16px;
  }
  .p1_02 {
    padding: 20px 10px 20px;
    & .fl {
      flex-direction: column;
    }
    & h4 {
      margin-bottom: 20px;
    }
    & h5{
      font-weight: bold;
      margin-bottom:5px;
    }
    & li {
      padding-left: 20px;
    }
    .txt_asta {
      font-size: 12px;
    }
    & .p1_02_img {
      & img {
          margin-right: -5px;
      }
      & p {
            padding-right: 0px;
            text-align: left;
            font-size: 12px;
            margin-top: 10px;
      }
    }
  }
}

/* p1 end */

/* p2 */

#p2 .ico_point::before{
  background: url(/common/img/facilities/asahikawa/ico_point_02.svg);
  background-size:cover;
}
#p2 .p2_intro{
  margin-bottom:10px;
}
#p2 .ul_cap{
  margin-bottom:40px;
  & li{
    position: relative;
    font-size:12px;
    padding-left: 15px;
    line-height: 180%;
    &:before{
      position: absolute;
      content:"※";
      top:0;
      bottom:0;
      left:3px;
      color: var(--dbrown);
    }
  }
}
.his_wrap{
  border-radius: 20px;
  border:solid 2px var(--dbrown);
  padding:40px 30px 25px;
  gap:20px;
  margin-bottom:0px;
  & > div.fl{
    justify-content: space-between;
    margin-bottom:30px;
  }
  & h4{
    max-width: 560px;
    margin: auto;
    margin-bottom:40px;
  }
  .txt_asta{
    text-align: right;
    width: fit-content;
    margin-right: 0;
    margin-left: auto;
  }
}
.his_box{
  max-width: 575px;
  gap:10px;
  font-size: 20px;
  & dl{
    max-width:325px;
  }
  & dt{
    font-weight: bold;
    font-size: 22px;
  }
  & .his_img,img{
    max-width: 240px;
    width:100%;
  }
}
@media (max-width: 1024px){
  #p2{
    padding-top:120px;
  }
  #p2 .txt_intro {
    margin-bottom: 30px;
  }
  #p2 h3 {
    font-size: 20px;
    margin-bottom:20px;
  }
  #p2 .ico_point::before {
    left:10%;
  }
  .his_wrap {
    padding: 20px 15px 25px;
    gap: 20px;
    margin-bottom: 40px;
    & h4 {
      margin-bottom:15px;
    }
    & > div.fl {
        justify-content: space-between;
        flex-direction: column;
        gap:15px;
    }
    .txt_asta{
      text-align: left;
      margin-left: 0;
    }

  }
  .his_wrap:last-of-type{
    margin-bottom:0;
  }
  .his_box {
    & .his_img, img {
      max-width: 100px;
      min-width: 100px;
      height: 100%;
    }
    & dt {
        font-size: 18px;
    }
    & dd {
        font-size: 16px;
    }
  }
}

/* p2 end*/

/* p3 */
#p3{
  padding-top:60px;
  padding-bottom:140px;
}
#p3 .ico_point::before{
  background: url(/common/img/facilities/asahikawa/ico_point_03.svg);
  background-size:cover;
}
#p3 {
  & h2{
    margin-bottom:50px;
  }
  & .fl{
    justify-content: space-between;
  }
  & p{
    max-width: 700px;
  }
  & img{
    max-width: 415px;
  }
  .txt_intro p{
    margin-bottom:20px;
  }
  .txt_asta{
    line-height: 180%;
  }
}
@media (max-width: 1024px){
  #p3 {
    padding-bottom: 60px;
    & h2 {
        margin-bottom: 20px;
    }
    & .fl {
      justify-content: space-between;
      flex-direction: column;
    }
  }
}
/* p3 end */

/* kujo_nav */
.kujo_nav .nav_ttl{
  background: url(/common/img/facilities/asahikawa/bg_nav_kujo.png);
  background-size:cover;
  padding:80px 0 100px;
  margin-bottom:50px;
  & h2{
    line-height: 1;
    color:#fff;
    font-size: 36px;
  }
  & .adj_nav{
    font-size: 36px;
  }
  & span{
    font-size: 60px;
  }
}
.kujo_nav .nav_ttl{
  margin-bottom:70px;
}
.asa_nav .kujo_adj{
  font-size: 22px;
  & span{
    font-size: 22px;
  }
}
.kujo_adj_02{
  padding-top:10px;
}
@media (max-width: 1024px){
  .kujo_nav .nav_ttl{
    background: url(/common/img/facilities/asahikawa/bg_nav_kujo_sp.png);
    background-size:cover;
  }
  .kujo_nav .nav_ttl {
    padding:30px 0 35px;
    & h2 {
        font-size: 22px;
      & span {
          font-size: 37px;
      }
    }
  }
  .asa_nav .kujo_adj{
    line-height: 140%;
    font-size: 17px;
  }
}

/* kujo_nav end*/

/* p4 */
#p4{

}
#p4 h2{
  margin-bottom:40px;
}
#p4 > div > .txt_intro{
  margin-bottom:50px;
}
#p4 .ico_point::before{
  background: url(/common/img/facilities/asahikawa/ico_point_04.svg);
  background-size:cover;
}

#p4 {
  & h2{
    margin-bottom:50px;
  }
  & .fl{
    justify-content: space-between;
  }
  & .p4_txt{
    max-width: 700px;
    & p{
      margin-bottom:20px;
    }
  }
  & .p4_img{
    max-width: 480px;
  }
}
@media (max-width: 1024px){
  #p4 {
    & .fl {
      flex-direction: column;
      & p{
        margin-bottom:15px;
      }
    }
  }
}
/* p4 end */

/* p5 */
#p5{
  background:var(--brown);
  background-image:url(/common/img/facilities/yaotome/bg_sec.png);
  background-size: cover;
  padding-bottom:0px;
 & .txt_intro{
  font-size: 20px;
  line-height: 160%;
  margin-bottom:50px;
 }
}
#p5 .ico_point::before{
  background: url(/common/img/facilities/asahikawa/ico_point_05_02.svg);
  background-size:cover;
}
#p5 .bg_brown_img{
  padding-bottom:30px;
}
#p5 .bg_brown_02{
  padding-top:50px;
  padding-bottom:50px;
}
#p5 h2{
  margin-bottom: 40px;
}
.dialo_wrap{
  margin-bottom:70px;
  & h4{
    font-size: 24px;
    text-align: center;
    margin-bottom:5px;
  } 
  & > img{
    max-width: 240px;
    display: block;
    margin: auto;
    margin-bottom:10px;
  }
  & > .txt_asta{
      text-align: center;
      display: block;
      width: fit-content;
      margin: auto;
      margin-bottom: 70px;
      position: relative;
      &:after{
        position: absolute;
        content:"";
        right:0;
        left:0;
        bottom:-45px;
        margin: auto;
        width: 0;
        height: 0;
        border-left: 20px solid transparent;
        border-right: 20px solid transparent;
        border-top: 20px solid var(--dbrown);
      }
  }
}
.dialo_wrap:last-of-type{
  margin-bottom:0;
}
.dialo_desc{
  border:solid 3px var(--dbrown);
  border-radius: 10px;
  padding:30px 40px;
  & h4{
    margin-bottom:30px;
  }
  & .dialo_desc_box {
    justify-content: space-between;
    gap:20px;
    margin-bottom:30px;
  }

  & dl{
    border:solid 1px var(--dbrown);
    max-width:370px;
    width:100%;
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.60);
    padding:10px 10px 15px;
  }
  & dt{
    text-align: center;
    font-size: 22px;
    color: var(--dbrown);
    padding-bottom:10px;
    margin-bottom:10px;
    border-bottom: solid 1px var(--dbrown);
    font-weight: bold;
  }
  & dd li{
    padding-left:25px;
    position: relative;
    &:before{
      position: absolute;
      content:"・";
      top:2px;
      left:2px;
      color:var(--dbrown);
    }
  }
  .dialo_desc_box_02{
    gap:20px;
    & p{
      font-size: 14px;
      font-weight: bold;
      margin-bottom:10px;
    }
    & >div{
      max-width:575px;
      width:100%;
    }
    & img{
      width:100%;
    }
  }
}
.p5_01{
  & p{
    margin-bottom: 40px;
  }
  & img{
    width:100%;
    max-width: 735px; 
  }
}

@media (max-width: 1024px){
  #p5 .bg_brown_img{
    padding-top:110px;
    padding-bottom: 40px;
  }
  #p5 {
    & h2 {
      margin-bottom: 20px;
    }
    & .txt_intro {
        font-size: 16px;
        line-height: 160%;
        margin-bottom: 40px;
    }
    & .p5_01 img{
      max-width: 100%;
    }
  }
  .dialo_wrap {
    margin-bottom:60px;
    & > img {
        max-width: 180px;
        margin-bottom: 0px;
    }
    & h4 {
        font-size: 18px;
        margin-bottom:10px;
        line-height: 140%;;
    }
    & > .txt_asta {
      margin-bottom: 60px;
        &:after {
          position: absolute;
          content: "";
          right: 0;
          left: 0;
          bottom: -40px;
          margin: auto;
          width: 0;
          height: 0;
          border-left: 17px solid transparent;
          border-right: 17px solid transparent;
          border-top: 17px solid var(--dbrown);
        }
    }
  }
  .dialo_desc {
    padding:15px 15px;
    & .dialo_desc_box {
        margin-bottom: 30px;
        flex-direction: column;
    }
    & dt {
      font-size: 16px;
    }
    & dd li {
        padding-left: 20px;
    }
    .dialo_desc_box_02 {
      flex-direction: column;
    }
  }
}
/* p5 end */

/* p6 */
#p6 {
  padding-bottom:140px;
}
#p6 h2{
  margin-bottom:50px;
}
#p6 > div > .txt_intro{
  margin-bottom:50px;
}
#p6 .ico_point::before{
  background: url(/common/img/facilities/asahikawa/ico_point_06.svg);
  background-size:cover;
}
/* room */
.p2_room .txt_intro{
  margin-bottom:70px;
}
.room_wrap{
  position: relative;
}
.room_ttl{
  position: absolute;
  top:0;
  left:0;
  & h4{
    width: fit-content;
    position:relative;
  }
  & h4:after{
   content:""; 
   position: absolute;
   margin:auto;
   top:0;
   bottom:0;
   right:-20px;
   width: 0;
    height: 0;
    border-left: 12px solid var(--dbrown);
    border-top: 8px solid transparent;
    border-bottom: 8px solid transparent;
  }
}
.room_img{
	max-width: 715px;
	margin: auto;
	display: block;
  position: relative;
}
.room_pin{
  width: 80px;
  position: absolute;
  cursor: pointer;
}
.room_pin:hover{
  animation: poyoyon .5s cubic-bezier(0.12, 0, 0.39, 0) 1 forwards;
}
@keyframes poyoyon {
  0% {
    transform: translateY(-5px);
  }
  50% {
    transform: translateY(0);
  }
  65% {
    transform: translateY(-0px);
  }
  100% {
    transform: translateY(0);
  }
  20%,100% {
    opacity: 1;
  }
}
.room_pop{
  border:solid 2px #13257D;
  padding:20px 30px;
  background: #fff;
  position: absolute;
  border-radius: 10px;
  display: none;
}
.room_pop.on {
  display: block;
  z-index: 50;
}
.room_pop .ttl{
  color:#13257D;
  font-weight: bold;
  margin-bottom:10px;
  font-size: 24px;
}
.room_pop .desc{
  font-size: 18px;
  margin-bottom:10px;
}
.room_pop .list{
  font-size: 16px;
  margin-bottom:10px;
}
.room_pop .link{
  width: fit-content;
  text-align: right;
  text-decoration: underline;
  color: #13257D;
  position: relative;
  display: block;
  margin-top:20px;
  padding-right: 20px;
  margin-right: 0;
  margin-left: auto;
}
.room_pop .link::after{
  content: '';
  display: block;
  width: 8px;
  height: 8px;
  border-top-color: transparent;
  border-right: solid 2px #122A88;
  border-bottom: solid 2px #122A88;
  border-left-color: transparent;
  transform: rotate(-45deg) skew(5deg, 5deg);
  position: absolute;
  right: 0;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}
.pin_01{
  top: 32px;
  left: 219px;
}
.pop_01{
  top: 96px;
  left: -203px;
}
.pin_02{
  top: 52px;
  left: 370px;
}
.pop_02{
  top: 44px;
  right: -210px;
}
.pin_03{
  top: 468px;
  left: 156px;
}
.pop_03{
  bottom: -70px;
  left: -302px;
}
.pin_04{
  top: 325px;
  right: 37px;
}
.pop_04{
  right: -260px;
  bottom: 230px;
}
.pop_close{
  cursor: pointer;
  position: absolute;
  top: 0px;
  right: 25px;
}
.pop_close::after{
  background: #122A88;
  width:50px;
  height: 50px;
  border-radius: 50px;
  position: absolute;
  content:"";
  top:0;
  bottom:0;
  right: 0;
  left: 0;
  margin: auto;
}
.pop_close::before{
  position: absolute;
  content: "×";
  top: -25px;
  bottom: 0;
  right: 0px;
  left: 10px;
  margin: auto;
  color: #fff;
  z-index: 20;
  font-size: 30px;
}
@media (max-width: 1024px){
  #p6{
    padding-bottom: 50px;
  }
  #p6 h2 {
    margin-bottom: 15px;
  }
  #p6 > div > .txt_intro {
    margin-bottom: 30px;
  }
  .room_ttl {
    position: relative;
    margin-bottom:20px;
    & h4{
      margin-bottom:10px;
    }
    & h4:after {
        transform: rotate(90deg);
    }
  }

  .room_pin {
    width: 50px;
  }
  .pin_01 {
    top: 2%;
    left: 29%;
  }
  .pin_02 {
    top: 4%;
    left: 50%;
  }
  .pin_03 {
    top: 57%;
    left: 20%;
  }
  .pin_04 {
    top: 39%;
    right: 4%;
  }
  .pop_01,
  .pop_02,
  .pop_03,
  .pop_04 {
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    height: fit-content;
  }
  .pop_close {
    cursor: pointer;
    position: absolute;
    top: -17px;
    right: -17px;
    display: block;
    width: 35px;
    height: 35px;
  }
  .pop_close::after {
    background: transparent;
    width: 35px;
    height: 35px;
  }
  .pop_close::before {
    top: 0;
    bottom: 0;
    right: 0px;
    left: -2px;
    margin: auto;
    color: #fff;
    z-index: 20;
    font-size: 34px;
    font-weight: 500;
    font-family: auto;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    content: "";
    background: url(/common/img/mimamorisystem/ico_close2.png);
    background-size: cover;
    overflow: visible;
    background-repeat: no-repeat;
  }

  .room_pop .ttl {
    font-size: 20px;
  }
  .room_pop .desc {
    font-size: 14px;
    margin-bottom: 10px;
  }
  .room_pop .link{
    font-size: 12px;
  }
  
}
@media (max-width: 1025px) and (min-width: 430px) {
  #room .room_img {
    max-width: 350px;
  }
}

/* p6 end */

/* list */
#list{
  padding-bottom:90px;
  .list_wrap{
    margin-bottom:30px;
  }
  .nav_ttl{
      background: url(/common/img/facilities/asahikawa/bg_nav_list.png);
      background-size:cover;
      margin-bottom:90px;
  }
  & h2{
    text-align: left;
  }
  & .list_box{
    justify-content: flex-start;
    font-family: "Noto Sans JP";
  }

  .list_mem_count {
    margin-top:20px;
    font-size: 16px;
    border: solid 3px #F0F0F0;
    font-weight: 400;
  }
  .list_mem_count {
    border-radius: 11px;
    padding: 6px 10px;
  }
  .list_mem_count p {
    padding-left: 30px;
    position: relative;
  }
  .list_mem_count p::before {
    position: absolute;
    content: "";
    top: 0;
    bottom: 0;
    left: 5px;
    width: 26px;
    height: 20px;
    margin: auto;
  }
  .list_mem_count p.room1::before {
    background: url(../img/facilities/ico_one.png) no-repeat;
    background-size: contain;
  }
  .list_mem_count p.room2::before {
    background: url(../img/facilities/ico_two.png) no-repeat;
    background-size: contain;
    left: 0px;
    top: 4px;
  }
  .list_mem_count span {
    font-size: 18px;
    color: #13257D;
    margin-left: 5px;
    font-weight: 500;
    font-weight: bold;
  }
  .list_mem_count span span {
    font-size: 16px;
    margin-left: 0;
  }
  .list_txt{
    max-width: 735px;
    width:100%;
    padding:10px 0 0;
  }
  .list_txt>p {
    margin-bottom: 0px;
    font-size: 16px;
  }
  .list_feat_box {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 15px;
    margin-top: 5px;
  }

  .list_feat_box:not(:has(span)) {
    margin-top: 0;
  }

  .list_pri {
    letter-spacing: -1px;
  }

  .list_pri span {
    color: #E28F3D;
    font-weight: bold;
    font-size: 30px;
  }

  .list_feat_box span {
    border-radius: 15px;
    margin-right: 10px;
    font-size: 16px;
    padding: 5px 13px;
    background: #F0F0F0;
    display: inline-block;
  }
  .txt_asta{
    font-size: 14px;
  }
}
@media (max-width: 1024px){
  #list .ico_point::before{
    background: url(/common/img/facilities/asahikawa/ico_point_check_02.svg);
    background-size:cover;
  }
  #list{
    padding-bottom:80px;
    .list_wrap{
      margin-bottom:30px;
    }
    .nav_ttl{
        background: url(/common/img/facilities/asahikawa/bg_nav_list_sp.png);
        background-size:cover;
        margin-bottom:90px;
        padding:50px 0;
    }
  }
  #list {
    & .list_box {
      padding: 10px;
      border-radius: 10px;
    }
    .list_mem_count p {
      font-size: 12px;
      padding-left: 20px;
    }

    .list_mem_count span {
      font-size: 14px;
    }

    .list_mem_count span span {
      font-size: 12px;
    }

    .list_mem_count p::before {
      left: 3px;
      width: 16px;
      height: 15px;
    }

    .list_mem_count p:last-child::before {
      width: 20px;
      height: 17px;
      left: -3px;
    }
    .list_txt>p {
        margin-bottom: 0px;
        font-size: 14px;
    }
    .list_txt h3 {
      font-size: 24px;
      text-decoration: none;
      margin-bottom: 10px;
      line-height: 140%;
    }

    .list_tbl {
      margin-bottom: 10px;
    }

    .list_tbl th {
      line-height: 1.5;
      border-bottom: solid 2px #fff;
      width: 20%;
    }

    .list_tbl td {
      padding: 10px 5px;
      font-size: 14px;
      line-height: 140%;
    }

    .list_tbl td .fl {
      width: 100%;
      line-height: 1.5;
    }

    .list_pri span {
      font-size: 14px;
    }

    .list_pri {
      letter-spacing: 0px;
    }

    .list_pri_front {
      font-size: 14px;
    }

    .list_feat_box {
      display: flex;
      flex-wrap: wrap;
      gap: 8px 10px;
      margin-bottom: 0px;
    }

    .list_feat_box span {
      border-radius: 15px;
      margin-right: 0px;
      font-size: 14px;
      padding: 5px 13px;
    }

    .list_cta {
      display: flex;
      flex-direction: row;
      justify-content: space-between;
      gap: 0;
      padding: 0;
    }

    .btn_list {
      font-size: 16px;
      padding: 12px 0;
      border-radius: 0;
      max-width: 33.3%;
      box-shadow: none;
    }

    .btn_list.btn_arr {
      background-color: #FFF;
      text-decoration: underline;
      color: #000;
      text-underline-offset: 3px;
    }

    .btn_list span {
      display: none;
    }

    .btn_arr:after {
      content: none;
    }

    .list_btm {
      margin-top: 5px;
      background: #FFF;
      padding: 0px 0;
    }

  }

}
/* list end */





#footer {
  margin-top:0;
}
@media (max-width: 1024px){
  #p4 h2 {
      margin-bottom: 20px;
  }
  #p4 > div > .txt_intro {
    margin-bottom: 30px;
  }
  #p4 h3 {
    font-size: 20px;
    margin-bottom:20px;
  }
  .p4_wrap > .fl {
    gap: 10px;
    flex-direction: column;
  }
  .p4_txt dl {
    gap:5px;
    & dt {
      font-size: 14px;
        min-width: 50px;
        height: 50px;
    }
  }
  #p4 dt.adj_03 {
    font-size: 14px;
  }
}
