﻿:root{
  --bg:#f5f6f7;
  --card:#ffffff;
  --text:#111827;
  --muted:#6b7280;
  --line:#e5e7eb;
  --brand:#1677ff;
  --danger:#ef4444;
  --shadow:0 6px 18px rgba(17,24,39,.08);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"PingFang SC","Segoe UI",Roboto,Helvetica,Arial,"Microsoft YaHei",sans-serif;
  background:var(--bg);
  color:var(--text);
}

.topbar{
  position:sticky;top:0;z-index:20;
  height:48px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 10px;
  background:#cf1111;
  color:#fff;
}
.topbar__title{
  position:absolute;left:50%;transform:translateX(-50%);
  font-weight:700;letter-spacing:.5px;
  max-width:70vw;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  pointer-events:none;
}
.topbar__right{display:flex;align-items:center;gap:8px}
#btnRefresh{display:none !important}
.topbar__shop{
  font-weight:800;
  font-size:12px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:160px;
}
.iconBtn{
  width:34px;height:34px;
  border:none;background:transparent;color:#fff;
  font-size:22px;line-height:34px;
}

.page{padding:10px 10px 140px}

.btn{
  border:1px solid var(--line);
  background:#fff;
  color:var(--text);
  border-radius:10px;
  padding:8px 10px;
  font-size:14px;
  line-height:1.1;
}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.btn--primary{background:var(--brand);border-color:var(--brand);color:#fff}
.btn[disabled]{opacity:.5}

.select,.input{
  background:#fff;
  border:1px solid var(--line);
  color:var(--text);
  border-radius:8px;
  padding:6px 10px;
  outline:none;
}
.select--compact{padding:5px 8px}
.input--compact{width:56px;text-align:center;padding:5px 8px}

.sep{opacity:.7}

/* Home tiles */
.homeSec{margin:12px 0}
.homeSec__title{font-weight:900;font-size:16px;margin:6px 2px 10px}
.homeGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.homeFollowRow{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.homeFollowLead{
  grid-column:span 2;
  display:block;
  min-height:0;
  border-radius:14px;
  border:none;
  background:transparent;
  overflow:hidden;
  text-decoration:none;
}
.homeFollowLead__img{
  display:block;
  width:100%;
  height:auto;
  object-fit:contain;
  border-radius:14px;
  border:1px solid var(--line);
  background:#fff;
}
.homeFollowLead:active{opacity:.92}
.homeFollowSpacer{grid-column:span 2;visibility:hidden;pointer-events:none}
.homeTile{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 6px;border-radius:14px;text-decoration:none;color:inherit}
.homeTile:active{background:#f3f4f6}
.homeTile__iconWrap{width:62px;height:62px;border-radius:999px;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 22px rgba(17,24,39,.10)}
.homeTile__icon{width:46px;height:46px;border-radius:14px;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center}
.tile__img{width:40px;height:40px;object-fit:contain}
.homeTile__t{font-weight:900;font-size:14px;line-height:1.1;text-align:center}
.homeTile__sub{font-size:12px;color:var(--muted);line-height:1.1;text-align:center}
.homeTile--wide{grid-column:span 2}
.homeTile--follow{
  align-items:stretch;
  justify-content:flex-start;
  padding:10px;
  gap:0;
  min-height:108px;
}
.homeTile--follow .homeTile__iconWrap{
  width:100%;
  height:100%;
  border-radius:16px;
  box-shadow:none;
  background:linear-gradient(135deg,#fb7185,#cf1111) !important;
}
.homeTile--followBanner{
  background:#fff;
}
.homeTile--follow .homeTile__iconWrap--followBg{
  background-color:#fff !important;
}
.homeTile--follow .homeTile__icon{
  width:100%;
  height:100%;
  border-radius:16px;
  overflow:hidden;
  background:rgba(255,255,255,.08);
}
.homeTile--follow .homeTile__icon--followGhost{
  width:100%;
  height:100%;
  background:transparent !important;
}
.homeTile--follow .homeTile__icon--followBg{
  display:block;
  min-height:88px;
  background-repeat:no-repeat;
  background-position:center;
  background-size:cover;
}
.homeTile__icon--fallback{
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:26px;
  font-weight:900;
  color:#fff;
  letter-spacing:2px;
  text-shadow:0 2px 10px rgba(0,0,0,.15);
}
.tile__img--follow{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  border-radius:16px;
}
/* Home style A: card + shadow */
.homeStyleA .homeTile{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)}
.homeStyleA .homeFollowLead{box-shadow:var(--shadow)}

/* Home style B: full grid separators */
.homeStyleB .homeGrid{gap:0;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.homeStyleB .homeTile{border-radius:0;padding:14px 6px;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.homeStyleB .homeFollowRow{gap:0;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.homeStyleB .homeFollowLead{border:none;border-right:1px solid var(--line);border-radius:0;min-height:0}
.homeStyleB .homeFollowLead__img{border:none;border-radius:0}
.homeStyleB .homeFollowSpacer{border-right:none;border-bottom:none}
.homeStyleB .homeTile:nth-child(4n){border-right:none}
.homeStyleB .homeTile__iconWrap{box-shadow:none}
.homeStyleB .homeTile__icon{background:transparent}
.homeStyleB .homeTile:active{background:#f9fafb}
.homeStyleB .homeTile--wide{grid-column:span 2}
.homeStyleB .homeTile--follow{padding:12px 10px}
.homeStyleB .homeTile--follow .homeTile__iconWrap{height:100%}

/* Home style C: minimal + bigger icon */
.homeStyleC .homeGrid{gap:12px}
.homeStyleC .homeFollowRow{gap:12px}
.homeStyleC .homeFollowLead{min-height:0;border-radius:18px;box-shadow:none}
.homeStyleC .homeFollowLead__img{border-radius:18px}
.homeStyleC .homeFollowSpacer{border:none;background:transparent}
.homeStyleC .homeTile{background:#fff;border:1px solid var(--line);box-shadow:none}
.homeStyleC .homeTile__iconWrap{width:74px;height:74px;box-shadow:none;background:transparent !important}
.homeStyleC .homeTile__icon{width:74px;height:74px;border-radius:18px;background:transparent !important}
.homeStyleC .tile__img{width:66px;height:66px}
.homeStyleC .homeTile--wide{grid-column:span 2}
.homeStyleC .homeTile--follow{padding:10px;min-height:108px}
.homeStyleC .homeTile--follow .homeTile__iconWrap{width:100%;height:100%;border-radius:18px}
.homeStyleC .homeTile--follow .homeTile__icon{width:100%;height:100%;border-radius:18px;background:transparent !important}
.homeStyleC .homeTile--follow .homeTile__iconWrap--followBg{background-color:#fff !important}
.homeStyleC .homeTile--follow .homeTile__icon--followGhost{background:transparent !important}
.homeStyleC .homeTile--follow .homeTile__icon--followBg{min-height:88px;border-radius:18px}
.homeStyleC .homeTile--follow .tile__img--follow{width:100%;height:100%;border-radius:18px}
.homeStyleC .homeTile--follow .homeTile__icon--fallback{font-size:28px}
.homeHero{margin:10px 0 14px}
.noticeBar{
  background:#fff;
  border:1px solid var(--line);
  border-radius:12px;
  padding:10px 12px;
  overflow:hidden;
}
.noticeBar__head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.noticeBar__label{font-weight:900;color:#111827;font-size:13px}
.noticeBar__toggle{border:none;background:transparent;color:#6b7280;font-size:16px;font-weight:900;line-height:1;padding:4px 6px}
.noticeBar__toggle:active{opacity:.65}
.noticeBar__marquee{margin-top:8px;position:relative;overflow:hidden}
.noticeBar__track{
  display:inline-block;
  white-space:nowrap;
  padding-left:100%;
  animation:noticeMarquee 14s linear infinite;
}
@keyframes noticeMarquee{
  0%{transform:translateX(0)}
  100%{transform:translateX(-100%)}
}
.noticeBar__text{font-weight:800;color:#374151;font-size:13px}
.noticeBar__detail{margin-top:8px}
.noticeBar__detailText{font-weight:800;color:#374151;font-size:13px;line-height:1.55;white-space:pre-wrap}
.noticeBar__imgs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:8px}
.noticeBar__img{width:100%;border-radius:12px;border:1px solid var(--line);background:#fff;object-fit:cover;aspect-ratio:16/9;display:block}

.imgPreview{padding:6px 0}
.imgPreview__img{width:100%;height:auto;max-height:62vh;object-fit:contain;display:block;border-radius:12px;border:1px solid var(--line);background:#fff}
.banner{
  margin-top:10px;
  border:1px solid var(--line);
  border-radius:12px;
  overflow:hidden;
  background:#fff;
}
.banner__scroller{
  display:flex;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.banner__scroller::-webkit-scrollbar{display:none}
.banner__item{flex:0 0 100%;scroll-snap-align:start}
.banner__img{width:100%;height:120px;object-fit:cover;display:block;background:#f3f4f6}
.banner__dots{display:flex;justify-content:center;gap:6px;padding:8px 0}
.banner__dot{width:8px;height:8px;border-radius:99px;background:#e5e7eb}
.banner__dot--on{background:#ef4444}

.authLinks{display:flex;justify-content:space-between;align-items:center;margin-top:14px}
.authLinks .linkBtn{border:none;background:transparent;color:#2563eb;font-weight:900;padding:6px 0}
.authLegal{margin-top:14px;color:#6b7280;font-size:12px;line-height:1.35}
.authLegal .linkBtn{border:none;background:transparent;color:#2563eb;font-weight:900;padding:0 2px}
.authLegal--bottom{margin:0;padding:0 8px 4px;text-align:center;font-size:11px}
.authPage{min-height:calc(100vh - 48px);display:flex;flex-direction:column;margin:-12px -12px 0;padding:14px 16px 0;background:linear-gradient(180deg,#cf1111 0 132px,#f5f6fa 132px 100%)}
.authWrap{max-width:420px;width:100%;margin:0 auto;position:relative;z-index:1}
.authLogoWrap{display:flex;justify-content:center;position:relative;z-index:2;margin:8px 0 -28px}
.authLogoBox{width:96px;height:96px;border-radius:28px;background:#fff;box-shadow:0 14px 32px rgba(207,17,17,.24);display:flex;align-items:center;justify-content:center;padding:12px}
.authLogoImg{width:100%;height:100%;display:block;object-fit:contain}
.authCard{background:#fff;border:1px solid rgba(255,255,255,.7);border-radius:24px;box-shadow:0 10px 28px rgba(15,23,42,.08);padding:46px 16px 18px}
.authCard--login{padding-top:18px}
.authLogoWrap--inline{margin:0 0 10px;position:static;z-index:0}
.authLogoWrap--inline .authLogoBox{width:84px;height:84px;border-radius:20px;background:transparent;box-shadow:none;padding:0}
.authLoginIntro{text-align:center;color:#6b7280;font-size:16px;font-weight:700;margin:0 0 14px}
.authBottom{margin-top:auto;padding:18px 0 10px}
.btn--full{width:100%}
.btn--authPrimary{background:#cf1111;border-color:#cf1111;color:#fff}
.btn--authPrimary[disabled]{opacity:.5}
.authForm .drawTitle{text-align:center;font-size:22px;font-weight:900;margin:0 0 16px}
.authForm .formRow{margin-top:12px}
.authForm .formLabel{width:56px;color:#6b7280;font-size:15px}
.authForm .input{height:42px;border-radius:12px;border-color:#e5e7eb;padding:0 12px;font-size:15px}
.authForm .btn{border-radius:999px;height:44px;font-size:16px}
.shopPickList{margin-top:10px;display:flex;flex-direction:column;gap:10px}
.shopPickItem{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px}
.shopPickItem__t{font-weight:900}
.shopPickItem__sub{margin-top:4px;color:#6b7280;font-size:12px}
.tile{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:12px;
  box-shadow:var(--shadow);
  padding:12px 8px;
  display:flex;
  flex-direction:column;
  gap:6px;
  text-align:center;
  align-items:center;
}
.tile__icon{width:42px;height:42px;display:flex;align-items:center;justify-content:center}
.tile__t{font-weight:800}
.tile__s{color:var(--muted);font-size:12px}
.tile__cta{margin-top:6px;color:var(--brand);font-size:12px}

/* Filters */
.filter{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:10px;
  box-shadow:var(--shadow);
  padding:10px;
  margin-bottom:10px;
}
.filter__row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.filter__meta{margin-top:8px;font-size:12px;color:var(--muted);display:flex;align-items:center;gap:8px}
.field{display:flex;align-items:center;gap:8px}
.field__label{font-size:12px;color:var(--muted)}
.check{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted)}

.dayHead{display:flex;align-items:center;justify-content:space-between;background:var(--card);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);padding:10px 12px;font-weight:900;color:#111827}
.dayHead__left{font-size:14px}
.dayHead__btn{border:none;background:transparent;font-size:14px;font-weight:900;color:#6b7280;padding:4px 8px;border-radius:10px}
.dayHead__btn:active{background:#f3f4f6}

.dayTabs{display:flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:2px 2px 8px 2px}
.dayTab{flex:0 0 auto;border:1px solid #c7e3c7;background:#eaf7ea;border-radius:8px;padding:8px 10px;min-width:92px;text-align:center}
.dayTab--on{border-color:#16a34a;box-shadow:0 2px 10px rgba(22,163,74,.15)}
.dayTab__date{font-weight:900;color:#166534;font-size:12px;line-height:1.1}
.dayTab__count{margin-top:3px;font-weight:900;color:#ef4444;font-size:12px;line-height:1.1}

.list{display:flex;flex-direction:column;gap:10px}

/* Match card layout */
.mcard{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:10px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.mcard__top{padding:10px;display:flex;gap:10px}
.mcard__left{width:82px;flex:0 0 82px;text-align:center}
.mnum{font-weight:800;font-size:14px}
.leagueTag{display:inline-block;margin-top:6px;padding:2px 8px;font-size:12px;color:var(--league-fg,#fff);background:var(--league-bg,#111827);border-radius:4px}
.mtime{margin-top:6px;color:var(--muted);font-size:12px}
.anBtn{margin-top:8px;width:100%;padding:7px 0;font-size:12px;border-radius:999px;border:1px solid #93c5fd;color:#1d4ed8;background:#eff6ff}

.mcard__main{flex:1 1 auto;min-width:0}
.teamsLine{display:flex;align-items:center;justify-content:center;gap:10px}
.teamName{font-weight:800;font-size:16px;max-width:44%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vs{color:var(--muted);font-weight:800}
.liveMidScore{color:var(--danger);font-weight:900}
.subLine{margin-top:4px;text-align:center;color:var(--muted);font-size:12px}
.qLine{margin-top:4px;text-align:center;color:var(--muted);font-size:12px}

.oddsBox{margin-top:10px;border:1px solid var(--line)}
.oddsBox--withMore{display:grid;grid-template-columns:minmax(0,1fr) 62px;border:1px solid var(--line);overflow:hidden}
.oddsRows{display:block;min-width:0}
.oddsBox--withMore .oddsRow:not(.oddsRow--2){grid-template-columns:44px minmax(0,1fr) minmax(0,1fr) minmax(0,1fr)}
.oddsRow{position:relative;display:grid;grid-template-columns:44px minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) 62px;align-items:stretch}
.oddsRow--2{grid-template-columns:44px minmax(0,1fr) minmax(0,1fr) 62px}
.oddsRow--noMore{grid-template-columns:44px 1fr 1fr 1fr}
.oddsRow--2.oddsRow--noMore{grid-template-columns:44px 1fr 1fr}
.oddsRow + .oddsRow{border-top:1px solid var(--line)}
.rqCol{display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;background:#16a34a}
.rqCol--spf{background:#9ca3af}
.rqCol--neg{background:#ef4444}
.rqCol--pos{background:#16a34a}
.rqCol--zero{background:#9ca3af}
.rqCol--total{background:#ef4444}

.cellWrap{position:relative;border-right:1px solid var(--line);min-width:0}
.oddsRow .cellWrap:last-of-type{border-right:none}
.cell{background:#fff;padding:10px 6px;display:flex;align-items:center;justify-content:space-between;gap:6px;overflow:hidden}
.cellBtn{width:100%;min-width:0;border:none;background:transparent;padding:0;display:flex;align-items:center;justify-content:space-between;gap:6px;font-size:14px}
.cellK{min-width:0;font-weight:800;color:#374151;white-space:nowrap}
.cellV{min-width:0;font-weight:800;color:#111827;position:relative;padding-right:12px;text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
.cell--on .cellBtn{color:#fff}
.cell--on{
  background:var(--danger);
}
.cell--on .cellK,.cell--on .cellV{color:#fff}
.cell--on .trend{color:#fff}
.cell--single{outline:1px solid var(--danger);outline-offset:-1px}
.cell--disabled{background:#f9fafb}
.cell--disabled .cellK,.cell--disabled .cellV{color:#9ca3af}

.zcOddsRow{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr);align-items:stretch}
.zcOddsRow .cellWrap:last-of-type{border-right:none}

.moreCol{display:flex;align-items:stretch;justify-content:stretch;border-left:1px solid var(--line);background:#fff;color:#374151;font-size:13px;min-width:62px}
.moreCol--span{grid-column:2;grid-row:1 / span 2;border-left:1px solid var(--line)}
.moreBtn{border:none;background:transparent;color:#374151;padding:8px 4px;white-space:normal;line-height:1.15;text-align:center;display:flex;flex:1 1 auto;flex-direction:column;align-items:center;justify-content:center;min-height:44px}
.moreBtn__t{font-weight:900;font-size:12px;color:#374151}
.moreBtn__sub{margin-top:4px;color:#9ca3af;font-size:11px;font-weight:800}

@media (max-width: 420px){
  .oddsBox--withMore{grid-template-columns:minmax(0,1fr) 50px}
  .moreCol{min-width:50px}
  .moreBtn{padding:6px 2px}
  .moreBtn__t{font-size:11px}
  .moreBtn__sub{font-size:10px}

  .mcard__left{width:76px;flex:0 0 76px}
  .oddsBox--withMore .oddsRow:not(.oddsRow--2){grid-template-columns:40px minmax(0,1fr) minmax(0,1fr) minmax(0,1fr)}
  .oddsRow{grid-template-columns:40px minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) 50px}
  .oddsRow--2{grid-template-columns:40px minmax(0,1fr) minmax(0,1fr) 50px}

  .cell{padding:8px 4px}
  .cellBtn{gap:4px;font-size:clamp(12px,3.2vw,13px)}
  .cellV{padding-right:11px}
  .oddsRow:not(.oddsRow--noMore) .singleBadge{right:56px}
}

.singleBadge{position:absolute;top:2px;right:6px;left:auto;font-size:10px;background:#ef4444;color:#fff;padding:0 4px;border-radius:3px;z-index:5}
.oddsRow:not(.oddsRow--noMore) .singleBadge{right:68px}
.trend{margin-left:2px;font-weight:900;opacity:.5}
.cellV .trend,.gv .trend{position:absolute;right:0;top:50%;transform:translateY(-50%);margin-left:0}
.trend--up{color:#ef4444}
.trend--down{color:#16a34a}

/* JCZQ list: hide trend in SPF / RSPF to avoid overlap on small screens */
.oddsRow--pool-had .trend,
.oddsRow--pool-hhad .trend{display:none}
.oddsRow--pool-had .cellV,
.oddsRow--pool-hhad .cellV{padding-right:0}

/* Slip footer */
.slip{position:fixed;left:0;right:0;bottom:56px;z-index:30;padding:10px 10px calc(10px + env(safe-area-inset-bottom));background:rgba(255,255,255,.96);border-top:1px solid var(--line);backdrop-filter: blur(10px)}
.slipbar{display:flex;align-items:center;gap:10px}
.slipbar__left{flex:0 0 auto}
.slipbar__mid{flex:1 1 auto;text-align:center;font-weight:800}
.slipbar__mid span{font-weight:900;color:#cf1111}
.slipbar__right{flex:0 0 auto}

/* Modal */
.hidden{display:none !important}
.modal.hidden{display:none}
.modal{
  position:fixed;
  left:0;right:0;top:0;
  height:100vh;
  height:100dvh;
  z-index:50
}
.modal__mask{position:fixed;inset:0;background:rgba(0,0,0,.45)}
.modal--nomaskclose .modal__mask{pointer-events:none}
.modal__sheet{
  position:fixed;
  left:0;right:0;bottom:0;
  background:#fff;
  border-top-left-radius:14px;border-top-right-radius:14px;
  border:1px solid var(--line);
  max-height:86vh;
  max-height:86dvh;
  display:flex;flex-direction:column
}
.modal__head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;border-bottom:1px solid var(--line)}
.modal__title{font-weight:800}
.modal__body{padding:10px;overflow:auto}
.modal__foot{padding:10px 10px calc(10px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--line)}
.modal__foot .btn{width:100%;padding:12px 10px;border-radius:14px;font-weight:900}
.modalBtnRow{display:flex;gap:10px}
.modalBtnRow .btn{flex:1 1 0}
.modalBtn--danger{border:none;background:var(--brand);color:#fff}
.modalBtn--ghost{background:#fff;color:var(--text);border:1px solid var(--line)}
.modalInput{width:100%;border:1px solid var(--line);border-radius:12px;padding:12px 12px;font-size:14px;outline:none}

.paySheetRow{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 0;border-bottom:1px solid var(--line)}
.paySheetKey{color:var(--muted);white-space:nowrap}
.paySheetVal{font-weight:800}
.paySheetVal--danger{color:var(--danger);font-weight:900}
.btn--disabledLike{background:#d1d5db !important;color:#6b7280 !important}

.nextFoot{display:flex;flex-direction:column;gap:10px}
.nextFoot__bar{display:grid;grid-template-columns:auto 56px 1fr auto;gap:10px;align-items:center}
.passBtn{border:1px solid var(--line);background:#fff;border-radius:10px;padding:10px 10px;font-weight:900}
.timesInput{border:1px solid var(--line);border-radius:10px;padding:10px 8px;font-weight:900;text-align:center}
.nextFoot__bonus{font-weight:900;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nextFoot__meta{font-weight:900;color:#cf1111;white-space:nowrap}
.nextFoot__actions{display:flex;gap:10px}
.btnOpt{flex:1 1 0;border:1px solid var(--danger);background:#fff;color:var(--danger);border-radius:12px;padding:12px 10px;font-weight:900}
.btnSubmit{flex:1 1 0;border:none;background:var(--danger);color:#fff;border-radius:12px;padding:12px 10px;font-weight:900}

.passPicker{position:fixed;inset:0;z-index:80}
.passPicker__mask{position:absolute;inset:0;background:rgba(0,0,0,.45)}
.passPicker__sheet{position:absolute;left:0;right:0;bottom:calc(var(--nextfoot-h,0px) + env(safe-area-inset-bottom,0px));background:#fff;border-top-left-radius:14px;border-top-right-radius:14px;border:1px solid var(--line);max-height:70vh;display:flex;flex-direction:column}
.passPicker__head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;border-bottom:1px solid var(--line)}
.passPicker__title{font-weight:900}
.passPicker__body{padding:10px;overflow:auto}

.meGrid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:12px}
.meTile{display:block;text-decoration:none;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px}
.meTile__t{font-weight:900;color:#111827}
.meTile__sub{margin-top:6px;color:var(--muted);font-size:12px}

.meHead{
  margin-top:10px;
  border-radius:16px;
  padding:16px;
  color:#fff;
  background:linear-gradient(135deg,#cf1111,#ef4444);
}
.meHead__inner{display:flex;align-items:center;gap:12px}
.meHead__av{
  width:56px;height:56px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.22);
  color:#fff;
  flex:0 0 auto;
}
.meHead__avImg{width:100%;height:100%;object-fit:cover;border-radius:999px;display:block}
.meHead__main{min-width:0}
.meHead__go{
  margin-left:auto;
  border:none;
  background:rgba(255,255,255,.18);
  color:#fff;
  width:34px;height:34px;
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  flex:0 0 auto;
}
.meHead__go:active{opacity:.7}
.meHead__name{font-weight:900;font-size:16px}
.meHead__meta{margin-top:6px;font-size:12px;opacity:.92;line-height:1.4}
.meHead__line{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:44vw}

.profileAvRow{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:10px}
.profileAv{width:72px;height:72px;border-radius:999px;background:#f3f4f6;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:#9ca3af;flex:0 0 auto;overflow:hidden}
.profileAv__img{width:100%;height:100%;object-fit:cover;display:block}
.profileAvRow__actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}

.mePrimaryRow{
  margin-top:12px;
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
}
.mePrimaryTile{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  color:inherit;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  padding:14px 12px;
  box-shadow:0 8px 22px rgba(0,0,0,.04);
}
.mePrimaryTile__ic{
  width:52px;height:52px;border-radius:18px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;
  flex:0 0 auto;
}
.mePrimaryTile__t{font-weight:900;color:#111827}
.mePrimaryTile__sub{margin-top:4px;color:var(--muted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:20ch}
.mePrimaryTile__txt{min-width:0}
.mePrimaryTile[data-k="orders"] .mePrimaryTile__ic{background:linear-gradient(135deg,#2563eb,#60a5fa)}
.mePrimaryTile[data-k="ledger"] .mePrimaryTile__ic{background:linear-gradient(135deg,#cf1111,#f97316)}

.mePanel{
  margin-top:12px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  padding:10px 10px 12px;
}
.mePanel__title{font-weight:900;color:#111827;margin:2px 6px 10px}
.mePanelGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.meMenu{
  margin-top:12px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  padding:12px 10px;
}
.meMenuGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.meMenuItem{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-decoration:none;
  color:inherit;
  padding:10px 6px;
  border-radius:14px;
  user-select:none;
}
.meMenuItem:active{background:#f9fafb}
.meMenuItem__ic{
  width:44px;height:44px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;
  color:#cf1111;
  background:#fff0f0;
}
.meMenuItem[data-k="orders"] .meMenuItem__ic{background:#eff6ff;color:#2563eb}
.meMenuItem[data-k="sec"] .meMenuItem__ic{background:#ecfdf5;color:#059669}
.meMenuItem[data-k="contact"] .meMenuItem__ic{background:#fefce8;color:#ca8a04}
.meMenuItem[data-k="share"] .meMenuItem__ic{background:#f5f3ff;color:#7c3aed}
.meMenuItem[data-k="more"] .meMenuItem__ic{background:#f3f4f6;color:#111827}
.meMenuItem[data-k="rp"] .meMenuItem__ic{background:#fff0f0;color:#cf1111}
.meMenuItem[data-k="messages"] .meMenuItem__ic{background:#ecfeff;color:#0891b2}
.meMenuItem[data-k="feedback"] .meMenuItem__ic{background:#fdf2f8;color:#db2777}
.meMenuItem[data-k="join"] .meMenuItem__ic{background:#f0fdf4;color:#16a34a}
.meMenuItem__t{margin-top:6px;font-size:12px;font-weight:900;color:#111827}

.profileList{
  margin-top:12px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
}
.profileRow{
  width:100%;
  border:none;
  background:transparent;
  padding:14px 12px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  text-align:left;
}
.profileRow + .profileRow{border-top:1px solid var(--line)}
.profileRow__l{font-weight:900;color:#111827}
.profileRow__r{display:flex;align-items:center;gap:10px;min-width:0}
.profileRow__rt{color:var(--muted);font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60vw}
.profileRow__arr{color:#c7c7c7;flex:0 0 auto}
.profileRow:active{background:#f9fafb}
.profileAvatar{width:44px;height:44px;border-radius:999px;background:#f3f4f6;color:#9ca3af;display:flex;align-items:center;justify-content:center;overflow:hidden;flex:0 0 auto}
.profileAvatar__img{width:100%;height:100%;object-fit:cover;display:block}

.fc3dPickText{white-space:normal;word-break:break-word;line-height:1.6;font-weight:800;color:#111827}
.fc3dHit{color:#ef4444;font-weight:900}

/* Digital order detail text rendering (PL5/QXC highlight) */
.digitalPickText{white-space:normal;word-break:break-word;line-height:1.6}
.digitalHit{color:#ef4444;font-weight:900}

/* Feedback submit */
.fbImgGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:10px 0}
.fbImgItem{position:relative;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}
.fbImgItem img{display:block;width:100%;aspect-ratio:1/1;object-fit:cover}
.fbImgDel{position:absolute;top:6px;right:6px;width:28px;height:28px;border-radius:999px;border:0;background:rgba(0,0,0,.55);color:#fff;font-weight:900;line-height:28px;text-align:center}

.msgList{display:flex;flex-direction:column;gap:10px}
.msgItem{
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px;
}
.msgItem--link{cursor:pointer}
.msgItem--link:active{background:#f9fafb}
.msgItem__t{font-weight:900;color:#111827}
.msgItem__b{margin-top:6px;color:var(--muted);font-size:12px;line-height:1.4}
.msgItem__time{margin-top:8px;color:var(--muted);font-size:12px}

.btn--dangerSolid{background:#cf1111;border-color:#cf1111;color:#fff}
.btn--dangerOutline{background:#fff;border:1px solid #cf1111;color:#cf1111}
.btn--full{width:100%}

.meMoreActions{
  position:fixed;
  left:12px;
  right:12px;
  bottom:calc(68px + env(safe-area-inset-bottom));
  display:flex;
  flex-direction:column;
  gap:12px;
  z-index:50;
}
.meMoreSpacer{height:170px}

/* Share overlay */
.shareOverlay{position:fixed;inset:0;z-index:45}
.shareOverlay__mask{position:absolute;inset:0;background:rgba(0,0,0,.55)}
.shareOverlay__wrap{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:16px 16px 170px}
.sharePoster{
  width:min(360px, 92vw);
  border-radius:20px;
  padding:22px 18px 16px;
  background:linear-gradient(180deg,#c81d1d 0%,#b01212 100%);
  color:#fff;
  box-shadow:0 18px 44px rgba(0,0,0,.35);
  text-align:center;
}
.sharePoster__title{font-size:30px;font-weight:900;letter-spacing:.5px}
.sharePoster__slogan{margin-top:8px;font-size:18px;font-weight:900;opacity:.95}
.sharePoster__code{margin-top:10px;font-size:14px;opacity:.95}
.shareQrBox{margin:16px auto 10px;background:#fff;border-radius:18px;padding:14px;display:inline-block}
.shareQr{width:220px;height:220px;object-fit:contain;display:block}
.shareQr--bad{opacity:.55;filter:grayscale(1)}
.shareHint{margin-top:8px;font-size:12px;opacity:.9}
.shareLinkInput{
  margin-top:10px;
  width:100%;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.35);
  background:rgba(0,0,0,.12);
  color:#fff;
  padding:10px 10px;
  font-size:12px;
  outline:none;
}
.shareActions{
  position:absolute;
  left:0;right:0;bottom:0;
  background:#fff;
  border-top-left-radius:16px;border-top-right-radius:16px;
  padding:12px 14px calc(14px + env(safe-area-inset-bottom));
  box-shadow:0 -10px 30px rgba(0,0,0,.18);
}
.shareActions__title{font-weight:900;text-align:center;color:#111827;padding:6px 0 10px}
.shareActions__row{display:flex;justify-content:center;gap:28px;padding:6px 0 12px}
.shareActBtn{border:none;background:transparent;display:flex;flex-direction:column;align-items:center;gap:8px;min-width:84px}
.shareActBtn__ic{
  width:46px;height:46px;border-radius:14px;
  background:#f3f4f6;color:#111827;
  display:flex;align-items:center;justify-content:center;
}
.shareActBtn__t{font-size:12px;font-weight:900;color:#111827}
.shareCancelBtn{
  width:100%;
  border:none;
  background:#fff;
  border-top:1px solid var(--line);
  padding:14px 10px;
  font-size:16px;
  font-weight:900;
  color:#6b7280;
  border-radius:0 0 16px 16px;
}
.shareToast{
  position:absolute;
  left:50%;
  bottom:calc(152px + env(safe-area-inset-bottom));
  transform:translateX(-50%);
  background:rgba(17,24,39,.92);
  color:#fff;
  padding:10px 12px;
  border-radius:12px;
  font-size:13px;
  font-weight:900;
  max-width:86vw;
  opacity:0;
  pointer-events:none;
  transition:opacity .18s ease;
}
.shareToast--on{opacity:1}

.walletCard{
  margin-top:10px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  padding:14px;
}
.walletTop{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.walletLabel{font-size:12px;font-weight:800;color:var(--muted)}
.walletBalance{margin-top:6px;font-size:34px;font-weight:900;color:#cf1111;font-variant-numeric:tabular-nums;line-height:1}
.walletSplit{margin-top:10px;display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}
.walletTop__right{display:flex;flex-direction:column;gap:10px;min-width:90px}
.walletTop__right .btn{border-radius:14px;padding:10px 12px;font-weight:900}

.ledgerFold{
  margin-top:12px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
}
.ledgerFold__head{
  width:100%;
  border:none;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px;
  font-weight:900;
  color:#111827;
}
.ledgerFold__headR{color:var(--muted);font-weight:900}
.ledgerFold__body{padding:0 14px 14px}
.pillTabs{display:flex;gap:8px;margin:12px 0}
.pillTab{
  border:1px solid var(--line);
  background:#f9fafb;
  border-radius:999px;
  padding:6px 12px;
  font-size:13px;
  font-weight:900;
  color:#111827;
}
.pillTab--on{border-color:#cf1111;color:#cf1111;background:#fff0f0}
.ledgerItem{display:flex;justify-content:space-between;gap:12px;padding:12px 0;border-top:1px solid var(--line)}
.ledgerItem__t{font-weight:900;color:#111827}
.ledgerItem__note{margin-top:4px;color:var(--muted);font-size:12px;white-space:pre-wrap}
.ledgerItem__time{margin-top:4px;color:var(--muted);font-size:12px}
.ledgerAmt{font-weight:900;text-align:right;font-variant-numeric:tabular-nums}
.ledgerAmt--in{color:#cf1111}
.ledgerAmt--out{color:#111827}
.ledgerItem__bal{margin-top:4px;color:var(--muted);font-size:12px;text-align:right}

.payTabs{
  margin-top:10px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  padding:6px;
  display:flex;
  gap:6px;
  overflow:auto;
}
.payTab{
  border:none;
  background:transparent;
  padding:10px 10px;
  border-radius:14px;
  font-weight:900;
  color:#111827;
  white-space:nowrap;
}
.payTab--on{background:#fff0f0;color:#cf1111}

.walletAmtBox{margin-top:12px}
.walletAmtRow{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:800;color:#374151;margin-top:8px}
.amtRow{display:flex;gap:10px;align-items:center}
.amtRow .input{flex:1}

.quickMoney{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.quickMoney .btn{border-radius:14px}
.payInfoRow{display:flex;align-items:center;gap:10px;margin:8px 0}
.payInfoRow__label{color:var(--muted);font-size:13px;white-space:nowrap}
.payInfoRow__val{flex:1;text-align:right;word-break:break-all}
.payInfoRow__copy{padding:6px 10px;border-radius:12px;font-size:12px;white-space:nowrap}
.payChannelList{margin-top:10px;display:flex;flex-direction:column;gap:10px}
.payChannel{
  display:flex;gap:10px;align-items:center;
  padding:12px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;
}
.payChannel--on{border-color:#cf1111;box-shadow:0 0 0 1px rgba(207,17,17,.08) inset}
.payChannel input{transform:scale(1.05)}
.payChannel__t{font-weight:900}
.payChannel__sub{margin-top:4px;font-size:12px;color:var(--muted)}
.payQr{width:100%;max-width:320px;border-radius:12px;border:1px solid var(--line);margin-top:10px;display:block;background:#fff}
.ageAgree{display:flex;gap:10px;align-items:center;margin-top:12px;color:var(--muted);font-size:12px}
.shopTips{margin-top:12px;border-top:1px solid var(--line);padding-top:12px}
.shopTips__t{font-weight:900;color:#111827}
.shopTips__list{margin-top:8px;display:flex;flex-direction:column;gap:6px}
.shopTips__item{color:var(--muted);font-size:12px;line-height:1.5}

.orderListItem{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 12px;background:#fff;border-bottom:1px solid var(--line)}
.orderListItem__t{font-weight:900}
.orderListItem__sub{margin-top:4px;color:var(--muted);font-size:12px}
.orderListItem__picks{margin-top:4px;color:#374151;font-size:12px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.orderListItem__amt{font-weight:900;text-align:right}
.orderListItem__st{margin-top:4px;color:#cf1111;font-weight:900;text-align:right;font-size:12px}
.orderListItem__st--muted{color:#9ca3af}
.orderListItem__win{margin-top:4px;color:#f59e0b;font-weight:900;text-align:right;font-size:12px}

.orderFilters{display:flex;gap:10px;padding:10px 12px;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:3}
.orderFilters__sel{flex:1;border:1px solid var(--line);border-radius:10px;padding:10px 10px;background:#fff;font-weight:800;color:#111827}
.qrImg{display:block;margin:12px auto 0;width:240px;height:240px;border-radius:12px;border:1px solid var(--line);background:#fff}

.radioRow{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line)}
.radioRow input{transform:scale(1.1)}

.sec{margin-bottom:14px}
.sec__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.sec__title{font-weight:800}
.grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border:1px solid var(--line);background:#fff}
.grid--3{grid-template-columns:repeat(3,1fr)}
.gcell{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:10px 6px;position:relative}
.gcell:nth-child(5n){border-right:none}
.grid--3 .gcell:nth-child(3n){border-right:none}
.gbtn{width:100%;border:none;background:transparent;padding:0;display:flex;flex-direction:column;align-items:center;gap:4px}
.gk{font-weight:800;color:#374151}
.gv{font-weight:800;position:relative;padding-right:10px;display:inline-block;min-width:3.4em;text-align:right;font-variant-numeric:tabular-nums}
.gcell--on{background:var(--danger)}
.gcell--on .gk,.gcell--on .gv{color:#fff}
.gcell--on .trend{color:#fff}
.gcell--disabled{background:#f9fafb}
.gcell--disabled .gk,.gcell--disabled .gv{color:#9ca3af}
.gridWrap{position:relative}

.chips{display:flex;flex-direction:column;gap:8px;margin-top:10px}
.chip{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 34px 10px 10px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#fff;
}
.chip__t{font-weight:800;color:#374151;font-size:13px}
.chip__v{font-weight:900;color:#111827;font-size:14px}
.chip__x{
  position:absolute;
  right:8px;
  top:50%;
  transform:translateY(-50%);
  border:none;
  width:26px;
  height:26px;
  border-radius:999px;
  background:#f3f4f6;
  color:#111827;
  font-size:18px;
  line-height:26px;
}
.timeLeft{font-weight:900;color:#2563eb}

.chip--small{padding:6px 8px;border-radius:8px;padding-right:8px}
.chip--small .chip__t{font-size:12px}
.chip--small .chip__v{font-size:12px}
.chip--small .chip__x{display:none}

.orderTable{margin-top:8px;display:flex;flex-direction:column;gap:10px}
.orderRow{border:1px solid var(--line);border-radius:12px;background:#fff;padding:10px;display:flex;gap:10px;align-items:flex-start}
.orderRow__left{flex:1 1 auto;min-width:0}
.orderRow__right{flex:0 0 auto;max-width:44%}
.orderRow__m{font-weight:800}
.orderRow__t{margin-top:4px;font-weight:900}
.orderRow__sub{margin-top:4px;color:var(--muted);font-size:12px}
.orderPicks{margin-top:2px;display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}

.orderBottom{position:fixed;left:0;right:0;bottom:0;z-index:40;padding:10px 10px calc(10px + env(safe-area-inset-bottom));background:rgba(255,255,255,.96);border-top:1px solid var(--line);backdrop-filter: blur(10px);display:flex;gap:10px}
.orderBottom .btn{flex:1 1 0}
.orderBtn--danger{border:none;background:var(--danger);color:#fff}

.betTable{margin-top:10px;border:1px solid var(--line);background:#fff}
.betTr{display:grid;grid-template-columns:84px 1fr 1.2fr 78px}
.betTr + .betTr{border-top:1px solid var(--line)}
.betTr--head{background:#f9fafb}
.betTd{padding:10px 8px;white-space:pre-line;font-size:13px}
.betTd + .betTd{border-left:1px solid var(--line)}
.betTd--c1{font-weight:900}
.betTd--c3{overflow-wrap:anywhere;word-break:break-word}
.betTd--c4{text-align:center}

.optBuy{display:flex;align-items:center;justify-content:center;gap:10px;margin:10px 0}
.optBuy__k{font-weight:800;color:#374151}
.optBuy__v{min-width:78px;text-align:center;font-weight:900}
.optInput{width:120px;max-width:42vw;border:1px solid var(--line);border-radius:10px;padding:8px 10px;font-weight:900;text-align:center}
.optTable{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}
.optRow{display:grid;grid-template-columns:64px 1fr 118px 88px;gap:0;align-items:center;border-top:1px solid var(--line);padding:10px}
.optRow--head{border-top:none;background:#f9fafb;font-weight:900;color:#374151}
.optC1{font-weight:900;color:#374151}
.optC2{font-size:12px;color:#4b5563;line-height:1.35}
.optC3{display:flex;align-items:center;justify-content:center;gap:6px}
.optNum{min-width:24px;text-align:center;font-weight:900}
.optNumInput{width:84px;max-width:24vw;border:1px solid var(--line);border-radius:10px;padding:6px 8px;font-weight:900;text-align:center}
.optC4{text-align:right;font-weight:900;color:#ef4444}
.optSum{margin-top:10px;text-align:center;color:#374151;font-weight:800}
.optFoot{margin-top:10px;display:flex;gap:10px;justify-content:space-between}

/* Digital lottery */
.drawCard{background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:12px;margin-bottom:10px}
.drawTitle{font-weight:900}
.drawTitleRow{display:flex;align-items:center;justify-content:space-between;gap:12px}
.drawTitleRow .btn{padding:6px 10px}
.drawSub{margin-top:6px;color:var(--muted);font-size:12px}
.drawSub--strong{color:var(--text);font-weight:900;font-size:13px}
.balls{margin-top:10px;display:flex;flex-wrap:wrap;gap:6px}
.ball{width:28px;height:28px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:13px;background:#fee2e2;color:#991b1b;border:1px solid #fecaca}
.ball--blue{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}
.ball--hit{background:#ef4444;color:#fff;border-color:#ef4444}
.ball--hit.ball--blue{background:#2563eb;color:#fff;border-color:#2563eb}
.pickPanel{background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:12px}
.pickHead{display:flex;align-items:center;justify-content:space-between}
.pickTitle{font-weight:900}
.pickActions{display:flex;gap:8px}
.numGrid{margin-top:10px;display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.numBtn{border:1px solid var(--line);background:#fff;border-radius:10px;padding:8px 0;font-weight:800}
.numBtn--on{background:var(--danger);border-color:var(--danger);color:#fff}
.numBtn--blue{border-color:#93c5fd;color:#1d4ed8}
.numBtn--blueOn{background:var(--brand);border-color:var(--brand);color:#fff}
.ballCell{display:flex;flex-direction:column;align-items:center;gap:6px}
.danBox{width:18px;height:18px;border:1px solid #d1d5db;border-radius:3px;background:#fff}
.danBox--on{background:var(--danger);border-color:var(--danger)}
.danBox--disabled{opacity:.35}

/* Draw hall (数字彩开奖) */
.drawTabs{display:flex;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}
.drawTab{flex:1;padding:12px 0;border:none;background:transparent;font-size:15px;color:var(--muted)}
.drawTab--on{color:var(--danger);font-weight:900;border-bottom:2px solid var(--danger)}
.drawList{padding:10px}
.drawRow{background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:12px;margin-bottom:10px}
.drawRow__head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.drawRow__title{font-size:16px;font-weight:900}
.drawRow__meta{margin-top:4px;color:var(--muted);font-size:12px}
.historyBtn{border:1px solid var(--line);background:#f9fafb;color:#111;padding:6px 10px;border-radius:999px;font-size:12px;white-space:nowrap}
.drawHist{padding:10px}
.drawHistRow{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--card);border:1px solid rgba(214,21,24,.22);border-radius:12px;padding:10px 12px;margin-bottom:10px}
.drawHistRow__left{min-width:92px}
.drawHistRow__issue{font-weight:900;font-size:14px}
.drawHistRow__date{margin-top:4px;color:var(--muted);font-size:12px}

.detailStats{margin-top:10px;display:grid;grid-template-columns:1fr 1fr;gap:6px 10px;padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:#fff}
.detailStat__k{color:var(--muted);font-size:12px;font-weight:800}
.detailStat__v{color:#ef4444;font-size:16px;font-weight:900}
.detailTable{margin-top:10px;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}
.detailRow{display:grid;grid-template-columns:110px 1fr 110px;gap:0;align-items:center;border-top:1px solid var(--line);padding:10px 12px}
.detailRow--head{border-top:none;background:#f9fafb;font-weight:900;color:#374151}
.detailC1{font-weight:900;color:#111827}
.detailC2{text-align:left;font-weight:900;color:#ef4444}
.detailC3{text-align:right;color:#111827;font-weight:800}

@media (max-width:390px){
  .oddsBox--withMore{grid-template-columns:minmax(0,1fr) 46px}
  .moreCol{min-width:46px}
  .oddsRow{grid-template-columns:40px minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) 46px}
  .oddsRow--2{grid-template-columns:40px minmax(0,1fr) minmax(0,1fr) 46px}
  .oddsRow:not(.oddsRow--noMore) .singleBadge{right:52px}
  .teamName{font-size:15px}
  .numGrid{grid-template-columns:repeat(6,1fr)}
}

/* Tab bar */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:40;height:56px;background:#fff;border-top:1px solid var(--line);display:flex;align-items:stretch;justify-content:space-around}
.tabbar__item{flex:1 1 0;display:flex;align-items:center;justify-content:center;text-decoration:none;color:#6b7280;font-weight:800}
.tabbar__item--on{color:#cf1111}



/* Account/Admin */
.seg{display:flex;gap:8px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:6px;overflow:hidden}
.seg__btn{flex:1 1 0;border:none;background:transparent;padding:10px 8px;border-radius:10px;font-weight:800;color:#374151}
.seg__btn--on{background:#ef4444;color:#fff}
.seg--wrap{flex-wrap:wrap;overflow:visible}
.seg--wrap .seg__btn{flex:0 0 calc(20% - 7px)}

.pickRow{margin-top:10px;border:1px solid var(--line);border-radius:10px;padding:10px;display:flex;align-items:center;justify-content:space-between;gap:10px;background:#fff}
.pickRow__t{font-weight:900;color:var(--muted)}
.form{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px}
.formRow{display:flex;gap:10px;align-items:center;margin-top:10px}
.formRow:first-child{margin-top:0}
.formLabel{width:72px;color:#6b7280;font-size:13px}
.formCtrl{flex:1 1 auto}
.help{font-size:12px;color:var(--muted);margin-top:8px;white-space:pre-wrap}
.legalText{font-size:12px;color:var(--muted);margin-top:8px;white-space:normal;line-height:1.65}
.legalP{margin:0 0 10px}
.legalP:last-child{margin-bottom:0}
.secTitle{margin-top:12px;font-weight:900;font-size:15px;color:#111}
.subTitle{margin-top:10px;font-weight:900;font-size:13px;color:#374151}
.kv{display:flex;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px dashed var(--line)}
.kv:last-child{border-bottom:none}
.kv__k{color:#6b7280;font-size:13px}
.kv__v{font-weight:800}
.table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.table th,.table td{border-bottom:1px solid var(--line);padding:10px 8px;font-size:13px;text-align:left}
.table th{background:#f9fafb;color:#374151}
.table tr:last-child td{border-bottom:none}
.table--bd-future{table-layout:fixed;width:100%}
.table--bd-future th:nth-child(1),.table--bd-future td:nth-child(1){width:18%}
.table--bd-future th:nth-child(2),.table--bd-future td:nth-child(2){width:24%;white-space:nowrap}
.table--bd-future th:nth-child(3),.table--bd-future td:nth-child(3){
  width:auto;
  white-space:normal;
  overflow:visible;
  text-overflow:clip;
  word-break:break-word;
  line-height:1.35;
}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;border:1px solid var(--line);border-radius:999px;padding:4px 10px;background:#fff;color:#374151}
.pill--ok{border-color:#86efac;background:#ecfdf5;color:#065f46}
.pill--warn{border-color:#fdba74;background:#fff7ed;color:#9a3412}
.pill--bad{border-color:#fca5a5;background:#fef2f2;color:#991b1b}

/* -------------------- Sport draw pages -------------------- */
.dayTabs{display:flex;gap:8px;overflow-x:auto;padding:10px;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:6}
.dayTabs::-webkit-scrollbar{display:none}
.dayTab{border:1px solid var(--line);background:#f9fafb;color:#111;padding:6px 12px;border-radius:999px;font-size:13px;white-space:nowrap;flex:0 0 auto}
.dayTab--on{border-color:var(--danger);color:var(--danger);font-weight:900;background:#fff0f0}

.sportDrawList{padding:10px}
.sportDrawCard{background:var(--card);border:1px solid rgba(214,21,24,.22);border-radius:12px;box-shadow:var(--shadow);margin-bottom:10px;overflow:hidden}
.sportDrawHead{display:grid;grid-template-columns:auto auto 1fr auto;gap:8px;align-items:center;padding:10px}
.sportDrawHead--sfgg{grid-template-columns:1fr auto 1fr}
.leagueTag{padding:4px 8px;border-radius:6px;color:#fff;font-weight:900;font-size:12px;min-width:48px;text-align:center}
.sportDrawNum{color:var(--muted);font-size:12px;white-space:nowrap}
.sportDrawTeams{display:flex;align-items:center;justify-content:center;gap:10px;min-width:0}
.sportDrawTeam{font-weight:900;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sportDrawVs{color:var(--muted);font-size:12px;flex:0 0 auto}
.sportDrawScore{font-weight:900;color:var(--danger);white-space:nowrap}

.poolGrid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));border-top:1px solid rgba(214,21,24,.22);background:#fff}
.poolGrid--lq{grid-template-columns:repeat(4,minmax(0,1fr))}
.poolGrid--bjdc{grid-template-columns:repeat(5,minmax(0,1fr))}
.poolCell{padding:10px 6px;border-right:1px solid rgba(214,21,24,.22);text-align:center;min-width:0}
.poolCell:last-child{border-right:none}
.poolCell__desc{font-size:12px;color:#111;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.poolCell__sp{margin-top:4px;font-size:12px;color:var(--muted);white-space:nowrap}

.sfggTeam{font-weight:900;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sfggTeam--win{color:var(--danger)}
.sfggTeam__sp{margin-top:4px;font-size:12px;font-weight:900;color:var(--danger)}
.sfggMid{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}
.sfggNo{font-size:12px;color:var(--muted);line-height:1;font-weight:900}
.sfggScore{font-weight:900;color:#111}
.sfggHandicap{font-size:12px;color:var(--muted)}
.sfggSp{display:flex;justify-content:center;gap:10px;padding:10px;border-top:1px solid rgba(214,21,24,.22);background:#fff}
.sfggSp__label{color:var(--muted);font-size:12px}
.sfggSp__val{font-weight:900;color:var(--danger)}

.ctzcHead{display:flex;justify-content:flex-end;padding:10px;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:6}
.ctzcHead .btn--ghost{color:var(--danger);border-color:rgba(215,50,45,.35)}
.ctzcPrize{padding:10px}
.ctzcPrizeRow{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;padding:8px 10px;background:var(--card);border:1px solid var(--line);border-radius:10px;margin-bottom:8px}
.ctzcPrizeRow__name{font-weight:900}
.ctzcPrizeRow__amt{color:var(--danger);font-weight:900}
.ctzcPrizeRow__cnt{color:var(--muted);font-size:12px}
.ctzcMatchList{padding:10px}
.ctzcMatchRow{display:grid;grid-template-columns:44px 1fr 70px 80px;gap:10px;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:10px;margin-bottom:10px}
.ctzcMatchNo{color:var(--muted);font-size:12px}
.ctzcMatchTeams{display:flex;align-items:center;justify-content:center;gap:8px;min-width:0}
.ctzcMatchTeam{font-weight:900;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ctzcMatchVs{color:var(--muted);font-size:12px}
.ctzcMatchScore{font-weight:900;color:var(--danger);text-align:right;white-space:nowrap}
.ctzcMatchRes{font-size:12px;color:#111;text-align:right;white-space:nowrap}
.topbar__title--drop{cursor:pointer;user-select:none}
.topbar__arrow{display:inline-block;margin-left:6px;font-size:12px;opacity:.9}
.issueDropMask{position:fixed;left:0;top:0;right:0;bottom:0;z-index:50;background:rgba(0,0,0,.35)}
.issueDropPanel{position:fixed;left:0;right:0;top:56px;background:#fff;padding:10px 12px 12px;border-bottom:1px solid var(--line)}
.issueGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.issueChip{position:relative;background:#fff;border:1px solid #d9d9d9;border-radius:8px;padding:14px 0;font-size:18px;font-weight:900;color:#111}
.issueChip--active{border-color:var(--danger);color:var(--danger);box-shadow:0 0 0 1px rgba(215,50,45,.2) inset}
.issueChip--active::after{content:"";position:absolute;right:0;bottom:0;width:0;height:0;border-left:20px solid transparent;border-top:20px solid transparent;border-right:0;border-bottom:20px solid var(--danger)}
.issueChip--active::before{content:"✓";position:absolute;right:4px;bottom:2px;color:#fff;font-size:12px;font-weight:900;z-index:1}

/* --- Analysis: BD lineup --- */
.lineup2{display:flex;gap:12px}
.lineup2__col{flex:1;background:#fff;border-radius:12px;padding:10px 12px;border:1px solid #eef2f7}
.plainList{margin:0;padding-left:18px;color:#111827}
.plainList li{line-height:1.6;font-size:13px}

.tableScroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.table--nowrap th,.table--nowrap td{white-space:nowrap}



