@charset "utf-8";

/* 임시 */
.sub_content_wrap{width: 100%;}
#menu{display: none;}
#sub_content{width: 100%;}

/* 대상 (초, 중, 고) */
.target{display: inline-block; vertical-align: top; width: 22px; height: 22px; line-height: 22px; border-radius: 50%; text-align: center; color: #fff; background-color: #ddd; font-size: 12px; text-indent: -1px; font-family: 'NotoB';}
.target:last-of-type{margin-right: 4px;}
.target.elementary{background-color: #e25d2f;}
.target.middle{background-color: #306ee0;}
.target.high{background-color: #318a28;}

/* 리스트 타입 */
.dot{}
.dot > li{position: relative; padding: 0 0 0 12px; margin: 0 0 3px; line-height: 130%;}
.dot > li:before{content: ""; position: absolute; top: 6px; left: 0; display: block; width: 5px; height: 5px; border-radius: 50%; background-color: #80705d;}

/* 세로 스크롤 박스 */
.scroll_box{overflow-y: auto; height: 120px; padding: 3px 0 0;}
.scroll_box::-webkit-scrollbar{width: 6px;}
.scroll_box::-webkit-scrollbar-thumb{background-color: #ddd;}
.scroll_box::-webkit-scrollbar-track{background-color: transparent;}

/* 페이징 (왼쪽 검색결과목록 하단) */
.pagination.map {display: inline-block; padding-left: 0; margin: 0; border-radius: 3px; white-space: nowrap; font-family:NotoDL; background-color: transparent; height: auto;}
.pagination.map > li {color: #7a878e}
.pagination.map > li {display: inline}
.pagination.map > li:first-child > a,
.pagination.map > li:first-child > span {border-top-left-radius: 3px; border-bottom-left-radius: 3px}
.pagination.map > li:last-child > a,
.pagination.map > li:last-child > span {border-top-right-radius: 3px; border-bottom-right-radius: 3px}

.pagination.map > li > a:focus,
.pagination.map > li > a:hover,
.pagination.map > li > span:focus,
.pagination.map > li > span:hover{z-index: 2; color: #fff; background-color: rgba(255,255,255,0.1); border-color: #fff;}

.pagination.map .disabled > a,
.pagination.map .disabled > span {box-shadow: none !important; color: #dbdee0 !important;}
.pagination.map > .disabled > a,
.pagination.map > .disabled > a:focus,
.pagination.map > .disabled > a:hover,
.pagination.map > .disabled > span,
.pagination.map > .disabled > span:focus,
.pagination.map > .disabled > span:hover {color: #777 !important; cursor: not-allowed; background-color: #fff; border-color: #ddd;}

.pagination.map > li > a,
.pagination.map > li > span {position: relative; float: left; box-sizing: border-box; width: 33px; height: 37px; line-height: 35px; padding: 0; text-align: center; margin-left: -1px; color: #ccc; text-decoration: none; background-color: #333; border: 1px solid #777;}

.pagination.map > .active > a,
.pagination.map > .active > span,
.pagination.map > .active > a:hover,
.pagination.map > .active > span:hover,
.pagination.map > .active > a:focus,
.pagination.map > .active > span:focus {background-color: #80705d; border-color: #80705d; z-index: 3; color: #fff !important; cursor: default;}

/* 페이징 추가 (왼쪽 검색결과목록 하단) */
.pagination.map > li.page-start > a,
.pagination.map > li.page-pre > a,
.pagination.map > li.page-next > a,
.pagination.map > li.page-end > a{font-size: 0; text-indent: -9999px;}
.pagination.map > li.page-start > a:before,
.pagination.map > li.page-end > a:before{content: ""; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); display: block; width: 11px; height: 11px; background: url("/images/web/common/page_arrow2.png") no-repeat;}
.pagination.map > li.page-pre > a:before,
.pagination.map > li.page-next > a:before{content: ""; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); display: block; width: 11px; height: 11px; background: url("/images/web/common/page_arrow.png") no-repeat;}
.pagination.map > li.page-next > a:before,
.pagination.map > li.page-end > a:before{transform: translate(-50%, -50%) rotate(180deg);}

/* 지도 영역 전체 */
.map{position: relative; height: calc(100vh - 210px); font-family: 'NotoR'; background-color: #acc;}

/* 지도 영역 왼쪽 검색 */
.map_search{position: absolute; z-index: 10; top: 0; left: 0; width: 320px; max-width: 100%; height: 100%; box-sizing: border-box; padding: 0 0 100px; background-color: #333; color: #fff; transition: all 0.3s;}
.map_search.fold{left: -320px;}
.map_search .top{padding: 30px 25px 0 30px;}
.map_search .top .sch_wrap{position: relative; /*border-radius: 4px;*/ overflow: hidden; color: #fff;}
.map_search .top .sch_wrap input[type="search"]{float: left; width: calc(100% - 60px); height: 40px; padding: 0 12px; box-sizing: border-box; border: none; border-radius: 4px 0 0 4px; background-color: #555;}
.map_search .top .sch_wrap input[type="search"] + label{}
.map_search .top .sch_wrap .btn_resource_search{display: inline-block; width: 60px; line-height: 40px; border-radius: 0 4px 4px 0; font-family: 'NotoB'; background-color: #ff875e;}
.map_search .top .length{margin: 15px 0; text-align: center; font-size: 14px;}
.map_search .top .length .number{display: inline-block; padding: 0 7px; margin: 0 0 0 3px; border-radius: 20px; font-family: 'NotoB'; background-color: #80705d;}
.map_search .mid{padding: 0 25px 0 30px; height: calc(100% - 121px); /*전체 - 탑높이*/}
.map_search .mid .resource_list{height: 100%; padding-right: 10px; box-sizing: border-box;}
.map_search .mid .resource_list::-webkit-scrollbar{width: 6px;}
.map_search .mid .resource_list::-webkit-scrollbar-thumb{background-color: #666; border-radius: 10px;}
.map_search .mid .resource_list::-webkit-scrollbar-track{background-color: transparent;}
.map_search .mid .resource_list > li{padding: 15px 0; border-top: 2px solid rgba(255,255,255,0.1);}
.map_search .mid .resource_list > li > a{}
.map_search .mid .resource_list > li .tit{}
.map_search .mid .resource_list > li .tit .name{vertical-align: top; color: #fff; font-family: 'NotoM';}
.map_search .mid .resource_list > li .place{margin: 4px 0 0; font-size: 14px; font-family: 'NotoM'; color: #fbf4e4;}
.map_search .mid .resource_list > li .tag_list{margin: 6px 0 0;}
.map_search .mid .resource_list > li .tag_list:after{content: ""; display: block; clear: both;}
.map_search .mid .resource_list > li .tag_list > li{display: inline-block; float: left; margin: 3px 3px 3px 0px;}
.map_search .mid .resource_list > li .tag_list .tag{display: block; padding: 3px 10px; border-radius: 26px; font-size: 13px; font-family: 'NotoM'; color: #fff; background-color: #555;}
.map_search .bottom{position: absolute; bottom: 0; left: 0; width: 100%; margin: 20px auto;}
.btn_sch_toggle{position: absolute; left: 100%; margin: 0 0 0 -2px; top: 50%; transform: translateY(-50%); display: block; width: 25px; height: 50px; border-radius: 0 5px 5px 0; font-size: 0; text-indent: -9999px; background-color: #333; cursor: pointer;}
.btn_sch_toggle:before{content: ""; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); display: block; width: 0; height: 0; border-right: 7px solid #fff; border-top: 4px solid transparent; border-bottom: 4px solid transparent;}
.map_search.fold .btn_sch_toggle{}
.map_search.fold .btn_sch_toggle:before{border-left: 7px solid #fff; border-top: 4px solid transparent; border-bottom: 4px solid transparent; border-right: none;}

/* 지도 뷰 영역 */
.map_view{position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: #ddd;}
.map_view .marker{position: absolute; top: 50%; left: 30%;}

@media (max-width: 1400px){
    .map{height: calc(100vh - 120px);}
    .map_search{width: 100%;}
    .map_search.fold{left: -100%;}
    .btn_sch_toggle{left: auto; right: 0; background-color: #fff; border-radius: 5px 0 0 5px;}
    .btn_sch_toggle:before{border-right: 7px solid #333; border-top: 4px solid transparent; border-bottom: 4px solid transparent; border-left: none;}
    .map_search.fold .btn_sch_toggle{left: 100%; right: auto; background-color: #333; border-radius: 0 5px 5px 0;}

    .map_view .marker{height: auto; width: 30px;}
}
@media (max-width: 580px){
    .map{height: calc(100vh - 94px);}
}
@media (max-width: 568px){
    .map_view .marker{width: 25px;}
}



/* 레이어 공통 */
.layer{display: none; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); box-sizing: border-box; padding: 20px 20px 20px 20px; border-radius: 4px 0px 4px 4px; box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.3); background-color: #fff;}
.layer.on{display: block;}
.layer .btn_close_layer{position: absolute; bottom: 100%; margin: 0 0 -1px; right: 0; border-radius: 4px 4px 0 0; box-shadow: 0px -5px 10px -5px rgb(0 0 0 / 30%); background-color: #fff; line-height: 0; font-size: 0; cursor: pointer;}
.layer .btn_close_layer span{position: relative; display: inline-block; width: 12px; height: 12px; background-color: #fff; margin: 6px 9px;}
.layer .btn_close_layer span:before,
.layer .btn_close_layer span:after{content: ""; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) rotate(45deg); display: block; width: 120%; height: 2px; background-color: #7f7f7f;}
.layer .btn_close_layer span:after{transform: translate(-50%, -50%) rotate(-45deg);}
.layer .tit{line-height: 150%; font-family: 'NotoM';}
.layer .tit .name{vertical-align: top; color: #333; font-size: 18px;}
.layer .tit .place{margin: 5px 0 0; color: #80705d; font-size: 15px; text-align: center;}

.cluster_list{}
.cluster_list > li{position: relative; padding: 0 0 0 12px; margin: 0 0 3px; line-height: 130%;}
.cluster_list > li:before{content: ""; position: absolute; top: 8px; left: 0; display: block; width: 5px; height: 5px; border-radius: 50%; background-color: #80705d;}
.cluster_list > li  a:hover,
.cluster_list > li  a:focus{text-decoration: underline;}

/* 레이어 - 클러스트 클릭 시 마을자원 목록 */
.layer.cluster{width: 240px; height: 160px; padding: 20px 10px 20px 20px;}
.layer.cluster .mid{height: 120px;}

/* 레이어 - 마커 클릭 시 상세보기 버튼 */
.layer.detail_view{width: 260px; left: 80%;}
.layer.detail_view.code2{top: 70%;}
.btn_detail_view{display: inline-block; box-sizing: border-box; padding: 8px 25px; margin: 20px 0 0; border-radius: 4px; background-color: #ff875e; font-family: 'NotoB'; color: #fff;}

/* 상세정보 */
.detail_info_wrap{display: none; position: relative; height: 100%; padding: 0 0 0 320px; transition: all 0.3s;}
.detail_info_wrap.on{display: block;}
.detail_info_wrap.expand{padding: 0;}
.detail_info{height: 100%; box-sizing: border-box;  padding: 40px 90px; background-color: #f6f6f6; color: #333;}
.detail_info .name{font-size: 32px; font-family: 'NotoB'; padding: 0 70px 0 0;}
.detail_info .place{padding: 10px 0 0; font-size: 22px; font-family: 'NotoB'; color: #80705d;}
.detail_info .detail_list{overflow-y: auto; height: calc(100% - 132px); box-sizing: border-box; padding: 0; margin: 40px 0 0; border-top: 3px solid #d1d1d1;}
.detail_info .detail_list > li{border-bottom: 1px solid #d1d1d1; font-size: 18px; padding: 22px 0 22px 30px;}
.detail_info .detail_list > li:before{top: 31px; left: 10px;}
.detail_info .detail_list > li:after{content: ""; display: block; clear: both;}
.detail_info .detail_list > li .tit{float: left; width: 170px; font-family: 'NotoB';}
.detail_info .detail_list > li > p{float: left; width: calc(100% - 170px); padding: 0 0 0 15px; box-sizing: border-box;}
.btn_close_detail{position: absolute; top: 30px; right: 27px; display: block; width: 70px; height: 70px; background-color: #ff875e; border-radius: 4px; font-size: 0; cursor: pointer;}
.btn_close_detail:before,
.btn_close_detail:after{content: ""; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) rotate(45deg); width: 55%; height: 6px; border-radius: 6px; background-color: #fff;}
.btn_close_detail:after{transform: translate(-50%, -50%) rotate(-45deg);}
@media (max-width: 1400px){
    .detail_info_wrap{padding: 0;}
}
@media (max-width: 1200px){
    .detail_info{padding: 40px 60px;}
}
@media (max-width: 768px){
    .detail_info{padding: 30px 35px;}
    .detail_info .name{font-size: 24px; padding: 0 35px 0 0;}
    .detail_info .place{font-size: 17px; padding: 0;}
    .detail_info .detail_list{height: calc(100% - 83px); margin: 20px 0 0;}
    .detail_info .detail_list > li{font-size: 15px; padding: 15px 0 15px 20px;}
    .detail_info .detail_list > li:before{top: 21px; left: 5px;}
    .detail_info .detail_list > li .tit{width: 70px;}
    .detail_info .detail_list > li > p{width: calc(100% - 70px); padding: 0;}
    .btn_close_detail{width: 35px; height: 35px;}
    .btn_close_detail:before,
    .btn_close_detail:after{height: 3px;}
}
@media (max-width: 568px){
    .detail_info{padding: 30px 30px;}
}
