/* ── RESET & BASE ──────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{
  --ink:#1c1b18;--ink2:#3e3d38;--ink3:#7c7b72;--ink4:#b8b7ae;
  --paper:#f7f5ef;--paper2:#edebd9;--paper3:#e2dfc9;
  --jade:#0e8c5e;--jade2:#0a6644;--jade-bg:#e8f5ee;
  --red:#c0392b;--red-bg:#fcecea;
  --amber:#b8670e;--amber-bg:#fdf3e0;
  --blue:#2563a8;--blue-bg:#ebf3fc;
  --serif:'Noto Serif SC',serif;
  --sans:'Noto Sans SC',sans-serif;
  --r:12px;--rs:8px;
}
html,body{height:100%;font-family:var(--sans);background:var(--paper);color:var(--ink);overflow:hidden}

/* ── APP SHELL ─────────────────────────────────── */
#app{display:flex;flex-direction:column;height:100vh;max-width:480px;margin:0 auto;position:relative;background:var(--paper)}

/* ── PAGES ─────────────────────────────────────── */
.pages{flex:1;position:relative;overflow:hidden}
.page{
  position:absolute;inset:0;display:flex;flex-direction:column;
  background:var(--paper);
  transform:translateX(100%);opacity:0;
  transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s;
  pointer-events:none;
}
.page.active{transform:translateX(0);opacity:1;pointer-events:all}
.page.slide-left-exit{transform:translateX(-28%);opacity:0;pointer-events:none}
.page.slide-page{transform:translateX(100%)}

/* ── SCROLL ─────────────────────────────────────── */
.scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
.scroll::-webkit-scrollbar{display:none}

/* ── TOPBAR ─────────────────────────────────────── */
.page-topbar{
  display:flex;align-items:center;gap:10px;padding:12px 16px 10px;
  background:var(--paper);border-bottom:1px solid var(--paper3);
  flex-shrink:0;position:relative;z-index:10;
}
.page-topbar.with-back{padding-left:12px}
.topbar-back{
  width:32px;height:32px;border-radius:50%;background:var(--paper2);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;flex-shrink:0;border:none;font-size:16px;color:var(--ink2);
}
.topbar-title{font-family:var(--serif);font-size:16px;font-weight:700;color:var(--ink);flex:1}
.topbar-sub{font-size:11px;color:var(--ink3);margin-top:1px}

/* ── BOTTOM NAV ─────────────────────────────────── */
.bottomnav{
  display:flex;align-items:stretch;
  border-top:1px solid var(--paper3);background:var(--paper);
  flex-shrink:0;
}
.bn-item{
  flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;padding:8px 4px 12px;cursor:pointer;
  border:none;background:transparent;color:var(--ink4);
  font-family:var(--sans);font-size:10px;gap:3px;transition:color .15s;
}
.bn-item.active{color:var(--jade)}
.bn-icon{font-size:21px;line-height:1}
.bn-label{font-weight:500}

/* ── BADGES ─────────────────────────────────────── */
.badge{display:inline-block;font-size:10px;padding:2px 8px;border-radius:20px;font-weight:500;white-space:nowrap}
.b-avail{background:var(--jade-bg);color:var(--jade2)}
.b-full{background:var(--red-bg);color:var(--red)}
.b-warn{background:var(--amber-bg);color:var(--amber)}
.b-user{background:var(--blue-bg);color:var(--blue)}
.b-src{background:var(--paper2);color:var(--ink3);border:1px solid var(--paper3)}
.b-new{background:#fef3c7;color:#92400e}

/* ── TOAST ──────────────────────────────────────── */
.toast{
  position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(8px);
  background:rgba(28,27,24,.92);color:#fff;border-radius:var(--r);
  padding:10px 18px;font-size:13px;white-space:nowrap;
  opacity:0;transition:all .25s;pointer-events:none;z-index:9999;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── LOADING ─────────────────────────────────────── */
.loading-placeholder{
  padding:24px;text-align:center;font-size:13px;color:var(--ink4);width:100%;
}

/* ── HOME ───────────────────────────────────────── */
.home-hero{
  background:var(--ink);padding:20px 20px 26px;
  position:relative;overflow:hidden;flex-shrink:0;
}
.home-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 120% at 80% -10%,#1a5c3a,transparent 60%);
  opacity:.6;
}
.hero-live{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  border-radius:20px;padding:4px 12px;font-size:12px;color:rgba(255,255,255,.85);
  margin-bottom:14px;position:relative;z-index:1;
}
.hero-dot{width:6px;height:6px;border-radius:50%;background:#4ade80;animation:pulse 2s infinite;display:inline-block}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero-title{font-family:var(--serif);font-size:26px;font-weight:700;color:#fff;line-height:1.3;position:relative;z-index:1;margin-bottom:4px}
.hero-sub{font-size:13px;color:rgba(255,255,255,.6);position:relative;z-index:1;margin-bottom:16px}
.hero-chips{display:flex;gap:8px;flex-wrap:wrap;position:relative;z-index:1}
.hero-chip{
  background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);
  border-radius:20px;padding:5px 13px;font-size:12px;color:rgba(255,255,255,.9);
  cursor:pointer;
}

/* stats */
.stats-bar{display:flex;border-bottom:1px solid var(--paper3);flex-shrink:0}
.stat-cell{flex:1;padding:13px 8px;text-align:center;border-right:1px solid var(--paper3)}
.stat-cell:last-child{border-right:none}
.stat-num{font-size:20px;font-weight:700;color:var(--jade);font-family:var(--serif)}
.stat-online .stat-num{color:var(--red)}
.stat-label{font-size:10px;color:var(--ink3);margin-top:2px}
.stat-dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--red);margin-right:3px;animation:pulse 1.5s infinite}

/* section header */
.sec-head{padding:14px 16px 6px;display:flex;align-items:center;justify-content:space-between}
.sec-title{font-family:var(--serif);font-size:15px;font-weight:700;color:var(--ink)}
.sec-more{font-size:12px;color:var(--jade);cursor:pointer}

/* new listings horizontal scroll */
.h-scroll{display:flex;gap:10px;padding:0 16px 14px;overflow-x:auto}
.h-scroll::-webkit-scrollbar{display:none}
.nl-card{
  flex-shrink:0;width:195px;background:#fff;border-radius:var(--r);
  border:1px solid var(--paper3);padding:13px;cursor:pointer;
}
.nl-card-name{font-size:13px;font-weight:500;color:var(--ink);margin-bottom:5px;line-height:1.4}
.nl-price{font-size:16px;font-weight:700;color:var(--jade);font-family:var(--serif);margin-bottom:5px}
.nl-price small{font-size:10px;font-weight:400;color:var(--ink3)}
.nl-meta{font-size:11px;color:var(--ink4);margin-bottom:5px}
.nl-time{font-size:10px;color:var(--jade2);display:flex;align-items:center;gap:3px;margin-top:4px}
.nl-dot{width:5px;height:5px;border-radius:50%;background:var(--jade);flex-shrink:0}

/* news */
.news-list{padding:0 16px 8px;display:flex;flex-direction:column;gap:8px}
.news-item{background:#fff;border-radius:var(--r);border:1px solid var(--paper3);padding:12px 14px;cursor:pointer}
.news-source{display:flex;align-items:center;gap:6px;margin-bottom:5px}
.news-src-tag{font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px}
.src-official{background:#dbeafe;color:#1e40af}
.src-user{background:var(--jade-bg);color:var(--jade2)}
.src-operator{background:var(--amber-bg);color:var(--amber)}
.news-date{font-size:10px;color:var(--ink4)}
.news-title{font-size:13px;font-weight:500;color:var(--ink);margin-bottom:4px;line-height:1.4}
.news-summary{font-size:12px;color:var(--ink3);line-height:1.5}

/* ── HOUSING MAP ────────────────────────────────── */
.map-hint{text-align:center;padding:7px;font-size:11px;color:var(--ink3);background:var(--paper2);border-bottom:1px solid var(--paper3);flex-shrink:0}
.zone-map{
  height:300px;background:linear-gradient(155deg,#c8e6d4,#b4d9c0 50%,#a0ccab);
  position:relative;flex-shrink:0;overflow:hidden;
}
.road{position:absolute;background:rgba(255,255,255,.55)}
.road.h{height:3px;left:0;right:0}
.road.v{width:3px;top:0;bottom:0}
.zone{
  position:absolute;border-radius:var(--r);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:4px;cursor:pointer;
  border:2px solid rgba(255,255,255,.5);transition:filter .15s;
}
.zone:active{filter:brightness(1.1)}
.zone-name{font-size:11px;font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.4);text-align:center;line-height:1.3}
.zone-price{font-size:11px;font-weight:700;color:#fff;background:rgba(0,0,0,.3);border-radius:20px;padding:2px 8px}
.venue-pin{position:absolute;transform:translate(-50%,-50%);z-index:5;display:flex;flex-direction:column;align-items:center}
.venue-circle{width:36px;height:36px;background:var(--ink);border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid #fff;font-size:15px}
.venue-label{background:var(--ink);color:#fff;font-size:10px;padding:3px 8px;border-radius:20px;white-space:nowrap;margin-top:4px}
.map-legend{position:absolute;bottom:10px;right:10px;background:rgba(247,245,239,.9);border-radius:var(--rs);padding:8px 10px}
.ml-row{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--ink2);margin-bottom:3px}
.ml-row:last-child{margin-bottom:0}
.ml-dot{width:9px;height:9px;border-radius:2px;flex-shrink:0}

/* ── ZONE LISTING ───────────────────────────────── */
.zone-tabs{display:flex;background:#fff;border-bottom:1px solid var(--paper3);flex-shrink:0}
.zt{flex:1;padding:10px 4px;text-align:center;font-size:13px;font-weight:500;color:var(--ink4);cursor:pointer;border-bottom:2.5px solid transparent;transition:all .15s}
.zt.active{color:var(--jade);border-bottom-color:var(--jade)}
.ztab{display:none;flex-direction:column;flex:1;overflow:hidden}
.ztab.active{display:flex}

.sort-bar{display:flex;background:#fff;border-bottom:1px solid var(--paper3);flex-shrink:0}
.sort-opt{flex:1;padding:9px 4px;text-align:center;font-size:12px;color:var(--ink3);cursor:pointer;border-bottom:2px solid transparent;font-weight:500}
.sort-opt.active{color:var(--jade);border-bottom-color:var(--jade)}
.price-range{padding:8px 14px;background:var(--paper2);border-bottom:1px solid var(--paper3);flex-shrink:0;display:none;gap:8px;align-items:center}
.price-range.show{display:flex}
.pr-label{font-size:12px;color:var(--ink3);white-space:nowrap}
.pr-input{width:70px;background:#fff;border:1px solid var(--paper3);border-radius:var(--rs);padding:5px 8px;font-size:12px;font-family:var(--sans);color:var(--ink);outline:none}
.pr-input:focus{border-color:var(--jade)}
.pr-btn{background:var(--jade);color:#fff;border:none;border-radius:var(--rs);padding:5px 12px;font-size:12px;cursor:pointer;font-family:var(--sans)}

/* listing cards */
.lcard{background:#fff;border-radius:var(--r);border:1px solid var(--paper3);padding:14px;cursor:pointer;position:relative}
.lcard.has-warn{border-left:3px solid var(--amber)}
.lc-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:7px}
.lc-name{font-size:14px;font-weight:500;color:var(--ink);line-height:1.4;flex:1;margin-right:10px}
.lc-price{font-size:17px;font-weight:700;color:var(--jade);text-align:right;white-space:nowrap;font-family:var(--serif)}
.lc-price small{display:block;font-size:10px;font-weight:400;color:var(--ink4)}
.lc-badges{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:6px}
.lc-meta{font-size:11px;color:var(--ink4);display:flex;gap:10px;margin-bottom:5px}
.lc-new{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--jade2);font-weight:500}
.lc-ndot{width:5px;height:5px;border-radius:50%;background:var(--jade);flex-shrink:0}

/* warn strip */
.warn-strip{display:flex;gap:7px;align-items:flex-start;background:var(--amber-bg);border-radius:var(--rs);padding:8px 10px;margin-top:8px}
.warn-strip .wt{font-size:11px;color:var(--amber);line-height:1.5}

/* zone info */
.zi-stat-row{display:flex;gap:8px;margin-bottom:10px}
.zi-stat{flex:1;background:var(--paper2);border-radius:var(--rs);padding:10px;text-align:center}
.zi-stat-num{font-size:16px;font-weight:700;color:var(--jade);font-family:var(--serif)}
.zi-stat-label{font-size:10px;color:var(--ink3);margin-top:2px}
.zi-sec-title{font-size:12px;font-weight:700;color:var(--ink4);letter-spacing:.4px;margin-bottom:8px;padding-bottom:5px;border-bottom:1px solid var(--paper3)}
.zi-overview{background:#fff;border-radius:var(--r);border:1px solid var(--paper3);padding:13px;margin-bottom:10px;font-size:13px;color:var(--ink2);line-height:1.7}
.zi-note{background:var(--blue-bg);border-radius:var(--r);padding:12px;margin-bottom:8px}
.zi-note-tag{font-size:10px;font-weight:700;color:var(--blue)}
.zi-note-who{font-size:10px;color:var(--ink4);margin-left:6px}
.zi-note-text{font-size:12px;color:var(--blue);line-height:1.5;margin-top:4px}
.zi-upload-btn{width:100%;background:var(--paper2);border:1px dashed var(--ink4);border-radius:var(--r);padding:12px;font-size:13px;color:var(--ink3);cursor:pointer;font-family:var(--sans);text-align:center;margin-top:4px}

/* zone transit */
.zt-sub-tabs{display:flex;gap:8px;padding:10px 14px 6px;flex-shrink:0}
.zt-sub-tab{flex:1;padding:8px;text-align:center;font-size:12px;font-weight:500;border-radius:var(--rs);cursor:pointer;border:1px solid var(--paper3);color:var(--ink3);background:#fff}
.zt-sub-tab.active{background:var(--jade);border-color:var(--jade);color:#fff}

/* ── DETAIL ─────────────────────────────────────── */
.detail-hero{
  height:160px;flex-shrink:0;background:linear-gradient(135deg,var(--paper2),var(--paper3));
  display:flex;align-items:center;justify-content:center;font-size:48px;
  position:relative;
}
.detail-body{padding:16px}
.dn{font-family:var(--serif);font-size:19px;font-weight:700;color:var(--ink);margin-bottom:6px}
.dp-row{display:flex;align-items:baseline;gap:6px;margin-bottom:14px}
.dp{font-size:28px;font-weight:700;color:var(--jade);font-family:var(--serif)}
.dp-unit{font-size:13px;color:var(--ink3)}
.ds-title{font-size:11px;font-weight:700;color:var(--ink4);letter-spacing:.5px;margin-bottom:7px;margin-top:14px}
.d-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.d-cell{background:var(--paper2);border-radius:var(--rs);padding:9px 11px}
.d-cell-l{font-size:10px;color:var(--ink3);margin-bottom:2px}
.d-cell-v{font-size:13px;font-weight:500;color:var(--ink)}
.warn-box{background:var(--amber-bg);border:1px solid #f59e0b33;border-radius:var(--r);padding:13px;margin-bottom:14px}
.wb-title{font-size:13px;font-weight:700;color:var(--amber);margin-bottom:5px}
.wb-text{font-size:12px;color:var(--amber);line-height:1.6}
.full-report{background:var(--red-bg);border:1px solid #fca5a555;border-radius:var(--r);padding:13px;margin-top:14px}
.fr-title{font-size:13px;font-weight:700;color:var(--red);margin-bottom:8px}
.fr-btn{width:100%;background:#fff;border:1px solid #fca5a5;border-radius:var(--rs);padding:9px;font-size:12px;color:var(--red);cursor:pointer;font-family:var(--sans);display:block;text-align:center}
.fr-count{font-size:11px;color:var(--red);margin-top:6px;text-align:center}
.cta-bar{padding:12px 16px;background:var(--paper);border-top:1px solid var(--paper3);flex-shrink:0;display:flex;gap:8px}
.btn-p{flex:1;background:var(--jade);color:#fff;border:none;border-radius:var(--r);padding:13px;font-size:15px;font-weight:700;font-family:var(--serif);cursor:pointer}
.btn-s{width:44px;background:var(--paper2);border:1px solid var(--paper3);border-radius:var(--r);font-size:17px;cursor:pointer;display:flex;align-items:center;justify-content:center}

/* ── TRANSIT ────────────────────────────────────── */
.transit-filter{padding:12px 14px;background:#fff;border-bottom:1px solid var(--paper3);flex-shrink:0}
.tf-label{font-size:11px;font-weight:700;color:var(--ink4);margin-bottom:7px;letter-spacing:.3px}
.tf-row{display:flex;align-items:center;gap:8px}
.tf-arrow{font-size:16px;color:var(--ink4);flex-shrink:0}
.tf-select-wrap{flex:1;position:relative}
.tf-select{width:100%;background:var(--paper2);border:1px solid var(--paper3);border-radius:var(--rs);padding:8px 28px 8px 10px;font-size:12px;font-family:var(--sans);color:var(--ink);appearance:none;outline:none}
.tf-caret{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:10px;color:var(--ink3);pointer-events:none}
.route-card{background:#fff;border-radius:var(--r);border:1px solid var(--paper3);overflow:hidden;cursor:pointer}
.rc-head{display:flex;align-items:center;gap:11px;padding:13px}
.rc-icon{width:38px;height:38px;border-radius:var(--rs);display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0}
.rc-info{flex:1}
.rc-name{font-size:13px;font-weight:500;color:var(--ink);margin-bottom:3px}
.rc-tags{display:flex;gap:8px;font-size:11px;color:var(--ink4)}
.rc-arrow{font-size:13px;color:var(--ink4);transition:transform .2s}
.route-card.open .rc-arrow{transform:rotate(90deg)}
.rc-detail{border-top:1px solid var(--paper3);max-height:0;overflow:hidden;transition:max-height .3s cubic-bezier(.4,0,.2,1)}
.route-card.open .rc-detail{max-height:600px}
.rc-inner{padding:13px}
.step-t{font-size:13px;font-weight:500;color:var(--ink);margin-bottom:3px}
.step-b{font-size:12px;color:var(--ink3);line-height:1.6;margin-bottom:10px}
.rc-note{background:var(--blue-bg);border-radius:var(--rs);padding:9px 11px;margin-top:4px}
.rc-note-tag{font-size:10px;font-weight:700;color:var(--blue)}
.rc-note-who{font-size:10px;color:var(--ink4);margin-left:6px}
.rc-note-text{font-size:12px;color:var(--blue);line-height:1.5;margin-top:3px}
.no-results{text-align:center;padding:32px 20px;font-size:13px;color:var(--ink3)}

/* ── AVOID ──────────────────────────────────────── */
.avoid-hero{background:var(--amber);padding:14px 18px 16px;flex-shrink:0}
.avoid-card{background:#fff;border-radius:var(--r);border:1px solid var(--paper3);overflow:hidden}
.avoid-head{background:var(--amber-bg);padding:11px 13px;border-left:4px solid var(--amber);display:flex;align-items:flex-start;gap:9px}
.avoid-name{font-size:13px;font-weight:500;color:var(--ink);margin-bottom:3px}
.avoid-body{padding:11px 13px}
.avoid-desc{font-size:12px;color:var(--ink2);line-height:1.6;margin-bottom:8px}
.avoid-meta{display:flex;justify-content:space-between;font-size:11px;color:var(--ink4);margin-bottom:7px}
.avoid-count{color:var(--red);font-weight:500}
.confirm-btn{width:100%;background:#fff;border:1px solid #fca5a5;border-radius:var(--rs);padding:8px;font-size:12px;color:var(--red);cursor:pointer;font-family:var(--sans);text-align:center;display:block}

/* ── UPLOAD ─────────────────────────────────────── */
.upload-body{padding:14px 16px 80px}
.trust-box{background:var(--blue-bg);border-radius:var(--r);padding:13px;margin-bottom:16px}
.tb-title{font-size:13px;font-weight:700;color:var(--blue);margin-bottom:7px}
.ti{display:flex;gap:7px;align-items:flex-start;margin-bottom:5px}
.ti-num{width:17px;height:17px;border-radius:50%;background:var(--blue);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.ti-text{font-size:12px;color:var(--blue);line-height:1.5}
.u-sec-title{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:9px}
.radio-group{display:flex;gap:7px;flex-wrap:wrap}
.ro{padding:5px 13px;border-radius:20px;border:1px solid var(--paper3);font-size:12px;color:var(--ink3);cursor:pointer;background:#fff}
.ro.active{background:var(--jade);border-color:var(--jade);color:#fff}
.field{margin-bottom:11px}
.field label{display:block;font-size:12px;font-weight:500;color:var(--ink3);margin-bottom:5px}
.field input,.field textarea{width:100%;background:#fff;border:1px solid var(--paper3);border-radius:var(--rs);padding:9px 11px;font-size:13px;font-family:var(--sans);color:var(--ink);outline:none}
.field input:focus,.field textarea:focus{border-color:var(--jade)}
.field textarea{min-height:72px;resize:vertical}
.disclaimer{background:var(--paper2);border-radius:var(--rs);padding:11px;font-size:11px;color:var(--ink3);line-height:1.6;margin-bottom:14px}
.submit-btn{width:100%;background:var(--jade);color:#fff;border:none;border-radius:var(--r);padding:15px;font-size:15px;font-weight:700;font-family:var(--serif);cursor:pointer}
