@charset "UTF-8";
/*
 ::::::::   ::::::::  ::::    ::::  ::::    ::::   ::::::::  ::::    :::
:+:    :+: :+:    :+: +:+:+: :+:+:+ +:+:+: :+:+:+ :+:    :+: :+:+:   :+:
+:+        +:+    +:+ +:+ +:+:+ +:+ +:+ +:+:+ +:+ +:+    +:+ :+:+:+  +:+
+#+        +#+    +:+ +#+  +:+  +#+ +#+  +:+  +#+ +#+    +:+ +#+ +:+ +#+
+#+        +#+    +#+ +#+       +#+ +#+       +#+ +#+    +#+ +#+  +#+#+#
#+#    #+# #+#    #+# #+#       #+# #+#       #+# #+#    #+# #+#   #+#+#
 ########   ########  ###       ### ###       ###  ########  ###    ####
*/
/* override */
select {
  font-family: "Noto Sans JP", 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif, 'Roboto', -apple-system;
}
.default .container {
  padding-top: 0px;
}
.default section {
    margin-top: 1rem;
    margin-bottom: 2rem;
}
.search-ctrl .children {display: inline-block;}
.search-ctrl .children:after {
    content: ".";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;
}
* html .search-ctrl .children {height: 1%;}
.search-ctrl .children {display: block;}
.pcv {
    display: block;
}
.spv {
    display: none;
}

.search-wrap {
    width: 1000px;
}


/*
 ::::::::  :::    ::: :::::::::
:+:    :+: :+:    :+: :+:    :+:
+:+        +:+    +:+ +:+    +:+
+#++:++#++ +#+    +:+ +#++:++#+
       +#+ +#+    +#+ +#+    +#+
#+#    #+# #+#    #+# #+#    #+#
 ########   ########  #########
*/
.col-sub {
    float: right;
    width: 300px;
}

.search_condition_extras {
    padding: 20px 20px 40px;
    background: #fff;
    border-radius: 5px;
}
.search_condition_extras h3 {
    margin-bottom: 30px;
    padding-bottom: 15px;
    font-size: 20px;
    font-weight: bold;
    color: #01627A;
    border-bottom: solid 2px #019FC7;
}
.conditions {
    margin-bottom: 30px;
}
.conditions h4 {
    margin-bottom: 15px;
    font-size: 16px;
    font-weight: bold;
    color: #01627A;
}
.checkbox-list {
    display: flex;
    flex-direction: row;
    flex-flow: wrap;
    justify-content: space-between;
}
.checkbox-list li {
    box-sizing: border-box;
    width: 45%;
}


/*
::::    ::::      :::     ::::::::::: ::::    :::
+:+:+: :+:+:+   :+: :+:       :+:     :+:+:   :+:
+:+ +:+:+ +:+  +:+   +:+      +:+     :+:+:+  +:+
+#+  +:+  +#+ +#++:++#++:     +#+     +#+ +:+ +#+
+#+       +#+ +#+     +#+     +#+     +#+  +#+#+#
#+#       #+# #+#     #+#     #+#     #+#   #+#+#
###       ### ###     ### ########### ###    ####
*/
.col-main {
    float: left;
    width: 660px;
}
.box-search h3 {
    margin-bottom: 5px;
    font-size: 20px;
    font-weight: bold;
    color: #01627A;
}

/* mod_condition */
.mod_condition {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-bottom: -15px !important;
}
.mod_condition h3 {
    width: 100%;
    flex-shrink: 0;
}

.mod_condition .mod_searchby_word {
    width: 490px;
}
.mod_searchby_word input[type="text"] {
    box-sizing: border-box;
    padding: 0 20px;
    width: 428px;
    height: 50px;
    font-size: 16px;
    vertical-align: top;
    border: solid 1px #bbb;
    border-radius: 5px 0 0 5px;
}
.mod_searchby_word input[type="text"]::placeholder {
    color: #ddd;
}
.mod_searchby_word .btn-submit {
    display: inline-block;
    margin-left: -5px;
    vertical-align: top;
    overflow: hidden;
}
.mod_searchby_word .btn-submit button {
    display: inline-block;
    box-sizing: border-box;
    margin-left: -5px;
    width: 60px;
    height: 50px;
    border-radius: 0 5px 5px 0;
    text-indent: -9999px;
}
.mod_searchby_word .btn-submit i {
    top: 15px;
    left: 29%;
    -webkit-transform: rotate(-45deg) scale(2.2);
    transform: rotate(-45deg) scale(2.2);
}
.mod_condition .mod_searchby_word .search_nearby {
  position: relative;
    padding: 15px 0;
    z-index: 50;
}
.mod_condition .mod_searchby_word .search_nearby a {
    font-size: 16px;
    text-decoration: underline;
    color: #019FC7;
}
.mod_condition .mod_searchby_word .search_nearby a.btn_clear {
    float: right;
    display: inline-block;
    margin-top: -5px;
    margin-right: -170px;
    padding: 5px 10px;
    font-size: 14px;
    text-decoration: none;
    color: #333;
    background: #fff;
    border: solid 2px #ccc;
    border-radius: 5px;
    cursor: pointer;
}

.mod_condition .mod_searchby_pref {
    position: relative;
    width: 150px;
}
.mod_condition .mod_searchby_pref::after {
    content: '';
    position: absolute;
    top: 13px;
    right: 15px;
    display: block;
    width: 15px;
    height: 15px;
    border-bottom: solid 2px #01627A;
    border-right: solid 2px #01627A;
    transform: rotate(45deg);
    pointer-events: none;
}
.mod_condition .mod_searchby_pref select {
    appearance: none;
    -webkit-appearance: none;
    box-sizing: border-box;
    padding: 0 15px;
    width: 150px;
    height: 50px;
    font-size: 16px;
    font-weight: bold;
    color: #01627A;
    background: #fff;
    border: 0;
    border-radius: 5px;
}
.mod_condition .mod_searchby_pref select::-ms-expand {
    display: none;
}

.mod_condition .mod_searchby_extras,
.search_condition_extras.mod_sp {
    display: none;
    width: 100%;
}

/* mod_map */
.mod_map {
    padding: 0;
    border-bottom: solid 0px #ddd;
}


/* box-result */
.box-result {
    overflow: hidden;
}
.box-result h3 {
    margin-bottom: 15px;
    font-size: 20px;
    font-weight: bold;
    color: #01627A;
}

/* result_info */
.result_count {
    margin-left: 15px;
    font-size: 20px;
    line-height: 40px;
    font-weight: normal;
    color: #3c3c3c;
}
.result_info .result_sort {
    float: right;
    width: 130px;
    height: 40px;
    font-size: 16px;
    line-height: 40px;
    text-align: center;
}
.result_info .result_sort a {
    display: block;
    width: 100%;
    height: 100%;
    text-decoration: none;
    color: #019FC7;
    background: #fff;
    border: solid 1px #019FC7;
    border-radius: 5px;
}

/* result_list */
.result_list {
    margin-bottom: 60px;
}
.result_list .item {
    margin-bottom: 10px;
}
.result_list .item.hide {
    display: none;
}
.result_list .item a {
    position: relative;
    color: #3c3c3c;
}
.result_list .item a::after {
    content: '';
    position: absolute;
    top: 45%;
    right: 20px;
    display: block;
    width: 15px;
    height: 15px;
    border-top: solid 2px #019FC7;
    border-right: solid 2px #019FC7;
    transform: rotate(45deg);
}
.result_list .item .location_name {
    display: block;
    font-size: 16px;
    line-height: 26px;
    font-weight: bold;
    font-style: normal;
}
.result_list .item .location_distance {
    display: block;
    font-size: 14px;
    color: #707070;
}
.result_list .item .detail_info {
    font-size: 14px;
}
.result_list .item .detail_info li {
    display: flex;
    flex-direction: row;
    margin-bottom: 5px;
}
.result_list .item .info_heading {
    position: relative;
    margin-right: 10px;
    width: 20%;
    color: #01627A;
}
.result_list .item .info_heading::after {
    content: ':';
    position: absolute;
    right: 0;
}
.result_list .item .info_value {
    width: 70%;
}
.result_list .item.mod_display_trigger {
}
.result_list .item.mod_display_trigger a {
    display: block;
    text-align: center;
    text-decoration: underline;
    font-weight: bold;
    color: #019FC7;
}
.result_list .item.mod_display_trigger a::after {
    position: static;
    margin-left: 7px;
    display: inline-block;
    width: 10px;
    height: 10px;
    vertical-align: 3px;
    border-top: solid 1px #019FC7;
    border-right: solid 1px #019FC7;
    transform: rotate(135deg);
}


/* filter block */
.btn-submit {
    position: relative;
}
.btn-submit i {
    position: absolute;
    pointer-events: none;
}
.search.icon {
    color: #000;
    position: absolute;
    margin-top: 2px;
    margin-left: 3px;
    width: 12px;
    height: 12px;
    border: solid 2px #fff;
    border-radius: 100%;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
.search.icon:before {
    content: '';
    position: absolute;
    top: 9px;
    left: 3px;
    height: 6px;
    width: 2px;
    background-color: #fff;
    border-radius: 0 0 6px 6px;
}



.btn-submit input,
.btn-submit button {
    color: #fff;
    background-color: #01627A;
    border: 0;
    border-radius: 5px;
    cursor: pointer;
}
.btn-submit input:hover {
    background-color: #019FC7;
}
.btn-submit.mod_side {
    display: block;
    margin: 0 auto;
    width: 260px;
    height: 50px;
    text-align: center;
    background-color: #fff;
}
.btn-submit.mod_side input,
.btn-submit.mod_side button {
    display: inline-block;
    width: 260px;
    height: 50px;
    font-size: 16px;
    font-weight: bold;
    box-shadow: 0 4px 4px rgba(0,0,0,.16);
}

/* by keywords */
.mod_searchby_word .fields {
    text-align: center;
}


/* by categories */
.mod_searchby_cat .fields {
    padding: 0 0 50px;
}

/* category filter */
.location-filter {
    overflow: hidden;
}
.search-ctrl {
    position: relative;
    margin: 0 auto;
    overflow: hidden;
}

















.search-ctrl li > span  {
    position: relative;
    display: inline-block;
    color: #3C3C3C;
}
.search-ctrl li > span > label  {
    font-size: 14px;
}






@media screen and (max-width:767px) {
    /* .box-search h3 {
        font-size: 20px;
    }
    .box-search .desc {
        margin-bottom: 10px;
        font-size: 12px;
    }
    .box-search.mod_searchby_word input[type="text"] {
        width: calc(100% - 90px);
    }
    .box-search.mod_searchby_word .btn-submit button {
        width: 60px;
    }
    .box-search.mod_searchby_word .btn-submit i {
        left: 34%;
    }
    .search-ctrl {
        width: 100%;
    }
    .search-ctrl > li > .children {
        padding: 20px;
    }
    .search-ctrl > li > ul > li > ul {
        padding: 0;
    }
    .search-ctrl > li > ul > li > ul > li {
        margin-bottom: 15px;
        width: 46%;
    } */
    
    .mod_condition .mod_searchby_word .search_nearby {
        padding: 20px 0;
    }
    .mod_condition .mod_searchby_word .search_nearby a.btn_clear {
      margin-right: 0;
      border: solid 1px #ccc;
    }
}



/* Base for label styling */
.search-ctrl [type="checkbox"]:not(:checked),
.search-ctrl [type="checkbox"]:checked {
    position: absolute;
    left: -9999px;
}
.search-ctrl [type="checkbox"]:not(:checked) + label,
.search-ctrl [type="checkbox"]:checked + label {
    position: relative;
    display: inline-block;
    padding-left: 30px;
    line-height: 20px;
    cursor: pointer;
}

/* checkbox aspect */
.search-ctrl [type="checkbox"]:not(:checked) + label:before,
.search-ctrl [type="checkbox"]:checked + label:before {
    content: '';
    position: absolute;
    left: 0; top: 0;
    width: 20px;
    height: 20px;
    border: 1px solid #000;
    background: #fff;
    border-radius: 4px;
    box-shadow: inset 0 1px 3px rgba(0,0,0,.1);
}
/* checked mark aspect */
.search-ctrl [type="checkbox"]:not(:checked) + label:after,
.search-ctrl [type="checkbox"]:checked + label:after {
    content: '\2713\0020';
    position: absolute;
    top: .15em; left: .22em;
    font-size: 19px;
    line-height: 0.8;
    color: #019FC7;
    transition: all .2s;
    font-family: 'Lucida Sans Unicode', 'Arial Unicode MS', Arial;
}
/* checked mark aspect changes */
.search-ctrl [type="checkbox"]:not(:checked) + label:after {
    opacity: 0;
    transform: scale(0);
}
.search-ctrl [type="checkbox"]:checked + label:after {
    opacity: 1;
    transform: scale(1);
}
/* disabled checkbox */
.search-ctrl [type="checkbox"]:disabled:not(:checked) + label:before,
.search-ctrl [type="checkbox"]:disabled:checked + label:before {
    box-shadow: none;
    border-color: #bbb;
    background-color: #ddd;
}
.search-ctrl [type="checkbox"]:disabled:checked + label:after {
    color: #999;
}
.search-ctrl [type="checkbox"]:disabled + label {
    color: #aaa;
}
/* accessibility */
.search-ctrl [type="checkbox"]:checked:focus + label:before,
.search-ctrl [type="checkbox"]:not(:checked):focus + label:before {
    border: 1px solid #000;
}

/* hover style just for information */
label:hover:before {
    border: 1px solid #019FC7!important;
}

.search-ctrl > li > span > input,
.search-ctrl > li > span > label::before,
.search-ctrl > li > span > label > small,
.search-ctrl > li > ul > li > span > label > small {
    /* display: none; */
}
.search-ctrl > li > span > label {
    /* padding-left: 0 !important;
	vertical-align: 40%; */
}



/*
:::::::::   ::::::::
:+:    :+: :+:    :+:
+:+    +:+ +:+
+#++:++#+  +#+
+#+        +#+
#+#        #+#    #+#
###         ########
*/
@media screen and (min-width:768px){
    .search .result {
      margin-top: 0;
    }
    .search .result .station {
        color: #01627a;
        font-size: 20px;
        margin: 30px 0 10px 0;
    }
    .search .result .white-box {
        background: #fff;
        padding: 15px 20px;
        display: block;
    }
    .search .result .white-box:not(:last-child) {
        margin-bottom: 10px;
    }
    .search .result .white-box .boxes {
        display: block;
        width: 95%;
    }
    .search .result .white-box .box-01 {
        margin-bottom: 5px;
        padding-bottom: 5px;
        width: 100%;
        height: 100%;
        display: block;
        vertical-align: top;
        font-size: 20px;
        word-break: break-all;
        border-bottom: solid 1px #ddd;
        padding-right: 0;
    }
    .search .result .white-box .box-02 {
        width: 100%;
        height: 100%;
        display: block;
        vertical-align: top;
    }
    .search .result .white-box span {
        padding: 0 5px;
    }
    .search .result .white-box a {
        cursor: pointer;
        text-decoration: underline !important;
        padding-left: 0 !important;
    }
    .search .pagination {
        text-align: center;
        margin-top: 45px;
    }
    .search .pagination a {
        color: #019FC7;
    }
    .search .pagination .page-numbers:not(.next):not(.prev) {
        background: #fff;
        display: inline-block;
        width: 40px;
        border-radius: 3px;
        margin: 0 2px;
        line-height: 40px;
        height: 40px;
    }
    .search .pagination .prev {
        margin-right: 10px;
    }
    .search .pagination .next {
        margin-left: 10px;
    }
    .search .notfound {
        text-align: center;
    }
}



/*
 ::::::::  :::::::::
:+:    :+: :+:    :+:
+:+        +:+    +:+
+#++:++#++ +#++:++#+
       +#+ +#+
#+#    #+# #+#
 ########  ###
*/
@media screen and (max-width:767px){
    .pcv {
        display: none;
    }
    .spv {
        display: block;
    }
    .search-wrap {
        width: auto;
    }
    /* sub */
    .col-sub {
        float: none;
        width: auto;
    }
    /* main */
    .col-main {
        float: none;
        width: auto;
    }

    /* mod_condition */
    .mod_condition h3 {
        font-size: 20px;
    }
    .mod_condition .mod_searchby_word {
        width: 100%;
    }
    .mod_searchby_word input[type="text"] {
        box-sizing: border-box;
        padding: 0 20px;
        width: calc(100% - 62px);
        height: 50px;
        font-size: 16px;
        border: solid 1px #bbb;
        border-radius: 5px 0 0 5px;
    }
    .mod_searchby_word .btn-submit button {
        display: inline-block;
        margin-left: -5px;
        width: 60px;
        height: 50px;
        border-radius: 0 5px 5px 0;
        text-indent: -9999px;
    }

    .conditions h4 {
        margin-top: 0 !important;
        margin-bottom: 25px;
    }

    .sp_heading {
        display: flex;
        flex-direction: row;
        align-items: center;
        flex-shrink: 0;
        width: 83px;
        font-size: 16px;
        font-weight: bold;
        color: #01627A;
        border-right: solid 1px #ddd;
    }
    .mod_condition .mod_searchby_pref,
    .mod_condition .mod_searchby_extras {
        display: flex;
        flex-direction: row;
        box-sizing: border-box;
        padding: 10px;
        width: 100%;
        background: #fff;
        border-radius: 5px;
    }
    .mod_condition .mod_searchby_pref {
        margin-bottom: 20px;
    }
    .mod_condition .mod_searchby_pref select {
        flex-basis: auto;
        width: 100%;
        height: 30px;
        font-size: 17px;
        font-weight: normal;
        color: #3c3c3c;
    }
    .mod_condition .mod_searchby_extras {
        position: relative;
    }
    .mod_condition .mod_searchby_extras::after {
        content: '';
        position: absolute;
        top: 56%;
        right: 15px;
        display: block;
        margin-top: -15px;
        width: 15px;
        height: 15px;
        border-bottom: solid 2px #01627A;
        border-right: solid 2px #01627A;
        transform: rotate(45deg);
        pointer-events: none;
    }
    .mod_condition .mod_searchby_extras.is_open {
        background: #019FC7;
    }
    .mod_condition .mod_searchby_extras.is_open .sp_heading,
    .mod_condition .mod_searchby_extras.is_open .extras_value {
        color: #fff;
    }
    .mod_condition .mod_searchby_extras.is_open::after {
        margin-top: -5px;
        border-bottom: solid 2px #fff;
        border-right: solid 2px #fff;
        transform: rotate(-135deg);
    }


    .search_condition_extras {
        position: relative;
        margin-top: 0 !important;
        padding: 20px 20px 30px;
    }
    .extras_value {
        box-sizing: border-box;
        padding: 0 25px 0 15px;
        font-size: 17px;
    }

    /* mod_map */
    .mod_map {
        margin: 30px 0 -15px !important;
        padding: 0;
        border-bottom: 0;
    }
    .mod_map iframe {
        width: 100%;
    }

    /* box-result */
    .box-result h3 {
        margin: 50px 0 10px;
        font-size: 20px;
    }

    /* result_info */
    .result_info {
        margin-bottom: 20px;
    }
    .result_info .result_count {
        font-size: 16px;
    }

    /* result_list */
    .result_list .item {
        margin-bottom: 15px;
    }
    .result_list .item .info_heading {
        margin-right: 10px;
        width: 33%;
    }
    .result_list .item.hide {
        display: none;
    }



    .search .container {
        width: 100%;
    }
    .search .result .station {
        color: #01627a;
        font-size: 20px;
        margin: 30px 0 10px 0;
    }
    .search .result .white-box {
        background: #fff;
        padding: 15px 33px 15px 20px;
        display: flex;
        width: 100%;
    }
    .search .result .white-box:not(:last-child) {
        margin-bottom: 10px;
    }
    .search .result .white-box .box-01 {
        width: 100%;
        display: inline-block;
        font-size: 20px;
        word-break: break-all;
        border-bottom: solid 1px #ddd;
    }
    .search .result .white-box .box-02 {
        width: 100%;
        display: inline-block;
    }
    .search .result .white-box .box-01 {
        padding: 0 0 10px;
    }
    .search .result .white-box .box-02 {
        padding: 10px 0 0;
    }
    .search .result .white-box .box-02 .term {
        margin-top: 10px;
    }
    .search .result .white-box span {
        padding: 0;
    }
    .search .result .white-box a {
        cursor: pointer;
    }
    .search .result .white-box .boxes {
        width: 100%;
        display: flex;
        flex-direction: column;
    }
    .search .result .white-box .box-02 .term {
        margin-top: 10px;
    }
    .search .result .white-box .box-02 img {
        width: 23px;
        margin-right: 5px;
    }


    .defalt-arrow::before {
        right: 3px;
        width: 16px;
        height: 16px;
        border-top: 2px solid #019FC7;
        border-right: 2px solid #019FC7;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
    }
    .search .pagination {
        text-align: center;
        margin-top: 45px;
    }
    .search .pagination a {
        color: #019FC7;
    }
    .search .pagination .page-numbers:not(.next):not(.prev) {
        background: #fff;
        display: inline-block;
        width: 40px;
        border-radius: 3px;
        margin: 0 2px;
        line-height: 40px;
        height: 40px;
    }
    .search .pagination .prev {
        margin-right: 10px;
    }
    .search .pagination .next {
        margin-left: 10px;
    }
    .search .notfound {
        text-align: center;
    }
}
div.map-marker-label {
    display: flex;
    max-width: 180px;
    word-wrap: break-word;
    text-align: left;
    text-shadow: 1px 1px 0 #ffffff, -1px 1px 0 #ffffff, 1px -1px 0 #ffffff, -1px -1px 0 #ffffff, 1px 0 0 #ffffff, 0 1px 0 #ffffff, -1px 0 0 #ffffff, 0 -1px 0 #ffffff;
    align-items: center;
    min-height: 60px;
    font-size: 16px;
    color: #ad0000;
}

.gm-style-iw.gm-style-iw-c {
  padding: 5px;
  max-width: 320px !important;
}
.gm-style .gm-style-iw-d {
  margin: 0 !important;
  padding: 0 !important;
  width: 330px;
}

.map-info {
    width: 310px;
}
.map-info-title {
    font-weight: bold;
    font-size: 12px;
}
.map-info-distance {
    font-size: 12px;
    color: #777;
    margin: 2px 0 5px;
    padding: 0 0 10px;
    border-bottom: solid 1px #ddd;
}
.map-info-row {
    font-size: 12px;
    padding: 3px;
    display: flex;
}
.map-info-label {
  position: relative;
  display: inline-block;
  width: 90px;
  color: #01627A;
    white-space: nowrap;
}
.map-info-label::after {
  content: '：';
  position: absolute;
  top: 0;
  right: 5px;
}
.map-info-link a,
.map-info-link a:visited {
    font-size: 12px;
    margin-top: 5px;
    text-decoration: underline;
    color: #019FC7;
}