:root{--bg:#0f1419;--panel:#1a212b;--panel2:#222c38;--ink:#e8edf2;--mut:#9fb0c0;--line:#2c3a48;
--green:#1faa59;--amber:#e0922f;--red:#d6483f;--grey:#7b8a99;--purple:#8b5cf6;--blue:#3b82f6;}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);font:14px/1.45 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}
a{color:#7fb6ff;text-decoration:none}a:hover{text-decoration:underline}
header{padding:18px 22px 10px}
h1{margin:0 0 2px;font-size:20px;letter-spacing:.2px}
.sub{color:var(--mut);font-size:12.5px}
.statusbar{display:flex;gap:18px;flex-wrap:wrap;margin-top:8px;font-size:12px;color:var(--mut)}
.statusbar b{color:var(--ink)}
.stats{display:flex;gap:10px;flex-wrap:wrap;margin:12px 22px 0}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:8px 14px;min-width:92px}
.stat .n{font-size:21px;font-weight:700}
.stat .l{font-size:11px;color:var(--mut);text-transform:uppercase;letter-spacing:.4px}
.stat.green .n{color:var(--green)}.stat.red .n{color:var(--red)}.stat.amber .n{color:var(--amber)}.stat.blue .n{color:var(--blue)}.stat.teal .n{color:#14b8a6}
.filterwrap{margin:14px 22px 0;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:11px 14px}
.frow{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin:4px 0}
.frow .lbl{color:var(--mut);font-size:11px;text-transform:uppercase;letter-spacing:.5px;width:64px;flex:none}
.btn{background:var(--panel2);border:1px solid var(--line);color:var(--ink);border-radius:20px;padding:5px 12px;cursor:pointer;font-size:12px}
.btn:hover{border-color:#3d5060}
.btn.on{background:#2a6df4;border-color:#2a6df4;color:#fff}
.btn.layer.on{background:var(--green);border-color:var(--green)}
.matchcount{margin-left:auto;color:var(--mut);font-size:12px}
.qbox{flex:1;min-width:180px;background:#0c1116;border:1px solid var(--line);color:var(--ink);border-radius:20px;padding:6px 12px;font-size:12.5px}
.num{width:110px;background:#0c1116;border:1px solid var(--line);color:var(--ink);border-radius:20px;padding:6px 10px;font-size:12.5px}
.sel{background:var(--panel2);border:1px solid var(--line);color:var(--ink);border-radius:20px;padding:6px 10px;font-size:12px;cursor:pointer}
.btn.clearb{border-color:#5a3a3f;color:#ff9a92}.btn.clearb:hover{background:#3a2326}
#map{height:460px;margin:12px 22px 0;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.legend{display:flex;gap:14px;flex-wrap:wrap;margin:10px 22px 0;font-size:12px;color:var(--mut)}
.dot{display:inline-block;width:11px;height:11px;border-radius:50%;margin-right:5px;vertical-align:middle}
.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:14px 22px 0;font-size:12px;color:var(--mut)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:16px;padding:12px 22px 30px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;scroll-margin-top:14px}
.card.match{box-shadow:0 0 0 1px rgba(31,170,89,.5)}
.card.bunk{box-shadow:0 0 0 1px rgba(214,72,63,.45)}
.card.agency{box-shadow:0 0 0 1px rgba(20,184,166,.5)}
.ph.noimg{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#15323a,#0f1f24)}
.ph .phx{color:#5fd0c4;font-size:12px}
.chip.agency{background:rgba(20,184,166,.92)}
.chip.wst{background:rgba(0,0,0,.6)}
.chip.wst.wok{background:rgba(31,170,89,.92)}
.chip.wst.wsum{background:rgba(224,146,47,.92)}
.chip.wst.wenq{background:rgba(59,130,246,.92)}
.agrow{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:10px;margin-bottom:6px}
.agcard{background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:9px 11px}
.agn{font-size:12.5px;font-weight:650}
.agseason{font-size:9.5px;font-weight:600;color:#5fd0c4;border:1px solid #14b8a6;border-radius:10px;padding:1px 6px;margin-left:4px}
.agnote{font-size:11px;color:var(--mut);margin-top:3px}
.aglinks{font-size:11.5px;margin-top:4px}
.card.flash{animation:fl 1.6s ease}
@keyframes fl{0%{box-shadow:0 0 0 3px var(--blue)}100%{box-shadow:0 0 0 1px var(--line)}}
.ph{position:relative;height:190px;background:#0a0e12;cursor:pointer;overflow:hidden}
.ph .phimg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.ph .nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.45);border:none;color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:15px;z-index:3}
.ph .nav.l{left:8px}.ph .nav.r{right:8px}
.ph .count{position:absolute;bottom:8px;right:10px;background:rgba(0,0,0,.55);color:#fff;border-radius:10px;padding:2px 8px;font-size:11px;z-index:3}
.ph .openfull{position:absolute;bottom:8px;left:10px;background:rgba(0,0,0,.6);color:#fff;border-radius:10px;padding:2px 9px;font-size:11px;z-index:3;font-weight:600}
.ph .openfull:hover{background:#2a6df4}
.chips{position:absolute;top:8px;left:8px;display:flex;gap:6px;flex-wrap:wrap;max-width:88%;z-index:3}
.chip{font-size:10.5px;font-weight:600;padding:3px 8px;border-radius:20px;color:#fff}
.chip.saved{background:rgba(139,92,246,.92)}.chip.found{background:rgba(59,130,246,.92)}
.chip.date{background:rgba(0,0,0,.6);font-weight:500}
.body{padding:12px 14px 14px;display:flex;flex-direction:column;gap:7px;flex:1;cursor:pointer}
.card:hover{border-color:#3d5060}
.ttl{font-size:14.5px;font-weight:650;line-height:1.25}
.ttl a{color:var(--ink)}
.mapbtn{align-self:flex-start;background:rgba(59,130,246,.16);color:#85b6ff;border:1px solid #3b82f6;border-radius:8px;padding:4px 11px;font-size:11.5px;font-weight:600;cursor:pointer}
.mapbtn:hover{background:#2a6df4;color:#fff}
.fullbtn{align-self:flex-start;background:rgba(20,184,166,.16);color:#5fd0c4;border:1px solid #14b8a6;border-radius:8px;padding:4px 11px;font-size:11.5px;font-weight:600}
.fullbtn:hover{background:#14b8a6;color:#04240f}
.badges{display:flex;gap:6px;flex-wrap:wrap}
.bdg{font-size:10.5px;font-weight:600;padding:2px 8px;border-radius:6px;border:1px solid var(--line)}
.bdg.match{background:rgba(31,170,89,.16);color:#54d98c;border-color:transparent}
.bdg.bunk{background:rgba(214,72,63,.16);color:#ff8a82;border-color:transparent}
.bdg.fail{background:rgba(224,146,47,.14);color:#f0b266;border-color:transparent}
.bdg.free{background:rgba(59,130,246,.16);color:#85b6ff;border-color:transparent}
.meta{font-size:12.5px;color:var(--mut)}
.loc a{font-size:12px}
.avail{display:flex;align-items:center;gap:7px;margin-top:2px}
.avail .k{font-size:11px;color:var(--mut);width:54px}
.pill{font-size:11px;font-weight:600;padding:2px 9px;border-radius:14px;cursor:help}
.pill.open{background:var(--green);color:#04240f}.pill.partial{background:var(--amber);color:#2a1700}.pill.closed{background:var(--red);color:#fff}
.adetail{font-size:11.5px;color:#c9b27e}
.price{font-size:16px;font-weight:700}.price .o{font-size:12px;color:var(--mut);text-decoration:line-through;font-weight:400;margin-left:6px}
.fb{display:flex;align-items:center;gap:8px;margin-top:6px;border-top:1px solid var(--line);padding-top:9px}
.fbtn{background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:5px 9px;cursor:pointer;font-size:14px}
.fbtn.like.on{background:rgba(31,170,89,.22);border-color:var(--green)}
.fbtn.dis.on{background:rgba(214,72,63,.22);border-color:var(--red)}
.note{flex:1;background:#0c1116;border:1px solid var(--line);color:var(--ink);border-radius:8px;padding:6px 8px;font-size:12px;min-width:80px}
.policy{margin:8px 22px 40px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px 20px}
.policy h2{font-size:15px;margin:0 0 8px}.policy p{color:var(--mut);font-size:12.5px;margin:6px 0}
.mapkey{display:flex;align-items:center;justify-content:center;height:100%;color:var(--mut);font-size:13px;text-align:center;padding:0 24px;line-height:1.6}
.mapkey code{background:#0c1116;border:1px solid var(--line);border-radius:5px;padding:1px 6px;color:#85b6ff}
.pp{color:#222;max-width:230px}.pp b{font-size:13px;color:#111}.pp .s{color:#555;font-size:11.5px}.pp a{color:#1a73e8}
.pp .view{display:inline-block;margin-top:6px;font-weight:600}
.muted{color:var(--mut)}

/* ---------- per-listing show page: lightbox only (layout is Tailwind) ---------- */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);display:none;align-items:center;justify-content:center;z-index:999;cursor:zoom-out}
.lightbox img{max-width:94vw;max-height:92vh;object-fit:contain;border-radius:6px}
.lightbox .lbnav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.14);border:none;color:#fff;width:46px;height:46px;border-radius:50%;font-size:24px;cursor:pointer}
.lightbox .lbnav.l{left:18px}.lightbox .lbnav.r{right:18px}
