:root{--bg:#f6f2ec;--card:#fff;--ink:#3b3a44;--muted:#88858f;--line:#efeae2;--mint:#a9d9c0;--mint-d:#6fb392;--lav:#cdbdee;--lav-d:#9c84d6;--peach:#f7cbb4;--peach-d:#ee9f7e;--sky:#aed7ea;--sky-d:#6fb1cf;--sun:#f6e3a8;--sun-d:#d9b24c;--rose:#f4c0cd;--rose-d:#e58aa0;--shadow:0 6px 18px rgba(80,70,90,.08)}*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;background:linear-gradient(160deg,#efe9f3,#eaf3ee 60%,#f6f2ec);color:var(--ink);-webkit-font-smoothing:antialiased;font-size:15px}button{font-family:inherit}a{color:inherit;text-decoration:none}.app{max-width:480px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;background:var(--bg);box-shadow:0 0 60px rgba(70,60,90,.08);position:relative}.appbar{display:flex;justify-content:space-between;align-items:center;padding:16px 18px 10px;position:-webkit-sticky;position:sticky;top:0;background:linear-gradient(180deg,var(--bg),hsla(36,36%,95%,.85));-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:20}.brand{font-weight:800;font-size:21px;letter-spacing:-.5px}.brand b,.iconbtn{color:var(--lav-d)}.iconbtn{width:40px;height:40px;border-radius:13px;background:#fff;box-shadow:var(--shadow);border:0;display:flex;align-items:center;justify-content:center;cursor:pointer}.iconbtn .ic{width:21px;height:21px}.content{flex:1 1;overflow-y:auto;padding:4px 16px 96px}.ic{width:1em;height:1em;display:inline-block;vertical-align:-.14em;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex:none}.ic.fill{fill:currentColor;stroke:none}.card{background:var(--card);border-radius:20px;padding:16px;box-shadow:var(--shadow);margin-bottom:14px}.card h3{font-size:13.5px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.4px;margin-bottom:10px;display:flex;align-items:center;gap:6px}.card h3 .ic{width:16px;height:16px;color:var(--lav-d)}.row{gap:12px}.row,.spread{display:flex;align-items:center}.spread{justify-content:space-between}.muted{color:var(--muted)}.small{font-size:13px}.b,.pill{font-weight:700}.pill{font-size:12px;padding:4px 10px;border-radius:999px;display:inline-flex;align-items:center;gap:5px}.pill .ic{width:13px;height:13px}.cover{width:46px;height:46px;border-radius:12px;object-fit:cover;flex:none;background:linear-gradient(135deg,#e7ddf7,#d7e9e0);display:flex;align-items:center;justify-content:center;font-weight:800;color:#7a6a9c}.cover.lg{width:60px;height:60px;border-radius:14px}.cover.xl{width:66px;height:66px;border-radius:14px}.avatar{width:34px;height:34px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:15px;flex:none}.avatar,.dot-c{border-radius:50%}.dot-c{width:13px;height:13px;display:inline-block;border:2px solid #fff;box-shadow:0 0 0 1px #ddd}.heroStat{background:hsla(0,0%,100%,.6);border-radius:14px;padding:10px;text-align:center;flex:1 1}.heroStat .n{font-size:20px;font-weight:800}.heroStat .l{font-size:11.5px;color:#615a72;font-weight:600}.cover-hero{position:relative;border-radius:22px;overflow:hidden;height:190px;margin-bottom:14px;box-shadow:var(--shadow)}.cover-hero .imgwrap,.cover-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.cover-hero .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:54px;font-weight:800;color:#fff;background:linear-gradient(135deg,#9c84d6,#6fb392)}.cover-hero .ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(40,30,60,.05),rgba(40,30,60,.78))}.cover-hero .txt{position:absolute;left:16px;right:16px;bottom:14px;color:#fff}.cover-hero .txt .k{font-size:12.5px;font-weight:700;opacity:.9}.cover-hero .txt .t{font-size:23px;font-weight:800;letter-spacing:-.5px;margin-top:2px}.cover-hero .cta{display:flex;gap:9px;margin-top:11px}.cover-hero .cta button{flex:1 1;border:0;border-radius:14px;padding:11px;font-weight:800;font-size:13.5px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px}.cover-hero .cta .ic{width:16px;height:16px}.cta-host{background:#fff;color:#5a4a78}.cta-join{background:hsla(0,0%,100%,.22);color:#fff;border:1px solid hsla(0,0%,100%,.4)}.carou{display:flex;gap:11px;overflow-x:auto;padding:2px 0 6px;margin-bottom:14px}.carou::-webkit-scrollbar{height:0}.carou .tile{flex:none;width:112px}.carou .tile .cv{width:112px;height:112px;border-radius:16px;object-fit:cover;box-shadow:var(--shadow);background:linear-gradient(135deg,#e7ddf7,#d7e9e0);display:flex;align-items:center;justify-content:center;font-weight:800;color:#7a6a9c;font-size:26px;position:relative}.carou .tile .nm{font-size:13px;font-weight:700;margin-top:6px}.carou .tile .sub{font-size:11.5px;color:var(--muted)}.resbadge{position:absolute;top:7px;right:7px;font-size:10.5px;font-weight:800;padding:2px 8px;border-radius:999px}.statstrip{display:flex;gap:9px;margin-bottom:14px}.statstrip .s{flex:1 1;background:#fff;border-radius:16px;padding:11px;text-align:center;box-shadow:var(--shadow)}.statstrip .n{font-size:20px;font-weight:800}.statstrip .l{font-size:11.5px;color:var(--muted);font-weight:600}.bar{height:10px;background:#efeaf2;overflow:hidden}.bar,.bar>span{border-radius:6px}.bar>span{display:block;height:100%}.distrow{display:grid;grid-template-columns:90px 1fr 36px;grid-gap:8px;gap:8px;align-items:center;font-size:13px;margin:7px 0}.heat{display:grid;grid-template-columns:repeat(14,1fr);grid-gap:4px;gap:4px;margin-top:6px}.heat i{aspect-ratio:1;border-radius:4px}.legend{display:flex;gap:6px;align-items:center;font-size:12px;color:var(--muted);margin-top:8px}.legend i{width:12px;height:12px;border-radius:3px;display:inline-block}.exp{border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-top:10px}.exp-h{width:100%;background:#faf8fc;border:0;padding:12px 14px;justify-content:space-between;cursor:pointer;font-weight:700;font-size:13.5px;color:#5d5770;gap:8px}.exp-h,.exp-h .lft{display:flex;align-items:center}.exp-h .lft{gap:7px}.exp-h .lft .ic{width:16px;height:16px;color:var(--lav-d)}.exp-h .chev{width:16px;height:16px;transition:transform .25s;color:#b3aec0}.exp.open .exp-h .chev{transform:rotate(180deg)}.exp-b{padding:6px 14px 12px}.field{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px dashed var(--line);font-size:14px}.field:last-child{border-bottom:0}.field .lbl{color:var(--muted);display:flex;align-items:center;gap:6px}.field .lbl .ic{width:15px;height:15px}.field .v{font-weight:700}.inp{background:#f4f1f8;border:1px solid #e7e1f0;border-radius:9px;padding:9px 12px;font-size:16px;color:#4a4658;font-weight:600}.searchbar{display:flex;align-items:center;gap:8px;background:#fff;border-radius:14px;padding:11px 14px;box-shadow:var(--shadow);margin-bottom:12px;color:#8e8a9c;font-size:14px}.searchbar .ic{width:17px;height:17px}.chips{display:flex;gap:7px;overflow-x:auto;padding-bottom:4px;margin-bottom:12px}.chips::-webkit-scrollbar{height:0}.chip{flex:none;font-size:13px;font-weight:700;padding:8px 13px;border-radius:999px;background:#fff;color:#7d7990;box-shadow:var(--shadow);cursor:pointer;display:inline-flex;align-items:center;gap:5px}.chip .ic{width:14px;height:14px}.chip.on{background:var(--lav);color:#4a3f63}.addbtn{width:100%;border:1.5px dashed #d6cfe0;background:none;color:#857d96;padding:12px;border-radius:14px;font-weight:700;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px}.addbtn .ic{width:16px;height:16px}.primary{width:100%;border:0;border-radius:16px;padding:15px;font-weight:800;font-size:15px;cursor:pointer;color:#2f5c47;background:linear-gradient(135deg,var(--mint),#c7e9d6)}.metaline{display:flex;gap:10px;flex-wrap:wrap;font-size:12.5px;color:var(--muted);margin-top:4px}.metaline span{display:inline-flex;align-items:center;gap:4px}.metaline .ic{width:13px;height:13px}.glist .grow{display:flex;gap:12px;padding:11px 0;border-bottom:1px solid var(--line)}.glist .grow:last-child{border-bottom:0}.qrbox{display:flex;flex-direction:column;align-items:center;gap:10px}.qrframe{position:relative;width:180px;height:180px;background:#fff;border-radius:18px;box-shadow:var(--shadow);padding:12px}.qrframe svg{width:100%;height:100%}.scanline{position:absolute;left:12px;right:12px;height:2px;background:linear-gradient(90deg,transparent,var(--lav-d),transparent);top:50%;animation:scan 2.4s ease-in-out infinite}@keyframes scan{0%,to{top:18px}50%{top:140px}}.near{display:flex;align-items:center;gap:11px;padding:11px 0;border-bottom:1px solid var(--line)}.near:last-child{border-bottom:0}.near .dist{margin-left:auto;text-align:right}.near .joinb{margin-left:8px;border:0;background:var(--mint);color:#2f5c47;font-weight:800;font-size:13px;padding:8px 14px;border-radius:11px;cursor:pointer}.tabs{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;padding:8px 12px calc(8px + env(safe-area-inset-bottom));z-index:30}.tabs .inner{background:#fff;border-radius:22px;box-shadow:0 8px 24px rgba(70,60,90,.16);display:flex;justify-content:space-around;padding:9px 2px}.tabs a{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:11px;color:#a8a3b8;font-weight:700;flex:1 1;padding:3px 0}.tabs a .ic{width:22px;height:22px}.tabs a.on{color:var(--lav-d)}.tag-new{background:var(--mint);color:#2f5c47}.tag-edge,.tag-new{font-size:10.5px;font-weight:800;padding:2px 8px;border-radius:999px;margin-left:6px;vertical-align:middle}.tag-edge{background:var(--lav);color:#4a3f63}.spark{display:flex;align-items:flex-end;gap:5px;height:78px;margin-top:6px}.spark i{flex:1 1;background:linear-gradient(180deg,var(--mint-d),var(--mint));border-radius:5px 5px 0 0}.center{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:16px;min-height:80vh;padding:24px}