/***** shop *****/
.page_wrapper {display: flex; flex-direction: column; padding-top: 2rem;}
.view_content {padding-bottom: 4rem;}
.shop_top {display: flex; gap: 2rem;}
.shop_top .top_left {width: 70%;}
.section_header {display: flex; align-items: center; gap: 6px; padding-bottom: 10px;}
.sh_tit {font-size: 1rem; font-weight: 700; margin: 0 2px;}
.sh_subtit {color: #777; font-size: 0.9rem; font-weight: 500; margin-top: 3px; margin-left: 5px;}
.rec_filterbox {display: flex; border-radius: 8px; background-color: #F5F7F8; font-size: 0.9rem; overflow: hidden;}
.rec_filterbox .btn_type {display: none; align-items: center; padding: 0.5rem 2.2rem; background-color: #F5F7F8; color: var(--main_c); font-weight: 500; white-space: nowrap; z-index: 2;}
.rec_filterbox .btn_type.sel_act {display: flex;}
.rec_filterbox .filter_item {width: fit-content; padding: 6px 0; color: #999;}
.rec_filterbox .filter_item.sel_act {color: #555; font-weight: 500;}
.filter_item .fi_inner {display: block; padding: 6px 1.5rem; border-radius: 6px; min-width: 7rem; white-space: nowrap; cursor: pointer;}
.filter_item .fi_inner:hover {background-color: #FFF;}
.filter_item.sel_act .fi_inner {background-color: #FFF;}
.rec_box {display: flex; flex-direction: column; gap: 1.8rem; margin-top: 10px; background-color: #F5F7F8; border-radius: 8px; /*padding: 1.5rem 2rem 1rem;*/ overflow: hidden;}
.rec_box .rec_exp {font-size: 0.9rem;}
.rec_tit {font-weight: 600; margin-bottom: 8px;}
.rec_box .rec_exp, .rec_box .rec_msgtype {padding: 1.5rem 2rem 0;}
.rec_msgtype .rec_list {display: flex; flex-wrap: wrap; gap: 8px;}
.rec_msgtype .rec_list span {padding: 4px 16px; background-color: #FFF; border-radius: 6px; color: #777; font-size: 0.9rem;}
.rec_shoplist .rec_tit {padding: 0 2rem;}
.rec_shoplist .shopSwiper {padding: 0 2rem;}
.shopSwiper {overflow-y: auto; padding-block: 4px;}
.shopSwiper.rec_filter {padding-block: 0;}
.shopSwiper .shop_card {display: flex; flex-direction: column; width: 320px; min-height: 150px; padding: 1rem; background-color: #FFF; border-radius: 12px; box-shadow: 0 0 4px rgba(155, 155, 155, 0.1);}
.shop_card .sc_header {display: flex; align-items: center;}
.shop_card .sc_region {color: #999; font-size: 0.85rem;}
.shop_card .sc_name {font-size: 0.95rem; font-weight: 600;}
.shop_card .sc_tag {margin-left: 6px; color: #ED1C85; font-size: 0.7rem; font-weight: 600; padding: 0 8px; border-radius: 99px; border: 1px solid #ED1C85; white-space: nowrap;}
.shop_card .sc_star {color: #999; font-size: 0.85rem; margin-left: auto; white-space: nowrap;}
.shop_card .sc_btime {display: flex; gap: 6px; margin-top: auto; font-size: 0.85rem; color: #999;}
.shop_card .shop_dist {margin-left: auto;}
.shop_card .sc_bottom {display: flex; align-items: center; gap: 6px; padding: 2px 10px; margin-top: 5px; margin-inline: -2px; border-radius: 6px; background-color: #F5F7F8; color: #777; font-size: 0.85rem;}
.rec_more {display: flex; margin-top: 1rem; padding: 0 2rem 1rem;}
.btn_more {margin-left: auto; color: #999; font-size: 0.85rem;}
.btn_more:hover {color: #393939;}

.shop_top .top_right {position: sticky; top: 90px; flex-grow: 1; display: flex; flex-direction: column; gap: 1.8rem; height: fit-content;}
.bg_map {position: relative; display: flex; justify-content: center; align-items: center; gap: 4px; width: 100%; height: 140px; border-radius: 8px; background: url('/assets/img/bg_map.png') center / cover no-repeat; overflow: hidden;}
.bg_map.dim_over {flex-direction: column;}
.bg_map.dim_over .access_txt {color: #FFF; font-weight: 500; z-index: 1; padding: 0 1rem; word-break: keep-all;}
.bg_map.dim_over .btn_access_loc {margin-top: 8px; background-color: var(--main_c); border-radius: 99px; padding: 4px 25px; color: #FFF; font-size: 0.85rem; font-weight: 500; z-index: 1;}
.top_right .bg_map::after {position: absolute; content: ""; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(235, 235, 235, 0.6);}
.top_right .bg_map.dim_over::after {background-color: rgba(80, 80, 80, 0.8);}
.bg_map span, .bg_map i {color: #555; font-size: 0.95rem; font-weight: 500;}
.shop_rankbox {display: flex; flex-direction: column; padding: 1rem; border-radius: 8px; background-color: #FFF; border: 1px solid #e1e1e1; font-size: 0.9rem;}
.shop_rankbox .rank_item {display: flex; align-items: center; gap: 10px; border-radius: 4px; padding: 0.4rem 0.2rem;}
.shop_rankbox .rank_item:hover {background-color: #FAFAFA;}
.rank_item .rank_icon {display: flex; align-items: center; justify-content: center; width: 30px;}
.rank_item .rank_icon i {font-size: 8px; color: #ED1C85;}
.rank_item .rank_icon.icon_down i {transform: rotate(180deg); color: #0722b8;}
.loc_granted {display: flex; flex-direction: column;}
.bg_map .cur_loc {z-index: 1;}
.bg_map .sel_loc {z-index: 1; display: flex; align-items: center; gap: 5px; margin-top: 5px;}
.bg_map .sel_loc select {padding: 6px 10px; font-size: 13px; margin: 0; backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(30px); background-color: rgba(255, 255, 255, 0.4); min-width: 120px; width: fit-content;}
.find_cur_loc {display: flex; align-items: center; gap: 3px; font-size: 11.4px; color: #999; padding: 0px 6px; border-radius: 99px; border: 1px solid #ccc; white-space: nowrap;}


.shop_list_inner {max-width: 1400px; padding-bottom: 4rem;}
.shop_listbox {margin-top: 3rem; overflow: hidden; min-height: 15rem;} /*250909 min-height 지우기*/
.shop_listbox .section_header {margin-bottom: 10px;}
.shopSwiper .shop_filter_item,
.shopSwiper .shop_filter_btn {width: fit-content; padding: 3px 15px; border-radius: 99px; background-color: #FFF; color: #555; font-size: 0.9rem; box-shadow: 0 0 6px rgba(0, 0, 0, 0.07);}
.shop_sort {width: fit-content;}
.shop_sort select {appearance: none; -webkit-appearance: none; -moz-appearance: none; width: fit-content; background-color: #64D0D7; border-radius: 99px; padding: 3px 20px; padding-right: 30px; box-shadow: 0 0 6px rgba(0, 0, 0, 0.07); color: #FFF; font-size: 0.9rem;}
.shop_sort::after {right: 8px; color: #FFF;}
.shop_sort select option {background-color: #FFF !important; color: #393939;}
.shop_list {display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem 1rem; margin-top: 1rem;}
.shop_img_card {position: relative; border-radius: 8px; border: 1px solid #E8E8E8; background-color: #FFF; box-shadow: 0 4px 10px rgba(155, 155, 155, 0.15); overflow: hidden;}
.shop_img_card a {display: flex; flex-direction: column; height: 100%;}
.shop_img_card .card_img {padding-bottom: 50.25%; background-position: center; background-size: cover; background-repeat: no-repeat; flex-shrink: 0;}
.shop_img_card .card_info {display: flex; flex-direction: column; height: 100%;}
.card_info .sc_header {padding: 1rem; padding-bottom: 2px;}
.card_info .sc_region {padding: 1rem; padding-top: 0;}
.card_info .info_course {font-size: 0.95rem; font-weight: 500;}
.card_info .bg_grey {display: flex; justify-content: space-between; align-items: flex-end; min-height: 4.8rem; gap: 1rem; margin-top: auto; padding:1rem; background: #fafafa;}
.card_info .bg_grey .info_price {display: flex; flex-direction: column; align-items: flex-end; margin-left: auto;}
.info_price .origin_price_box {display: flex; align-items: center; gap: 5px; font-size: 0.9rem; margin-bottom: -3px;}
.info_price .origin_price_box .sale_percent {color: #EF4646;}
.info_price .origin_price_box .origin_price {color: #999; text-decoration: line-through; text-decoration-color: #aaa;}
.info_price .final_price {font-size: 1.05rem; font-weight: 600;}
.shop_img_card .dim_over {position: absolute; top: 0; left: 0; background-color: rgb(18 22 22 / 70%); width: 100%; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center; color: #FFF; font-weight: 500;}
.shop_img_card.open .dim_over {display: none;}
/*모바일뷰 하단내비게이션,지도모달보기버튼*/
.bottom_nav {display: none; position: fixed; bottom: 0; left: 0; width: 100%; height: 60px; background: #fff; border-top: 1px solid #ddd; z-index: 10;}
.nav_content {max-width: 35rem; margin: 0 auto; height: 100%; display: flex; justify-content: space-around; align-items: center;}
.nav_content a {text-decoration: none; color: #333; font-size: 12px; display: flex; flex-direction: column; align-items: center; justify-content: center;}
.nav_content i {font-size: 20px; margin-bottom: 3px;}
.btn_modal_map {position: fixed; bottom: 20px; left: 50%; transform: translateX(-50%); background: #000; color: #fff; padding: 0.5rem 1rem; border-radius: 99px; border: none; font-size: 0.9rem; display: flex; align-items: center; gap: 6px; z-index: 11; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);}
.btn_modal_map i {font-size: 1rem;}
/*shop/view*/
.menu_list {display: flex; align-items: center; height: 100%; gap: 1rem;}

.jobs_sh .menu_list {flex-wrap: wrap; gap: 0.5rem;}
.menu_list .menu_item {display: flex; justify-content: center; align-items: center; width: fit-content; height: 100%; cursor: pointer; color: #999999; font-weight: 500;}
.menu_list .sel_filter_item {position: relative; height: fit-content; padding: 4px 1.5rem 4px 0.6rem; color: #777; background-color: #f2f2f2; border-radius: 6px; font-size: 0.9rem; white-space: nowrap;}
.menu_list .sel_filter_item::after {position: absolute; font-family: "RemixIcon"; content: "\EB98"; top: 50%; transform: translateY(-50%); right: 7%;}
.shop_sh .wide_view {margin: 0 auto;}
.shop_sh .menu_list .menu_item {position: relative; padding: 18px 0; min-width: 4rem;}
.shop_sh .menu_list .menu_item:hover,
.shop_sh .menu_list .menu_item.sel_act {color: #424242; font-weight: 600;}
.shop_sh .menu_list .menu_item.sel_act::after {position: absolute; content: ""; bottom: 0; left: 0; width: 100%; height: 3px; background-color: #333;}

.gallery_area {position: relative; display: flex; gap: 10px; margin-bottom: 1.5rem; height: clamp(200px, 50vw, 400px);}
.gallery_area .gal_main {flex: 1; height: auto; border-radius: 16px 0 0 16px; overflow: hidden;}
.gallery_area .gal_main.dft_img {border-radius: 16px;}
.gallery_area .gal_sub {flex: 1.2; display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; border-radius: 0 16px 16px 0; overflow: hidden;}
.gallery_area .gal_sub >*:last-child:nth-child(odd) {grid-column: span 2;}
.gallery_area .gal_img {width: 100%; height: 100%;}
.db_show_img {position: absolute; bottom: 14px; right: 14px; font-size: 1.4rem; color: #FFF;}
.db_show_img:hover {transform: scale(1.1);}

.info_list_area {display: flex; gap: 40px;}
.info_list_area .list_container {display: flex; flex-direction: column; flex-grow: 1; gap: 3rem;}
.list_container .cont_tit {flex-direction: column; align-items: flex-start; margin: 0; gap: 6px;}
.list_container .cont_tit .tit_sub {color: #777; margin-top: 2px;}
.list_container .cont_tit .tit_txt {font-size: 1.4rem; font-weight: 600;}
.sec_tit {color: #999; font-weight: 600;}
.sec_cont {margin-top: 12px;}
.sec_cont .course_name {color: #333; font-weight: 600; margin-bottom: 10px;}
.sec_cont .course_name:not(:first-child) {margin-top: 20px;}
.sec_cont .course_list {display: flex; flex-direction: column;}
.sec_cont .item_box {display: flex; gap: 1.3rem; background-color: #f5f5f5; border-radius: 8px; padding: 1rem; margin-bottom: 12px;}
.item_box.use_info {flex-direction: column; gap: 0;}
.item_box .info_tit {font-weight: 600;}
.item_box .info_list {display: flex; flex-direction: column; gap: 16px; font-weight: 600;}
.item_box .info_box .box_label {display: flex; align-items: center; gap: 6px; margin-bottom: 6px;}
.item_box .info_box .box_label i {font-size: 5px;}
.item_box .info_box .box_text {margin-left: 12px; line-height: 1.6; font-weight: 400;}
.item_box .item_txt {position: relative;}
.item_box .item_txt span {word-break: keep-all; line-height: 1.4;}
.item_box .item_txt .btn_subtxt {color: #777; font-size: 14px; margin-left: 5px; transition: none; text-decoration: underline 1px #999;}
.item_box .item_txt .btn_subtxt:hover, .item_box .item_txt .btn_subtxt.sel_act {color: #333; font-weight: 600; text-decoration: underline 1px #999; text-underline-offset: 2px;}
.item_box .item_txt .all_time {right: 0; display: flex; flex-direction: column; width: auto; min-width: 0; gap: 16px; border-radius: 8px; border: 1px solid #E1E1E1;}
.item_box .item_detail {flex: 1;}
.item_box .item_detail .detail_title {font-weight: 700; padding-bottom: 12px;}
.item_box .item_detail .detail_desc {color: #777; font-size: 0.95rem; font-weight: 500;}
.item_box .item_price {display: flex;}
.item_price .price_box {padding: 0.6rem; text-align: right;}
.item_price .price_box .price_text {color: #777; font-size: 0.95rem; font-weight: 700; margin-bottom: 8px;}
.item_price .price_box .sale_box {display: flex; margin-bottom: 2px;}
.sale_box .sale_percent {color: #ff3100; margin-right: 5px;}
.sale_box .origin_price {color: #aaa; text-decoration: line-through; flex: 1;}
.item_price .price_box .final_price {font-size: 1.1rem; font-weight: 600;}
.sec_cont .shop_intro {color: #333; font-weight: 500; line-height: 1.8;}

.info_list_area .floating_box {position: sticky; top: calc(var(--basic_header_height) + 80px); flex-shrink: 0; width: 40%; max-width: 430px; height: fit-content; color: #333;}
.info_list_area .floating_box .summary_list {padding: 0.8rem 1rem; border-radius: 16px; border: 1px solid #d9d9d9;}
.info_list_area .floating_box .summary_list.on {box-shadow: 0 0 10px rgba(217, 217, 217, 0.4);}
.summary_list .sum_item {padding: 1.4rem 0.8rem; display: flex; flex-direction: column; gap: 12px;}
.summary_list .sum_item:not(:last-child) {border-bottom: 1px solid #E1E1E1;}
.summary_list .sum_item .item_box {display: flex; gap: 6px; font-size: 0.95rem;}
.summary_list .sum_item .btn_call {width: 100%; margin-top: 12px; padding: 10px; background-color: #393939; border-radius: 8px; color: #fff; font-weight: 500; text-align: center; z-index: 10;}
.summary_list .sum_item .btn_call:hover {background-color: var(--main_c);}
.info_list_area .floating_box .btn_report {width: 100%; padding: 14px; color: #ccc;}
.info_list_area .floating_box .btn_report:hover {color: #333;}
.map_area {margin-top: 50px;}
.map_wrap {border-radius: 8px; overflow: hidden; margin-top: 10px;}
.map_wrap #staticMap {width: 100%; height: 380px;}

/*shop filter*/
.btn_modal_close {margin-left: 0; margin-right: 6px;}
.btn_modal_close i {color: inherit; font-size: 1.2rem; font-weight: 300;}
.modal_content .mc_select {padding: 0.8rem 1.2rem;}
.shop_modal .modal_content {width: 90%; max-width: 700px;}

.sel_box {flex: 1; min-width: 0;}
.sel_content {display: flex; flex-wrap: wrap; margin-bottom: 1.5rem; margin-right: 0.6rem; gap: 0.5rem;}
.sel_tit {margin-left: 4px; margin-bottom: 8px; width: 100px; color: #393939; font-size: 0.9rem; font-weight: 600;}
.sel_content .sel_item {width: fit-content; padding: 0.2rem 1rem; border-radius: 99px; background: #FFF; color: #999; font-size: 0.9rem; box-shadow: inset 0 0 0.8px 0.5px #ccc; cursor: pointer; white-space: nowrap;}
.sel_content .sel_item.sel_act {background-color: rgba(var(--main_c_rgb), 0.15); box-shadow: inset 0 0 0.8px 0.5px var(--main_c); color: var(--main_c);}
.sel_content .sel_item input[type="checkbox"] {display: none;}

.set_loc_wrap {flex-wrap: nowrap;}
.shop_modal .custom_selbox {width: 100%;}
.shop_modal .custom_sel {width: 100%;}

/**~~~~**/
.shop_filterbox {overflow: visible; padding-right: 1.5rem;}
.shop_filterbox .btn_reset {border: 1px solid rgba(var(--main_c_rgb), 0.8); color: var(--main_c) !important; font-size: 0.86rem;}

.shop_filter_item {position: relative;}
.shop_filter_item.sel_act>button {color: var(--main_c);}
.shop_filter_item>button {color: #555;}
.shop_filter_item .shop_chkbox {position: absolute; top: 120%; left: 0; width: auto; min-width: 200px; height: auto; padding: 0.8rem; background-color: #FFF; border-radius: 8px; box-shadow: 0 0 6px rgba(155,155,155,0.3);}
.sel_loc .custom_selbox {width: 100%;}
.sel_loc .custom_sel {width: 100%; padding: 0.5rem 1rem;}

.map_loading_hidden {position: absolute; left: -3000px;}
@media (max-width: 1280px) {
	.shop_list {grid-template-columns: repeat(3, 1fr);}
}

@media (max-width: 1024px) {
	.shop_top .top_left {width: 66%;}
	.bg_map.dim_over .access_txt {font-size: 0.86rem;}
	/*shop/view*/
	.gallery_area .gal_main, .gallery_area .gal_sub {flex: 1;}
	.gallery_area .gal_sub {grid-template-columns: 1fr;}
	.gallery_area .gal_sub .gal_img:nth-child(3), .gallery_area .gal_sub .gal_img:nth-child(4) {display: none;}
	.info_list_area {flex-direction: column;}
	.info_list_area .floating_box {width: 100%; max-width: none; position: static;}
	.sec_cont .item_box {flex-direction: column;}
	.item_box .item_price {align-self: flex-end;}
}

@media (max-width: 900px) {
	.shop_list {grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));}
}

@media (max-width: 768px) {
	/*shop/list*/
	.shop_top {flex-direction: column-reverse;}
	.shop_top .top_left {width: 100%;}
	.shop_top .top_right {position: static;}
	.filter_item .fi_inner {min-width: 0;}
	.rec_box .rec_exp, .rec_box .rec_msgtype {padding: 1rem 1rem 0;}
	.rec_shoplist .rec_tit, .rec_shoplist .shopSwiper {padding: 0 1rem;}
	.rec_more {padding: 0 1rem 1rem;}
	.ss_rank {display: none;} /**/
	/*shop*/
	.bottom_nav {display: block;}
	.preset_box {flex-direction: column; padding: 0;}
	.preset_box .preset_tabs {flex-direction: row; justify-content: space-around; margin: 0; padding: 0; width: 100%;}
	.preset_box .preset_tabs .preset_tab {position: relative; padding: 1rem; width: 100%; border-bottom: 2px solid #e8e8e8;}
	.preset_box .preset_tabs .preset_tab.sel_act {border-color: var(--main_c);}
	.preset_box .preset_group {gap: 2rem;}
	.location_box {flex-direction: column; gap: 6px; padding: 1rem;}
	.location_box .cur_loc, .location_box .sel_loc, .custom_selbox_wrap {width: 100%;}
	/* .location_box .cur_loc .cur_loc_txt, .location_box .cur_loc .find_cur_loc {margin-right: 0;} */
	/* .btn_modal_map {bottom: 80px;} */
	.filter_box {flex-direction: column; display: none;}
	.filter_box.open {display: flex; padding: 1rem;}
	.filter_box .sel_box:not(:last-child) {border: none; border-bottom: 1px solid #E8E8E8; padding-bottom: 1rem;}
	.filter_box_icon {display: inline-block;}
	.shop_filter_box {display: none;}
	.shop_filter_box.open {display: flex;}
	.shop_bottom {margin-bottom: 80px;}
}

@media (max-width: 600px) {
	.map_wrap #staticMap {height: 200px;}
	.shop_filter_item .shop_chkbox {min-width: 0; flex-wrap: nowrap; flex-direction: column; align-items: center; left: 50%; transform: translateX(-50%);}
}