@charset "utf-8";
@import url("contents.css");
@import url("popup.css");

/* header */
header h1{ border-bottom: 1px solid #D9D9D9; border-right: 1px solid #D9D9D9; top: 0px !important; position: relative !important;}
header h1 a{ display: block; background: url(/images/house/common/logo.png) no-repeat center center; width: 79px; height: 55px;}
/* header top */
.top-area{ position: fixed; top: 0; left: 0; display: flex; justify-content: space-between; width: 100%; height:55px; border-bottom: 1px solid #D9D9D9; background-color: #fff; box-sizing: border-box; z-index: 1100; min-width: 800px;}
.top-area .top-area__left{ display: flex; align-items: center; }
.top-area .top-area__left h2 a{ position: relative; margin:16px 30px 16px 20px; width: 69px; height: 28px; display: inline-block;}
.top-area .top-area__left h2 a::before { position: absolute; top: 0; left: 0; content: ''; background: url(/images/house/common/sistem_logo.svg) no-repeat 0 0; width: 69px; height: 28px;}

/*top-left map location*/
.top-area .top-area__left .map-setting{ position: relative; }

/*map-location 지역정보*/
.top-area__left .map-setting__location{ position: relative; display: flex; align-items: center; border: 1px solid #D3D3D3;; border-radius: 22px; height: 36px;  padding:0 12px 0 40px; box-sizing: border-box; cursor: pointer;}
.top-area__left .map-setting__location::before{ position: absolute; top: 50%; left: 13px; width: 24px; height: 24px; transform: translateY(-50%); -webkit-transform: translateY(-50%); background: url(/images/house/icon/icon_map_pin.svg) no-repeat 0 0; content: '';}
.top-area__left .map-setting__location span{ position: relative; }
.top-area__left .map-setting__location span:not(:first-child){ margin-left: 25px;}
.top-area__left .map-setting__location span:not(:first-child)::before{ position: absolute; top: 50%; left: -20px; width: 20px; height: 20px; transform: translateY(-50%); -webkit-transform: translateY(-50%); background: url(/images/house/common/chevron_right.svg) no-repeat 0 0; content: '';}
.top-area__left .map-setting__location span:last-child{ color: var(--color-black); font-weight: 600;}

/*map-select 지역설정*/
.top-area__left .map-setting__select{ display: none; position: absolute; top: 47px; border-radius: 8px; left: 0; background-color: #fff; box-shadow: 6px 6px 18px 0px rgba(0, 0, 0, 0.20); overflow: hidden;}
.top-area__left .map-setting__select > div{ display: flex;}
.top-area__left .map-setting__select .map-setting-list{ width: 364px;} 
.top-area__left .map-setting__select .map-setting-list ul{ height: 228px; flex: 1;}
.top-area__left .map-setting__select .map-setting-list ul:not(:first-child){ border-left: 1px solid #D3D3D3; }
.top-area__left .map-setting__select .map-setting-list ul li{ display: block; cursor: pointer; padding:0 20px; line-height: 38px; letter-spacing: -1px;font-size: 13px;}
.top-area__left .map-setting__select .map-setting-list ul li.active,
.top-area__left .map-setting__select .map-setting-list ul li:hover{ background: var(--color-blue); color: #fff;}

.top-area__left .map-setting__select .map-setting-btn{ display: flex; justify-content: center; align-items: center; padding: 7px 0; gap: 4px; border-top: 1px solid #D3D3D3; }
.map-setting-btn .btn.cancel{ margin-right: 12px;}
.zoom-in,
.zoom-out{ width: 24px; height: 24px; background-position: 50% 50%; background-repeat: no-repeat;}
.zoom-in{ background-image: url(/images/house/common/btn_zoom_in.svg);}
.zoom-out{ background-image: url(/images/house/common/btn_zoom_out.svg);}

/*top-right*/
.top-area .top-area__right{ display: flex; align-items: center; margin-right: 20px;}
.top-area .top-area__right .utill-btn{ display: flex; }
.top-area .top-area__right .utill-btn li{ position: relative;}
.top-area .top-area__right .utill-btn li+li::before{ content: ''; position: absolute; top: 50%; left: 0; transform: translateY(-50%); -webkit-transform: translateY(-50%);  background-color: #D3D3D3; width: 1px; height: 18px;}
.top-area .top-area__right .utill-btn .btn{ position: relative; display: inline; padding: 0 11px 0 31px; outline:none;}
.top-area .top-area__right .utill-btn .btn::before{ content: ''; position: absolute; top: 50%; left: 10px; transform: translateY(-50%); -webkit-transform: translateY(-50%);  width: 16px; height: 18px; background-position: 0 center; background-repeat: no-repeat;}

.top-area .top-area__right .utill-btn .btn:hover::before{ background-position: -16px center;}
.top-area .top-area__right .utill-btn .btn:hover{ color: var(--color-blue); font-weight: 600;}

.top-area .top-area__right .utill-btn .bookmark::before{ background-image: url(/images/house/icon/icon_utill_bookmark.svg);}
.top-area .top-area__right .utill-btn .share::before{ background-image: url(/images/house/icon/icon_utill_share.svg);}
.top-area .top-area__right .utill-btn .save::before{ background-image: url(/images/house/icon/icon_utill_save.svg);}
.top-area .top-area__right .utill-btn .report::before{ background-image: url(/images/house/icon/icon_utill_report.svg);}

#main{ position: absolute; top: 55px; left: 80px; width: calc(100% - 80px); height: calc(100% - 55px); }

/*lnb*/
nav { position: fixed; top: 55px; left: 0; width: 80px; height: 100%; border-right: 1px solid #D9D9D9; background-color: #fff; z-index: 1002; box-sizing: border-box;}
nav .lnb li{ height: 80px; border-bottom: 1px solid #D9D9D9;}
nav .lnb li button{ position: relative; display: block; width: 100%; height: 80px; box-sizing: border-box; padding-top: 38px; text-align: center;}
nav .lnb li button::before{ position: absolute; top: 16px; left: 50%; width: 30px; height: 30px; background-repeat: no-repeat; background-position: 0 0; content: ''; transform: translateX(-50%); -webkit-transform: translateX(-50%); }
nav .lnb li button.simple::before{ background-image: url(/images/house/icon/icon_nav_simple.svg); }
nav .lnb li button.detail::before{ background-image: url(/images/house/icon/icon_nav_detail.svg); }
nav .lnb li button.housing::before{ background-image: url(/images/house/icon/icon_nav_housing.svg); }
nav .lnb li button.help::before{ background-image: url(/images/house/icon/icon_nav_help.svg); }
nav .lnb li.active a::before{ background-position: -30px 0;}

/*lnb active*/
nav .lnb li.active{ background: var(--bg-gradient); box-shadow: 0 8px 8px -8px rgba(27, 83, 227, 0.5);}
nav .lnb li.active button{ color: #fff; font-weight: 600;}
nav .lnb li.active button::before{ background-position: -30px 0; }

/****** nav layer ******/
.nav-layer{ position: absolute; z-index: 1001 !important; left: -395px; width: 394px; height: auto; background-color: #fff; border-radius: 0 0 14px 0; box-shadow: 4px 4px 12px 0px rgba(0, 0, 0, 0.12); z-index: 99; }
.nav-layer.active{ left: 0; } 
/* nav layer 열기 닫기 버튼*/
.nav-layer .nav-layer__btn{ position:absolute; top: 21px; left: 100%; width: 23px; height: 42px; border-radius: 0px 10px 10px 0px; background: #fff; box-shadow: 4px 4px 12px 0px rgba(0, 0, 0, 0.12); }
.nav-layer .nav-layer__btn::before{ position: absolute; top: 10px; left: 0; width: 21px; height: 21px; background: url(/images/house/common/chevron_left.svg) no-repeat 0 0; content: '';  transform:rotate(-180deg); }
.nav-layer.active .nav-layer__btn::before{ transform:rotate(0deg); }

/* nav layer 하단 버튼영역*/
.nav-layer .button-wrap{ display: flex; justify-content: space-between; width: calc(100% - 40px); position: absolute; left: 20px; bottom: 25px; }
.nav-layer .button-wrap > .btn{ position: relative; border-radius: 8px; font-size: 15px; letter-spacing: -1px; background-color: #E9E9E9; color: var(--color-gray); height: 45px;outline: none;}
.btn.redo{ padding-left: 24px; width: 97px;}
.btn.assay{ width: calc(100% - 107px);}
.btn.assay.inquiry{ width: 100%;}
.btn.redo::before{ content: ''; background: url(/images/house/icon/icon_redo.svg) no-repeat -20px 0; position: absolute; top: 50%; left: 16px; transform: translateY(-50%); -webkit-transform: translateY(-50%); width: 20px; height: 20px;}
.btn.redo:hover,
.btn.redo:active,
.btn.redo.active,
.btn.redo:hover::before{color: var(--color-black); background-position: -40px 0; font-weight: 600;}
.btn.assay.active{ color: #fff; background: var(--bg-gradient); font-weight: 700; }
/*하단 버튼 비활성화시*/
.btn.redo:disabled::before{ background-position: 0 0 !important;}
.btn.redo:disabled,
.btn.assay:disabled{ color: #B8B8B8; font-weight: 500; cursor: auto;}
.btn.assay:disabled:hover{ color: #B8B8B8; background: #E9E9E9; }

/* nav layer 추천지역 기본-최소화*/
.nav-layer.type02 { width: 216px; left: 0;}
.nav-layer.type02.active{ width: 394px; left: 0; }

/* nav layer 컨텐츠*/
.nav-layer .nav-layer__box{ height: 100%; max-height: calc(100vh - 195px); padding: 20px 20px 5px; margin-bottom: 90px; }
.nav-layer .nav-layer__box.ty02{ height: 100%; max-height: calc(100vh - 115px); padding: 20px; margin-bottom: 0; }
.nav-layer__box__iner{ width: calc(100% + 6px);}
.nav-layer__box__iner .title-h2{ display: flex; align-items: center; }
.nav-layer__box__iner .title-h2 i.icon-title{ width:32px; height: 32px; background: var(--color-blue) url(/images/house/icon/icon_map_search.svg) no-repeat center center; border-radius: 100%; margin-right: 5px;}
.nav-layer__box__iner .title-h2 .btn.prev{ background: url(/images/house/common/btn_prev.svg) no-repeat 0 0; width: 32px; height: 32px; margin-right: 6px;}
.nav-layer__box__iner h2{ font-size: 18px; font-weight: 700;  color: var(--color-black);}
.nav-layer__box__iner .bg-box{ background-color: #F4F8FF; font-size: 13px; padding: 10px 12px; line-height: 22px; letter-spacing: -1px; border-radius: 6px;}

.nav-layer__box__iner .text-title-wrap{ position: relative; margin-top: 20px;}
.nav-layer__box__iner .text-title-wrap .text-title{ color: var(--color-black); font-weight: 700; font-size: 15px;}

/*도움말*/
.nav-layer.help{ height: 100%; border-radius: 0;  }
.nav-layer.help.active{ width: 300px !important;} 
.nav-layer.help .nav-layer__box{ padding: 16px 20px; margin-bottom: 0; }
.nav-layer.help .menu-help{ color: #202020;}
.nav-layer.help .menu-help h2{ font-size: 18px; font-weight: 700; padding-bottom: 16px; }
.nav-layer.help .menu-help .menu{ border-top: 1px solid #D3D3D3;border-bottom: 1px solid #D3D3D3;}
.nav-layer.help .menu-help .menu > li button{ font-size: 16px; display: block; width: 100%; text-align: left; line-height: 26px; }
.nav-layer.help .menu-help .menu > li{ font-size: 16px; padding: 12px 0; line-height: 26px; }
.nav-layer.help .menu-help .menu > li + li{ border-top: 1px dashed #D3D3D3;}
.nav-layer.help .menu-help .menu > li.active,
.nav-layer.help .menu-help .menu > li button.active,
.nav-layer.help .menu-help .menu > li.active > button{ color: var(--color-blue); font-weight: 700; }
.nav-layer.help .menu-help .menu .sub{ margin-top: 6px; background-color: #F4F4F4; border-radius: 8px; padding: 12px 16px; }
.nav-layer.help .menu-help .menu .sub button{ font-size: 14px; color: var(--color-gray); }
.nav-layer.help .menu-help .menu .sub li{ position: relative; padding-left: 8px; color: var(--color-gray);}
.nav-layer.help .menu-help .menu .sub li.active,
.nav-layer.help .menu-help .menu .sub li button.active{ color: var(--color-blue);}
.nav-layer.help .menu-help .menu .sub li::before{ content: '·'; position: absolute; top: 50%; left: 0;transform: translateY(-50%); -webkit-transform: translateY(-50%);  }
.guide-page { cursor: grab; }
.guide-page:active { cursor: grabbing; }
.guide-page .explan-wrap { display: grid; gap: 20px; grid-template-columns: 1fr 0.5fr; }
.guide-page .explan-wrap img { width: 100%; min-width: 480px; }

/*데이터 보드 - 기본*/
.data-board{ position: absolute; top: 20px; right: 70px; width: 310px; height: 197px; border: 1px solid #D9D9D9; border-radius: 10px; background-color: #fff; box-shadow:  6px 6px 20px 0px rgba(0, 0, 0, 0.20); color: var(--color-black); z-index: 100; }/*mng_20240726 김도영 데이터보드 위치 수정 right 20->70px*/
.data-board .data-board__title{ border-bottom: 1px solid #E9E9E9; padding: 12px 18px; height: 45px; box-sizing: border-box; display: flex; justify-content: space-between; align-items: center;}
.data-board .data-board__title h3{ display: flex; align-items: center; font-weight: 600; font-size: 16px; line-height:45px }

.data-board .data-board__title .btn.more{ background: url(/images/house/common/btn_more_active.svg) no-repeat center center; width: 24px; height: 24px;}
/*.data-board .data-board__title .btn.more:hover,*/
/*.data-board .data-board__title .btn.more:active{ background-image: url(/images/house/common/btn_more_active.svg) }*/
.data-board .data-board__adress{ padding: 8px 17px; }
.data-board .data-board__adress span{ padding-left:27px; font-weight: 600; position: relative; color: #000; letter-spacing: -0.5px; line-height: 24px; }
.data-board .data-board__adress span::before{ position: absolute; top: 50%; left: 0; transform: translateY(-50%); -webkit-transform: translateY(-50%); width: 24px; height: 24px; background: url(/images/house/icon/icon_map_pin.svg) no-repeat 0 0; content: ''; margin-top: -1px;}
.data-board .data-board__list{ padding:0 20px; box-sizing: border-box; position: relative; }
/*데이터 보드 - 데이터없을때*/
.data-board.small{ width: auto; height: 36px; border-radius: 4px; }
.data-board.small .data-board__title{ border: none;  padding: 7px 13px; justify-content: center; height: 36px; }
.data-board.small .data-board__title h3{ font-size: 14px; line-height:22px }

/*데이터 보드 스와이퍼*/
.data-board__list .swiper-wrapper{ position: relative;}
.data-board__list .swiper-wrapper .swiper-slide{ background-color: #F4F8FF; height: 76px; border-radius: 5px; font-size: 14px; line-height: 18px; padding: 15px; overflow: hidden; box-sizing: border-box; word-break: break-all; font-weight: 400;}
.data-board__list .swiper-pagination{ position: absolute; bottom: 18px !important;}
:root{--swiper-theme-color: #1B53E3 !important;}

/* 지도 툴바 ******************/
.control-wrap{ position: absolute; bottom: 40px; right: 20px; z-index: 99; text-align: center; width: 44px; font-size: 12px; }
.control-wrap .control-list:not(.map){ position: relative; border: 1px solid #D9D9D9; border-radius: 8px; background-color: #fff; box-shadow: 4px 4px 12px 0px rgba(0, 0, 0, 0.12);}
.control-wrap .control-list button{ letter-spacing: -0.7px; font-size: 12px; }
/*지표POI 영역 */
.control-list.item{ padding: 42px 0 0; }
.control-list.item:before{  position: absolute; top: 0; left: 0; width: 42px; height: 42px; border-radius: 8px 8px 0 0;  background: #E9EFFF url(/images/house/icon/icon_control_pin.svg) no-repeat center 7px; content: '';}
.control-list.item > ul > li{ position: relative; height: 32px;}
.control-list.item > ul > li .item-title button{ cursor: pointer; z-index: 11; width:100%; height: 32px;}
.control-list.item > ul > li:hover .item-title button,
.control-list.item > ul > li.active .item-title button{ background-color: var(--color-blue); color: #fff; font-weight: 700;}
/*초기화버튼*/
.control-list.item > ul > li .item-title:last-child button{ border-radius: 0 0 8px 8px; background-color: #E9EFFF; color: #1B53E3;}
.control-list.item > ul > li.active .item-title:last-child button{ color: #1B53E3; font-weight: 500;}
.control-list.item > ul > li:hover .item-title:last-child button{ background-color: var(--color-blue); color: #fff; font-weight: 700; }

.control-list.item > ul > li .item-menu{ display: none; position: absolute; top: 0px; right: 100%; background-color:#fff; box-shadow: 4px 4px 12px 0px rgba(0, 0, 0, 0.12); border-radius: 8px 0px 8px 8px; border: 1px solid #D9D9D9; z-index: 111; text-align: left; padding: 13px 11px; font-weight: 400; min-width: 135px; box-sizing: border-box; }
.control-list.item > ul > li .item-menu > li{ position: relative; background-position: 0 0 ; background-repeat: no-repeat; cursor: pointer; }
.control-list.item > ul > li .item-menu > li+li { margin-top: 5px; }
.control-list.item > ul > li .item-menu > li.active > button{ font-weight: 700; color: var(--color-blue);}
.control-list.item > ul > li .item-menu > li label{ display: flex !important; align-items: center; cursor: pointer;}
.control-list.item > ul > li .item-menu > li label span:last-child{ margin-left: 5px; }
.control-list.item > ul > li .item-menu > li > button{ position: relative; display: block; padding-left: 34px; line-height:26px; font-size: 12px; }
.control-list.item > ul > li .item-menu > li > button i{ position: absolute; top: 0; left: 0; width: 26px !important; height: 26px !important; background-repeat: no-repeat; background-image: url(/images/house/icon/spr_icon_item.svg); }


.control-list.item > ul > li .item-menu-sub{ display: none; position: absolute; top: 10px; right: calc(100% + 10px); background-color:#F2F5FF; box-shadow: 1px 3px 4px 0px rgba(0, 0, 0, 0.12); border-radius: 8px 0px 8px 8px; border: 1px solid #D9D9D9; z-index: 111; text-align: left; padding: 13px 11px; font-weight: 400; min-width: 110px; box-sizing: border-box; }
.control-list.item > ul > li .item-menu-sub::before{ content: ''; position: absolute; border-style: solid; border-width: 8px 8px 0 0 ; border-color: #D9D9D9 transparent;	display: block;	width: 0;	z-index: 0;	top: -1px;	left: 100%;}
.control-list.item > ul > li .item-menu-sub::after{	content: ''; position: absolute; border-style: solid; border-width: 7px 7px 0 0 ;	border-color: #F2F5FF transparent;	display: block;	width: 0;	z-index: 1;	top: 0; left: calc(100% - 1px); }
.control-list.item > ul > li .item-menu-sub li > button{ position: relative; display: block; padding-left: 34px; line-height:28px; font-size: 12px;}
.control-list.item > ul > li .item-menu-sub > li > button i{ position: absolute; top: 0; left: 0; width: 28px !important; height: 28px !important; background-repeat: no-repeat; background-image: url(/images/house/icon/spr_icon_item_02.svg); }
.control-list.item > ul > li .item-menu-sub > li:hover{ font-weight: 700; color: var(--color-blue);}

/*지도 확대 축소*/
.control-list.zoom{ margin-top: 4px;}
.control-list.zoom .btn{ position: relative; width: 100%; height: 35px; }
.control-list.zoom .btn::before{ position: absolute; top: 50%; left: 50%; transform: translate(-50% , -50%); content: ''; width: 24px; height: 24px; background-position: 0 0; background-repeat: no-repeat;}
.control-list.zoom .btn.type-zoom-in::before{ background-image: url(/images/house/icon/icon_control_zoomin.svg);}
.control-list.zoom .btn.type-zoom-out::before{ background-image: url(/images/house/icon/icon_control_zoomout.svg); }
.control-list.zoom .btn:hover{ background-color: var(--color-blue); }
.control-list.zoom .btn:hover::before{ background-position: -24px 0; }
.control-list.zoom .btn.type-zoom-in{ border-radius: 8px 8px 0 0;}
.control-list.zoom .btn.type-zoom-out{ border-radius: 0 0 8px 8px;}
.control-list.zoom span{ display: inline-block;}

/*지도측정, 지도선택*/
.control-list.map{ margin-top: 4px; cursor:pointer;}
.control-list.map > ul > li{ position: relative; height: 57px; border: 1px solid #D9D9D9; border-radius: 8px; background-color: #fff; box-shadow: 4px 4px 12px 0px rgba(0, 0, 0, 0.12);}/*mng_20240716 김도영 지도선택 밑에 지도이름 추가하며 height 52->57로 변경*/
.control-list.map > ul > li.setting{ margin-top: 4px;}
.control-list.map > ul > li:hover{border-color: var(--color-blue); background: var(--color-blue);  border-radius: 8px; color: #fff; font-weight: 600;}
.control-list.map > ul > li.active{ border-color: var(--color-blue); background: var(--color-blue); border-radius: 0 8px 8px 8px; color: #fff; font-weight: 600;  }
.control-list.map > ul > li.active:hover{ border-radius: 0 8px 8px 8px; }
.control-list.map > ul > li .item-title button{ position: relative;font-size: 10px !important; letter-spacing: -0.5px !important; width:100%; height: 52px; border-radius: 8px; padding-top: 32px; cursor: pointer; z-index: 11;}
.control-list.map > ul > li .item-title button::before{ position: absolute; content: ''; top: 6px; width: 24px; height: 24px;  left: 50%; transform: translateX(-50%); -webkit-transform: translateX(-50%); background-position: 0 0; background-repeat: no-repeat;}
.control-list.map > ul > li.measure .item-title button::before{background-image: url(/images/house/icon/icon_control_measure.svg);}
.control-list.map > ul > li.setting .item-title button::before{background-image: url(/images/house/icon/icon_control_setting.svg);}
.control-list.map > ul > li.measure:hover .item-title button::before,
.control-list.map > ul > li.measure.active .item-title button::before{ background-position: -21px 0;}
.control-list.map > ul > li.setting:hover .item-title button::before,
.control-list.map > ul > li.setting.active .item-title button::before{ background-position: -24px 0;}
.control-list.map > ul > li:hover button,
.control-list.map > ul > li.active button{ color: #fff;}

.control-list.map .item-menu{ display: none; position: absolute; top: 0px; right: calc(100% + 1px); background-color:#fff; box-shadow: 4px 4px 12px 0px rgba(0, 0, 0, 0.12); border-radius: 8px 0 0 8px; border: 1px solid #D9D9D9; z-index: 111; text-align: left; font-weight: 400; padding:5px 11px 0; height: 44px; box-sizing: border-box; }
.control-list.map .item-menu > ul{ display: flex !important; color: var(--color-gray) ; padding: 0 !important;}
.control-list.map .item-menu > ul > li+li{ margin-left: 15px; }
.control-list.map .item-menu > ul > li a{ display: flex; text-align: center; display: inline-block; font-size: 10px; line-height: 1.2;}
.control-list.map .item-menu > ul > li a i{ width: 18px !important; height: 18px !important; background-repeat: no-repeat; background-image: url(/images/house/icon/spr_icon_map.svg);  display: inline-block; }
.control-list.map .item-menu > ul > li a:hover{ color: var(--color-blue); text-decoration: underline; font-weight: 700; }

