
/*
  CSS 구역 안내
  - :root/body/page-tabs : 공통 변수와 상단 메뉴
  - #map-container/detail-panel : 지도/매물 패널
  - #community-page/post-* : 커뮤니티
  - #hotdeal-page/hd-* : 꿀템
  - modal/auth/report/msg : 모달 UI
  - @media : 모바일 반응형
*/
:root{--forest:#3a4a3c;--pine:#4e6352;--sage:#3d6b47;--mint:#b2c2b6;--gold:#d8d0c4;--gold-lt:#b6a895;--cream:#2f2a25;--sand:#ece7df;--linen:#ffffff;--stone:#8e857b;--charcoal:#383530;--shadow:0 2px 16px rgba(20,20,20,0.05);--shadow-lg:0 10px 36px rgba(20,20,20,0.08);--radius:6px;--radius-lg:10px;--green:#07883d;--green-700:#14663a;--green-900:#143b28;--green-soft:#edf8f2;--yellow-soft:#fff6db;--blue-soft:#edf5ff;--purple-soft:#f5efff;--h-text:#1f2a24;--h-muted:#444;--h-line:#e6ebe8;--h-bg:#f7f9f8;--h-shadow:0 18px 45px rgba(20,59,40,.12);--h-radius:22px;--tabs-h:62px;--mob-tabs-h:56px}
*{margin: 0; padding: 0; box-sizing: border-box}
body{font-family: 'Noto Sans KR',sans-serif; font-size: 16px; overflow: hidden; height: 100vh; background: #f7f9f8; color: #2f2a25; -webkit-font-smoothing: antialiased; line-height: 1.6}
/* ── 모바일 지도 페이지: body overflow 터치 간섭 해제 ── */
@media(max-width:768px){
  html:has(body.map-page-active),
  body.map-page-active{
    /* overflow:hidden 유지하되 iOS Safari 터치 간섭 해제 */
    overflow: hidden !important;
    -webkit-overflow-scrolling: auto !important;
    height: 100vh;
    padding-bottom: 0 !important;
    /* 터치를 하위 요소(카카오맵)로 통과시킴 */
    touch-action: none !important;
  }
}
.page-tabs{position: fixed; top: 0; left: 0; right: 0; z-index: 200; display: flex; align-items: stretch; background: rgba(255,255,255,.92); border-bottom: 1px solid rgba(230,235,232,.95); box-shadow: 0 8px 28px rgba(20,59,40,.08); height: var(--tabs-h); padding: 0 28px; gap: 0; backdrop-filter: blur(14px)}
.page-tab-logo{font-family: Pretendard,'Noto Sans KR',sans-serif; font-size: 1.35rem; font-weight:900!important; color: var(--green-900); letter-spacing: -.04em; display: flex; align-items: center; margin-right: 32px; flex-shrink: 0; gap: 2px}
.page-tab-logo em{color:var(--gold-lt);font-style:normal}
.page-tab-logo small{font-family:'Noto Sans KR',sans-serif;font-size:0.62rem;font-weight:400;color:rgba(255,255,255,0.45);letter-spacing:0.5px;display:block;margin-top:2px;white-space:nowrap}
.page-tab{display: flex; align-items: center; gap: 7px; padding: 0 22px; border: none; background: none; font-family: Pretendard,'Noto Sans KR',sans-serif; font-size: 0.96rem; font-weight: 600; color: #596760; cursor: pointer; border-bottom: 3px solid transparent; margin-bottom: -3px; transition: color 0.2s,border-color 0.2s; white-space: nowrap; letter-spacing: 0.3px}
.page-tab:hover{color:var(--green)}
.page-tab.active{color: var(--gold-lt); border-bottom-color: var(--gold-lt)}
.page-tab-spacer{flex:1}
.page-tab-auth{display:flex;align-items:center;gap:10px;flex-shrink:0}
#hotdeal-page{display:none;position:fixed;inset:0;top:var(--tabs-h);background:#eee8dc;overflow-y:auto;z-index:100}
.hd-hero{background:var(--forest);padding:28px 24px 20px;text-align:center;border-bottom:3px solid var(--gold)}
.hd-hero-title{font-family:'Noto Serif KR',serif;font-size:1.5rem;font-weight:900;color:#fff;margin-bottom:6px}
.hd-hero-title em{color:var(--gold-lt);font-style:normal}
.hd-hero-sub{font-size:0.84rem;color:rgba(255,255,255,0.5);margin-bottom:18px}
.hd-post-btn{padding:14px 32px;background:#b87a10;color:#fff8ee;border:none;border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:0.93rem;font-weight:700;cursor:pointer;transition:all 0.18s;letter-spacing:0.3px;box-shadow:0 2px 8px rgba(140,90,10,0.28)}
.hd-post-btn:hover{background:#9a6508;transform:translateY(-1px);box-shadow:0 4px 12px rgba(140,90,10,0.38)}
.hd-body{max-width:1080px;margin:0 auto;padding:28px 24px 80px}
.hd-filter-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:22px}
.hd-chip{padding:7px 16px;border-radius:20px;border:1.5px solid var(--sand);background:#fff;font-family:'Noto Sans KR',sans-serif;font-size:0.8rem;font-weight:600;color:#444;cursor:pointer;transition:all 0.13s;white-space:nowrap}
.hd-chip:hover,.hd-chip.active{background:var(--pine);border-color:var(--pine);color:#fff}
.hd-sort-right{margin-left:auto;display:flex;gap:7px}
.hd-grid{display:flex;flex-direction:column;gap:9px}
.hd-card{background:#fff;border-radius:var(--radius);border:1px solid #e2ddd3;overflow:hidden;box-shadow:0 1px 6px rgba(30,40,32,0.07);transition:box-shadow 0.18s,border-color 0.18s,transform 0.15s;display:flex;flex-direction:row;align-items:stretch;min-height:112px;cursor:pointer;border-left:4px solid transparent}
.hd-card:hover{box-shadow:var(--shadow-lg);border-left-color:var(--gold);transform:translateY(-1px)}
.hd-card-thumb{width:140px;min-width:140px;background:var(--linen);display:flex;align-items:center;justify-content:center;font-size:3rem;overflow:hidden;position:relative;flex-shrink:0}
.hd-card-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.hd-badge-row{position:absolute;top:6px;left:6px;display:flex;flex-direction:column;gap:3px}
.hd-badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:0.64rem;font-weight:800;letter-spacing:0.4px}
.hd-badge-sale{background:#e67e22;color:#fff}
.hd-card-body{padding:14px 18px 12px;flex:1;display:flex;flex-direction:column;justify-content:center;min-width:0;border-left:1px solid #f0ebe2}
.hd-card-title{font-size: 1rem; font-weight: 700; color: var(--charcoal); margin-bottom: 6px; line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden}
.hd-card-desc{font-size:0.81rem;color:#333;line-height:1.65;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:8px;flex:1}
.hd-card-meta{font-size:0.73rem;color:#333;display:flex;align-items:center;gap:10px}
.hd-card-url{font-size:0.72rem;color:var(--sage);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#hd-write-modal{display:none;position:fixed;inset:0;top:var(--tabs-h);z-index:400;background:#eae4d8;overflow-y:auto}
.hd-modal-box{background:#fff;border-radius:var(--radius-lg);max-width:820px;margin:36px auto 80px;box-shadow:0 4px 32px rgba(0,0,0,0.08);border-top:6px solid var(--gold)}
.hd-modal-head{padding:22px 26px 0;display:flex;align-items:center;justify-content:space-between;font-family:'Noto Serif KR',serif;font-size:1.1rem;font-weight:700;color:var(--forest);margin-bottom:18px;position:sticky;top:0;background:#fff;z-index:2;padding-bottom:16px;border-bottom:1px solid var(--sand)}
.hd-modal-body{padding:20px 26px 26px}
.hd-form-field{margin-bottom:15px}
.hd-form-label{display:block;font-size:0.82rem;font-weight:700;color:var(--forest);margin-bottom:6px}
.hd-form-label .req{color:#c0392b;margin-left:2px}
.hd-form-input{width:100%;padding:11px 14px;border:1.5px solid var(--sand);border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:0.9rem;color:var(--charcoal);background:var(--linen);outline:none;transition:border-color 0.2s}
.hd-form-input:focus{border-color:var(--pine);background:#fff}
.hd-form-textarea{min-height:100px;resize:vertical;line-height:1.8}
.hd-cat-group{display:flex;gap:7px;flex-wrap:wrap}
.hd-cat-btn{padding:7px 14px;border-radius:3px;border:1.5px solid var(--sand);background:#fff;font-family:'Noto Sans KR',sans-serif;font-size:0.82rem;font-weight:600;color:#444;cursor:pointer;transition:all 0.15s}
.hd-cat-btn:hover,.hd-cat-btn.active{background:var(--pine);border-color:var(--pine);color:#fff}
.hd-modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:14px 26px;border-top:1px solid var(--sand);background:var(--linen);position:sticky;bottom:0}
.hd-btn-cancel{padding:11px 20px;background:#fff;color:#444;border:1.5px solid var(--sand);border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:0.88rem;font-weight:700;cursor:pointer}
.hd-btn-submit{padding:11px 26px;background:var(--pine);color:#fff;border:none;border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:0.88rem;font-weight:700;cursor:pointer;transition:background 0.18s}
.hd-btn-submit:hover{background: var(--forest); color: #fff}
#hd-detail-page{display:none;position:fixed;inset:0;top:var(--tabs-h);background:var(--linen);overflow-y:auto;z-index:110}
.hd-detail-wrap{max-width:760px;margin:0 auto;padding:32px 24px 100px}
.hd-detail-back{display:inline-flex;align-items:center;gap:8px;color:var(--pine);font-size:0.88rem;font-weight:700;cursor:pointer;margin-bottom:24px;background:none;border:none;font-family:'Noto Sans KR',sans-serif}
.hd-detail-back:hover{color:var(--forest)}
.hd-detail-box{background:#fff;border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow);border:1px solid var(--sand);border-top:4px solid var(--gold);margin-bottom:16px}
#gl-detail-page{display:none;position:fixed;inset:0;top:var(--tabs-h);background:#f7f5f1;overflow-y:auto;z-index:110}
.gl-detail-wrap{max-width:780px;margin:0 auto;padding:28px 24px 100px}
.gl-detail-back{display:inline-flex;align-items:center;gap:8px;color:var(--pine);font-size:0.88rem;font-weight:700;cursor:pointer;margin-bottom:22px;background:none;border:none;font-family:'Noto Sans KR',sans-serif}
.gl-detail-back:hover{color:var(--forest)}
.gl-detail-box{background:#fff;border-radius:var(--radius-lg);padding:28px 28px 24px;box-shadow:var(--shadow);margin-bottom:14px;border:1px solid var(--sand);border-top:4px solid var(--pine)}
.gl-detail-photo-wrap{width: 100%; border-radius: 18px !important; overflow: hidden; background: #1a1a1a; aspect-ratio: 16/10 !important; display: flex; align-items: center; justify-content: center; position: relative; margin-bottom: 20px; max-width: 640px; margin-left: auto !important; margin-right: auto !important; box-shadow: 0 16px 44px rgba(42,61,45,0.16)}
.gl-detail-photo-wrap img{width:100%;height:100%;object-fit:cover;display:block}
.gl-detail-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,0.38);border:none;color:#fff;font-size:1.4rem;cursor:pointer;border-radius:50%;width:38px;height:38px;display:flex;align-items:center;justify-content:center;transition:background 0.15s;z-index:2}
.gl-detail-nav:hover{background:rgba(0,0,0,0.62)}
.gl-detail-nav.prev{left:10px}
.gl-detail-nav.next{right:10px}
.gl-detail-dots{position:absolute;bottom:10px;left:0;right:0;display:flex;gap:5px;justify-content:center}
.gl-detail-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.4);cursor:pointer;transition:background 0.15s}
.gl-detail-dot.active{background:#fff}
@media(max-width:768px){.gl-detail-wrap{padding:16px 12px 80px}.gl-detail-box{padding:18px 16px 18px}.gl-detail-title{font-size:1.15rem}.gl-detail-price{font-size:1.3rem}#gl-detail-page{top:52px}}
#community-page{display:none;position:fixed;inset:0;top:var(--tabs-h);background:#eee8dc;overflow-y:auto;z-index:100}
.comm-hero{background:linear-gradient(135deg,#faf7f2 0%,#f4f0e6 100%);padding:28px 24px 20px;text-align:center;border-bottom:2px solid #e8e0d0}
.comm-hero-title{font-family:'Noto Serif KR',serif;font-size:1.5rem;font-weight:900;color:var(--forest);margin-bottom:6px}
.comm-hero-title em{color:var(--sage);font-style:normal}
.comm-hero-sub{font-size:0.84rem;color:#444;margin-bottom:18px}
.comm-post-btn{padding:13px 32px;background:#f3efe9;color:var(--charcoal);border:1.5px solid #d8d0c4;border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:0.93rem;font-weight:700;cursor:pointer;transition:all 0.18s;letter-spacing:0.3px;box-shadow:0 2px 8px rgba(30,40,32,0.08)}
.comm-post-btn:hover{background:#ebe4db;border-color:#c8c0b4;transform:translateY(-1px);box-shadow:0 4px 12px rgba(30,40,32,0.13)}
.comm-layout{max-width:980px;margin:0 auto;padding:28px 24px 80px;display:grid;grid-template-columns:1fr 256px;gap:28px}
@media(max-width:640px){.comm-layout{grid-template-columns:1fr}.comm-sidebar{display:block;margin-top:8px}.comm-sidebar-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 16px;background:#fff;border:1px solid #e2ddd3;border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:0.86rem;font-weight:700;color:var(--forest);cursor:pointer;margin-bottom:4px}.comm-sidebar-toggle .toggle-arrow{transition:transform 0.2s;font-style:normal}.comm-sidebar-toggle.open .toggle-arrow{transform:rotate(180deg)}.comm-sidebar-collapsible{display:none;animation:sidebarFadeIn 0.18s ease}.comm-sidebar-collapsible.open{display:block}@keyframes sidebarFadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}}
.cat-bar{display:flex;gap:6px;flex-wrap:wrap;padding:10px 0 12px;border-bottom:1px solid var(--sand);margin-bottom:14px}
.region-tab-row{display: flex !important; gap: 6px; flex-wrap: wrap; border-bottom: 2px solid var(--sand); margin-bottom: 12px; background: #fff; border-radius: 10px; padding: 12px 14px 14px; box-shadow: 0 1px 6px rgba(30,40,32,0.05); align-items: center; border: 1px solid var(--sand)}
.region-tab{padding: 7px 13px; border: 1.5px solid var(--sand); background: #fff; font-family: 'Noto Sans KR',sans-serif; font-size: 0.8rem !important; font-weight: 600 !important; color: #444; cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -2px; transition: all 0.15s; white-space: nowrap; border-radius: var(--radius); margin: 0}
.region-tab:hover{color: var(--pine); border-color: var(--pine)}
.region-tab.active{color: var(--forest); border-bottom-color: var(--pine); font-weight: 700; background: #f3ede2; border-color: #cfc3b3}
.sigungu-bar{display:flex;gap:6px;flex-wrap:wrap;padding:8px 2px 6px;min-height:unset;transition:opacity 0.15s;background:#f8f5ee;border-radius:0 0 var(--radius) var(--radius);border:1px solid var(--sand);border-top:none;margin-bottom:10px}
#write-region-wrap .region-tab-row{margin-bottom:0;border-radius:var(--radius) var(--radius) 0 0}
#write-region-wrap .sigungu-bar{border-radius:0 0 var(--radius) var(--radius);margin-bottom:0;padding:10px 14px}
.sigungu-chip{padding:4px 13px 5px;border-radius:20px;border:1.5px solid var(--sand);background:#fff;font-family:'Noto Sans KR',sans-serif;font-size:0.78rem;font-weight:600;color:#444;cursor:pointer;transition:all 0.13s;white-space:nowrap;line-height:1.2;display:inline-flex;align-items:center}
.sigungu-chip:hover{border-color:var(--sage);color:var(--pine)}
.sigungu-chip.active{background:var(--pine);border-color:var(--pine);color:#fff}
.cat-chip{padding:6px 15px;border-radius:20px;border:1.5px solid var(--sand);background:#fff;font-family:'Noto Sans KR',sans-serif;font-size:0.81rem;font-weight:600;color:#444;cursor:pointer;transition:all 0.15s;letter-spacing:0.2px}
.cat-chip:hover,.cat-chip.active{background:var(--pine);border-color:var(--pine);color:#fff}
.post-card{background: #fff; border-radius: var(--radius); padding: 24px 26px; margin-bottom: 8px; box-shadow: 0 1px 6px rgba(30,40,32,0.07); cursor: pointer; transition: box-shadow 0.18s,transform 0.15s,border-left-color 0.15s; border: 1px solid #e2ddd3; border-left: 4px solid transparent}
.post-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px);border-left-color:var(--pine)}
.post-card-top{display:flex;align-items:flex-start;gap:14px}
.post-card-thumb{width:76px;height:76px;border-radius:var(--radius);object-fit:cover;flex-shrink:0}
.post-card-body{flex:1;min-width:0}
.post-cat-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:0.71rem;font-weight:700;margin-bottom:7px;letter-spacing:0.4px}
.post-card-title{font-family:'Noto Serif KR',serif;font-size:1.0rem;font-weight:700;color:var(--forest);margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.5}
.post-card-preview{font-size:0.84rem;color:#333;line-height:1.7;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.post-card-meta{display:flex;align-items:center;gap:14px;margin-top:12px;font-size:0.76rem;color:#333;border-top:1px solid #f0ebe2;padding-top:10px}
.post-card-meta span{display:flex;align-items:center;gap:3px}
.comm-sidebar-toggle{display:none}.comm-sidebar-collapsible{display:block}
.sidebar-box{background:#fff;border-radius:var(--radius);padding:18px 20px;margin-bottom:16px;box-shadow:0 1px 6px rgba(30,40,32,0.07);border:1px solid #e2ddd3}
.sidebar-box-title{font-family:'Noto Serif KR',serif;font-size:0.9rem;font-weight:700;color:var(--forest);margin-bottom:12px;padding-bottom:10px;border-bottom:2px solid var(--sand);letter-spacing:0.3px;display:flex;align-items:center;gap:6px}
.hot-post{padding:9px 0;border-bottom:1px solid #f4f0e8;font-size:0.82rem;color:var(--charcoal);cursor:pointer;display:flex;gap:8px;align-items:flex-start;line-height:1.55}
.hot-post:last-child{border-bottom:none}
.hot-post:hover{color:var(--pine)}
.hot-num{color:var(--gold);font-weight:800;flex-shrink:0;font-size:0.76rem;min-width:16px}
.tag-cloud{display:flex;flex-wrap:wrap;gap:6px}
.tag-item{padding:5px 11px;background:var(--linen);border-radius:20px;font-size:0.75rem;color:var(--pine);cursor:pointer;font-weight:600;transition:background 0.15s;border:1px solid var(--sand)}
.tag-item:hover{background:var(--sand);color:var(--forest)}
@media(max-width:500px){.gallery-grid{grid-template-columns:1fr}}
.gallery-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);border-top-color:var(--pine)}
.gallery-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.view-toggle-btn.active{background:var(--forest);border-color:var(--forest);color:#fff}
#post-detail-page{display:none;position:fixed;inset:0;top:var(--tabs-h);background:var(--linen);overflow-y:auto;z-index:110}
.post-detail-wrap{max-width:760px;margin:0 auto;padding:32px 24px 100px}
.post-detail-back{display:inline-flex;align-items:center;gap:8px;color:var(--pine);font-size:0.88rem;font-weight:700;cursor:pointer;margin-bottom:24px;background:none;border:none;font-family:'Noto Sans KR',sans-serif;letter-spacing:0.2px}
.post-detail-back:hover{color:var(--forest)}
.post-detail-box{background:#fff;border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow);margin-bottom:16px;border:1px solid var(--sand);border-top:4px solid var(--pine)}
.post-detail-cat{display:inline-block;padding:4px 12px;border-radius:2px;font-size:0.76rem;font-weight:700;margin-bottom:12px;letter-spacing:0.5px}
.post-detail-title{font-family:'Noto Serif KR',serif;font-size:1.45rem;font-weight:700;color:var(--forest);margin-bottom:12px;line-height:1.5}
.post-detail-meta{display:flex;align-items:center;gap:16px;font-size:0.8rem;color:#333;margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--sand)}
.post-detail-body{font-size: 1rem; color: #333; line-height: 2; white-space: pre-wrap}
.post-detail-photos{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.post-detail-photos img{width:calc(50% - 6px);aspect-ratio:4/3;object-fit:cover;border-radius:var(--radius);cursor:pointer}
.post-detail-tags{display:flex;gap:7px;flex-wrap:wrap;margin-top:18px}
.post-detail-actions{display:flex;align-items:center;gap:12px;margin-top:22px;padding-top:18px;border-top:1px solid var(--sand)}
.btn-like{display:flex;align-items:center;gap:7px;padding:10px 20px;border-radius:var(--radius);border:1.5px solid var(--sand);background:#fff;color:#444;font-family:'Noto Sans KR',sans-serif;font-size:0.86rem;font-weight:600;cursor:pointer;transition:all 0.15s}
.btn-like.liked{background:#f5f0e8;border-color:var(--gold);color:var(--gold)}
.btn-like:hover{border-color:var(--pine);color:var(--pine)}
.btn-post-edit{padding:10px 16px;background:var(--linen);color:var(--forest);border:1px solid var(--sand);border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:0.82rem;font-weight:700;cursor:pointer}
.btn-post-delete{padding:10px 16px;background:#fff5f5;color:#c0392b;border:1px solid #fdd;border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:0.82rem;font-weight:700;cursor:pointer}
.comments-box{background:#fff;border-radius:var(--radius-lg);padding:26px 32px;box-shadow:var(--shadow);border:1px solid var(--sand)}
.comments-title{font-family:'Noto Serif KR',serif;font-size:1rem;font-weight:700;color:var(--forest);margin-bottom:18px}
.comment-item{padding:14px 0;border-bottom:1px solid var(--linen)}
.comment-item:last-child{border-bottom:none}
.comment-top{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.comment-nick{font-size:0.85rem;font-weight:700;color:var(--forest)}
.comment-date{font-size:0.76rem;color:#333}
.comment-body{font-size: 0.94rem; color: #444; line-height: 1.8}
.comment-actions{display:flex;align-items:center;gap:4px;margin-left:auto}
.comment-edit-btn,.comment-delete-btn{padding:3px 9px;border-radius:4px;border:none;cursor:pointer;font-family:'Noto Sans KR',sans-serif;font-size:0.72rem;font-weight:600;transition:background 0.15s}
.comment-edit-btn{background:var(--linen);color:#444}
.comment-edit-btn:hover{background:var(--sand)}
.comment-delete-btn{background:#fff0f0;color:#c0392b}
.comment-delete-btn:hover{background:#ffd6d6}
.comment-edit-wrap{margin-top:8px;display:flex;gap:8px;align-items:flex-end}
.comment-edit-textarea{flex:1;padding:10px 14px;border:1.5px solid var(--pine);border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:0.88rem;color:var(--charcoal);background:#fff;resize:none;min-height:44px;max-height:120px;outline:none}
.comment-edit-save{padding:10px 16px;background:var(--pine);color:#fff;border:none;border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:0.82rem;font-weight:700;cursor:pointer;white-space:nowrap}
.comment-edit-cancel{padding:10px 12px;background:var(--linen);color:#444;border:1.5px solid var(--sand);border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:0.82rem;font-weight:700;cursor:pointer;white-space:nowrap}
.comment-like{display:inline-flex;align-items:center;gap:4px;font-size:0.76rem;color:#333;cursor:pointer;margin-top:6px;background:none;border:none;font-family:'Noto Sans KR',sans-serif}
.comment-like.liked{color:var(--gold)}
.comment-input-wrap{margin-top:18px;display:flex;gap:10px;align-items:flex-end}
.comment-input{flex:1;padding:12px 16px;border:1.5px solid var(--sand);border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:0.9rem;color:var(--charcoal);background:var(--linen);resize:none;min-height:48px;max-height:120px;transition:border-color 0.2s}
.comment-input:focus{outline:none;border-color:var(--pine)}
.comment-submit{padding:12px 20px;background:var(--pine);color:#fff;border:none;border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:0.88rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:background 0.18s}
.comment-submit:hover{background:var(--forest)}
#write-modal{display:none;position:fixed;inset:0;top:var(--tabs-h);z-index:400;background:#eae4d8;overflow-y:auto}
.write-modal-box{background:#fff;border-radius:var(--radius-lg);max-width:840px;margin:36px auto 80px;box-shadow:0 4px 32px rgba(0,0,0,0.08);border-top:6px solid var(--pine)}
.write-modal-head{padding:24px 28px 0;position:sticky;top:0;background:#fff;z-index:2;border-radius:var(--radius-lg)var(--radius-lg)0 0}
.write-modal-title{font-family:'Noto Serif KR',serif;font-size:1.15rem;font-weight:700;color:var(--forest);margin-bottom:18px;display:flex;align-items:center;justify-content:space-between}
.write-modal-body{padding:18px 28px 28px}
.write-field{margin-bottom:16px}
.write-label{display:block;font-size:0.83rem;font-weight:700;color:var(--forest);margin-bottom:7px;letter-spacing:0.2px}
.write-input{width:100%;padding:12px 16px;border:1.5px solid var(--sand);border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:0.92rem;color:var(--charcoal);background:var(--linen);box-sizing:border-box;transition:border-color 0.2s}
.write-input:focus{outline:none;border-color:var(--pine);background:#fff}
.write-cat-group{display:flex;gap:7px;flex-wrap:wrap}
.write-tag-input{display:flex;gap:8px}
.write-tag-chips{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.write-tag-chip{padding:4px 12px;background:var(--linen);border-radius:2px;font-size:0.76rem;color:var(--pine);font-weight:600;display:flex;align-items:center;gap:5px;border:1px solid var(--sand)}
.write-tag-chip button{background:none;border:none;color:#333;cursor:pointer;font-size:0.72rem;padding:0;line-height:1}
.write-photo-area:hover{border-color:var(--pine)}
.write-photo-thumb{position:relative;width:calc(33.333% - 6px);aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden}
.write-photo-thumb img{width:100%;height:100%;object-fit:cover}
.write-photo-thumb button{position:absolute;top:3px;right:3px;width:20px;height:20px;border-radius:50%;border:none;background:rgba(0,0,0,0.55);color:#fff;font-size:10px;cursor:pointer}
.rich-editor-toolbar{display:flex;gap:6px;flex-wrap:wrap;align-items:center;padding:8px;border:1.5px solid #ccc;border-bottom:none;border-radius:6px 6px 0 0;background:#f5f5f5}
.rich-editor-btn{padding:7px 11px;border:1px solid #ddd6ce;background:#fff;border-radius:6px;font-family:'Noto Sans KR',sans-serif;font-size:0.78rem;font-weight:700;color:var(--charcoal);cursor:pointer;transition:all .15s;line-height:1}
.rich-editor-btn:hover{background:#f0ebe4;border-color:var(--pine);color:var(--pine)}
.rich-editor-box{min-height:600px;padding:16px;border:1.5px solid #ccc;border-radius:0 0 6px 6px;background:#fff;font-family:'Noto Sans KR',sans-serif;font-size:.94rem;line-height:1.9;color:#333;outline:none;overflow:visible;resize:vertical;box-shadow:inset 0 1px 4px rgba(0,0,0,0.04)}
.rich-editor-box:focus{border-color:var(--pine)}
.rich-editor-box:empty:before{content:attr(data-placeholder);color:#333}
.rich-editor-box img{max-width:100%;height:auto;border-radius:8px;margin:10px 0;display:block;cursor:pointer}
.rich-editor-box img.img-selected{outline:2.5px solid var(--pine);outline-offset:2px}
.rich-editor-box table{border-collapse:collapse;width:100%;margin:14px 0;font-size:0.92rem}
.rich-editor-box table td,.rich-editor-box table th{border:1.5px solid #d0c8be;padding:8px 12px;min-width:60px;vertical-align:top;word-break:break-word}
.rich-editor-box table th{background:#f5f1ec;font-weight:700;text-align:center}
.rich-editor-box table tr:nth-child(even)td{background:#faf8f5}
.rich-editor-sep{display:inline-block;width:1px;height:22px;background:#ddd6ce;margin:0 2px;vertical-align:middle}
#img-float-bar{display:none;position:absolute;z-index:500;background:rgba(30,40,32,0.93);border-radius:8px;padding:5px 6px;gap:3px;align-items:center;box-shadow:0 4px 18px rgba(0,0,0,0.28);pointer-events:auto;backdrop-filter:blur(4px)}
#img-float-bar.show{display:flex}
.ifb-btn{padding:5px 9px;background:none;border:none;color:#fff;font-size:0.75rem;font-weight:700;cursor:pointer;border-radius:5px;font-family:'Noto Sans KR',sans-serif;white-space:nowrap;transition:background .12s}
.ifb-btn:hover{background:rgba(255,255,255,0.18)}
.ifb-sep{width:1px;height:16px;background:rgba(255,255,255,0.22);margin:0 2px}
.ifb-size{display:flex;align-items:center;gap:5px;padding:0 4px}
.ifb-size input[type=range]{width:72px;accent-color:#a8d5b5;height:3px;cursor:pointer}
.ifb-size span{color:#a8d5b5;font-size:0.72rem;font-weight:700;min-width:26px}
.ifb-preset{display:flex;align-items:center;gap:3px;padding:0 2px}
.ifb-preset-btn{padding:3px 8px;background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.22);color:#fff;font-size:0.68rem;font-weight:700;border-radius:4px;cursor:pointer;font-family:'Noto Sans KR',sans-serif;transition:background .12s;white-space:nowrap}
.ifb-preset-btn:hover{background:rgba(255,255,255,0.28)}
.ifb-preset-btn.active{background:#4e6352;border-color:#a8d5b5;color:#a8d5b5}
.write-photo-counter{display:inline-flex;align-items:center;font-size:0.72rem;font-weight:700;color:#333;margin-left:2px;padding:2px 8px;border-radius:10px;background:#f0f7f3;border:1px solid #c8e0d0;white-space:nowrap;line-height:1;height:32px}
.write-photo-counter.full{background:#fff3f3;border-color:#f5c6c6;color:#c62828}
.rich-editor-box .img-left{margin-left:0;margin-right:auto}
.rich-editor-box .img-center{margin-left:auto;margin-right:auto}
.rich-editor-box .img-right{margin-left:auto;margin-right:0}
.post-detail-body.rich-body{white-space:pre-wrap}
.post-detail-body.rich-body img{max-width:100%;height:auto;border-radius:8px;margin:12px 0;display:block}
.post-detail-body.rich-body .img-left{margin-left:0;margin-right:auto}
.post-detail-body.rich-body .img-center{margin-left:auto;margin-right:auto}
.post-detail-body.rich-body .img-right{margin-left:auto;margin-right:0}
#map-container{display:none;position:fixed;left:0;right:0;width:100vw;top:124px;height:calc(100vh - 124px);bottom:0;z-index:1;touch-action:none}
#map{width:100%;height:100%;touch-action:none}
/* ── 모바일 터치 드래그 수정 ── */
/* 카카오맵은 touch-action:none이 필요함 (자체 터치핸들러 사용).
   pan-x pan-y로 바꾸면 브라우저가 스크롤을 처리하려 해서
   카카오맵의 preventDefault()가 막혀 드래그가 안 됨. */
@media(max-width:768px){
  #map-container,#map{
    touch-action: none !important;
    pointer-events: auto !important;
    will-change: transform;
  }
  /* 지도 내부 카카오맵 생성 div들도 터치 허용 */
  #map > div, #map > div > div{
    pointer-events: auto !important;
    touch-action: none !important;
  }
}
.top-nav{position: fixed; top:var(--tabs-h); left: 0; right: 0; z-index: 50; display: none !important; align-items: center; gap: 14px; padding: 9px 20px; background: rgba(255,255,255,.96); border-bottom: 1px solid rgba(255,255,255,0.08); box-shadow: 0 3px 16px rgba(0,0,0,0.2); backdrop-filter: blur(12px)}
.search-wrap{flex:1;max-width:480px;position:relative}
.search-wrap input{width:100%;padding:11px 18px 11px 44px;border:2px solid var(--gold);border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:0.92rem;color:var(--charcoal);background:rgba(255,255,255,0.93);transition:background 0.2s}
.search-wrap input:focus{outline:none;background:#fff;border-color:var(--gold-lt)}
.search-wrap .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#444;font-size:1rem;pointer-events:none}
.filter-chips{display:flex;gap:6px;flex-shrink:0;align-items:center}
.chip{padding:0 24px;height:48px;border-radius:8px;border:2px solid rgba(255,255,255,0.28);background:rgba(255,255,255,0.08);font-family:'Noto Sans KR',sans-serif;font-size:1.02rem;font-weight:700;color:rgba(255,255,255,0.88);cursor:pointer;transition:all 0.15s;white-space:nowrap;letter-spacing:0.4px;display:flex;align-items:center;gap:6px;line-height:1}
.chip:hover{background:rgba(255,255,255,0.18);color:#fff;border-color:rgba(255,255,255,0.5);transform:translateY(-1px)}
.chip.active{background:var(--gold);border-color:var(--gold);color:#fff;font-weight:800;box-shadow:0 2px 10px rgba(138,112,85,0.45)}
.filter-main-btn{display:inline-flex;align-items:center;gap:7px;padding:0 18px;height:40px;border-radius:20px;background:#fff;border:1.5px solid #ddd6ce;font-family:'Noto Sans KR',sans-serif;font-size:0.86rem;font-weight:700;color:#2f2a25;cursor:pointer;white-space:nowrap;transition:all 0.18s;box-shadow:0 1px 6px rgba(20,20,20,0.06);position:relative;flex-shrink:0}
.filter-main-btn:hover{border-color:#b0a896;box-shadow:0 2px 12px rgba(20,20,20,0.1);background:#faf7f3}
.filter-main-btn.active,#adv-filter-btn.active{background:#2f2a25;border-color:#2f2a25;color:#fff;box-shadow:0 2px 12px rgba(20,20,20,0.22)}
.filter-btn-icon{display:flex;align-items:center;justify-content:center;opacity:0.8}
.filter-btn-text{letter-spacing:0.1px}
.filter-active-dot{position:absolute;top:8px;right:8px;width:7px;height:7px;background:#e05c3a;border-radius:50%;border:1.5px solid #fff}
.register-btn{display: inline-flex !important; align-items: center; gap: 6px; background: var(--green); color: #fff; border-radius: 20px; padding: 0 20px; height: 40px !important; font-size: 0.86rem !important; font-weight: 700 !important; box-shadow: 0 2px 10px rgba(43,95,58,0.28); transition: all 0.18s; letter-spacing: 0.1px}
.register-btn:hover{background:#1e4529;box-shadow:0 4px 16px rgba(43,95,58,0.38);transform:translateY(-1px)}
#adv-filter-panel{display:none;position:fixed;z-index:49;background:#ffffff;border:1px solid #e8e3dc;border-radius:16px;box-shadow:0 12px 40px rgba(20,20,20,0.16),0 2px 8px rgba(20,20,20,0.06);width:440px;max-height:calc(100vh - 140px);overflow-y:auto;overflow-x:hidden;padding:0;scrollbar-width:thin;scrollbar-color:#e0dbd3 transparent}
#adv-filter-panel::-webkit-scrollbar{width:4px}
#adv-filter-panel::-webkit-scrollbar-track{background:transparent}
#adv-filter-panel::-webkit-scrollbar-thumb{background:#e0dbd3;border-radius:4px}
#adv-filter-panel.open{display:block;animation:filterSlideIn 0.22s cubic-bezier(0.34,1.56,0.64,1)}
@keyframes filterSlideIn{from{opacity:0;transform:translateY(-8px)scale(0.97)}to{opacity:1;transform:translateY(0)scale(1)}}
#prox-filter-panel{display:none;position:fixed;z-index:49;background:#ffffff;border:1px solid #e8e3dc;border-radius:16px;box-shadow:0 12px 40px rgba(20,20,20,0.16),0 2px 8px rgba(20,20,20,0.06);width:440px;max-height:calc(100vh - 140px);overflow-y:auto;overflow-x:hidden;padding:0;scrollbar-width:thin;scrollbar-color:#e0dbd3 transparent}
#prox-filter-panel::-webkit-scrollbar{width:4px}
#prox-filter-panel::-webkit-scrollbar-track{background:transparent}
#prox-filter-panel::-webkit-scrollbar-thumb{background:#e0dbd3;border-radius:4px}
#prox-filter-panel.open{display:block;animation:filterSlideIn 0.22s cubic-bezier(0.34,1.56,0.64,1)}
#prox-filter-btn.active{background:#2b5f3a;color:#fff;border-color:#2b5f3a}
.adv-filter-dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:13px 16px 11px;border-bottom:1px solid #f0ebe4;background:#faf7f3;position:sticky;top:0;z-index:2}
.adv-filter-header-left{display:flex;align-items:center;gap:8px}
.adv-filter-header-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#2b5f3a;border-radius:8px;color:#fff}
.adv-filter-dropdown-title{font-size:0.88rem;font-weight:800;color:#1e2820;letter-spacing:-0.01em}
.adv-filter-dropdown-close{background: rgba(255,255,255,.96)!important; border: 1.5px solid rgba(31,42,36,.18)!important; cursor: pointer; width: 28px; height: 28px; border-radius: 8px; display: inline-flex !important; align-items: center !important; justify-content: center !important; color: #1f2a24 !important; transition: all 0.15s; box-shadow: 0 4px 14px rgba(0,0,0,.22)!important; font-weight: 900 !important; line-height: 1 !important; opacity: 1 !important}
.adv-filter-dropdown-close:hover{background:#e8e0d5;color:#2f2a25}
.adv-filter-grid{display:flex;flex-wrap:nowrap;gap:0;align-items:flex-start;flex-direction:column;width:100%}
.adv-filter-group{display:flex;flex-direction:column;gap:8px;padding:12px 16px;border-bottom:1px solid #f0ebe4;width:100%;box-sizing:border-box}
.adv-filter-group:last-child{border-bottom:none}
.adv-filter-label{font-size:0.76rem;font-weight:800;color:#333;letter-spacing:0.5px;text-transform:uppercase;margin-bottom:0;display:flex;align-items:center;gap:6px}
.adv-filter-label-dot{width:6px;height:6px;border-radius:50%;background:#2b5f3a;flex-shrink:0}
.adv-filter-chips{display:flex;gap:5px;flex-wrap:wrap;align-items:center}
.adv-chip{padding:0 16px;height:36px;border-radius:9px;border:1.5px solid #e0dbd3;background:#fff;font-family:'Noto Sans KR',sans-serif;font-size:0.85rem;font-weight:700;color:#3a3530;cursor:pointer;transition:all 0.14s;white-space:nowrap;display:flex;align-items:center;gap:4px}
.adv-chip:hover{border-color:#2b5f3a;color:#2b5f3a;background:#f0f7f2}
.adv-chip.active{background:#2b5f3a;border-color:#2b5f3a;color:#fff;box-shadow:0 2px 8px rgba(43,95,58,0.25)}
.adv-chip.deal-매매.active{background:#1a4f2e;border-color:#1a4f2e}
.adv-chip.deal-전세.active{background:#3a2875;border-color:#3a2875}
.adv-chip.deal-월세.active{background:#7a4a10;border-color:#7a4a10}
.adv-range-input{width: 90px; padding: 0 10px; height: 34px; border: 1.5px solid #e0dbd3; border-radius: 8px; background: #fff; color: var(--charcoal); font-family: 'Noto Sans KR',sans-serif; font-size: 0.85rem; font-weight: 500; outline: none; transition: all 0.15s; border-color: var(--sand)}
.adv-range-input::placeholder{color: #333; font-weight: 400}
.adv-range-input:focus{border-color:#2b5f3a;background:#fff;box-shadow:0 0 0 3px rgba(43,95,58,0.1)}
.adv-dual-slider{pointer-events:none}
.adv-dual-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#2b5f3a;border:2.5px solid #fff;box-shadow:0 1px 6px rgba(43,95,58,0.4);pointer-events:all;cursor:pointer}
.adv-dual-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#2b5f3a;border:2.5px solid #fff;box-shadow:0 1px 6px rgba(43,95,58,0.4);pointer-events:all;cursor:pointer}
.adv-filter-actions{display:flex;gap:8px;align-items:center;padding:11px 16px;border-top:1px solid #f0ebe4;justify-content:flex-end;background:#faf7f3;position:sticky;bottom:0;z-index:2}
.adv-reset-btn{padding:0 14px;height:32px;border-radius:8px;border:1.5px solid #e0dbd3;background:#fff;color:#333;font-family:'Noto Sans KR',sans-serif;font-size:0.79rem;font-weight:700;cursor:pointer;transition:all 0.15s}
.adv-reset-btn:hover{background:#f5f0e8;color:#2b5f3a;border-color:#c8bfb5}
.adv-apply-btn{padding: 0 20px; height: 32px; border-radius: 8px; border: none; background: #2b5f3a; color: #fff; font-family: 'Noto Sans KR',sans-serif; font-size: 0.79rem; font-weight: 700; cursor: pointer; transition: all 0.15s; box-shadow: 0 2px 8px rgba(43,95,58,0.25); letter-spacing: 0.1px}
.adv-apply-btn:hover{background:#1e4529;box-shadow:0 4px 14px rgba(43,95,58,0.38);transform:translateY(-1px)}
.adv-prox-quick-btn{padding:0 11px;height:28px;border-radius:6px;border:1.5px solid #e0dbd3;background:#fff;font-family:'Noto Sans KR',sans-serif;font-size:0.76rem;font-weight:700;color:#3a3530;cursor:pointer;transition:all 0.13s}
.adv-prox-quick-btn:hover{background:#f0f7f2;border-color:#2b5f3a;color:#2b5f3a}
.adv-prox-all-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;padding:5px 10px;border-radius:8px;background:#f0f7f2;border:1.5px solid #d0e8d8;flex-wrap:nowrap}
.adv-prox-all-label{font-size:0.74rem;font-weight:800;color:#2b5f3a;white-space:nowrap}
.adv-prox-all-slider{flex:1;min-width:80px;-webkit-appearance:none;appearance:none;height:4px;border-radius:4px;background:#b8d8c4;outline:none;cursor:pointer}
.adv-prox-all-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:#2b5f3a;cursor:pointer;border:2.5px solid #fff;box-shadow:0 1px 4px rgba(43,95,58,0.4)}
.adv-prox-all-val{font-size:0.74rem;font-weight:800;color:#2b5f3a;white-space:nowrap;min-width:40px;text-align:right}
.adv-proximity-item{display:flex;flex-direction:row;align-items:center;gap:8px;background:#faf7f3;border:1.5px solid #e8e3dc;border-radius:8px;padding:5px 9px;transition:border-color 0.15s}
.adv-proximity-item:hover{border-color:#c8bfb5}
.adv-proximity-lbl{font-size:0.75rem;font-weight:700;color:#3a3530;white-space:nowrap;min-width:80px;flex-shrink:0}
.adv-prox-row{display:flex;flex-direction:row;align-items:center;gap:6px;flex:1;min-width:0}
.adv-prox-slider{flex:1;min-width:40px;-webkit-appearance:none;appearance:none;height:3px;border-radius:3px;background:#d8d0c8;outline:none;cursor:pointer}
.adv-prox-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:13px;height:13px;border-radius:50%;background:#2b5f3a;cursor:pointer;border:2px solid #fff;box-shadow:0 1px 4px rgba(43,95,58,0.4)}
.adv-prox-input-row{display:flex;align-items:center;gap:3px;flex-shrink:0}
.adv-prox-input{width:44px !important;min-width:0;padding:0 4px;height:26px !important;font-size:0.76rem !important;text-align:center;border:1.5px solid #e0dbd3;border-radius:6px;background:#fff}
.adv-prox-unit{font-size:0.72rem;color:#333;font-weight:600;white-space:nowrap}
#active-filter-bar{display:none;position:fixed;top:124px;left:0;right:0;z-index:48;background:rgba(30,61,34,0.95);border-bottom:1px solid rgba(255,255,255,0.08);padding:7px 28px;align-items:center;gap:8px;flex-wrap:wrap}
#active-filter-bar:empty{display:none !important}
.active-filter-tag{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;background:rgba(166,124,58,0.25);border:1px solid rgba(166,124,58,0.5);font-size:0.74rem;font-weight:600;color:var(--gold-lt)}
.active-filter-tag button{background:none;border:none;color:var(--gold-lt);font-size:0.72rem;cursor:pointer;padding:0;line-height:1;opacity:0.7}
.active-filter-tag button:hover{opacity:1}
#msg-modal-overlay{display:none;position:fixed;inset:0;z-index:650;background:rgba(20,25,22,0.55);backdrop-filter:blur(4px);align-items:center;justify-content:center}
#msg-modal-overlay.open{display: flex; visibility: visible; pointer-events: auto}
.msg-modal-box{background:#fff;border-radius:16px;width:min(460px,94vw);box-shadow:0 20px 60px rgba(0,0,0,0.22);border-top:5px solid var(--pine);overflow:hidden}
.msg-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 16px;border-bottom:1px solid var(--sand);background:#faf7f3}
.msg-modal-title{font-family:'Noto Serif KR',serif;font-size:1.05rem;font-weight:700;color:var(--forest);display:flex;align-items:center;gap:8px}
.msg-modal-close{background:#f0ebe4;border:none;cursor:pointer;width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#444;font-size:1rem;transition:all 0.15s}
.msg-modal-close:hover{background:#e8e0d5;color:#2f2a25}
.msg-modal-body{padding:20px 22px 22px}
.msg-to-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:#f0f7f2;border:1.5px solid #c8e0d0;border-radius:20px;font-size:0.84rem;font-weight:700;color:var(--pine);margin-bottom:14px}
.msg-textarea{width:100%;min-height:110px;padding:12px 14px;border:1.5px solid var(--sand);border-radius:8px;font-family:'Noto Sans KR',sans-serif;font-size:0.9rem;color:var(--charcoal);background:var(--linen);resize:none;outline:none;line-height:1.75;transition:border-color 0.2s}
.msg-textarea:focus{border-color:var(--pine);background:#fff}
.msg-char-count{font-size:0.73rem;color:#333;text-align:right;margin-top:5px}
.msg-modal-footer{display:flex;gap:8px;justify-content:flex-end;padding:14px 22px;border-top:1px solid var(--sand);background:#faf7f3}
.msg-cancel-btn{padding:10px 18px;background:#fff;color:#444;border:1.5px solid var(--sand);border-radius:8px;font-family:'Noto Sans KR',sans-serif;font-size:0.86rem;font-weight:700;cursor:pointer}
.msg-send-btn{padding:10px 22px;background:var(--pine);color:#fff;border:none;border-radius:8px;font-family:'Noto Sans KR',sans-serif;font-size:0.86rem;font-weight:700;cursor:pointer;transition:background 0.15s}
.msg-send-btn:hover{background:var(--forest)}
.msg-send-btn:disabled{background:#b0c4b8;cursor:not-allowed}
.msg-item{padding:14px 18px;border-bottom:1px solid #f0ebe4;cursor:pointer;transition:background 0.13s;display:flex;flex-direction:column;gap:4px}
.msg-item:hover{background:#faf7f3}
.msg-item.unread{background:#f0f7f2;border-left:3px solid var(--pine)}
.msg-item-header{display:flex;align-items:center;justify-content:space-between;gap:8px}
.msg-item-from{font-size:0.84rem;font-weight:700;color:var(--forest)}
.msg-item-date{font-size:0.72rem;color:#333;white-space:nowrap}
.msg-item-preview{font-size:0.82rem;color:#333;line-height:1.5;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.msg-item-ref{font-size:0.73rem;color:var(--pine);margin-top:2px}
.msg-unread-dot{width:8px;height:8px;border-radius:50%;background:var(--pine);flex-shrink:0}
.msg-detail-box{padding:20px 22px;border-bottom:1px solid var(--sand)}
.msg-detail-meta{font-size:0.78rem;color:#333;margin-bottom:12px;display:flex;gap:14px;flex-wrap:wrap}
.msg-detail-body{font-size:0.92rem;color:var(--charcoal);line-height:1.85;white-space:pre-wrap}
.msg-detail-ref{font-size:0.78rem;color:var(--pine);margin-top:10px;padding:8px 12px;background:#f0f7f2;border-radius:6px}
.msg-empty{padding:60px 20px;text-align:center;color:#333;font-size:0.88rem;line-height:2.2}
.msg-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;background:#c0392b;color:#fff;border-radius:9px;font-size:0.68rem;font-weight:800;position:absolute;top:-5px;right:-5px}
#report-modal-overlay{display:none;position:fixed;inset:0;z-index:600;background:rgba(20,25,22,0.55);backdrop-filter:blur(4px);align-items:center;justify-content:center}
#report-modal-overlay.open{display:flex}
.report-modal-box{background:#fff;border-radius:16px;width:360px;max-width:calc(100vw - 32px);box-shadow:0 20px 60px rgba(0,0,0,0.22);overflow:hidden;animation:reportSlideUp 0.22s cubic-bezier(0.34,1.56,0.64,1)}
@keyframes reportSlideUp{from{opacity:0;transform:translateY(16px)scale(0.96)}to{opacity:1;transform:translateY(0)scale(1)}}
.report-modal-header{background:#fff8f7;padding:18px 20px 14px;border-bottom:1px solid #f5deda;display:flex;align-items:center;justify-content:space-between}
.report-modal-title{font-family:'Noto Serif KR',serif;font-size:1rem;font-weight:700;color:#3a1a18;display:flex;align-items:center;gap:7px}
.report-modal-close{background:#f0ebe4;border:none;cursor:pointer;width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#444;transition:all 0.15s;font-size:0.85rem}
.report-modal-close:hover{background:#e8e0d5;color:#2f2a25}
.report-modal-body{padding:18px 20px}
.report-modal-subtitle{font-size:0.78rem;color:#444;margin-bottom:13px;line-height:1.6}
.report-reasons{display:flex;flex-direction:column;gap:7px}
.report-reason-btn{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:10px;border:1.5px solid #ece6df;background:#faf7f3;font-family:'Noto Sans KR',sans-serif;font-size:0.84rem;font-weight:600;color:#3a3530;cursor:pointer;transition:all 0.14s;text-align:left}
.report-reason-btn:hover{border-color:#e05c3a;background:#fff5f3;color:#c0392b}
.report-reason-btn.selected{border-color:#c0392b;background:#fff0ee;color:#c0392b}
.report-reason-btn .reason-icon{font-size:1.1rem;flex-shrink:0}
.report-reason-btn .reason-text{flex:1;line-height:1.3}
.report-reason-btn .reason-check{width:18px;height:18px;border-radius:50%;border:2px solid #ddd;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:0.65rem;transition:all 0.14s}
.report-reason-btn.selected .reason-check{background:#c0392b;border-color:#c0392b;color:#fff}
.report-modal-footer{padding:12px 20px 18px;display:flex;gap:8px}
.report-cancel-btn{flex:1;padding:12px;border-radius:8px;border:1.5px solid #e0dbd3;background:#fff;font-family:'Noto Sans KR',sans-serif;font-size:0.85rem;font-weight:700;color:#333;cursor:pointer;transition:all 0.15s}
.report-cancel-btn:hover{background:#f5f0e8}
.report-submit-btn{flex:2;padding:12px;border-radius:8px;border:none;background:#c0392b;font-family:'Noto Sans KR',sans-serif;font-size:0.85rem;font-weight:700;color:#fff;cursor:pointer;transition:all 0.15s;box-shadow:0 2px 8px rgba(192,57,43,0.28)}
.report-submit-btn:hover{background:#a93226;box-shadow:0 4px 14px rgba(192,57,43,0.38)}
.report-submit-btn:disabled{background:#ccc;box-shadow:none;cursor:default}
.btn-report{display:inline-flex;align-items:center;gap:5px;padding:9px 14px;border-radius:8px;border:1.5px solid #f5deda;background:#fff8f7;font-family:'Noto Sans KR',sans-serif;font-size:0.82rem;font-weight:700;color:#a0443a;cursor:pointer;transition:all 0.15s}
.btn-report:hover{background:#fff0ee;border-color:#e05c3a;color:#c0392b}
.btn-share{display:inline-flex;align-items:center;gap:5px;padding:9px 14px;border-radius:8px;border:1.5px solid #d8e8dd;background:#f4faf6;font-family:'Noto Sans KR',sans-serif;font-size:0.82rem;font-weight:700;color:#2d6b42;cursor:pointer;transition:all 0.15s}
.btn-share:hover{background:#e6f4ec;border-color:var(--pine);color:var(--forest)}
.btn-share.copied{background:var(--forest);border-color:var(--forest);color:#f4f0e8}
.nav-btn{padding:11px 22px;border-radius:var(--radius);background:#6aba7a;color:#fff;border:none;font-family:'Noto Sans KR',sans-serif;font-size:0.9rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:all 0.18s;letter-spacing:0.3px;box-shadow:0 2px 8px rgba(60,150,90,0.22)}
.nav-btn:hover{background:#50a564;transform:translateY(-1px);box-shadow:0 4px 12px rgba(60,150,90,0.32)}
.auth-btn{display:inline-flex;align-items:center;padding:8px 16px;border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:0.84rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all 0.2s;letter-spacing:0.2px;flex-shrink:0}
.auth-btn-outline{background: #fff; color: #243029; border: 1.5px solid rgba(255,255,255,0.35); border-color: #dfe8e3}
.auth-btn-outline:hover{background:rgba(255,255,255,0.12);color:#fff;border-color:rgba(255,255,255,0.6)}
.auth-btn-filled{background:var(--gold);color:#fff;border:1.5px solid var(--gold)}
.auth-btn-filled:hover{background:var(--gold-lt);border-color:var(--gold-lt)}
.auth-btn-logout{background:rgba(255,255,255,0.1);color:rgba(255,255,255,0.78);border:1px solid rgba(255,255,255,0.22)}
.auth-btn-logout:hover{background:rgba(255,255,255,0.2);color:#fff}
.pin{position:absolute;transform:translate(-50%,-100%);cursor:pointer;z-index:10;transition:transform 0.2s}
.pin:hover{transform:translate(-50%,-100%)scale(1.12);z-index:20}
.pin.active{transform:translate(-50%,-100%)scale(1.15);z-index:25}
.detail-panel{position:absolute;top:0;left:0;bottom:0;width:480px;background:#fff;border-radius:0;box-shadow:4px 0 28px rgba(30,40,32,0.13);z-index:40;transition:transform 0.32s cubic-bezier(0.4,0,0.2,1),opacity 0.22s;opacity:0;pointer-events:none;overflow-y:auto;overflow-x:hidden;border-right:1px solid var(--sand);border-top:3px solid var(--pine);transform:translateX(-100%)}
.detail-panel.open{transform:translateX(0);opacity:1;pointer-events:all}
.panel-img-placeholder{width:100%;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;font-size:3.5rem;background:var(--linen)}
.panel-body{padding:22px 24px 24px}
.panel-tags{display:flex;gap:7px;margin-bottom:12px;flex-wrap:wrap}
.panel-tag{font-size:0.72rem;font-weight:700;letter-spacing:0.8px;padding:4px 10px;border-radius:2px}
.tag-new{background:#f0f6ec;color:var(--pine)}
.tag-type{background:var(--linen);color:#1a1a1a;font-size:0.85rem;font-weight:700}
.tag-hot{background:#fff0f0;color:#c0392b}
.panel-title{font-family:'Noto Serif KR',serif;font-size:1.2rem;font-weight:700;color:var(--forest);margin-bottom:7px;margin-top:16px;line-height:1.4}
.panel-loc{font-size:0.85rem;color:#444;margin-bottom:0;padding-bottom:14px;border-bottom:1px solid var(--sand);display:flex;align-items:center;gap:5px}
.panel-stats{display:flex;gap:0;background:var(--linen);border-radius:var(--radius);overflow:hidden;margin-top:14px;margin-bottom:18px;border:1px solid var(--sand)}
.panel-stat{flex:1;padding:12px 0;text-align:center;border-right:1px solid var(--sand)}
.panel-stat:last-child{border-right:none}
.stat-val{font-family:'Noto Serif KR',serif;font-size:0.92rem;font-weight:700;color:var(--forest);display:block}
.stat-lbl{font-size:0.7rem;color:#444;margin-top:3px}
.panel-price{font-family: 'Noto Serif KR',serif; font-size: 1.6rem; font-weight: 900; color: var(--pine); margin-bottom: 0; padding-bottom: 16px; border-bottom: 1px solid var(--sand); line-height: 1.35}
.panel-price small{font-size:0.78rem;font-weight:400;color:#444;font-family:'Noto Sans KR',sans-serif}
.panel-actions{display:flex;gap:10px;flex-wrap:wrap;padding-top:10px;margin-top:0}
.btn-save{padding:12px 20px;background:var(--linen);color:var(--forest);border:1.5px solid var(--sand);border-radius:var(--radius);font-size:1rem;cursor:pointer;transition:background 0.18s}
.btn-save:hover{background:var(--sand)}
.panel-close{position: absolute; top: 12px !important; right: 12px !important; width: 42px !important; height: 42px !important; border-radius: 50%; background: rgba(58,74,60,0.18); color: var(--forest); border: none; font-size: 1rem; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background 0.18s; z-index: 5}
.panel-close:hover{background:rgba(58,74,60,0.32)}
.count-badge{position:absolute;bottom:36px;left:200px;top:auto;right:auto;transform:none;background:rgba(30,61,34,0.90);color:var(--gold-lt);z-index:30;padding:8px 20px;border-radius:20px;font-size:0.82rem;font-weight:700;backdrop-filter:blur(8px);box-shadow:0 2px 14px rgba(0,0,0,0.22);pointer-events:none;animation:badgeFadeIn 0.5s ease;letter-spacing:0.3px;cursor:default}
@keyframes badgeFadeIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.pin-tooltip{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translateX(-50%);background:rgba(30,40,32,0.95);color:#fff;border-radius:8px;padding:8px 12px;font-family:'Noto Sans KR',sans-serif;font-size:0.75rem;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity 0.15s;z-index:50;min-width:130px;text-align:center;box-shadow:0 4px 16px rgba(0,0,0,0.3)}
.pin-tooltip[onclick]{pointer-events:auto;cursor:pointer}
.pin-tooltip[onclick]:hover{background:rgba(20,60,35,0.98)}
.pin-tooltip::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:rgba(30,40,32,0.95)}
.pin:hover .pin-tooltip{opacity:1}
@keyframes pinBounce{0%{transform:translate(-50%,-100%)scale(0.5);opacity:0}60%{transform:translate(-50%,-110%)scale(1.15);opacity:1}80%{transform:translate(-50%,-95%)scale(0.95)}100%{transform:translate(-50%,-100%)scale(1);opacity:1}}
.legend{position:absolute;right:22px;bottom:28px;z-index:30;background:rgba(255,255,255,0.95);border-radius:var(--radius);padding:14px 18px;box-shadow:var(--shadow);border:1px solid var(--sand)}
.legend-title{font-size:0.72rem;font-weight:700;color:#444;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:10px}
.legend-item{display:flex;align-items:center;gap:9px;margin-bottom:6px;font-size:0.8rem;color:var(--charcoal);font-weight:500;transition:color 0.15s}
.legend-item:hover{color:var(--pine)}
.legend-item:last-child{margin-bottom:0}
.legend-dot{width:10px;height:10px;border-radius:2px;flex-shrink:0}
.list-panel{position:absolute;top:0;left:0;bottom:0;width:340px;z-index:35;background:#fff;border-right:1px solid var(--sand);overflow-y:auto;transform:translateX(-100%);transition:transform 0.3s cubic-bezier(0.4,0,0.2,1);box-shadow:4px 0 24px rgba(0,0,0,0.10)}
.list-panel.open{transform:translateX(0)}
.list-header{padding:14px 18px;border-bottom:1px solid var(--sand);font-family:'Noto Serif KR',serif;font-size:1.0rem;font-weight:700;color:var(--forest);background:var(--linen);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:5}
.list-header small{font-family:'Noto Sans KR',sans-serif;font-size:0.78rem;font-weight:400;color:#444}
.list-item{display:flex;gap:10px;padding:8px 12px;border-bottom:1px solid var(--linen);cursor:pointer;transition:background 0.15s,border-left-color 0.15s;border-left:3px solid transparent;align-items:stretch}
.list-item:hover{background:var(--linen);border-left-color:var(--mint)}
.list-item.active{background:#eef6ee;border-left-color:var(--pine)}
.list-item.highlighted{animation:listHighlight 0.6s ease}
@keyframes listHighlight{0%,100%{background:inherit}30%,70%{background:#d8f0d8}}
@keyframes syncPulse{0%,100%{opacity:1}50%{opacity:0.3}}
.list-thumb{width:80px;min-width:80px;align-self:stretch;border-radius:var(--radius);overflow:hidden;flex-shrink:0;background:linear-gradient(135deg,#a8c890,#8ab878);display:flex;align-items:center;justify-content:center;font-size:1.5rem}
.list-info{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:space-between}
.list-price{font-family:'Noto Serif KR',serif;font-size:0.85rem;font-weight:700;color:var(--pine);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.list-toggle{position:absolute;top:14px;left:22px;z-index:36;background:#fff;border:1px solid var(--sand);border-radius:var(--radius);padding:8px 14px;font-family:'Noto Sans KR',sans-serif;font-size:0.83rem;font-weight:700;color:var(--forest);cursor:pointer;display:flex;align-items:center;gap:6px;box-shadow:var(--shadow);transition:left 0.3s cubic-bezier(0.4,0,0.2,1),background 0.15s}
.list-toggle:hover{background:var(--linen)}
.list-toggle.shifted{left:356px}
.modal-overlay{display:none;position:fixed;inset:0;top:var(--tabs-h);z-index:400;background:#eae4d8;overflow-y:auto}
.modal-overlay.open{display:block}
.modal{background:#fff;border-radius:var(--radius-lg);max-width:840px;margin:36px auto 80px;box-shadow:0 4px 32px rgba(0,0,0,0.08);border-top:6px solid var(--pine)}
.modal-header{padding:24px 26px 18px;border-bottom:1px solid var(--sand);display:flex;justify-content:space-between;align-items:center}
.modal-header h2{font-family:'Noto Serif KR',serif;font-size:1.2rem;font-weight:700;color:var(--forest)}
.modal-close:hover{background:var(--sand);color:var(--forest)}
.modal-body{padding:22px 26px 26px;display:flex;flex-direction:column;gap:16px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-label{font-size:0.82rem;font-weight:700;color:var(--forest);letter-spacing:0.3px}
.form-input,.form-select,.form-textarea{padding:11px 14px;border:1.5px solid var(--sand);border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:0.92rem;color:var(--charcoal);background:var(--linen);transition:border-color 0.18s}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--pine);background:#fff}
.form-textarea{resize:vertical;min-height:76px;line-height:1.7}
.form-submit{width:100%;padding:15px;background:var(--pine);color:#fff;border:none;border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:1rem;font-weight:700;cursor:pointer;margin-top:4px;transition:background 0.18s;letter-spacing:0.5px}
.form-submit:hover{background:var(--forest)}
.form-hint{font-size:0.78rem;color:#444;text-align:center;margin-top:-8px}
.loc-btn{padding:7px 13px;border-radius:var(--radius);border:1.5px solid var(--sand);background:#fff;font-family:'Noto Sans KR',sans-serif;font-size:0.8rem;font-weight:600;color:#444;cursor:pointer;transition:all 0.15s}
.loc-btn:hover{border-color:var(--pine);color:var(--pine)}
.loc-btn.active{background:var(--pine);border-color:var(--pine);color:#fff}
@keyframes fadeDown{from{opacity:0;transform:translateX(-50%)translateY(-8px)}to{opacity:1;transform:translateX(-50%)translateY(0)}}
.panel-proximity{background:#fff;border-radius:14px;border:1px solid #e6ddd0;margin-bottom:18px;overflow:hidden;box-shadow:0 8px 24px rgba(48,64,50,.06)}
.panel-proximity-title{font-family:Pretendard,'Noto Sans KR',sans-serif;font-size:0.82rem;font-weight:900;color:#24382b;letter-spacing:-0.02em;text-transform:none;padding:13px 15px 11px;border-bottom:1px solid #eee7dc;background:linear-gradient(180deg,#fffdf8 0%,#faf6ee 100%)}
.panel-proximity-notice{margin:10px 12px 12px!important;padding:8px 10px!important;background:#fffaf0!important;border:1px solid #f1e2bd!important;border-radius:9px!important;font-family:Pretendard,'Noto Sans KR',sans-serif!important;font-size:0.74rem!important;color:#7a5a1e!important;line-height:1.55!important}
.proximity-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;background:#fff}
.proximity-item{min-height:78px;padding:12px 15px 13px;border-bottom:1px solid #eee7dc;border-right:1px solid #eee7dc;display:flex;flex-direction:column;justify-content:center;gap:6px;font-family:Pretendard,'Noto Sans KR',sans-serif;background:#fff}
.proximity-item:nth-child(2n){border-right:none}
.proximity-item:nth-last-child(-n+2){border-bottom:none}
.proximity-item:last-child:nth-child(odd){grid-column:span 2;border-right:none}
.proximity-icon-lbl{display:flex;align-items:center;gap:6px;font-size:0.78rem;color:#405347;font-weight:800;letter-spacing:-0.02em;line-height:1.25}
.proximity-val{display:flex;flex-direction:column;gap:2px;line-height:1.25}
.proximity-distance{font-size:1.02rem;font-weight:900;color:#111827;letter-spacing:-0.03em}
.proximity-place{font-size:0.8rem;font-weight:600;color:#5b665f;letter-spacing:-0.02em;word-break:keep-all;overflow-wrap:anywhere}
.proximity-val.empty{display:block;color:#8a8176;font-weight:600;font-size:0.84rem;font-style:normal}
#ruler-tooltip{position:absolute;z-index:50;pointer-events:none;background:rgba(30,61,34,0.92);color:#fff;padding:8px 14px;border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:0.82rem;font-weight:700;backdrop-filter:blur(6px);box-shadow:0 4px 16px rgba(0,0,0,0.25);white-space:nowrap;display:none}
#ruler-crosshair{position:absolute;inset:0;z-index:45;pointer-events:none;cursor:crosshair;display:none}
.ruler-point{position:absolute;width:14px;height:14px;background:var(--gold);border:2px solid #fff;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 2px 8px rgba(0,0,0,0.3);pointer-events:none}
.ruler-line{position:absolute;background:var(--gold);height:2px;transform-origin:left center;pointer-events:none;opacity:0.8}
#ruler-info-bar{position:absolute;bottom:80px;left:50%;transform:translateX(-50%);background:rgba(30,61,34,0.95);color:#fff;padding:9px 18px;border-radius:var(--radius);font-family:'Noto Sans KR',sans-serif;font-size:0.82rem;font-weight:700;backdrop-filter:blur(8px);box-shadow:0 2px 14px rgba(0,0,0,0.22);z-index:50;display:flex;visibility:hidden;gap:10px;align-items:center;white-space:nowrap}
#hotdeal-page,#community-page{background:#f7f5f1}
.page-tabs,.top-nav,.hd-hero{background:rgba(255,255,255,0.96);border-bottom-color:var(--sand);box-shadow:0 4px 20px rgba(20,20,20,0.05);backdrop-filter:blur(10px)}
.page-tab-logo,.page-tab-logo small,.page-tab,.logo,.hd-hero-title,.adv-filter-label,.adv-range-sep,.adv-unit{color:var(--charcoal)}
.logo em,.page-tab-logo em,.hd-hero-title em{color:var(--gold-lt)}
.chip,.adv-chip,.adv-reset-btn{background:#fff;border-color:#e0dbd3;color:#3a3530}
.chip:hover,.chip.active,.adv-chip:hover,.adv-chip.active,.adv-reset-btn:hover{background:#f0f7f2;border-color:#2b5f3a;color:#2b5f3a}
.hd-post-btn,.comment-submit,.form-submit,.loc-btn.active,.sigungu-chip.active,.cat-chip.active,.view-toggle-btn.active,.hd-chip:hover,.hd-chip.active,.hd-cat-btn:hover,.hd-cat-btn.active{background:#f3efe9;border-color:#d8d0c4;color:var(--charcoal)}
.list-item.active,.tag-new,.hd-badge-new{background:#f6f2eb;color:var(--charcoal);border-color:var(--sand)}
.modal,.write-modal-box,.post-detail-box,.detail-panel{box-shadow:0 10px 34px rgba(20,20,20,0.08)}
html{font-size:16px;scroll-behavior:smooth}
button,input,select,textarea{font:inherit}
input::placeholder,textarea::placeholder{color:#9b9389;opacity:1}
.page-tab,.chip,.nav-btn,.loc-btn,.cat-chip,.sigungu-chip,.view-toggle-btn,.hd-chip,.hd-cat-btn,.hd-post-btn,.comment-submit,.form-submit,.hd-btn-cancel,.hd-btn-submit,.btn-like,.btn-post-edit,.btn-post-delete{min-height:40px}
.page-tab-logo small,.hd-hero-sub,.adv-filter-label,.adv-range-sep,.adv-unit{color:#333}
#login-btn,#signup-btn,#user-greeting,#user-info button{color:#4b433b}
#login-btn{background:#fff;border-color:var(--sand)}
#signup-btn{background:var(--gold);border-color:var(--gold);color:#fff}
#signup-btn:hover{background:var(--gold-lt);border-color:var(--gold-lt)}
#user-greeting{font-size:0.88rem;font-weight:700;display:inline-flex;visibility:visible;opacity:1;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#243029!important;}
#user-info button{background:#f3efe9;border:1.5px solid var(--sand);color:#4b433b;border-radius:var(--radius);padding:7px 14px;font-size:0.84rem;font-weight:600;cursor:pointer;transition:background 0.18s;white-space:nowrap}
#user-info button:hover{background:#e8e0d0}
.top-nav,#adv-filter-panel{box-shadow:0 4px 20px rgba(20,20,20,0.05)}
.search-wrap input,.adv-range-input,.form-input,.form-select,.form-textarea,.write-input,.hd-form-input,.comment-input{min-height:44px;line-height:1.6}
.search-wrap input,.form-input,.form-select,.form-textarea,.write-input,.hd-form-input,.comment-input,.adv-range-input{border-width:1.5px}
.search-wrap input:focus,.form-input:focus,.form-select:focus,.form-textarea:focus,.write-input:focus,.hd-form-input:focus,.comment-input:focus,.adv-range-input:focus{border-color:#c7baa8;box-shadow:0 0 0 3px rgba(216,208,196,0.28)}
.hd-body,.comm-layout,.post-detail-wrap,.hd-detail-wrap{line-height:1.7}
.hd-card-body,.post-card,.post-detail-box,.comments-box,.sidebar-box,.modal-body,.write-modal-body,.hd-modal-body,.panel-body{line-height:1.7}
.hd-card-title,.post-card-title,.list-name,.panel-title,.post-detail-title{letter-spacing:-0.01em;line-height:1.5}
.hd-card-desc,.post-card-preview,.comment-body,.post-detail-body{color:#333}
.hd-card-desc,.post-card-preview{font-size:0.84rem;line-height:1.7}
.post-card-meta,.post-detail-meta,.comment-date,.list-loc-text,.list-type,.stat-lbl,.form-hint{color:#444}
.legend,.count-badge,.list-toggle,#saved-btn,#saved-panel,.detail-panel,.post-card,.gallery-card,.hd-card,.sidebar-box,.post-detail-box,.comments-box,.modal,.write-modal-box,.hd-modal-box{box-shadow:0 8px 28px rgba(20,20,20,0.06)}
@media(max-width:1024px){.page-tabs,.top-nav{padding-left:16px;padding-right:16px}.hd-body,.comm-layout,.post-detail-wrap,.hd-detail-wrap{padding-left:16px;padding-right:16px}.modal,.write-modal-box,.hd-modal-box{margin:20px 16px 60px}.comm-layout{grid-template-columns:1fr}.comm-sidebar{display:block}}
@media(max-width:768px){html{font-size:15px}body{font-size:15px}.page-tabs{height:auto;min-height:52px;padding:0 12px;gap:0;flex-wrap:nowrap}.page-tab-logo{font-size:1.1rem;margin-right:12px;flex-shrink:0}.page-tab-logo small{display:none}.page-tab{padding:0 14px;font-size:0.88rem;flex-shrink:0;min-height:52px}.page-tab-auth{flex-shrink:0;gap:6px}.auth-btn{padding:6px 10px;font-size:0.76rem}#user-greeting{display:none}.auth-btn-logout{font-size:0.78rem;padding:6px 10px}#hotdeal-page,#community-page,#gallery-page,.modal-overlay,#hd-write-modal,#hd-detail-page{top:52px}.top-nav{top:52px !important;flex-wrap:wrap;gap:8px;padding:10px 12px}.search-wrap{order:0;max-width:none;width:100%;flex:none}.filter-chips{order:1;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%;gap:5px;scrollbar-width:none}.filter-chips::-webkit-scrollbar{display:none}.chip{padding:0 18px;height:44px;font-size:0.92rem}#adv-filter-btn{order:2}.nav-btn{order:2;padding:9px 16px;font-size:0.84rem}#adv-filter-panel{width:calc(100vw - 16px)!important;max-width:320px;left:8px !important}#active-filter-bar{top:52px;padding:6px 12px}.list-panel{width:88vw;max-width:320px}.list-toggle{top:10px;left:12px;padding:8px 12px;font-size:0.8rem}.list-toggle.shifted{left:min(calc(88vw + 6px),346px)}.post-card{padding:16px 14px}.post-card-title{font-size:0.96rem}.modal-body,.write-modal-body,.hd-modal-body{padding:16px 14px}.modal-header,.hd-modal-head,.write-modal-head{padding:16px 14px 14px}.form-row{grid-template-columns:1fr}.comm-layout{grid-template-columns:1fr;padding:16px 12px 80px;gap:0}.comm-sidebar{display:block;margin-top:16px}.hd-body{padding:16px 12px 80px}.hd-hero{padding:20px 16px 16px}.comm-hero{padding:20px 16px 16px}.hd-filter-bar{gap:6px}.hd-chip{padding:6px 12px;font-size:0.78rem}.legend{display:none}.panel-body{padding:16px 16px 24px}#modal-body .form-area-row,.form-area-row{flex-direction:column}.post-detail-wrap,.hd-detail-wrap{padding:12px 12px 80px}}
@media(max-width:480px){.page-tab{padding:0 10px;font-size:0.82rem}.page-tab-logo{font-size:1rem;margin-right:8px}.chip,.cat-chip,.sigungu-chip,.hd-chip,.hd-cat-btn,.loc-btn,.view-toggle-btn{font-size:0.78rem;padding:5px 10px}.panel-title,.post-detail-title{font-size:1.1rem}.list-panel{width:92vw}.list-toggle.shifted{left:min(calc(92vw + 6px),356px)}.detail-panel{height:88vh}.modal,.write-modal-box,.hd-modal-box{margin:8px 4px 60px}.auth-btn{padding:5px 8px;font-size:0.74rem}.post-card{padding:14px 12px}.post-card-title{font-size:0.9rem}.post-card-preview{font-size:0.8rem}.search-wrap input{font-size:0.85rem;padding:10px 14px 10px 38px}.search-wrap .search-icon{left:12px}}
.search-autocomplete{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border-radius:var(--radius);box-shadow:0 6px 24px rgba(0,0,0,0.14);border:1px solid var(--sand);z-index:60;max-height:260px;overflow-y:auto;display:none}
.search-autocomplete.open{display:block;animation:filterSlideIn 0.15s ease}
.autocomplete-item{padding:10px 16px;cursor:pointer;font-size:0.88rem;color:var(--charcoal);display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--linen);transition:background 0.12s}
.autocomplete-item:last-child{border-bottom:none}
.autocomplete-item:hover{background:var(--linen)}
.autocomplete-item-icon{font-size:1rem;flex-shrink:0}
.autocomplete-item-text{flex:1;min-width:0}
.autocomplete-item-main{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.autocomplete-item-sub{font-size:0.75rem;color:#444;margin-top:1px}
.autocomplete-item-badge{font-size:0.7rem;color:var(--pine);font-weight:700;flex-shrink:0}
.list-sort-bar{display:flex;gap:4px;padding:8px 12px;border-bottom:1px solid var(--sand);background:var(--linen)}
.list-sort-btn{padding:4px 10px;border-radius:12px;border:1.5px solid var(--sand);background:#fff;font-family:'Noto Sans KR',sans-serif;font-size:0.74rem;font-weight:600;color:#444;cursor:pointer;transition:all 0.12s;white-space:nowrap}
.list-sort-btn.active{background:var(--pine);border-color:var(--pine);color:#fff}
.scroll-top-btn{position:fixed;bottom:32px;right:24px;z-index:150;width:44px;height:44px;border-radius:50%;background:var(--forest);color:#fff;border:none;font-size:1.1rem;cursor:pointer;box-shadow:0 4px 16px rgba(0,0,0,0.22);display:none;align-items:center;justify-content:center;transition:all 0.2s;opacity:0;transform:translateY(10px)}
.scroll-top-btn.visible{display:flex;opacity:1;transform:translateY(0)}
.scroll-top-btn:hover{background:var(--pine);transform:translateY(-2px)}
.mobile-bottom-tabs{display:none;position:fixed;bottom:0;left:0;right:0;z-index:190;height:var(--mob-tabs-h);background:var(--forest);border-top:2px solid var(--gold);box-shadow:0 -4px 20px rgba(0,0,0,0.18);flex-direction:row}
.mobile-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;border:none;background:none;color:rgba(255,255,255,0.5);cursor:pointer;font-family:'Noto Sans KR',sans-serif;font-size:0.65rem;font-weight:600;transition:color 0.15s;padding:6px 0}
.mobile-tab .m-icon{font-size:1.25rem;line-height:1}
.mobile-tab.active{color:var(--gold-lt)}
.mobile-tab:hover{color:rgba(255,255,255,0.85)}
@media(max-width:640px){.mobile-bottom-tabs{display:flex}}
@media(hover:none)and(pointer:coarse){.pin:hover .pin-tooltip{opacity:0}.hd-post-btn:hover,.nav-btn:hover,.hd-card:hover{transform:none !important}.page-tab{min-height:48px}.hd-chip,.cat-chip,.sigungu-chip,.loc-btn{min-height:40px}#hotdeal-page,#community-page,#gallery-page,.list-panel,.detail-panel,.modal-overlay,#hd-write-modal{-webkit-overflow-scrolling:touch}}
#gallery-page{display:none;position:fixed;inset:0;top:var(--tabs-h);background:#eee8dc;overflow-y:auto;z-index:100}
.gl-hero{background:linear-gradient(135deg,#faf7f2 0%,#f4f0e6 100%);padding:28px 24px 20px;text-align:center;border-bottom:2px solid #e8e0d0}
.gl-hero-title{font-family:'Noto Serif KR',serif;font-size:1.5rem;font-weight:900;color:var(--forest);margin-bottom:6px}
.gl-hero-title em{color:var(--sage);font-style:normal}
.gl-hero-sub{font-size:0.84rem;color:#444}
.gl-body{max-width:1080px;margin:0 auto;padding:28px 24px 80px}
.gl-register-box{margin:0 0 18px;padding:16px 18px;background:#fffdf8;border:1px solid #e6ddcf;border-left:4px solid var(--pine);border-radius:var(--radius-lg);box-shadow:0 2px 12px rgba(30,40,32,0.06);display:flex;align-items:center;justify-content:space-between;gap:12px}
.gl-register-box strong{display:block;color:var(--forest);font-size:0.95rem;margin-bottom:3px}
.gl-register-box span{color:#444;font-size:0.8rem}
.gl-register-btn{border:none;background:var(--pine);color:#fff;padding:10px 16px;border-radius:999px;font-family:'Noto Sans KR',sans-serif;font-size:0.84rem;font-weight:800;cursor:pointer;white-space:nowrap;box-shadow:0 4px 14px rgba(78,99,82,0.18)}
.gl-register-btn:hover{background:var(--forest)}
@media(max-width:600px){.gl-register-box{flex-direction:column;align-items:stretch;text-align:center}.gl-register-btn{width:100%}}
.gl-filter-bar{display:flex;gap:7px;flex-wrap:wrap;align-items:center;margin-bottom:20px}
.gl-chip{padding:7px 15px;border-radius:20px;border:1.5px solid var(--sand);background:#fff;font-family:'Noto Sans KR',sans-serif;font-size:0.79rem;font-weight:600;color:#444;cursor:pointer;transition:all 0.13s;white-space:nowrap}
.gl-chip:hover,.gl-chip.active{background:var(--pine);border-color:var(--pine);color:#fff}
.gl-count{font-size:0.78rem;color:#444;margin-left:auto}
.gl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.gl-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;border:1px solid #e2ddd3;box-shadow:0 2px 10px rgba(30,40,32,0.07);cursor:pointer;transition:transform 0.15s,box-shadow 0.15s}
.gl-card:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(30,40,32,0.14)}
.gl-card-img{width:100%;aspect-ratio:4/3;background:var(--linen);display:flex;align-items:center;justify-content:center;font-size:3.5rem;overflow:hidden;position:relative}
.gl-card-img img{width:100%;height:100%;object-fit:cover;display:block}
.gl-card-badge{position:absolute;top:8px;left:8px;display:flex;gap:4px;flex-wrap:wrap}
.gl-badge{padding:3px 9px;border-radius:20px;font-size:0.65rem;font-weight:800;letter-spacing:0.3px}
.gl-badge-deal{background:var(--forest);color:#fff}
.gl-badge-type{background:rgba(255,255,255,0.88);color:var(--charcoal)}
.gl-photo-count{position:absolute;bottom:7px;right:8px;background:rgba(0,0,0,0.52);color:#fff;font-size:0.68rem;font-weight:700;padding:2px 7px;border-radius:10px}
.gl-card-info{padding:12px 14px 14px}
.gl-card-price{font-size:0.88rem;font-weight:800;color:var(--pine);margin-bottom:5px}
@media(max-width:600px){.gl-grid{grid-template-columns:repeat(2,1fr);gap:9px}.gl-lb-arrow.prev{left:-38px}.gl-lb-arrow.next{right:-38px}#gallery-page{top:52px}}
@media(max-width:360px){.gl-grid{grid-template-columns:1fr}}
#home-page{display: none; position: fixed; inset: 0; top:var(--tabs-h); background: linear-gradient(180deg,#f8fbf9 0%,#f2f7f4 100%); overflow-y: auto; z-index: 100; font-family: Pretendard,'Noto Sans KR',sans-serif}
.h-page{width:min(1400px,100%);margin:0 auto;padding:0 32px 60px}
.h-hero{position:relative;min-height:400px;padding:64px 64px 110px;border-radius:0 0 28px 28px;overflow:visible;background:linear-gradient(90deg,rgba(246,252,248,.95)0%,rgba(246,252,248,.72)42%,rgba(255,255,255,.08)82%),url("https://images.unsplash.com/photo-1500382017468-9049fed747ef?auto=format&fit=crop&w=1800&q=85")center/cover no-repeat}
.h-hero h1{margin:0 0 16px;max-width:580px;color:var(--green-900);font-size:clamp(30px,3.8vw,52px);line-height:1.12;font-weight:900;letter-spacing:-.05em}
.h-hero p{margin:0;color:#294134;font-size:19px;line-height:1.55;font-weight:650}
.h-search{position:relative;z-index:20;width:min(860px,100%);min-height:66px;margin-top:36px;display:flex;align-items:center;border:1px solid rgba(230,235,232,.95);border-radius:20px;background:#fff;box-shadow:var(--h-shadow);overflow:visible}
.h-search-loc .s-icon{margin-right:10px;font-size:19px;color:#444}
.h-search-loc input{width:100%;border:0;outline:0;background:transparent;color:#243029;font-size:15px;font-family:inherit}
.h-search-loc input::placeholder{color:#9da7a1}
.h-region-select{position:relative;flex:1 1 auto;min-width:220px;height:66px;background:#fff;border-radius:20px 0 0 20px;overflow:visible}
.h-region-trigger{width:100%;height:100%;border:0;background:#fff;padding:0 20px;display:flex;align-items:center;justify-content:space-between;gap:10px;border-radius:20px 0 0 20px;color:#243029;text-align:left;font-family:inherit;cursor:pointer}
.h-region-label{color:#9da7a1;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.h-region-select.has-value .h-region-label{color:#243029;font-weight:800}
.h-region-chevron{width:30px;height:30px;flex:0 0 30px;border-radius:999px;background:#e9f5ee;position:relative;transition:.18s ease}
.h-region-chevron::before{content:"";position:absolute;left:50%;top:47%;width:7px;height:7px;border-right:2px solid var(--green);border-bottom:2px solid var(--green);transform:translate(-50%,-62%)rotate(45deg);transition:.18s ease}
.h-region-select.is-open .h-region-chevron{background:var(--green)}
.h-region-select.is-open .h-region-chevron::before{border-color:#fff;transform:translate(-50%,-35%)rotate(225deg)}
.h-region-panel{position:absolute;top:calc(100% + 10px);left:0;z-index:3000;width:min(580px,calc(100vw - 40px));padding:14px;border:1px solid rgba(7,136,61,.14);border-radius:20px;background:#fff;box-shadow:0 20px 48px rgba(20,59,40,.18);opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-6px)scale(.98);transform-origin:top left;transition:.18s ease}
.h-region-select.is-open .h-region-panel{opacity:1;visibility:visible;pointer-events:auto;transform:none}
.h-region-panel-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding-bottom:12px;margin-bottom:12px;border-bottom:1px solid var(--h-line)}
.h-region-panel-head strong{color:var(--green-900);font-size:14px;font-weight:900}
.h-region-reset{min-height:32px;border:0;border-radius:999px;padding:0 13px;background:var(--green-soft);color:var(--green);font-size:12px;font-weight:900;cursor:pointer;font-family:inherit}
.h-region-cols{display:grid;grid-template-columns:180px 1fr;gap:10px}
.h-region-col-title{margin:0 0 7px;color:#444;font-size:11px;font-weight:900}
.h-region-list{display:flex;flex-direction:column;gap:4px;max-height:290px;overflow:auto;padding-right:2px}
.h-region-list button{width:100%;min-height:36px;border:0;border-radius:10px;background:#fff;color:#28332d;font-size:13px;font-weight:800;text-align:left;padding:0 11px;cursor:pointer;font-family:inherit}
.h-region-list button:hover,.h-region-list button.is-active{background:var(--green-soft);color:var(--green)}
.h-region-list button.sigungu-all{color:var(--green-900);background:#f7fbf8}
.h-type-select{position:relative;flex:0 0 180px;height:66px;border-left:1px solid var(--h-line);overflow:visible}
.h-type-trigger{width:100%;height:100%;border:0;background:#fff;padding:0 16px;display:flex;align-items:center;justify-content:space-between;gap:8px;color:#243029;font-size:14px;font-weight:800;text-align:left;cursor:pointer;font-family:inherit}
.h-type-label{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.h-type-chevron{width:30px;height:30px;flex:0 0 30px;border-radius:999px;background:#e9f5ee;position:relative;transition:.18s ease}
.h-type-chevron::before{content:"";position:absolute;left:50%;top:47%;width:7px;height:7px;border-right:2px solid var(--green);border-bottom:2px solid var(--green);transform:translate(-50%,-62%)rotate(45deg);transition:.18s ease}
.h-type-select.is-open .h-type-chevron{background:var(--green)}
.h-type-select.is-open .h-type-chevron::before{border-color:#fff;transform:translate(-50%,-35%)rotate(225deg)}
.h-type-menu{position:absolute;top:calc(100% + 10px);left:0;right:0;z-index:2000;list-style:none;margin:0;padding:8px;border:1px solid rgba(7,136,61,.14);border-radius:16px;background:#fff;box-shadow:0 20px 48px rgba(20,59,40,.18);opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-6px)scale(.98);transform-origin:top center;transition:.18s ease}
.h-type-select.is-open .h-type-menu{opacity:1;visibility:visible;pointer-events:auto;transform:none}
.h-type-menu li{min-height:38px;display:flex;align-items:center;border-radius:10px;padding:0 11px;color:#28332d;font-size:13px;font-weight:800;cursor:pointer}
.h-type-menu li:hover,.h-type-menu li[aria-selected="true"]{background:var(--green-soft);color:var(--green)}
.h-search-btn{flex: 0 0 120px; height: 56px; margin-right: 5px; border: 0; border-radius: 16px; background: linear-gradient(135deg,var(--green),#22a65a); color: #fff; display: flex; align-items: center; justify-content: center; gap: 7px; font-size: 15px; font-weight: 900; font-family: inherit; box-shadow: 0 10px 22px rgba(7,136,61,.24); cursor: pointer; transition: .18s ease}
.h-search-btn:hover{background:var(--green-700)}
.h-shortcuts{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:32px 0 36px}
.h-shortcut{min-height:118px;border:1px solid var(--h-line);border-radius:20px;background:#fff;box-shadow:0 10px 28px rgba(20,59,40,.06);display:flex;align-items:center;gap:16px;padding:24px;transition:.2s ease;cursor:pointer;text-decoration:none;color:inherit}
.h-shortcut:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(20,59,40,.11)}
.h-sc-icon{width:56px;height:56px;flex:0 0 56px;border-radius:16px;display:grid;place-items:center;font-size:26px}
.h-sc-icon.map{background:var(--green-soft)}
.h-sc-icon.list{background:var(--blue-soft)}
.h-sc-icon.comm{background:var(--purple-soft)}
.h-sc-icon.deal{background:var(--yellow-soft)}
.h-sc-text strong{display:block;margin-bottom:6px;font-size:17px;font-weight:900;letter-spacing:-.03em}
.h-sc-text span{display:block;color:var(--h-muted);font-size:13px;line-height:1.5}
.h-sc-arrow{margin-left:auto;color:#555;font-size:22px}
.h-types{display:grid;grid-template-columns:repeat(7,1fr);gap:12px;margin-bottom:28px}
.h-type-card{min-height:104px;border:1px solid var(--h-line);border-radius:16px;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;font-weight:900;font-size:14px;box-shadow:0 8px 20px rgba(20,59,40,.04);transition:.2s ease;cursor:pointer;text-decoration:none;color:inherit}
.h-type-card:hover{transform:translateY(-3px);box-shadow:0 14px 28px rgba(20,59,40,.09)}
.h-type-card.is-active{border-color:rgba(7,136,61,.35);background:var(--green-soft);color:var(--green)}
.h-type-card.is-disabled{opacity:.45;pointer-events:none}
.h-type-icon{font-size:28px}
.h-count{color:var(--green);font-weight:900;font-size:13px}
.h-section-head{display:flex;justify-content:space-between;align-items:center;margin:28px 0 14px}
.h-section-head h2{margin:0;font-size:22px;letter-spacing:-.04em;font-weight:900}
.h-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.h-prop-card{position:relative;overflow:hidden;border:1px solid var(--h-line);border-radius:20px;background:#fff;box-shadow:0 10px 28px rgba(20,59,40,.05);transition:.2s ease;cursor:pointer}
.h-prop-card:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(20,59,40,.1)}
.h-prop-img{height: 156px; background-size: cover; background-position: center; background-color: #e7efe9}
.h-prop-badge{position:absolute;top:12px;left:12px;background:var(--green);color:#fff;border-radius:999px;padding:6px 11px;font-size:11px;font-weight:900;box-shadow:0 8px 18px rgba(7,136,61,.22)}
.h-prop-heart{position:absolute;top:11px;right:12px;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.9);color:#e84d69;font-size:20px;border:1px solid rgba(230,235,232,.85);cursor:pointer}
.h-prop-info{padding:14px 16px}
.h-prop-loc{margin:0 0 7px;color:var(--h-muted);font-size:12px}
.h-prop-price{margin:0 0 7px;color:var(--green);font-size:19px;font-weight:900}
.h-empty{display: none; margin-top: 16px; padding: 50px 24px; border: 1px dashed rgba(7,136,61,.28); border-radius: 22px; background: radial-gradient(circle at top,rgba(7,136,61,.08),transparent 38%),#fff; text-align: center; box-shadow: 0 12px 32px rgba(20,59,40,.06)}
.h-empty.is-show{display:block}
.h-empty-icon{width:68px;height:68px;margin:0 auto 16px;display:grid;place-items:center;border-radius:22px;background:var(--green-soft);font-size:32px}
.h-empty h3{margin:0 0 7px;color:var(--green-900);font-size:20px;font-weight:900;letter-spacing:-.04em}
.h-empty p{margin:0;color:var(--h-muted);font-size:13px;line-height:1.65}
.h-empty-reset{margin-top:16px;min-height:40px;padding:0 18px;border:0;border-radius:12px;background:var(--green);color:#fff;font-size:14px;font-weight:900;cursor:pointer;font-family:inherit;box-shadow:0 10px 22px rgba(7,136,61,.18)}
.h-benefits{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:30px}
.h-benefit{display:flex;align-items:center;gap:14px;border:1px solid var(--h-line);border-radius:18px;background:#fff;padding:16px 18px;transition:.2s ease}
.h-benefit:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(20,59,40,.07)}
.h-benefit-icon{width:48px;height:48px;flex:0 0 48px;border-radius:14px;display:grid;place-items:center;background:var(--green-soft);font-size:23px}
.h-benefit strong{display:block;margin-bottom:3px;font-weight:900;font-size:14px}
.h-benefit span{color:var(--h-muted);font-size:12px;line-height:1.5}
.h-legal{margin-top:40px;position:relative;overflow:hidden;border:1px solid rgba(39,93,62,.14);border-radius:26px;background:radial-gradient(circle at top right,rgba(92,159,117,.14),transparent 34%),linear-gradient(135deg,#fff 0%,#f7fbf8 100%);box-shadow:0 18px 48px rgba(20,59,40,.09);padding:28px 30px}
.h-legal::before{content:"";position:absolute;left:30px;top:26px;width:40px;height:4px;border-radius:999px;background:linear-gradient(90deg,var(--green),#b7d8c2)}
.h-legal-topline{display:inline-flex;align-items:center;gap:7px;margin-top:12px;padding:6px 11px;border-radius:999px;background:rgba(7,136,61,.08);color:var(--green-900);font-size:11px;font-weight:900}
.h-legal-dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(7,136,61,.12)}
.h-legal-title{margin:12px 0 0;color:#20362a;font-size:19px;line-height:1.35;letter-spacing:-.04em;font-weight:900}
.h-legal-sub{margin:7px 0 0;max-width:800px;color:#444;font-size:13px;line-height:1.75}
.h-legal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-top:20px}
.h-legal-item{background:rgba(255,255,255,.74);border:1px solid rgba(221,229,224,.9);border-radius:16px;padding:13px;color:#444;font-size:12px;line-height:1.62}
.h-legal-item strong{display:block;color:#20362a;font-size:13px;margin-bottom:4px;font-weight:900}
.h-copyright{text-align:center;color:#555;font-size:11px;margin:16px 0 0}
.h-footer-links{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:14px;color:#444;font-size:12px;font-weight:800}
.h-footer-links a{padding:5px 7px;border-radius:999px;transition:.18s ease;color:inherit;text-decoration:none}
.h-footer-links a:hover{background:rgba(7,136,61,.08);color:var(--green)}
.copy-toast.is-show{opacity:1;transform:translateX(-50%)translateY(0)}
@media(max-width:1100px){.h-shortcuts,.h-cards,.h-benefits{grid-template-columns:repeat(2,1fr)}.h-types{grid-template-columns:repeat(4,1fr)}.h-legal-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:820px){.h-region-cols{grid-template-columns:1fr}.h-region-list{max-height:180px}.h-region-panel{width:100%}}
@media(max-width:720px){.h-page{padding:0 14px 40px}.h-hero{padding:36px 18px 30px;min-height:auto}.h-hero h1{font-size:30px}.h-hero p{font-size:15px}.h-search{flex-direction:column;padding:10px;gap:8px}.h-region-select,.h-type-select{width:100%;flex:auto;height:54px;border-left:0;border-radius:14px}.h-region-trigger{border-radius:14px;height:54px}.h-search-btn{width:100%;flex:auto;height:54px;margin:0;border-radius:14px}.h-shortcuts,.h-types,.h-cards,.h-benefits,.h-legal-grid{grid-template-columns:1fr}.h-types{grid-template-columns:repeat(2,1fr)}.h-shortcuts{margin-top:22px}.h-shortcut{min-height:106px;padding:20px}.h-legal{padding:24px 18px}}
@media(max-width:420px){.h-types{grid-template-columns:repeat(2,1fr)}}
html,body{width: 100%; min-height: 100%; max-width: 100%; overflow-x: hidden}
.auth-btn-filled,#signup-btn{background:var(--green);border-color:var(--green);color:#fff;box-shadow:0 8px 18px rgba(7,136,61,.18)}
#home-page .h-hero{min-height:460px;border-radius:0 0 34px 34px;box-shadow:inset 0 -90px 80px rgba(247,249,248,.86)}
#home-page .h-hero h1{text-shadow:0 2px 0 rgba(255,255,255,.4)}
#home-page .h-search{border:1px solid rgba(7,136,61,.12);box-shadow:0 22px 55px rgba(20,59,40,.16)}
.h-shortcut,.h-type-card,.h-prop-card,.h-benefit,.h-legal{border-color:#e4ece7}
.h-section-head h2::before{content:"";display:inline-block;width:5px;height:24px;margin-right:10px;border-radius:999px;background:var(--green);vertical-align:-5px}
.h-prop-card,.gl-card,.post-card,.hd-card{overflow:hidden}
.h-prop-title,.gl-card-title,.post-card-title,.hd-card-title{word-break:keep-all}
.filter-main-btn,.register-btn{border-radius:999px}
@media(max-width:768px){#home-page{top:52px}.page-tab-logo::before{width:28px;height:28px;font-size:15px;margin-right:6px}.h-region-panel{left:50%!important;transform:translateX(-50%)translateY(-6px)scale(.98);width:calc(100vw - 36px)!important}.h-region-select.is-open .h-region-panel{transform:translateX(-50%)}.h-search{box-shadow:0 14px 36px rgba(20,59,40,.14)}}
@media(max-width:640px){#home-page,#community-page,#gallery-page,#hotdeal-page{bottom:calc(var(--mob-tabs-h) + env(safe-area-inset-bottom,0px)) !important;padding-bottom:0}.mobile-bottom-tabs{background:rgba(255,255,255,.96);border-top:1px solid #e1e9e5;backdrop-filter:blur(12px)}.mobile-tab{color:#444}}
#gl-detail-agency-btn:hover{background:var(--forest)}
#gl-detail-edit-btn:hover{background:#e8ddd0}
#gl-detail-del-btn:hover{background:#ffd6d6}
#gl-detail-msg-btn:hover{background:var(--forest)}
.write-submit-btn:hover{background:var(--forest)}
#auth-modal button[onclick="doLogin()"]:hover,#auth-modal button[onclick="doSignup()"]:hover{background:var(--forest)}
.list-item[role="button"]:focus-visible{outline:2px solid var(--gold);outline-offset:-2px}
.panel-close,.modal-close,.msg-modal-close,.report-modal-close,.side-panel-close{background:rgba(255,255,255,.96)!important;color:#1f2a24 !important;border:1.5px solid rgba(31,42,36,.18)!important;box-shadow:0 4px 14px rgba(0,0,0,.22)!important;font-size:0 !important;font-weight:900 !important;line-height:1 !important;display:inline-flex !important;align-items:center !important;justify-content:center !important;opacity:1 !important}
.panel-close::before,.modal-close::before,.msg-modal-close::before,.report-modal-close::before,.side-panel-close::before{content:"×";font-size:25px;font-weight:900;line-height:1;color:#1f2a24}
.panel-close:hover,.modal-close:hover,.msg-modal-close:hover,.report-modal-close:hover,.side-panel-close:hover,.adv-filter-dropdown-close:hover{background:#ffffff !important;color:#000 !important;transform:scale(1.06);box-shadow:0 6px 18px rgba(0,0,0,.28)!important}
.side-panel-close,.msg-modal-close,.report-modal-close,.modal-close,.adv-filter-dropdown-close{width:36px !important;height:36px !important;border-radius:50% !important}
img,video{max-width:100%}
button,input,textarea,select{font-family:inherit}
@media(max-width:1024px){.page-tabs{padding:0 14px}.page-tab{padding:0 16px}#adv-filter-panel,#prox-filter-panel{width:min(440px,calc(100vw - 24px));right:12px;left:auto}.detail-panel{width:min(480px,92vw)}.gl-body,.hd-body,.comm-layout{max-width:100%}}
@media(max-width:768px){body{min-width:0}.page-tabs{height:52px;padding:0 10px;gap:0}.page-tab-logo{margin-right:10px;font-size:1.05rem}.page-tab{min-width:max-content;height:52px;padding:0 12px;font-size:.84rem}.page-tab-auth{gap:6px}.auth-btn{padding:6px 10px;font-size:.76rem}.top-nav{top:52px;padding:8px 10px;gap:8px;overflow-x:auto;align-items:flex-start}.search-wrap{min-width:220px;flex:1 0 100%;max-width:none}.filter-chips{flex:1 0 auto;overflow-x:auto;padding-bottom:2px}.chip{height:40px;padding:0 14px;font-size:.86rem}.filter-main-btn,.register-btn{height:38px;padding:0 14px}#hotdeal-page,#community-page,#gallery-page,#gl-detail-page,#hd-detail-page,#post-detail-page,#write-modal,#hd-write-modal{top:52px}#adv-filter-panel,#prox-filter-panel{top:104px !important;left:8px !important;right:8px !important;width:calc(100vw - 16px)!important;max-height:calc(100vh - 116px)}.adv-proximity-grid{display:flex;flex-direction:column;gap:5px}.hd-card{min-height:96px}.hd-card-thumb{width:96px;min-width:96px}.post-card-top{gap:10px}.post-card-thumb{width:64px;height:64px}.gallery-grid,.gl-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.modal,.write-modal-box,.hd-modal-box{width:calc(100vw - 16px);margin:12px 8px 70px}.modal-footer,.hd-modal-footer{flex-wrap:wrap}}
@media(max-width:420px){.gallery-grid,.gl-grid{grid-template-columns:1fr}.page-tab-logo small{display:none !important}#user-greeting{display:none !important}.hd-card-title,.post-card-title,.gl-card-title{white-space:normal}.hd-sort-right{margin-left:0;width:100%}}
.sigungu-section{display:none;width:100%;margin:0 0 14px;padding:14px 14px 16px;background:#f7faf8;border:1.5px solid #dfe9e2;border-left:5px solid var(--pine);border-radius:12px;box-shadow:0 2px 10px rgba(30,40,32,0.05)}
.sigungu-section-head{display:flex;align-items:center;gap:8px;margin-bottom:10px;padding-bottom:9px;border-bottom:1px solid #e2ebe5}
.sigungu-section-kicker{font-size:0.72rem;font-weight:800;color:#444;letter-spacing:0.3px}
.sigungu-section-head strong{font-size:0.9rem;font-weight:900;color:var(--forest)}
.sigungu-section-title{display:flex;align-items:center;gap:6px;font-size:0.82rem;font-weight:900;color:var(--pine);margin-bottom:9px}
.sigungu-section-title::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--pine)}
.sigungu-section .sigungu-bar{display:flex;flex-wrap:wrap;gap:7px;padding:0;margin:0;background:transparent;border:0;border-radius:0}
.sigungu-section .sigungu-chip{padding:7px 14px 8px;border-radius:8px;background:#fff;border:1.5px solid #dcd6cc;color:#444;font-size:0.8rem !important}
.sigungu-section .sigungu-chip:hover{border-color:var(--pine);color:var(--pine)}
.sigungu-section .sigungu-chip.active{background:var(--pine);border-color:var(--pine);color:#fff}
@media(max-width:640px){.sigungu-section{padding:12px 10px 14px;border-radius:10px}.sigungu-section .sigungu-chip{padding:7px 11px;font-size:0.78rem !important}}
.price-box{display:flex;gap:8px;align-items:center}
.price-input{flex:1;min-width:0}
.unit-btn{height:44px;padding:0 14px;border:1.5px solid var(--sand);background:#fff;border-radius:8px;cursor:pointer;font-size:0.82rem;font-weight:700;color:#444}
.unit-btn.active{background:var(--pine);color:#fff;border-color:var(--pine)}
.map-mode-btn{display:inline-flex!important;align-items:center;gap:6px;height:40px!important;padding:0 16px;border-radius:20px;background:#fff;border:1.5px solid #ddd6ce;color:#2f2a25;font-family:'Noto Sans KR',sans-serif;font-size:.86rem!important;font-weight:800!important;cursor:pointer;white-space:nowrap;box-shadow:0 1px 6px rgba(20,20,20,.06);transition:all .18s}
.map-mode-btn:hover{background:#faf7f3;border-color:#b0a896;transform:translateY(-1px)}
.map-mode-btn.active{background:#2f2a25;border-color:#2f2a25;color:#fff}
.btn-map-mode{display:inline-flex;align-items:center;gap:6px;padding:12px 14px;background:#f4faf6;color:#2d6b42;border:1.5px solid #d8e8dd;border-radius:8px;font-family:'Noto Sans KR',sans-serif;font-size:.84rem;font-weight:800;cursor:pointer;transition:all .15s;white-space:nowrap}
.btn-map-mode:hover{background:#e6f4ec;border-color:var(--pine);color:var(--forest)}
#roadview-modal-overlay{display:none;position:fixed;inset:0;z-index:720;background:rgba(20,25,22,.62);backdrop-filter:blur(4px);align-items:center;justify-content:center;padding:18px}
#roadview-modal-overlay.open{display:flex}
.roadview-modal-box{width:min(980px,96vw);height:min(720px,86vh);background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 24px 70px rgba(0,0,0,.28);display:flex;flex-direction:column;border-top:5px solid var(--pine)}
.roadview-modal-head{height:52px;display:flex;align-items:center;justify-content:space-between;padding:0 18px;background:#faf7f3;border-bottom:1px solid var(--sand)}
.roadview-modal-title{font-family:'Noto Serif KR',serif;font-size:1rem;font-weight:900;color:var(--forest)}
.roadview-modal-close{width:32px;height:32px;border:0;border-radius:9px;background:#ece7df;color:#444;font-size:1rem;font-weight:900;cursor:pointer}
.roadview-modal-close:hover{background:#ded6ca;color:#222}
#roadview-view{flex:1;width:100%;min-height:320px;background:#eee}
.roadview-modal-note{padding:9px 14px;background:#fff;color:#444;font-size:.78rem;border-top:1px solid var(--sand);line-height:1.5}
@media(max-width:768px){.map-mode-btn{height:36px;padding:0 12px;font-size:.8rem!important}.roadview-modal-box{width:100vw;height:100vh;border-radius:0}.roadview-modal-head{height:50px}}
#inbox-header-btn{display:inline-flex;visibility:visible;pointer-events:auto;position:relative;align-items:center;gap:6px}
#inbox-panel[style*="display:flex"],#inbox-panel[style*="display:flex"]{display:flex!important;visibility:visible!important;pointer-events:auto!important}
#inbox-panel-overlay[style*="display:block"],#inbox-panel-overlay[style*="display:block"]{display:block!important;visibility:visible!important;pointer-events:auto!important}
@media (max-width:768px){body{overflow-x:hidden}.page-tabs{height:52px;padding:0 10px;gap:2px}.page-tab-logo{margin-right:8px;font-size:1.05rem}.page-tab{padding:0 12px;font-size:.86rem}.top-nav{top:52px!important;padding:8px 10px;gap:7px}.search-wrap{min-width:100%;max-width:none}.detail-panel{width:min(100vw,420px)}#inbox-panel{top:52px!important;height:calc(100vh - 52px)!important;width:100vw!important}#inbox-panel-overlay{top:52px!important}}
img{max-width:100%}
.side-panel{display:none;position:fixed;top:var(--tabs-h);right:0;z-index:501;width:min(430px,100vw);height:calc(100vh - 62px);background:#fff;box-shadow:-4px 0 32px rgba(0,0,0,.14);border-left:1px solid var(--sand);flex-direction:column;font-family:'Noto Sans KR',sans-serif;outline:none}
.side-panel-overlay{display:none;position:fixed;inset:0;top:var(--tabs-h);z-index:500;background:rgba(20,25,22,.28);backdrop-filter:blur(1px)}
.side-panel-head{padding:17px 20px 14px;border-bottom:1px solid rgba(255,255,255,.14);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--forest)}
.side-panel-title{font-family:'Noto Serif KR',serif;font-size:1.05rem;font-weight:800;color:#fff}
.side-panel-sub{font-size:.74rem;color:rgba(255,255,255,.62);margin-top:3px}
.side-panel-close{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.82);font-size:1rem;cursor:pointer;border-radius:9px;width:32px;height:32px;line-height:1}
.side-panel-close:hover{background:rgba(255,255,255,.2);color:#fff}
.side-panel-content{flex:1;overflow-y:auto;background:#fff}
.activity-badge{align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#c0392b;color:#fff;font-size:.68rem;font-weight:900;line-height:1}
.activity-tabs{display:flex;border-bottom:1px solid var(--sand);background:#fff;position:sticky;top:0;z-index:2}
.activity-tab{flex:1;padding:13px 0;border:none;border-bottom:2px solid transparent;background:#fff;font-family:'Noto Sans KR',sans-serif;font-size:.83rem;font-weight:900;color:#444;cursor:pointer}
.activity-tab span{font-size:.72rem;opacity:.8}
.activity-tab.active{color:var(--pine);border-bottom-color:var(--pine)}
.activity-list{padding:12px}
.activity-card{display:flex;gap:12px;align-items:flex-start;background:#fff;border:1.5px solid #e8ede9;border-radius:12px;padding:14px;margin-bottom:10px;cursor:pointer;transition:border-color 0.18s,box-shadow 0.18s,transform 0.15s}
.activity-card:hover{border-color:#d8e6dd;box-shadow:0 7px 22px rgba(30,40,32,.08)}
.activity-thumb{width:68px;height:68px;border-radius:10px;overflow:hidden;background:#f4f0e8;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.activity-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.activity-thumb-emoji{font-size:1.7rem}
.activity-main{min-width:0;flex:1}
.activity-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}
.activity-pill{display:inline-flex;padding:2px 8px;border-radius:999px;background:#f0f7f2;color:var(--pine);font-size:.68rem;font-weight:900}
.activity-date{font-size:.7rem;color:#444;white-space:nowrap}
.activity-main h4{font-size:.92rem;color:var(--forest);font-weight:900;line-height:1.45;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0 0 3px}
.activity-main p{font-size:.76rem;color:#333;line-height:1.55;margin:0 0 4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.activity-main strong{display:block;font-size:.9rem;color:var(--pine);font-weight:900;margin-top:2px}
.activity-main small{font-size:.72rem;color:#444}
.activity-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.activity-actions button,.activity-primary{padding:7px 10px;border:1px solid #d8e8dd;background:#f4faf6;color:#2d6b42;border-radius:8px;font-family:'Noto Sans KR',sans-serif;font-size:.74rem;font-weight:900;cursor:pointer}
.activity-actions button:hover,.activity-primary:hover{background:#e6f4ec;border-color:var(--pine)}
.activity-actions button.danger{border-color:#f3c3c3;background:#fff5f5;color:#c0392b}
.activity-actions button.danger:hover{background:#ffe9e9}
.activity-empty{padding:58px 24px;text-align:center;color:#444;line-height:1.75}
.activity-empty-icon{font-size:2.4rem;margin-bottom:10px}
.activity-empty b{display:block;color:var(--forest);font-size:.98rem;margin-bottom:4px}
.activity-empty p{font-size:.82rem;margin-bottom:14px;color:#444}
.activity-primary{display:inline-flex;text-decoration:none}
.side-panel-open{overflow:hidden}
@media(max-width:768px){.side-panel{top:52px!important;height:calc(100vh - 52px)!important;width:100vw!important}.side-panel-overlay{top:52px!important}.activity-list{padding:10px}.activity-card{padding:12px}.activity-thumb{width:62px;height:62px}.page-tab-auth{gap:6px}}
@media(min-width:769px){body.map-page-active .top-nav{display:flex !important;top:89px !important}}
body.map-page-active #map-container{display:block !important;position:fixed !important;left:0 !important;right:0 !important;width:100vw !important;top:155px;bottom:0;height:calc(100vh - 155px)}
body:not(.map-page-active) #map-container{display:none !important}
body:not(.map-page-active) .list-panel,body:not(.map-page-active) .detail-panel{display:none !important}
/* ── 모바일: 지도 전체화면 (필터/목록 숨김) ── */
@media(max-width:768px){
  body.map-page-active .top-nav{display:none !important}
  body.map-page-active .list-panel{display:none !important}
  body.map-page-active .list-toggle{display:none !important}
  body.map-page-active #active-filter-bar{display:none !important}
  body.map-page-active #map-container{
    display:block !important;
    position:fixed !important;
    left:0 !important;
    right:0 !important;
    /* top/height/bottom은 JS adjustMapLayout()이 인라인으로 제어 */
    top:52px;
    height:calc(100vh - 52px);
    bottom:0;
  }
}
/* ── 모바일 하단 탭바가 있을 때 지도 height 보정 ── */
@media(max-width:640px){
  body.map-page-active #map-container{
    display:block !important;
    position:fixed !important;
    left:0 !important;
    right:0 !important;
    top:52px;
    height:calc(100vh - 52px - var(--mob-tabs-h));
    bottom:var(--mob-tabs-h);
  }
}
img,video,canvas,svg{max-width:100%}
@media(max-width:768px){input,select,textarea{font-size:16px !important}}
.pagination{display:flex;align-items:center;justify-content:center;gap:6px;padding:24px 0 8px;flex-wrap:wrap}
.pg-btn{min-width:36px;height:36px;padding:0 10px;border-radius:8px;border:1.5px solid var(--sand);background:#fff;font-family:'Noto Sans KR',sans-serif;font-size:0.82rem;font-weight:700;color:#444;cursor:pointer;transition:all 0.14s;display:inline-flex;align-items:center;justify-content:center}
.pg-btn:hover:not(:disabled){border-color:var(--pine);color:var(--pine);background:#f0f7f2}
.pg-btn.active{background:var(--pine);border-color:var(--pine);color:#fff}
.pg-btn:disabled{opacity:0.38;cursor:default}
.pg-ellipsis{color:#444;font-size:0.82rem;padding:0 4px;line-height:36px}
@media(max-width:480px){.pg-btn{min-width:32px;height:32px;font-size:0.78rem}.pagination{gap:4px}}
#photo-lb-overlay.is-open{display:flex !important;animation:lbFadeIn 0.18s ease}
@keyframes lbFadeIn{from{opacity:0}to{opacity:1}}
#photo-lb-img.lb-changing{opacity:0}
#photo-lb-overlay{background:radial-gradient(circle at center,rgba(255,255,255,0.08),rgba(0,0,0,0.92)58%)!important}
#photo-lb-img{background:rgba(0,0,0,0.18)}
#photo-lb-prev,#photo-lb-next{width:56px !important;height:56px !important;background:rgba(255,255,255,0.18)!important;backdrop-filter:blur(8px);box-shadow:0 14px 34px rgba(0,0,0,0.28)}
#photo-lb-prev:hover,#photo-lb-next:hover{background:rgba(255,255,255,0.3)!important}
.gl-detail-photo-wrap::after{content:'클릭해서 크게 보기';position:absolute;right:12px;bottom:12px;padding:7px 12px;border-radius:999px;background:rgba(0,0,0,0.48);color:#fff;font-size:0.76rem;font-weight:700;letter-spacing:-0.2px;pointer-events:none;opacity:0.92}
.gl-detail-photo-wrap .gl-detail-dots,.gl-detail-photo-wrap .gl-detail-nav,.gl-detail-photo-wrap #gl-detail-counter{z-index:3}
@media(max-width:640px){#photo-lb-img{width:98vw !important;height:86vh !important}.gl-detail-photo-wrap::after{font-size:0.7rem;padding:6px 10px}}
/* 터치 기기: "클릭" → "탭" */
@media(hover:none) and (pointer:coarse){
  .gl-detail-photo-wrap::after{content:'탭해서 크게 보기'}
}
.gl-detail-photo-wrap img,.panel-img,.post-detail-photos img,.gl-card-img img,.hd-card-thumb img{cursor:zoom-in !important}
.hvr-forest{background:var(--pine);color:#fff}
.hvr-forest:hover{background:var(--forest)}
.hvr-sand:hover{background:var(--sand)}
.hvr-edit{background:#f5f0e8;color:var(--forest);border:none}
.hvr-edit:hover{background:#e8ddd0}
.hvr-del{background:#fff0f0;color:#c0392b;border:none}
.hvr-del:hover{background:#ffd6d6}


/* ==================== MOBILE ====================
   브레이크포인트: 1024 / 768 / 640 / 600 / 540 / 480 / 420 / 380 / 360
   원칙
   - 터치 타겟 44px 이상
   - 폰트 최소 12px (화면 내 최소 0.75rem)
   - 입력필드 font-size 16px (iOS 자동 줌 방지)
   - safe-area-inset-bottom 대응
   - hover 잔상 제거 (touch 기기)
================================================ */

/* ── CSS 변수 재정의 ── */
@media(max-width:768px){
  :root{ --tabs-h:52px; --mob-tabs-h:56px }
}

/* ── 1024px: 탭·패널 여백 축소 ── */
@media(max-width:1024px){
  .page-tabs{ padding:0 14px }
  .page-tab{ padding:0 16px }
  #adv-filter-panel,#prox-filter-panel{ width:min(440px,calc(100vw - 24px)); right:12px; left:auto }
  .detail-panel{ width:min(480px,92vw) }
  .gl-body,.hd-body,.comm-layout{ max-width:100% }
}

/* ── 768px: 상단 탭바 ── */
@media(max-width:768px){
  body{ min-width:0; overflow-x:hidden !important }
  .page-tabs{
    height:52px !important; padding:0 14px !important; gap:0 !important;
    flex-wrap:nowrap !important;
  }
  .page-tab-logo{ font-size:1.05rem !important; margin-right:10px !important; flex-shrink:0 }
  .page-tab-logo small{ display:none !important }
  .page-tab{ padding:0 12px !important; font-size:0.86rem !important; flex-shrink:0; min-height:52px !important }
  .page-tab-auth{ flex-shrink:0; gap:6px }
  .auth-btn{ padding:6px 10px; font-size:0.76rem }
  #user-greeting{ display:none !important }
  #user-info{ gap:5px !important }
  #inbox-header-btn,.auth-btn-logout{ padding:5px 9px !important; font-size:0.76rem !important }
}

/* ── 768px: 페이지 top 위치 통일 ── */
@media(max-width:768px){
  #hotdeal-page,#community-page,#gallery-page,
  #gl-detail-page,#hd-detail-page,#post-detail-page,
  #home-page,#write-modal,.modal-overlay,#hd-write-modal{ top:52px !important }
}

/* ── 768px: 지도 & 네비 ── */
@media(max-width:768px){
  body.map-page-active .top-nav,
  body.map-page-active .list-panel,
  body.map-page-active .list-toggle,
  body.map-page-active #active-filter-bar{ display:none !important }
  body.map-page-active #map-container{
    display:block !important; position:fixed !important;
    left:0 !important; right:0 !important;
    top:52px; height:calc(100vh - 52px); bottom:0;
  }
  #map-container,#map{ touch-action:none !important; pointer-events:auto !important }
  #map > div,#map > div > div{ pointer-events:auto !important; touch-action:none !important }
  .top-nav{ top:52px !important; padding:8px 10px !important; gap:8px !important; overflow-x:auto }
  .search-wrap{ min-width:100%; max-width:none; flex:1 0 100% }
  .filter-chips{ flex:1 0 auto; overflow-x:auto; padding-bottom:2px; scrollbar-width:none }
  .filter-chips::-webkit-scrollbar{ display:none }
  .chip{ height:40px; padding:0 14px; font-size:0.86rem }
  .filter-main-btn,.register-btn{ height:38px; padding:0 14px }
  #adv-filter-panel,#prox-filter-panel{
    top:104px !important; left:8px !important; right:8px !important;
    width:calc(100vw - 16px) !important; max-height:calc(100vh - 116px);
  }
  .adv-proximity-grid{ display:flex; flex-direction:column; gap:5px }
}

/* ── 768px: 매물 상세 패널 (바텀시트) ── */
@media(max-width:768px){
  .detail-panel{
    top:auto !important; bottom:0 !important; left:0 !important; right:0 !important;
    width:100% !important; height:min(82vh, calc(100vh - 60px)) !important;
    border-radius:20px 20px 0 0 !important;
    border-top:3px solid var(--pine) !important; border-right:none !important;
    transform:translateY(100%) !important;
    box-shadow:0 -8px 40px rgba(0,0,0,0.18) !important;
    padding-bottom:env(safe-area-inset-bottom,0px) !important;
  }
  .detail-panel.open{ transform:translateY(0) !important }
  .detail-panel::before{
    content:''; display:block; width:36px; height:4px;
    background:rgba(0,0,0,0.15); border-radius:2px; margin:10px auto 0;
  }
  .panel-body{ padding:12px 14px calc(24px + env(safe-area-inset-bottom,0px)) !important }
  .panel-title{ font-size:1.1rem !important; line-height:1.45 !important; word-break:keep-all !important }
  .panel-price{ font-size:1.45rem !important; line-height:1.3 !important }
  .panel-price small{ font-size:0.82rem !important }
  .panel-loc,.panel-addr{ font-size:0.88rem !important; color:#333 !important; word-break:keep-all !important; white-space:normal !important }
  .panel-tag{ font-size:0.75rem !important }
  .panel-stats{ flex-wrap:wrap !important }
  .panel-stat{ flex:1 1 40% !important; min-width:0 !important }
  .stat-val{ font-size:0.95rem !important }
  .stat-lbl{ font-size:0.73rem !important }
  .panel-actions{ flex-wrap:wrap !important; gap:8px !important }
  .panel-actions > *{ flex:1 1 auto !important; text-align:center !important; font-size:0.82rem !important }
  .panel-img,.panel-img-placeholder{ aspect-ratio:16/9 }
  .list-panel{ width:88vw !important; max-width:320px !important }
  .list-toggle.shifted{ left:calc(88vw + 6px) !important }
  .list-item{ padding:10px 12px !important; gap:8px !important }
  .list-thumb{ width:64px !important; min-width:64px !important }
  .list-info{ min-width:0; overflow:hidden }
  .list-price{ white-space:normal !important; font-size:0.9rem !important; word-break:keep-all !important }
  .list-name{ font-size:0.88rem !important; line-height:1.5 !important }
  .pin-tooltip{ font-size:0.79rem !important; padding:10px 14px !important; border-radius:10px !important; min-width:144px !important }
  .panel-proximity-title{ font-size:0.9rem !important }
  .panel-proximity-notice{ font-size:0.79rem !important }
  .proximity-icon-lbl{ font-size:0.82rem !important }
  .proximity-place{ font-size:0.83rem !important }
  .proximity-val{ font-size:0.92rem !important }
  #inbox-panel,#inbox-panel-overlay,
  .side-panel,.side-panel-overlay{
    top:52px !important; height:calc(100vh - 52px) !important; width:100vw !important;
  }
  .map-mode-btn{ height:36px; padding:0 12px; font-size:0.8rem !important }
}

/* ── 768px: 커뮤니티 ── */
@media(max-width:768px){
  .comm-layout{ grid-template-columns:1fr !important; padding:14px 12px 80px !important; gap:0 !important }
  .comm-hero{ padding:18px 14px 14px !important }
  .comm-hero-title{ font-size:1.25rem !important; word-break:keep-all !important }
  .cat-bar{ flex-wrap:nowrap !important; overflow-x:auto !important; scrollbar-width:none !important }
  .cat-bar::-webkit-scrollbar{ display:none }
  .cat-chip{ flex-shrink:0 !important; font-size:0.87rem !important }
  .post-card{ padding:16px 14px !important }
  .post-card-title{
    font-size:0.97rem !important; line-height:1.55 !important; color:#1a1a1a !important;
    white-space:normal !important; -webkit-line-clamp:2 !important;
    display:-webkit-box !important; -webkit-box-orient:vertical !important; overflow:hidden !important;
  }
  .post-card-preview{ font-size:0.88rem !important; color:#222 !important; line-height:1.8 !important; -webkit-line-clamp:2 !important; word-break:keep-all !important }
  .post-card-meta{ flex-wrap:wrap !important; gap:8px !important; font-size:0.81rem !important; color:#4a4a4a !important }
  .post-cat-badge{ font-size:0.79rem !important }
  .post-card-thumb{ width:64px !important; height:64px !important }
}

/* ── 768px: 꿀템 ── */
@media(max-width:768px){
  .hd-hero{ padding:18px 14px 14px !important }
  .hd-hero-title{ font-size:1.35rem !important; word-break:keep-all !important }
  .hd-hero-sub{ color:rgba(255,255,255,0.82) !important }
  .hd-body{ padding:14px 12px 80px !important }
  .hd-filter-bar{
    flex-wrap:nowrap !important; overflow-x:auto !important;
    scrollbar-width:none !important; -webkit-overflow-scrolling:touch !important; align-items:center !important;
  }
  .hd-filter-bar::-webkit-scrollbar{ display:none }
  .hd-chip{ flex-shrink:0 !important; font-size:0.86rem !important }
  .hd-card{ min-height:96px !important }
  .hd-card-thumb{ width:96px !important; min-width:96px !important }
  .hd-card-body{ padding:12px 14px !important }
  .hd-card-title{ font-size:0.97rem !important; line-height:1.6 !important; color:#1a1a1a !important; -webkit-line-clamp:2 !important }
  .hd-card-desc{ font-size:0.88rem !important; color:#222 !important; line-height:1.8 !important; -webkit-line-clamp:2 !important; word-break:keep-all !important }
  .hd-card-meta{ font-size:0.81rem !important; color:#4a4a4a !important }
  .hd-card-url{ font-size:0.8rem !important; color:#4a4a4a !important }
  .hd-sort-right{ flex-shrink:0 !important }
}

/* ── 768px: 갤러리 ── */
@media(max-width:768px){
  .gl-body{ padding:14px 10px 80px !important }
  .gl-filter-bar{ flex-wrap:nowrap !important; overflow-x:auto !important; scrollbar-width:none !important }
  .gl-filter-bar::-webkit-scrollbar{ display:none }
  .gl-chip{ flex-shrink:0 !important; font-size:0.86rem !important }
  .gl-grid{ grid-template-columns:repeat(2,minmax(0,1fr)) !important; gap:10px !important }
  .gl-card-info{ padding:9px 10px 10px !important }
  .gl-card-price{ font-size:0.88rem !important }
  .gl-badge{ font-size:0.73rem !important }
  .gl-photo-count{ font-size:0.73rem !important }
  .gl-card-title{ white-space:normal !important; -webkit-line-clamp:2 !important }
}

/* ── 768px: 홈 ── */
@media(max-width:768px){
  #home-page{ top:52px !important }
  .h-page{ padding:0 14px 40px !important }
  .h-hero{ padding:32px 18px 56px !important; min-height:240px !important }
  .h-hero h1{ font-size:clamp(20px,5.5vw,32px) !important; line-height:1.15 !important }
  .h-hero p{ font-size:14px !important; line-height:1.7 !important }
  .h-search{
    flex-direction:column !important; border-radius:16px !important;
    padding:8px !important; gap:2px !important; min-height:auto !important;
  }
  .h-region-select{ width:100% !important; height:50px !important; border-radius:10px 10px 0 0 !important }
  .h-region-trigger{ border-radius:10px 10px 0 0 !important; height:50px !important }
  .h-type-select{ width:100% !important; height:50px !important; border-left:none !important; border-top:1px solid var(--h-line) !important; border-radius:0 !important }
  .h-search-btn{ width:100% !important; border-radius:0 0 10px 10px !important; height:48px !important; margin:0 !important }
  .h-region-panel{ width:calc(100vw - 24px) !important; left:50% !important; transform:translateX(-50%) !important }
  .h-shortcuts{ grid-template-columns:repeat(2,1fr) !important; gap:8px !important }
  .h-shortcut{ min-height:68px !important; padding:14px 16px !important }
  .h-types{ grid-template-columns:repeat(4,1fr) !important; gap:8px !important }
  .h-benefits,.h-legal-grid{ grid-template-columns:1fr !important }
  .h-prop-img{ height:150px !important }
  .h-prop-price{ font-size:15px !important }
  .h-prop-loc{ font-size:12px !important }
  .h-section-head h2{ font-size:17px !important }
  .h-sc-text strong{ font-size:14px !important }
  .h-legal-item{ font-size:12px !important; padding:10px !important }
  .h-legal-item strong{ font-size:13px !important }
  .h-legal-title{ font-size:16px !important }
  .h-legal-sub{ font-size:13px !important }
  .h-benefit strong{ font-size:14px !important }
  .h-benefit span{ font-size:12px !important }
  .h-type-card{ font-size:13px !important }
  .h-copyright{ font-size:12px !important }
}

/* ── 768px: 글 상세·댓글 ── */
@media(max-width:768px){
  .post-detail-wrap,.hd-detail-wrap,.gl-detail-wrap{ padding:12px 12px 80px !important }
  .post-detail-box,.hd-detail-box,.gl-detail-box{ padding:18px 14px !important }
  .post-detail-title{ font-size:1.18rem !important; line-height:1.48 !important; color:#111 !important; word-break:keep-all !important }
  .post-detail-body{ font-size:1rem !important; line-height:1.9 !important; color:#1a1a1a !important; word-break:keep-all !important }
  .post-detail-meta{ font-size:0.81rem !important; color:#4a4a4a !important }
  .post-detail-cat{ font-size:0.82rem !important }
  .post-detail-actions{ flex-wrap:wrap !important; gap:8px !important }
  .post-detail-photos img{ width:calc(50% - 5px) !important }
  .comments-box{ padding:16px 12px !important }
  .comment-body{ font-size:0.88rem !important; color:#222 !important; line-height:1.8 !important; word-break:keep-all !important }
  .comment-date{ font-size:0.81rem !important; color:#4a4a4a !important }
  .comment-edit-btn,.comment-delete-btn{ font-size:0.79rem !important; padding:5px 10px !important }
  .gl-detail-title{ font-size:1.12rem !important; line-height:1.48 !important; word-break:keep-all !important }
  .gl-detail-price{ font-size:1.28rem !important }
  .hd-detail-box h2{ font-size:1.12rem !important; line-height:1.48 !important; word-break:keep-all !important }
  .sidebar-box-title{ font-size:0.95rem !important; word-break:keep-all !important }
  .hot-post{ font-size:0.88rem !important; line-height:1.72 !important; color:#222 !important }
}

/* ── 768px: 모달·폼 ── */
@media(max-width:768px){
  .modal,.write-modal-box,.hd-modal-box{
    width:calc(100vw - 16px) !important; margin:12px 8px 70px !important; border-radius:12px !important;
  }
  .modal-header,.hd-modal-head,.write-modal-head{
    padding:14px 13px 12px !important; position:sticky !important; top:0 !important; z-index:10 !important; background:#fff !important;
  }
  .modal-body,.write-modal-body,.hd-modal-body{ padding:14px 13px !important }
  .modal-footer,.hd-modal-footer{ flex-wrap:wrap !important; padding-bottom:calc(14px + env(safe-area-inset-bottom,0px)) !important }
  .form-row{ grid-template-columns:1fr !important }
  .modal-overlay,#hd-write-modal,#write-modal{ padding-bottom:env(safe-area-inset-bottom,0px) !important }
  .rich-editor-box{ min-height:260px !important }
  .comment-form{ padding-bottom:calc(16px + env(safe-area-inset-bottom,0px)) !important }
  input,select,textarea,
  .hd-form-input,.write-input,.form-input,.comment-input,#addr-search-input{ font-size:16px !important }
  .hd-form-label,.write-label,.form-label{ font-size:0.86rem !important; line-height:1.6 !important }
  .hd-btn-cancel,.hd-btn-submit,.comm-post-btn,.hd-post-btn{ font-size:0.95rem !important }
  .btn-like,.btn-post-edit,.btn-post-delete{ font-size:0.86rem !important }
  .form-area-row,.modal-body .form-area-row{ flex-direction:column !important }
}

/* ── 768px: 지역탭·태그·기타 ── */
@media(max-width:768px){
  .region-tab-row{ overflow-x:auto !important; flex-wrap:nowrap !important; -webkit-overflow-scrolling:touch !important; scrollbar-width:none !important }
  .region-tab-row::-webkit-scrollbar{ display:none }
  .region-tab-row > div[style*="width:100%"]{ display:none !important }
  .region-tab{ flex-shrink:0 !important; font-size:0.87rem !important }
  .sigungu-bar{ overflow-x:auto !important; flex-wrap:nowrap !important; scrollbar-width:none !important }
  .sigungu-bar::-webkit-scrollbar{ display:none }
  .sigungu-chip{ flex-shrink:0 !important; font-size:0.85rem !important }
  .rich-editor-toolbar{ overflow-x:auto !important; flex-wrap:nowrap !important; scrollbar-width:none !important; padding:6px !important; gap:4px !important }
  .rich-editor-toolbar::-webkit-scrollbar{ display:none }
  .rich-editor-btn{ flex-shrink:0 !important; font-size:0.73rem !important; white-space:nowrap !important }
  .search-autocomplete{ max-height:200px }
  .autocomplete-item{ font-size:0.9rem !important; padding:11px 14px !important }
  .autocomplete-item-sub{ font-size:0.79rem !important; color:#4a4a4a !important }
  .autocomplete-item-badge{ font-size:0.75rem !important }
  .list-sort-btn{ font-size:0.79rem !important }
  .tag-item{ font-size:0.82rem !important }
  .msg-item-from{ font-size:0.84rem !important }
  .msg-item-preview{ font-size:0.84rem !important; color:#4a4a4a !important; white-space:normal !important; -webkit-line-clamp:1 !important; display:-webkit-box !important; -webkit-box-orient:vertical !important; overflow:hidden !important }
  .msg-item-date{ font-size:0.75rem !important }
  .msg-item-ref{ font-size:0.79rem !important; color:#4a4a4a !important }
  .activity-main h4{ white-space:normal !important; -webkit-line-clamp:2 !important; display:-webkit-box !important; -webkit-box-orient:vertical !important; overflow:hidden !important }
  .active-filter-tag{ font-size:0.79rem !important }
  .body{ font-size:15px !important; line-height:1.75 !important; color:#1a1a1a !important }
}

/* ── 768px: 터치 타겟 44px ── */
@media(max-width:768px){
  button,.page-tab,
  .chip,.cat-chip,.sigungu-chip,.hd-chip,.hd-cat-btn,
  .loc-btn,.region-tab,.adv-chip,.gl-chip,
  .comment-submit,.form-submit,.hd-btn-submit,.hd-btn-cancel,
  .btn-like,.btn-post-edit,.btn-post-delete,
  .post-detail-back,.gl-detail-back,.hd-detail-back,
  .write-submit-btn,.hd-post-btn,.comm-post-btn,
  .mobile-tab{ min-height:44px !important }
}

/* ── 640px: 하단 탭바 ── */
@media(max-width:640px){
  .mobile-bottom-tabs{
    display:flex !important;
    background:rgba(255,255,255,0.97) !important;
    border-top:1px solid #e1e9e5 !important;
    backdrop-filter:blur(16px) !important; -webkit-backdrop-filter:blur(16px) !important;
    min-height:var(--mob-tabs-h) !important;
    height:calc(var(--mob-tabs-h) + env(safe-area-inset-bottom,0px)) !important;
    padding-bottom:env(safe-area-inset-bottom,0px) !important;
    z-index:300 !important;
  }
  .mobile-tab{ color:#888 !important; font-size:0.68rem !important; min-height:44px !important }
  .mobile-tab.active{ color:var(--green) !important }
  #home-page,#community-page,#gallery-page,#hotdeal-page{
    bottom:calc(var(--mob-tabs-h) + env(safe-area-inset-bottom,0px)) !important;
  }
  #toast{
    bottom:calc(var(--mob-tabs-h) + env(safe-area-inset-bottom,0px) + 8px) !important;
    max-width:calc(100vw - 32px) !important; white-space:normal !important;
    text-align:center !important; font-size:0.82rem !important; border-radius:12px !important;
  }
  .scroll-top-btn{
    bottom:calc(var(--mob-tabs-h) + env(safe-area-inset-bottom,0px) + 10px) !important;
    right:14px !important; width:40px !important; height:40px !important;
  }
  #adv-filter-panel,#prox-filter-panel{
    width:calc(100vw - 16px) !important; max-width:none !important;
    left:8px !important; right:8px !important; max-height:75vh;
  }
  .adv-chip{ height:34px; font-size:0.82rem; padding:0 12px }
  .h-cards{ grid-template-columns:1fr !important; gap:10px !important }
  .h-prop-cards{ grid-template-columns:repeat(2,1fr) !important; gap:10px !important }
  .h-prop-img{ height:160px !important }
  .h-shortcuts{ grid-template-columns:repeat(2,1fr) !important; gap:10px !important }
  .h-shortcut{ min-height:68px !important; padding:14px 16px !important; gap:10px !important }
  .h-sc-text span{ display:none !important }
  .h-sc-text strong{ font-size:14px !important; margin-bottom:0 !important }
  .h-sc-icon{ width:40px !important; height:40px !important; flex:0 0 40px !important; font-size:20px !important; border-radius:12px !important }
  .h-benefits{ grid-template-columns:1fr !important; gap:8px !important }
  .h-benefit{ padding:12px 14px !important; gap:10px !important }
  .h-legal-item{ font-size:11px !important; padding:10px !important }
  .h-legal-title{ font-size:16px !important }
  .comm-layout{ grid-template-columns:1fr !important }
  .comm-sidebar-collapsible.open{ display:block }
  .loc-btn{ padding:5px 10px; font-size:0.77rem }
  .sigungu-chip{ padding:4px 10px; font-size:0.75rem }
  #addr-search-input{ font-size:16px !important }
  .region-tab-row{ overflow-x:auto; flex-wrap:nowrap !important; scrollbar-width:none }
  .region-tab-row::-webkit-scrollbar{ display:none }
  .region-tab-row > div[style*="width:100%"]{ display:none !important }
  .hd-sort-right{ margin-left:0 !important; width:100% !important; justify-content:flex-end !important }
  .write-photo-thumb{ width:calc(50% - 5px) !important }
  .write-photo-thumb button{ width:28px !important; height:28px !important; font-size:13px !important }
  .h-prop-info{ padding:10px 12px !important }
  #photo-lb-prev,#photo-lb-next{ width:40px !important; height:40px !important }
  #photo-lb-img{ width:98vw !important; height:86vh !important }
  .gl-detail-photo-wrap{ max-width:100% !important; aspect-ratio:4/3 !important }
  .gl-detail-wrap{ padding:14px 12px 80px !important }
}

/* ── 540px: 가격 입력 행 ── */
@media(max-width:540px){
  .price-box{ flex-wrap:wrap !important }
  .unit-btn,.price-input{ width:100% !important }
}

/* ── 480px: 소형 보정 ── */
@media(max-width:480px){
  .page-tab{ padding:0 10px !important; font-size:0.82rem !important }
  .page-tab-logo{ font-size:1rem !important; margin-right:8px !important }
  .hd-card-thumb{ width:80px !important; min-width:80px !important }
  .hd-card-title{ font-size:0.84rem !important }
  .hd-card{ min-height:80px !important }
  .hd-card-desc{ font-size:0.79rem !important; -webkit-line-clamp:2 !important }
  .panel-title{ font-size:1.05rem !important }
  .panel-price{ font-size:1.35rem !important }
  .post-detail-photos img{ width:100% !important }
  .post-detail-title{ font-size:1.1rem !important }
  .gl-detail-price{ font-size:1.18rem !important }
  .h-types{ grid-template-columns:repeat(2,1fr) !important; gap:8px !important }
  .h-type-card{ font-size:12px !important; min-height:80px !important; gap:4px !important }
  .h-region-panel{ width:calc(100vw - 16px) !important; left:50% !important; transform:translateX(-50%) !important }
  .h-type-menu{ left:auto !important; right:0 !important }
  .comm-post-btn,.hd-post-btn{ padding:11px 24px !important; font-size:0.88rem !important; width:100% !important }
  .pg-btn{ min-width:34px !important; height:34px !important; font-size:0.76rem !important }
  .pagination{ gap:4px !important }
  .proximity-item{ min-height:auto !important; padding:10px 12px !important }
  .proximity-distance{ font-size:0.92rem !important }
  .proximity-place{ font-size:0.74rem !important }
  .proximity-icon-lbl{ font-size:0.72rem !important }
  .write-tag-input{ flex-wrap:wrap !important }
  .write-tag-input input{ width:100% !important }
  #auth-modal > div > div:first-child{ padding:16px 18px 0 }
  #auth-modal > div > div:last-child{ padding:16px 18px 18px }
  .post-card-title{ white-space:normal !important }
}

/* ── 420px ── */
@media(max-width:420px){
  .gl-grid{ grid-template-columns:1fr !important }
  .page-tab-logo small{ display:none !important }
  #user-greeting{ display:none !important }
  .hd-card-title,.post-card-title,.gl-card-title{ white-space:normal }
  .hd-sort-right{ margin-left:0; width:100% }
  .h-shortcuts{ grid-template-columns:1fr !important }
  .h-shortcut{ min-height:80px !important }
}

/* ── 380px ── */
@media(max-width:380px){
  .h-prop-cards{ grid-template-columns:1fr !important }
}

/* ── 360px: 극소형 ── */
@media(max-width:360px){
  body{ font-size:14px !important }
  .hd-card-thumb{ width:64px !important; min-width:64px !important }
  .panel-price{ font-size:1.2rem !important }
  .post-detail-title{ font-size:1.0rem !important }
  .h-hero h1{ font-size:20px !important }
  .mobile-tab{ font-size:0.65rem !important }
  .gl-grid{ grid-template-columns:1fr !important }
}

/* ── 640px: 상단 탭 메뉴 숨김 (하단탭으로 대체) ── */
@media(max-width:640px){
  #tab-home,#tab-map,#tab-gallery,#tab-community,#tab-hotdeal{ display:none !important }
  .page-tab-spacer{ display:none !important }
  .page-tabs{ justify-content:space-between !important; padding:0 14px !important }
  .page-tab-auth{ gap:6px !important }
  #user-info{ gap:6px !important }
}

/* ── 320px: 최소 지원 너비 ── */
@media(max-width:320px){
  .page-tab-logo{ font-size:0.9rem !important; margin-right:0 !important }
  .page-tab-auth{ gap:4px !important }
  #user-info{ gap:4px !important }
  #inbox-header-btn .btn-label,
  #my-activity-header-btn .btn-label{ display:none !important }
  #inbox-header-btn,
  #my-activity-header-btn{ padding:6px 8px !important; gap:0 !important }
  .auth-btn-logout{ font-size:0 !important; padding:6px 8px !important }
  .auth-btn-logout::before{ content:'↩'; font-size:0.85rem; display:inline-block }
  #login-btn,#signup-btn{ padding:6px 10px !important; font-size:0.78rem !important }
}

/* ── 가로모드 ── */
@media(max-height:500px) and (max-width:900px){
  .mobile-bottom-tabs{ display:none !important }
  body{ padding-bottom:0 !important }
  #home-page,#community-page,#gallery-page,#hotdeal-page{ bottom:0 !important }
  .detail-panel{ height:90vh !important }
  body.map-page-active #map-container{ top:52px !important; height:calc(100vh - 52px) !important }
}

/* ── 터치 기기: hover 잔상 제거 ── */
@media(hover:none) and (pointer:coarse){
  .hd-card:hover,.h-prop-card:hover,.gl-card:hover,.post-card:hover{ transform:none !important }
  button,.page-tab,.mobile-tab,
  .chip,.cat-chip,.sigungu-chip,.hd-chip,.gl-chip,.hd-cat-btn,.loc-btn,.region-tab{ min-height:44px !important }
}

/* ── 지도 body.map-page-active 터치 ── */
@media(max-width:768px){
  html body.map-page-active{
    overflow-x:hidden !important; overflow-y:hidden !important;
    touch-action:none !important; -webkit-overflow-scrolling:auto !important;
  }
}

/* ==================== MOBILE END ==================== */

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   AI 매물검색 탭 스타일
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.page-tab--ai {
  position: relative;
  background: linear-gradient(135deg, #07883d 0%, #059635 100%) !important;
  color: #fff !important;
  border-radius: 8px !important;
  margin: 8px 0 8px 8px !important;
  padding: 0 16px !important;
  font-weight: 800 !important;
  font-size: 0.86rem !important;
  border-bottom: none !important;
  box-shadow: 0 2px 10px rgba(7,136,61,.3);
  transition: transform .15s, box-shadow .15s, opacity .15s !important;
  letter-spacing: 0.01em !important;
}
.page-tab--ai:hover {
  color: #fff !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(7,136,61,.42) !important;
}
.page-tab--ai::after {
  content: 'NEW';
  position: absolute;
  top: -4px; right: -4px;
  background: #ff4444;
  color: #fff;
  font-size: 0.52rem;
  font-weight: 900;
  padding: 1px 4px;
  border-radius: 4px;
  letter-spacing: 0.05em;
  box-shadow: 0 1px 4px rgba(255,68,68,.4);
}

.mobile-tab--ai {
  color: #07883d !important;
  font-weight: 800 !important;
}
.mobile-tab--ai .m-icon {
  filter: drop-shadow(0 1px 2px rgba(7,136,61,.3));
}

/* 모바일 하단 탭은 공간이 좁으므로 AI검색 탭 숨김 (상단 네비로만 노출) */
#mob-tab-ai {
  display: none !important;
}

/* AI 검색 섹션 하이라이트 애니메이션 */
@keyframes aisHighlight {
  0%   { box-shadow: 0 6px 28px rgba(7,136,61,.07), 0 1px 4px rgba(0,0,0,.04), 0 0 0 0 rgba(7,136,61,0); }
  30%  { box-shadow: 0 6px 28px rgba(7,136,61,.12), 0 1px 4px rgba(0,0,0,.06), 0 0 0 7px rgba(7,136,61,.22); }
  100% { box-shadow: 0 6px 28px rgba(7,136,61,.07), 0 1px 4px rgba(0,0,0,.04), 0 0 0 0 rgba(7,136,61,0); }
}
.ais-card--highlight {
  animation: aisHighlight 1.2s cubic-bezier(.22,.68,0,1.1) both !important;
}

@media(max-width:768px) {
  .page-tab--ai {
    font-size: 0.78rem !important;
    padding: 0 10px !important;
    margin: 6px 0 6px 6px !important;
  }
  .page-tab--ai::after { display: none; }
}
@media(max-width:480px) {
  .page-tab--ai {
    font-size: 0.72rem !important;
    padding: 0 8px !important;
  }
}
