:root{
  --bg:#16161A; --bg2:#1E1E24; --bg3:#26262E; --line:#33333D;
  --ink:#ECEAE5; --ink2:#A8A6A0; --ink3:#76747010;
  --gold:#C9A86A; --gold-dim:#8C7748;
  --high:#D98A6A; --low:#7FB084; --mid:#9A98A2;
  --radius:14px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{
  background:var(--bg); color:var(--ink);
  font-family:-apple-system,"PingFang TC","Helvetica Neue",system-ui,sans-serif;
  display:flex; flex-direction:column; height:100dvh; overflow:hidden;
}

/* ---------- top bar ---------- */
.topbar{
  padding:max(12px,env(safe-area-inset-top)) 14px 10px;
  background:linear-gradient(180deg,#1A1A1F,#16161A);
  border-bottom:1px solid var(--line); flex:none;
}
.brand{font-weight:700;letter-spacing:.04em;font-size:16px;margin-bottom:9px}
.brand .mark{
  background:var(--gold); color:#1A1712; padding:2px 7px;border-radius:7px;
  font-weight:800;margin-right:4px
}
.brand .sub{color:var(--ink2);font-weight:500;font-size:12px;margin-left:8px;letter-spacing:.02em}

.searchwrap{display:flex;gap:8px}
#search{
  flex:1;background:var(--bg3);border:1px solid var(--line);color:var(--ink);
  border-radius:11px;padding:11px 13px;font-size:15px;outline:none
}
#search::placeholder{color:#6E6C66}
#search:focus{border-color:var(--gold-dim)}
#searchBtn{
  background:var(--gold);color:#1A1712;border:none;border-radius:11px;
  padding:0 16px;font-weight:700;font-size:14px;cursor:pointer
}
#searchBtn:active{transform:scale(.97)}

.radiusbar{display:flex;align-items:center;gap:9px;margin-top:9px;flex-wrap:wrap}
.rlabel{color:var(--ink2);font-size:12px}
.chips{display:flex;gap:6px}
.chips button{
  background:var(--bg3);border:1px solid var(--line);color:var(--ink2);
  border-radius:20px;padding:5px 11px;font-size:12.5px;cursor:pointer
}
.chips button.on{background:var(--gold);color:#1A1712;border-color:var(--gold);font-weight:700}
.centerinfo{color:var(--gold);font-size:12.5px;margin-left:auto;font-weight:600;max-width:55%;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ---------- layout ---------- */
.layout{flex:1;display:flex;min-height:0}
.map{flex:1;min-height:0;background:#0E0E11}
.panel{
  width:min(42%,440px);flex:none;background:var(--bg2);
  border-left:1px solid var(--line);display:flex;flex-direction:column;min-height:0
}
.tabs{display:flex;border-bottom:1px solid var(--line);flex:none}
.tab{
  flex:1;background:none;border:none;color:var(--ink2);padding:13px 8px;
  font-size:14px;cursor:pointer;border-bottom:2px solid transparent;font-weight:600
}
.tab.on{color:var(--ink);border-bottom-color:var(--gold)}
.tab em{color:var(--gold);font-style:normal;font-weight:700;margin-left:3px}
.tabbody{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}
.tabbody.hidden{display:none}

.list{padding:10px}
.empty{color:var(--ink2);font-size:13.5px;line-height:1.7;padding:22px 16px;text-align:center}

/* ---------- listing card ---------- */
.card{
  position:relative;
  background:var(--bg3);border:1px solid var(--line);border-radius:var(--radius);
  padding:12px 13px 12px 15px;margin-bottom:10px;cursor:pointer;transition:all .15s
}
.card:hover{border-color:var(--gold-dim)}
.card.active{
  border-color:var(--gold);background:#2C2A23;
  box-shadow:0 0 0 1.5px var(--gold),0 8px 24px #C9A86A33
}
.card.active::before{
  content:"";position:absolute;left:0;top:11px;bottom:11px;width:4px;
  background:var(--gold);border-radius:0 4px 4px 0
}
.specs{display:flex;flex-wrap:wrap;gap:5px;margin:9px 0 7px}
.chip{font-size:12px;padding:3px 9px;border-radius:8px;background:var(--bg2);border:1px solid var(--line);color:var(--ink2)}
.chip.type{background:#2E2A20;border-color:var(--gold-dim);color:var(--gold);font-weight:700}
.chip.park.yes{background:#16271A;border-color:#3C5E40;color:var(--low);font-weight:700}
.chip.park.no{background:#2A2A30;color:#74726C}
.chip.src{font-weight:700}
.chip.src.sy{background:#27241C;border-color:var(--gold-dim);color:var(--gold)}
.chip.src.s591{background:#1C2630;border-color:#3A5570;color:#9FC0DE}
.chip.src.yc{background:#221A2E;border-color:#5A4A70;color:#C8B3E0}
.chip.src.ct{background:#2A1F12;border-color:#6E5230;color:#E0B88A}
.chip.dup{background:#2A2A30;color:var(--ink2);font-weight:600}
.chip.src.fb{background:#16271E;border-color:#3C5E48;color:#7FC4A0}
.meta2{color:var(--ink2);font-size:12.5px;line-height:1.6}
.card .row1{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.card .title{font-weight:700;font-size:14.5px;line-height:1.35;flex:1}
.card .price{color:var(--gold);font-weight:800;font-size:16px;white-space:nowrap}
.card .price small{font-weight:600;font-size:11px;color:var(--ink2)}
.card .meta{color:var(--ink2);font-size:12.5px;margin-top:6px;line-height:1.6}
.card .meta b{color:var(--ink);font-weight:600}
.card .foot{display:flex;align-items:center;gap:8px;margin-top:9px;flex-wrap:wrap}
.badge{font-size:11.5px;font-weight:700;padding:3px 8px;border-radius:7px}
.badge.high{background:#3A241C;color:var(--high)}
.badge.low{background:#1E2E20;color:var(--low)}
.badge.mid{background:#2A2A30;color:var(--mid)}
.badge.na{background:#2A2A30;color:var(--ink2);font-weight:600}
.dist{color:var(--ink2);font-size:11.5px;margin-left:auto}
.card a.link{color:var(--gold);font-size:12px;text-decoration:none;border:1px solid var(--gold-dim);padding:3px 9px;border-radius:7px}

/* ---------- price box ---------- */
.pricebox{padding:12px}
.ph{font-size:14px;font-weight:700;margin:4px 2px 10px;color:var(--ink)}
.ptable{width:100%;border-collapse:collapse;font-size:13px}
.ptable th{color:var(--ink2);font-weight:600;text-align:right;padding:7px 6px;border-bottom:1px solid var(--line);font-size:11.5px}
.ptable th:first-child{text-align:left}
.ptable td{padding:9px 6px;border-bottom:1px solid var(--line);text-align:right}
.ptable td:first-child{text-align:left;font-weight:600}
.ptable td .u{color:var(--gold);font-weight:800}
.ptable td .n{color:var(--ink2);font-size:11px}
.src{color:#65635E;font-size:10.5px;line-height:1.6;padding:8px 14px 16px}

/* ---------- 新增物件區塊 ---------- */
.uploadwrap{padding:14px}
.up3-head{font-size:15px;font-weight:700;margin:2px 2px 8px}
.upd-note{color:var(--ink2);font-size:13px;line-height:1.7;margin:0 2px 14px}
.upd-note b{color:var(--gold)}
.dropzone{display:block;border:1.5px dashed var(--gold-dim);border-radius:14px;background:#201E18;padding:26px 16px;text-align:center;cursor:pointer;transition:all .15s}
.dropzone:hover,.dropzone.over{border-color:var(--gold);background:#262219}
.dz-ico{font-size:26px;margin-bottom:6px}
.dz-main{color:var(--gold);font-weight:700;font-size:14px}
.dz-sub{color:var(--ink2);font-size:12px;margin-top:4px;line-height:1.5}
.dz-prev{max-width:100%;max-height:170px;border-radius:10px;margin-bottom:8px}
.paste-or{text-align:center;color:var(--ink2);font-size:12px;margin:13px 0}
.fbtext{width:100%;min-height:88px;background:var(--bg3);border:1px solid var(--line);border-radius:11px;color:var(--ink);padding:11px 12px;font-size:14px;font-family:inherit;line-height:1.6;resize:vertical;outline:none}
.fbtext:focus{border-color:var(--gold-dim)}
.addbtn{width:100%;margin-top:12px;background:var(--gold);color:#1A1712;border:none;border-radius:11px;padding:13px;font-weight:800;font-size:15px;cursor:pointer}
.addbtn:active{transform:scale(.99)}
.lock-note{color:#8A8780;font-size:11.5px;line-height:1.6;margin-top:12px;text-align:center}
.lock-note b{color:var(--ink2)}

/* ---------- map marker ---------- */
.pin{
  background:var(--gold);color:#1A1712;font-weight:800;font-size:11px;
  padding:3px 7px;border-radius:11px;border:1.5px solid #1A1712;
  box-shadow:0 2px 6px #0008;white-space:nowrap;transform:translateY(-50%)
}
.pin.active{background:#1A1712;color:var(--gold);border-color:var(--gold)}
.pin.center{background:#fff;color:#1A1712;border-radius:50%;width:16px;height:16px;padding:0}
.pin.fb{background:#6FB3A8;color:#0E1A18;border-color:#0E1A18}
.pin.fb.active{background:#0E1A18;color:#6FB3A8;border-color:#6FB3A8}
.pin.s591{background:#6E93B5;color:#0E1620;border-color:#0E1620}
.pin.s591.active{background:#0E1620;color:#9FC0DE;border-color:#9FC0DE}
.pin.yc{background:#A88FC9;color:#160E20;border-color:#160E20}
.pin.yc.active{background:#160E20;color:#C8B3E0;border-color:#C8B3E0}
.pin.ct{background:#D8954C;color:#1F1408;border-color:#1F1408}
.pin.ct.active{background:#1F1408;color:#E8B888;border-color:#E8B888}
.srctag{background:#234B45;color:#9FD8CE;font-size:10px;font-weight:700;padding:2px 6px;border-radius:6px;margin-right:3px}
.src-note{color:var(--ink2);font-size:11.5px;margin-left:auto}

/* ---------- toast ---------- */
.toast{
  position:fixed;left:50%;bottom:28px;transform:translateX(-50%);
  background:#000C;color:var(--ink);padding:10px 16px;border-radius:10px;
  font-size:13px;border:1px solid var(--line);z-index:50;max-width:80%
}
.toast.hidden{display:none}

/* ---------- mobile ---------- */
@media (max-width:760px){
  .layout{flex-direction:column}
  .map{height:42vh;flex:none}
  .panel{width:100%;flex:1;border-left:none;border-top:1px solid var(--line)}
  .centerinfo{max-width:100%}
}
