/*---------------------------------------------------------------------------*/
@media screen and (min-width: 768px), print {
  .contents {
    text-align: left;
  }
  .contents .explanation {
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 30px;
    margin: 28px 0;
  }
  .contents .shop_list {
    background-color: #d9d9d9;
    border-top: 2px solid #c3c3c3;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    text-align: center;
  }
  .contents .shop_list:nth-of-type(2n) {
    background-color: #fff;
  }
  .contents .shop_list:last-of-type {
    border-bottom: 2px solid #c3c3c3;
  }
  .contents .shop_list .image {
    width: 323px;
  }
  .contents .shop_list .image span:first-of-type {
    height: 70px;
    width: 120px;
    background-image: url("../images/tel_reservation_img01.png");
    background-repeat: no-repeat;
    -moz-background-size: contain;
         background-size: contain;
    text-indent: -9999px;
    display: inline-block;
  }
  .contents .shop_list .content {
    width: 770px;
    padding: 30px 45px;
    font-size: 1.5rem;
    border-left: 1px solid #c3c3c3;
    line-height: 28px;
    text-align: left;
  }
  .contents .shop_list .content a {
    color: #000a6e !important;
    font-size: 1.8rem;
    font-weight: bold;
    letter-spacing: 1.2px;
  }
  .contents .shop_list .content .text_red {
    color: #fc0000;
  }
  .contents .shop_list .content span {
    color: #fc0000;
  }
  .contents .caution {
    font-size: 1.6rem;
    margin: 27px 0 50px;
  }
  .contents .otherwise {
    margin-top: 62px;
  }
  .contents .otherwise p {
    margin-top: 20px;
  }
}

@media screen and (max-width: 767px) {
  .contents {
    text-align: left;
  }
  .contents a {
    text-decoration: none;
  }
  .contents .explanation {
    margin: 3.64583vw 0 8.59375vw;
    font-size: 3.90625vw;
    font-weight: bold;
  }
  .contents .shop_list {
    background-color: #d9d9d9;
    border-top: 1px solid #c3c3c3;
  }
  .contents .shop_list:nth-of-type(2n) {
    background-color: #fff;
  }
  .contents .shop_list:last-of-type {
    border-bottom: 1px solid #c3c3c3;
  }
  .contents .shop_list .image {
    width: 100%;
    text-align: center;
    padding: 15.625vw 0 10.41667vw;
    border-bottom: 1px solid #c3c3c3;
  }
  .contents .shop_list .image span:first-of-type {
    height: 22.78646vw;
    width: 39.0625vw;
    background-image: url("../images/tel_reservation_img01.png");
    -moz-background-size: contain;
         background-size: contain;
    background-repeat: no-repeat;
    text-indent: -9999px;
    display: inline-block;
  }
  .contents .shop_list .content {
    width: 100%;
    padding: 6.51042vw 3.90625vw;
    font-size: 3.90625vw;
    line-height: 5.85938vw;
  }
  .contents .shop_list .content .text_red {
    color: #fc0000;
  }
  .contents .shop_list .content span {
    color: #fc0000;
    background-repeat: no-repeat;
    background-position: -9999px;
  }
  .contents .shop_list .content a {
    color: #000a6e !important;
    font-size: 4.6875vw;
    font-weight: bold;
  }
  .contents .caution {
    font-size: 3.90625vw;
    margin: 4.55729vw 0 9.11458vw;
  }
  .contents .otherwise {
    margin-top: 9.11458vw;
  }
  .contents .otherwise p {
    margin-top: 6.51042vw;
  }
  .contents .btn_link_top {
    display: block;
    margin-top: 11.71875vw;
    margin-bottom: 11.71875vw;
    text-align: -webkit-center;
  }
}
