:root{
  --bg:#eef1f5; --card:#ffffff; --line:#e7eaf0; --soft:#f4f6f9;
  --txt:#1b2433; --txt2:#3a4658; --sub:#8b94a6;
  --blue:#2a7de1; --bluebg:#eaf2fd;
  --red:#e0322f; --redbg:#fdecec;       /* 台股:紅=加碼/新增/正 */
  --green:#11a05f; --greenbg:#e6f6ee;   /* 綠=減碼/移除/負 */
  --gold:#caa24a;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;background:var(--bg);color:var(--txt);font-size:17px;
  font-family:-apple-system,"PingFang TC","Microsoft JhengHei",sans-serif;-webkit-font-smoothing:antialiased}
body{padding-bottom:env(safe-area-inset-bottom)}
#hdr{position:sticky;top:0;z-index:10;background:#d7e0ec;
  backdrop-filter:blur(12px);padding:calc(env(safe-area-inset-top) + 10px) 10px 10px;
  border-bottom:1px solid #c2cedd;box-shadow:0 1px 6px rgba(20,40,80,.07);
  display:flex;align-items:center;gap:4px}
#title{font-size:21px;font-weight:800;flex:1;letter-spacing:.3px;padding-left:2px}
.sub{font-size:16px;color:var(--txt2);font-weight:700}
.back{background:none;border:0;color:var(--blue);font-size:38px;font-weight:600;line-height:1;
  min-width:44px;height:44px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;margin:-4px 0;border-radius:12px}
.back:active{background:rgba(42,125,225,.14)}
.back[hidden]{display:none}
main{max-width:680px;margin:0 auto;padding:12px 14px 30px}
.loading{color:var(--sub);text-align:center;padding:48px}
.cmp{font-size:14px;color:var(--sub);margin:4px 2px 12px}
.cmp b{color:var(--txt2)}
/* 首頁分頁(主動/國內/國外) */
.tabs{display:flex;gap:5px;background:#e3e9f1;border-radius:13px;padding:4px;margin:6px 0 12px}
.tab{flex:1;font-size:15.5px;font-weight:800;padding:9px 0;border:0;border-radius:10px;
  background:none;color:var(--txt2);cursor:pointer;transition:background .12s}
.tab.on{background:var(--card);color:var(--blue);box-shadow:0 1px 3px rgba(20,40,80,.12)}
.tab i{font-style:normal;font-size:11px;font-weight:800;background:var(--blue);color:#fff;
  border-radius:999px;padding:0 5px;margin-left:3px;vertical-align:1px;min-width:16px;display:inline-block}
.tab.on i{background:var(--blue)}
/* 自選星號 */
.star{background:none;border:0;font-size:21px;line-height:1;color:#cdd5e1;cursor:pointer;
  padding:2px 2px;margin:-4px 0 -4px -4px;min-width:30px;height:38px;flex:none}
.star.on{color:#f2b400}
.star:active{transform:scale(.85)}
/* 首頁頂列 + 更新按鈕 */
.hometop{display:flex;align-items:center;justify-content:space-between;gap:10px;
  font-size:13.5px;color:var(--sub);margin:4px 2px 12px}
.hometop b{color:var(--txt2);font-weight:700}
.refbtn{font-size:14px;font-weight:700;padding:7px 14px;border-radius:999px;cursor:pointer;
  border:1px solid var(--blue);background:var(--bluebg);color:var(--blue);white-space:nowrap}
.refbtn:active{background:#d8e8fb}
.refbtn:disabled{opacity:.6}
.dinfo{font-size:14px;color:var(--sub);margin:4px 2px 10px}
.dinfo b{color:var(--txt2);font-weight:700}
/* 4 卡片摘要(新增/刪除/加碼/減碼) — 扁平兩列 */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:7px;margin-bottom:12px}
.dcard{border-radius:10px;padding:6px 4px 5px;text-align:center;border:1px solid;box-shadow:none}
.dcard .ct{font-size:13px;font-weight:800}
.dcard .cn{font-size:19px;font-weight:800;line-height:1.1;margin-top:1px}
.dcard.add{background:#fbf4e0;border-color:#ecdcae}
.dcard.add .ct,.dcard.add .cn{color:#bd9430}
.dcard.rem{background:#f1f3f7;border-color:#e1e6ed}
.dcard.rem .ct,.dcard.rem .cn{color:#7c8696}
.dcard.up{background:var(--redbg);border-color:#f6cfcf}
.dcard.up .ct,.dcard.up .cn{color:var(--red)}
.dcard.dn{background:var(--greenbg);border-color:#c1e7d2}
.dcard.dn .ct,.dcard.dn .cn{color:var(--green)}

/* 首頁 ETF 卡 */
.etf-card{background:var(--card);border:1px solid var(--line);border-radius:16px;
  padding:14px 16px;margin:10px 0;display:flex;align-items:center;gap:12px;cursor:pointer;
  box-shadow:0 1px 3px rgba(20,30,50,.04);transition:transform .08s}
.etf-card:active{transform:scale(.985);background:var(--soft)}
.etf-id{font-weight:800;font-size:18px;min-width:74px;color:var(--blue)}
.etf-meta{flex:1;min-width:0}
.etf-name{font-size:17px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--txt)}
.etf-sum{font-size:14px;margin-top:5px;display:flex;gap:7px;flex-wrap:wrap;align-items:center}
.pill{font-size:13px;font-weight:800;padding:2px 9px;border-radius:999px}
.pill.add{color:var(--red);background:var(--redbg)}     /* 新增=紅 */
.pill.rem{color:var(--green);background:var(--greenbg)} /* 移除=綠 */
.pill.up{color:var(--red);background:var(--redbg)}      /* 加碼=紅 */
.pill.dn{color:var(--green);background:var(--greenbg)}  /* 減碼=綠 */
.pill.flat{color:var(--sub);background:var(--soft);font-weight:600}
.chev{color:#c4ccd8;font-size:24px}
.tag{font-size:12px;color:var(--sub);border:1px solid var(--line);border-radius:6px;padding:1px 7px;background:var(--soft)}

/* 日期選擇 */
.dsel{display:flex;gap:8px;overflow-x:auto;padding:4px 0 12px;-webkit-overflow-scrolling:touch}
.dchip{flex:none;font-size:14px;padding:7px 13px;border-radius:999px;border:1px solid var(--line);
  background:var(--card);color:var(--txt2);cursor:pointer;font-weight:600}
.dchip.on{background:var(--blue);color:#fff;border-color:var(--blue)}

/* 區塊卡 */
.sec{background:var(--card);border:1px solid var(--line);border-radius:14px;margin:11px 0;overflow:hidden;
  box-shadow:0 1px 3px rgba(20,30,50,.04)}
.sec h3{margin:0;padding:12px 15px;font-size:15px;font-weight:800;display:flex;justify-content:space-between;
  align-items:center;border-bottom:1px solid var(--line)}
.sec h3 .c{color:var(--sub);font-weight:700;font-size:14px}
.colhd{display:flex;padding:8px 15px;font-size:12px;color:var(--sub);border-bottom:1px solid var(--line);background:var(--soft)}
.colhd .cR{margin-left:auto;text-align:right;min-width:96px}
.row{display:flex;align-items:center;gap:10px;padding:7px 14px;border-bottom:1px solid var(--line)}
.row:last-child{border-bottom:0}
.row .id{flex:1;min-width:0}
.row .id .nm{font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.25}
.row .id .sid{font-size:11.5px;color:var(--sub);line-height:1.2}
.row .id .nm .t{font-size:11px;font-weight:800;padding:0 6px;border-radius:5px;margin-left:6px;vertical-align:1px}
.t.add{color:var(--red);background:var(--redbg)} .t.up{color:var(--red);background:var(--redbg)}
.t.dn{color:var(--green);background:var(--greenbg)}
.col{min-width:92px;text-align:right}
.col .v{font-size:15px;font-weight:700;font-variant-numeric:tabular-nums;line-height:1.2}
.col .v .u{font-size:10.5px;font-weight:600;color:var(--sub);margin-left:1px}
.col .chg{font-size:12px;font-weight:700;font-variant-numeric:tabular-nums;line-height:1.2}
.col .chg .u{font-size:10px;font-weight:600;margin-left:1px}
/* 排序按鈕 */
.sortbtns{display:flex;align-items:center;gap:7px;padding:10px 15px;font-size:13px;color:var(--sub);
  border-bottom:1px solid var(--line);background:var(--soft)}
.sortbtn{font-size:14px;font-weight:700;padding:5px 14px;border-radius:999px;cursor:pointer;
  border:1px solid var(--line);background:var(--card);color:var(--txt2)}
.sortbtn.on{background:var(--blue);color:#fff;border-color:var(--blue)}
.pos{color:var(--red)} .neg{color:var(--green)} .zero{color:var(--sub)}
.empty{color:var(--sub);padding:14px 15px;font-size:14px}
/* 清倉移除:單行緊湊 */
.remrow{display:flex;align-items:center;gap:8px;padding:7px 14px;border-bottom:1px solid var(--line);font-size:15px}
.remrow:last-child{border-bottom:0}
.remrow .rnm{font-weight:600}
.remrow .rsid{font-size:11.5px;color:var(--sub)}
.remrow .rw{margin-left:auto;font-size:13px;font-weight:700}
.remrow .rtag{font-size:11px;font-weight:800;color:var(--green);background:var(--greenbg);padding:2px 8px;border-radius:6px}
/* 權重條 */
.wbar{height:3px;background:var(--soft);border-radius:3px;margin-top:4px;overflow:hidden}
.wbar > i{display:block;height:100%;background:var(--blue);border-radius:3px}

#ftr{text-align:center;padding:24px 18px calc(env(safe-area-inset-bottom) + 32px);margin-top:16px;border-top:1px solid var(--line)}
#ftr .fname{font-size:15px;font-weight:800;color:var(--txt);margin-bottom:8px}
#ftr .fsrc{font-size:12.5px;color:var(--sub);line-height:1.8}
#ftr .fsrc a{color:var(--blue);text-decoration:none}
#ftr .fdis{font-size:11.5px;color:var(--sub);margin-top:6px;line-height:1.7}
#ftr .fcredit{font-size:13px;font-weight:800;margin-top:14px;color:var(--gold);letter-spacing:.5px}
