/* ===== 會員中心 / 登入註冊（沿用 style.css 的 :root 變數）===== */
.subbar{
  max-width:1200px;margin:0 auto;padding:14px 20px;display:flex;align-items:center;gap:14px;
}
.subbar a.back{color:var(--red);font-weight:700;}
.subbar h1{font-size:22px;color:var(--ink);}

/* ---- 會員版面 ---- */
.mwrap{max-width:1200px;margin:0 auto;padding:24px 20px 60px;display:grid;grid-template-columns:300px 1fr;gap:24px;align-items:start;}
.mside{display:flex;flex-direction:column;gap:16px;position:sticky;top:24px;}

.profile{
  background:var(--red-grad);border:1px solid var(--gold-2);border-radius:18px;
  padding:18px;color:#fff;box-shadow:var(--shadow);
}
.profile__top{display:flex;align-items:center;gap:12px;}
.profile__avatar{width:64px;height:64px;border-radius:50%;background:#fff3;border:2px solid var(--gold-1);
  display:grid;place-items:center;overflow:hidden;flex:0 0 auto;}
.profile__avatar img{width:100%;height:100%;object-fit:contain;}
.profile__meta{font-size:13px;line-height:1.7;}
.profile__meta b{font-size:15px;}
.tag{display:inline-block;background:var(--gold-grad);color:var(--red-deep);font-size:11px;font-weight:800;
  padding:2px 8px;border-radius:8px;margin-right:4px;}
.tag--vip{background:#fff2cf;}
.wallet{margin-top:16px;display:flex;align-items:center;gap:10px;background:#ffffff22;border-radius:12px;padding:10px 12px;}
.wallet__cur{font-weight:800;font-size:13px;display:flex;align-items:center;gap:6px;}
.wallet__bal{flex:1;font-size:20px;font-weight:800;}
.wallet__btn{background:var(--gold-grad);color:var(--red-deep);border:none;border-radius:20px;
  padding:7px 16px;font-weight:800;cursor:pointer;white-space:nowrap;}

.quick{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;background:var(--card);
  border:1px solid #f0dcbf;border-radius:16px;padding:14px 8px;box-shadow:var(--shadow);}
.quick a{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 2px;border-radius:10px;
  color:var(--ink);font-size:13px;position:relative;transition:.15s;}
.quick a:hover{background:#fbeede;color:var(--red);}
.quick a.is-active{color:var(--red);font-weight:700;}
.quick a span{font-size:22px;}
.quick .badge{position:absolute;top:4px;right:14px;background:var(--red);color:#fff;font-size:10px;
  border-radius:10px;padding:0 5px;font-weight:700;}

.mlist{background:var(--card);border:1px solid #f0dcbf;border-radius:16px;overflow:hidden;box-shadow:var(--shadow);}
.mlist a{display:flex;align-items:center;gap:12px;padding:15px 16px;color:var(--ink);font-weight:600;font-size:15px;}
.mlist a + a{border-top:1px solid #f2e4cf;}
.mlist a:hover{background:#fbeede;color:var(--red);}
.mlist a span{font-size:20px;}
.mlist a .arrow{margin-left:auto;color:var(--muted);}

/* ---- 內容面板 ---- */
.mpanel{display:none;background:var(--card);border:1px solid #f0dcbf;border-radius:18px;
  padding:28px 30px;box-shadow:var(--shadow);min-height:520px;}
.mpanel.is-active{display:block;}
.mpanel__title{font-size:24px;font-weight:800;color:var(--ink);padding-bottom:16px;border-bottom:1px solid #f0dcbf;margin-bottom:20px;}
.mpanel__sub{color:var(--muted);font-weight:700;margin:24px 0 10px;}

.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 40px;}
@media(max-width:760px){.info-grid{grid-template-columns:1fr;}}
.info-row{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 4px;border-bottom:1px solid #f3ece0;font-size:15px;}
.info-row .k{color:var(--ink);font-weight:600;}
.info-row .v{color:var(--muted);display:flex;align-items:center;gap:6px;}
.info-row .v.link{color:var(--red);cursor:pointer;}
.info-row .v .arrow{color:#c9b89c;}

/* ---- 表單 ---- */
.field{margin-bottom:18px;}
.field label{display:block;font-size:14px;font-weight:600;margin-bottom:7px;color:var(--ink);}
.field input,.field select{width:100%;padding:13px 14px;border:1.5px solid #e6d6bd;border-radius:12px;
  font-size:15px;background:#fffdf9;outline:none;transition:.15s;color-scheme:light;}
.field input:focus,.field select:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(200,16,46,.12);}
/* 下拉：紅金自訂箭頭，取代原生箭頭；彈窗淺色(color-scheme) */
.field select{appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:40px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='13' height='8'><path d='M1 1.5L6.5 6.5L12 1.5' fill='none' stroke='%23b0894e' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;background-position:right 15px center;}
.field .hint{font-size:12px;color:var(--muted);margin-top:6px;}
/* 顯示密碼切換 */
.pwd-wrap{position:relative;}
.pwd-wrap input{padding-right:46px;}
.pwd-eye{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:34px;height:34px;
  display:grid;place-items:center;background:none;border:none;cursor:pointer;color:var(--muted);
  opacity:.65;transition:.15s;border-radius:8px;padding:0;}
.pwd-eye:hover{opacity:1;background:rgba(200,16,46,.06);}
.pwd-eye.on{opacity:1;color:var(--red);}
.pwd-hint{font-size:12px;color:#c8102e;margin-top:6px;line-height:1.5;font-weight:600;}
.btn-primary{width:100%;background:var(--red-grad);color:#fff;border:none;border-radius:12px;
  padding:14px;font-size:16px;font-weight:800;cursor:pointer;box-shadow:0 6px 16px rgba(200,16,46,.3);transition:.15s;}
.btn-primary:hover{filter:brightness(1.05);transform:translateY(-1px);}
.btn-gold{background:var(--gold-grad);color:var(--red-deep);}

/* ---- 登入 / 註冊卡 ---- */
/* 登入/註冊頁背景圖 */
.auth-page{min-height:100vh;background:url(../assets/promo/auth-bg.jpg) center center/cover no-repeat fixed;}
.auth{max-width:440px;margin:40px auto;background:rgba(255,251,244,.94);backdrop-filter:blur(4px);
  border:1px solid #f0dcbf;border-radius:20px;
  padding:34px 30px;box-shadow:0 18px 40px rgba(80,20,10,.35);}
.auth__logo{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:22px;}
.auth__logo img{width:64px;height:64px;}
.auth__logo b{font-size:22px;color:var(--red);}
.auth__tabs{display:flex;background:#f3e3c8;border-radius:30px;padding:5px;margin-bottom:24px;}
.auth__tabs a{flex:1;text-align:center;padding:10px;border-radius:30px;font-weight:700;color:var(--muted);}
.auth__tabs a.is-active{background:var(--red);color:#fff;}
.auth__alt{text-align:center;margin-top:18px;font-size:14px;color:var(--muted);}
.auth__alt a{color:var(--red);font-weight:700;}

/* ---- USDT 儲值 ---- */
.usdt-net{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap;}
.usdt-net button{flex:1;min-width:120px;padding:12px;border:1.5px solid #e6d6bd;background:#fffdf9;border-radius:12px;
  font-weight:700;cursor:pointer;transition:.15s;}
.usdt-net button.is-active{border-color:var(--red);background:#fbeede;color:var(--red);}
.usdt-addr{display:flex;align-items:center;gap:10px;background:#f7f0e5;border:1px dashed var(--gold-2);
  border-radius:12px;padding:14px;margin:10px 0 6px;word-break:break-all;font-family:monospace;font-size:14px;}
.usdt-addr button{margin-left:auto;background:var(--red);color:#fff;border:none;border-radius:8px;padding:8px 14px;cursor:pointer;white-space:nowrap;}
.usdt-qr{width:160px;height:160px;margin:14px auto;border-radius:12px;border:5px solid #fff;box-shadow:var(--shadow);
  background:repeating-linear-gradient(0deg,#222 0 8px,#fff 8px 16px),repeating-linear-gradient(90deg,#222 0 8px,#fff 8px 16px);
  background-blend-mode:difference;}

/* ---- 空狀態 / 列表 ---- */
.empty{text-align:center;color:var(--muted);padding:80px 20px;}
.empty .ico{font-size:54px;opacity:.5;}
.msg-item{display:flex;gap:14px;padding:16px 4px;border-bottom:1px solid #f3ece0;}
.msg-item .dot{width:9px;height:9px;border-radius:50%;background:var(--red);margin-top:6px;flex:0 0 auto;}
.msg-item h4{font-size:15px;margin-bottom:4px;}
.msg-item p{color:var(--muted);font-size:13px;}
.msg-item time{color:#c9b89c;font-size:12px;}

/* ---- 關於 / 幫助 ---- */
.doc-list a{display:flex;align-items:center;justify-content:space-between;padding:18px 4px;
  border-bottom:1px solid #f3ece0;color:var(--ink);font-weight:600;font-size:16px;cursor:pointer;}
.doc-list a:hover{color:var(--red);}
.faq__q{padding:18px 4px;border-bottom:1px solid #f3ece0;cursor:pointer;font-weight:700;display:flex;justify-content:space-between;align-items:center;}
.faq__a{display:none;padding:0 4px 18px;color:var(--muted);line-height:1.9;border-bottom:1px solid #f3ece0;}
.faq.open .faq__a{display:block;}
.faq.open .faq__q{color:var(--red);}

/* ===== VIP 元件（原創）===== */
.vip-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;}
.vip-cards{display:flex;gap:16px;overflow-x:auto;padding:6px 2px 18px;scroll-snap-type:x mandatory;scrollbar-width:none;scroll-behavior:smooth;}
/* VIP 卡片輪播容器 + 左右箭頭 */
.vip-carousel{position:relative;}
.vip-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:36px;height:36px;border-radius:50%;
  border:1px solid var(--gold-2);background:rgba(120,12,22,.78);color:var(--gold-1);font-size:22px;line-height:1;
  display:grid;place-items:center;cursor:pointer;box-shadow:0 4px 12px rgba(0,0,0,.3);transition:opacity .2s,transform .1s;}
.vip-nav:active{transform:translateY(-50%) scale(.92);}
.vip-nav--prev{left:-2px;}
.vip-nav--next{right:-2px;}
.vip-nav.is-off{opacity:0;pointer-events:none;}
.vip-cards::-webkit-scrollbar{display:none;}
.vip-card{flex:0 0 230px;scroll-snap-align:center;border-radius:18px;padding:20px;color:#fff;
  background:linear-gradient(160deg,#5b1f22,#8e0b20);border:1px solid var(--gold-2);position:relative;box-shadow:0 8px 20px rgba(120,40,20,.3);}
.vip-card.cur{background:linear-gradient(160deg,#c8102e,#7f0a1d);outline:2px solid var(--gold-1);}
.vip-card__dec{position:absolute;top:0;right:0;background:var(--gold-grad);color:var(--red-deep);
  font-size:11px;font-weight:800;padding:4px 12px;border-bottom-left-radius:12px;}
.vip-card__badge{width:68px;height:68px;margin:6px auto 8px;
  display:grid;place-items:center;font-size:26px;}
.vip-card__badge img{width:100%;height:100%;object-fit:contain;
  filter:drop-shadow(0 3px 6px rgba(0,0,0,.35));}
.vip-card__lv{text-align:center;font-size:26px;font-weight:900;color:var(--gold-1);margin-bottom:14px;}
.vip-card__bar{height:8px;border-radius:6px;background:#ffffff2e;overflow:hidden;margin-bottom:7px;}
.vip-card__bar i{display:block;height:100%;background:var(--gold-grad);}
.vip-card__txt{font-size:12px;text-align:center;color:#ffe8b0;}
.vip-keep{text-align:center;color:var(--muted);font-size:13px;margin:6px 0 22px;}

.vip-bene{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;margin-top:8px;}
.bene{background:#fffaf2;border:1px solid #f0dcbf;border-radius:14px;padding:18px 10px;text-align:center;}
.bene .ico{font-size:26px;}
.bene .num{font-size:22px;font-weight:800;color:var(--red);margin-top:6px;}
.bene .t{font-size:13px;color:var(--muted);margin-top:2px;}

/* ===== RWD ===== */
@media(max-width:900px){
  .mwrap{grid-template-columns:1fr;}
  .mside{position:static;}
}

/* ===== 我的：分組宮格版型 ===== */
.mcol{max-width:560px;margin:0 auto;padding:18px 14px 70px;display:flex;flex-direction:column;gap:16px;}
.detail-bar{display:none;max-width:560px;margin:0 auto;padding:14px;align-items:center;gap:12px;}
.detail-bar.show{display:flex;}
.detail-bar button{background:none;border:none;color:var(--red);font-weight:800;font-size:16px;cursor:pointer;}
.detail-bar h2{font-size:18px;color:var(--ink);}

/* 個人卡（加強版）*/
.pcard{position:relative;overflow:hidden;
  /* 放入 assets/promo/wallet-bg.png 後自動當卡片背景；無圖則漸層 */
  background:url(../assets/promo/wallet-bg.png) right center/cover no-repeat, var(--red-grad);
  border:none;border-radius:20px;padding:18px;color:#fff;box-shadow:var(--shadow);
  text-shadow:0 1px 3px rgba(0,0,0,.55);}
/* 輕量左側遮罩：只保證左上文字可讀，盡量讓底圖呈現 */
/* 全卡暗紅面紗：把金元寶壓成低調底紋，文字到處都清楚（左側再深一點給名稱）*/
.pcard::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(100deg, rgba(40,5,11,.88) 0%, rgba(44,6,12,.66) 48%, rgba(44,6,12,.60) 100%);}
.pcard>*{position:relative;z-index:1;}
.pcard__top{display:flex;align-items:center;gap:12px;}
.pcard__av{width:60px;height:60px;border-radius:18px;border:3px solid var(--gold-1);overflow:hidden;background:#fff2;flex:0 0 auto;}
.pcard__av img{width:100%;height:100%;object-fit:contain;}
.pcard__name{font-size:17px;font-weight:900;}
.pcard__id{font-size:11px;opacity:.8;letter-spacing:1px;margin-top:2px;}
.pcard__carry{margin-left:auto;text-align:right;background:rgba(28,4,8,.42);border:1px solid #ffffff2b;
  border-radius:12px;padding:7px 11px;backdrop-filter:blur(3px);}
.pcard__carry .l{font-size:10px;opacity:.85;}
.pcard__carry .n{font-size:14px;font-weight:900;font-style:italic;color:var(--gold-1);}
.pcard__carry .bar{width:90px;height:6px;background:#ffffff33;border-radius:6px;margin-top:5px;overflow:hidden;}
.pcard__carry .bar i{display:block;height:100%;width:35%;background:var(--gold-grad);}
.pcard__wallets{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px;}
.wcard{background:#ffffff1f;border:1px solid #ffffff2b;border-radius:14px;padding:12px;}
.wcard .h{font-size:11px;opacity:.9;display:flex;align-items:center;gap:5px;}
.wcard .v{font-size:18px;font-weight:900;font-style:italic;margin-top:4px;}
.wcard .recover{margin-top:8px;width:100%;background:var(--gold-grad);color:var(--red-deep);border:none;border-radius:10px;padding:8px;font-weight:800;font-size:12px;cursor:pointer;}

/* 分組宮格 */
.mgroup{background:var(--card);border:1px solid #f0dcbf;border-radius:16px;padding:14px 12px 16px;box-shadow:var(--shadow);}
.mgroup__t{font-weight:800;color:var(--ink);font-size:14px;margin-bottom:12px;}
.mgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px 4px;}
.mgrid button{display:flex;flex-direction:column;align-items:center;gap:7px;background:none;border:none;cursor:pointer;color:var(--ink);font-size:11px;line-height:1.2;text-align:center;}
.mgrid .ic{width:56px;height:56px;display:grid;place-items:center;font-size:27px;transition:.15s;}
.mgrid .ic img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 3px 7px rgba(120,40,20,.28));}
.mgrid button:active .ic{transform:scale(.9);}
.logout{width:100%;color:var(--red);background:#fff1f0;border:1px solid #f3d2d2;border-radius:16px;
  padding:16px;font-weight:800;letter-spacing:3px;cursor:pointer;font-size:13px;}

/* ===== VIP 系統 ===== */
.vipsys{display:flex;flex-direction:column;gap:18px;}
.vip-prog{background:#fffaf2;border:1px solid #f0dcbf;border-radius:14px;padding:16px;}
.vip-prog__h{display:flex;justify-content:space-between;align-items:center;font-weight:800;color:var(--ink);margin-bottom:12px;}
.vip-prog__h .cur{background:var(--gold-grad);color:var(--red-deep);padding:3px 12px;border-radius:20px;font-size:13px;}
.vip-prog__row{margin-bottom:12px;}
.vip-prog__row .l{display:flex;justify-content:space-between;font-size:13px;color:var(--muted);margin-bottom:5px;}
.vip-prog__row .l b{color:var(--red);}
.vbar{height:9px;background:#f0dcbf;border-radius:6px;overflow:hidden;}
.vbar i{display:block;height:100%;background:var(--red-grad);border-radius:6px;transition:width 1s ease;}

.salary{background:#fffaf2;border:1px solid #f0dcbf;border-radius:14px;padding:16px;}
.salary__tabs{display:flex;background:#f3e3c8;border-radius:30px;padding:4px;margin-bottom:14px;}
.salary__tabs button{flex:1;border:none;background:none;padding:9px;border-radius:30px;font-weight:700;color:var(--muted);cursor:pointer;}
.salary__tabs button.is-active{background:var(--red);color:#fff;}
.salary__body{display:flex;align-items:center;gap:14px;}
.salary__amt{font-size:30px;font-weight:900;font-style:italic;color:var(--red);}
.salary__amt small{font-size:14px;color:var(--muted);font-style:normal;font-weight:600;}
.salary__claim{margin-left:auto;background:var(--gold-grad);color:var(--red-deep);border:none;border-radius:20px;padding:10px 22px;font-weight:800;cursor:pointer;}
.salary__claim:disabled{opacity:.5;cursor:not-allowed;filter:grayscale(.3);}

.giftlist{background:#fffaf2;border:1px solid #f0dcbf;border-radius:14px;padding:8px 16px;}
.giftrow{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid #f3ece0;}
.giftrow:last-child{border-bottom:none;}
.giftrow .lv{width:48px;height:48px;color:var(--red-deep);
  display:grid;place-items:center;font-weight:900;font-size:13px;flex:0 0 auto;}
.giftrow .lv img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.25));}
.giftrow .info{flex:1;min-width:0;}
.giftrow .info .t{font-weight:800;color:var(--ink);}
.giftrow .info .d{font-size:12px;color:var(--muted);margin-top:2px;}
.giftrow .info .d b{color:var(--red);}
.giftrow .amt{font-weight:900;color:var(--gold-deep);font-style:italic;font-size:16px;}
.giftrow .st{font-size:11px;font-weight:800;padding:4px 10px;border-radius:20px;flex:0 0 auto;}
.st--lock{background:#eee;color:#999;}
.st--ok{background:var(--gold-grad);color:var(--red-deep);}

.rebate-note{background:#fbeede;border-radius:12px;padding:14px 16px;color:var(--ink);font-size:13px;line-height:1.9;}
.rebate-note b{color:var(--red);}

/* 單一錢包 */
.pcard__wallet{margin-top:14px;background:rgba(28,4,8,.40);border:1px solid #ffffff2b;border-radius:14px;padding:14px;
  backdrop-filter:blur(3px);}
.pcard__wallet .h{font-size:12px;opacity:.9;}
.pcard__wallet .v{font-size:26px;font-weight:900;font-style:italic;margin-top:4px;}
.pcard__acts{display:flex;gap:8px;margin-top:12px;}
.pcard__acts button{flex:1;border:1px solid rgba(255,214,140,.55);border-radius:10px;padding:10px;font-weight:800;font-size:14px;cursor:pointer;
  background:rgba(255,255,255,.14);color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.4);transition:.15s;}
.pcard__acts button:active{transform:scale(.97);}
.pcard__acts button:first-child{background:var(--gold-grad);color:var(--red-deep);border-color:transparent;text-shadow:none;}
.pcard__acts .recover{background:var(--gold-grad);color:var(--red-deep);}

/* 選單 / 底部列 icon 圖片 */
.hmenu a img{width:22px;height:22px;object-fit:contain;}
.bnav a img{width:24px;height:24px;object-fit:contain;}
.bnav a.center img{width:30px;height:30px;}

/* VIP 卡可拖曳 + 獎勵分頁 */
.vip-cards{cursor:grab;}
.vip-cards.drag{cursor:grabbing;scroll-snap-type:none;scroll-behavior:auto;}
.vip-hint{text-align:center;color:var(--muted);font-size:12px;margin:-6px 0 4px;}
.rwd-tabs{display:flex;gap:6px;background:#f3e3c8;border-radius:30px;padding:4px;margin-bottom:12px;overflow-x:auto;scrollbar-width:none;}
.rwd-tabs::-webkit-scrollbar{display:none;}
.rwd-tabs button{flex:1;min-width:74px;border:none;background:none;padding:9px 6px;border-radius:30px;font-weight:700;color:var(--muted);cursor:pointer;white-space:nowrap;}
.rwd-tabs button.is-active{background:var(--red);color:#fff;}
.giftrow.me{background:#fff4e0;border-radius:10px;margin:0 -8px;padding-left:8px;padding-right:8px;}

/* ===== 存款 / 提款 / 記錄 ===== */
.panel-actions{display:flex;justify-content:flex-end;margin-bottom:14px;}
.ghost-link{color:var(--red);font-weight:700;font-size:14px;cursor:pointer;background:#fbeede;padding:7px 14px;border-radius:20px;}

.seg-tabs{display:flex;gap:8px;margin-bottom:16px;}
.seg-tabs button{flex:1;border:1.5px solid #e6d6bd;background:#fffdf9;border-radius:12px;padding:10px;font-weight:700;color:var(--muted);cursor:pointer;transition:.15s;}
.seg-tabs button.is-active{background:var(--red);color:#fff;border-color:var(--red);}

.pay-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;}
@media(max-width:560px){.pay-grid{grid-template-columns:repeat(3,1fr);}}
.pay-method{position:relative;border:1.5px solid #eadcc4;border-radius:14px;background:#fffdf9;padding:14px 6px 10px;text-align:center;cursor:pointer;transition:.15s;}
.pay-method:hover{border-color:var(--gold-2);}
.pay-method.is-active{border-color:var(--red);background:#fff5f3;box-shadow:0 0 0 2px rgba(200,16,46,.12);}
.pay-method .pm-ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:24px;margin:0 auto 7px;background:#f3e8d6;}
.pay-method .pm-n{font-size:13px;font-weight:700;color:var(--ink);line-height:1.2;}
.pay-method .pm-l{font-size:11px;color:var(--muted);margin-top:3px;}
.pay-method .pm-tag{position:absolute;top:0;right:0;background:var(--red);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-bottom-left-radius:10px;}

.amt-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;}
.amt-chips button{border:1.5px solid #e6d6bd;background:#fffdf9;border-radius:20px;padding:7px 16px;font-weight:700;cursor:pointer;color:var(--ink);}
.amt-chips button.is-active{background:var(--red);color:#fff;border-color:var(--red);}

.wbal{background:var(--red-grad);color:#fff;border-radius:14px;padding:16px;margin-bottom:16px;}
.wbal .l{font-size:12px;opacity:.85;}
.wbal .v{font-size:28px;font-weight:900;font-style:italic;}
.addr-empty{border:1.5px dashed #d8c4a4;border-radius:14px;padding:26px;text-align:center;color:var(--muted);cursor:pointer;}
.addr-empty .plus{font-size:30px;color:var(--gold-2);}
.addr-card{display:flex;align-items:center;gap:12px;border:1.5px solid #eadcc4;border-radius:14px;padding:14px;cursor:pointer;}
.addr-card.is-active{border-color:var(--red);background:#fff5f3;}
.addr-card .ic{font-size:24px;}
.addr-card .info{flex:1;min-width:0;}
.addr-card .info b{font-size:14px;}
.addr-card .info span{font-size:12px;color:var(--muted);word-break:break-all;}
.pwd-banner{display:flex;align-items:center;gap:12px;background:#fff7e6;border:1px solid #f3dca0;border-radius:14px;padding:14px;margin:14px 0;}
.pwd-banner .ic{font-size:22px;}
.pwd-banner b{font-size:14px;color:var(--ink);}
.pwd-banner p{font-size:12px;color:var(--muted);}
.pwd-banner button{margin-left:auto;background:var(--gold-grad);color:var(--red-deep);border:none;border-radius:20px;padding:8px 16px;font-weight:800;cursor:pointer;white-space:nowrap;}

.rec-filter{display:flex;gap:8px;margin-bottom:14px;overflow-x:auto;scrollbar-width:none;}
.rec-filter::-webkit-scrollbar{display:none;}
.rec-filter button{border:1.5px solid #e6d6bd;background:#fffdf9;border-radius:20px;padding:7px 16px;font-weight:700;color:var(--muted);cursor:pointer;white-space:nowrap;}
.rec-filter button.is-active{background:var(--red);color:#fff;border-color:var(--red);}
.rec-summary{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px;}
.rec-summary .card{border:1px solid #f0dcbf;border-radius:14px;padding:16px;text-align:center;}
.rec-summary .card .l{font-size:13px;color:var(--muted);}
.rec-summary .card .v{font-size:24px;font-weight:900;color:var(--red);font-style:italic;margin-top:4px;}
.rec-row{display:flex;align-items:center;gap:12px;padding:14px 4px;border-bottom:1px solid #f3ece0;}
.rec-row .info{flex:1;min-width:0;}
.rec-row .info b{font-size:14px;}
.rec-row .info span{font-size:12px;color:var(--muted);}
.rec-row .amt{font-weight:800;font-style:italic;}
.rec-st{font-size:11px;font-weight:800;padding:4px 10px;border-radius:20px;}
.rec-st.pending{background:#fff3d6;color:#b8860b;}
.rec-st.completed{background:#e3f6ea;color:#1f8f4d;}
.rec-st.failed,.rec-st.rejected{background:#fdeaea;color:#c0392b;}

/* 客服聯絡 */
.contact-row{display:flex;align-items:center;gap:14px;background:#fffaf2;border:1px solid #f0dcbf;border-radius:16px;padding:18px;margin-bottom:14px;box-shadow:var(--shadow);}
.contact-row .ic{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;font-size:24px;background:#eef6ff;flex:0 0 auto;}
.contact-row .info{flex:1;}
.contact-row .info b{font-size:17px;color:var(--ink);}
.contact-row .info span{display:block;font-size:12px;color:var(--muted);margin-top:2px;}
.contact-row .arr{color:#c9b89c;font-size:20px;}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.contact-card{background:#fffaf2;border:1px solid #f0dcbf;border-radius:16px;padding:22px 16px;text-align:center;cursor:pointer;box-shadow:var(--shadow);}
.contact-card .ic{font-size:30px;}
.contact-card b{display:block;margin-top:8px;color:var(--ink);}
.contact-card span{font-size:12px;color:var(--muted);}

/* ===== 每日簽到 ===== */
.signin-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;}
.signin-head .t{font-weight:800;font-size:16px;color:var(--ink);}
.signin-head .t b{color:var(--red);font-size:18px;}
.signin-head .s{font-size:12px;color:var(--muted);margin-top:2px;}
.signin-days{display:flex;flex-direction:column;gap:10px;margin-bottom:18px;}
.si-day{display:flex;align-items:center;gap:12px;border:1.5px solid #eadcc4;border-radius:14px;padding:14px;}
.si-day.today{border-color:var(--red);background:#fff5f3;box-shadow:0 0 0 2px rgba(200,16,46,.1);}
.si-day.done{opacity:.6;}
.si-day .d{font-weight:800;color:var(--ink);}
.si-day .r{color:var(--gold-deep);font-weight:900;font-style:italic;font-size:16px;}
.si-day .st{margin-left:auto;font-size:12px;font-weight:800;padding:5px 14px;border-radius:20px;background:#eee;color:#999;}
.si-day.today .st{background:var(--red-grad);color:#fff;}
.si-day.done .st{background:#e3f6ea;color:#1f8f4d;}
.signin-prog{background:#fffaf2;border:1px solid #f0dcbf;border-radius:14px;padding:16px;margin-bottom:16px;}
.signin-prog .row{display:flex;justify-content:space-between;font-size:13px;color:var(--muted);margin-bottom:6px;}
.signin-prog .row b{color:var(--red);}
.signin-prog .pbar{height:8px;background:#f0dcbf;border-radius:6px;overflow:hidden;margin-bottom:14px;}
.signin-prog .pbar:last-child{margin-bottom:0;}
.signin-prog .pbar i{display:block;height:100%;background:var(--red-grad);transition:width .6s ease;}

/* ===== 代理系統 ===== */
.agent-hero{position:relative;overflow:hidden;border-radius:18px;padding:24px 22px;margin-bottom:18px;color:#fff;
  /* 放入 assets/promo/agent-banner.png 後自動當背景；無圖則漸層 */
  background:url(../assets/promo/agent-banner.png) right center/cover no-repeat, linear-gradient(120deg,#7a1320,#c8102e 55%,#e8a23a);
  box-shadow:0 10px 24px rgba(120,40,20,.3);}
.agent-hero::after{content:"👑";position:absolute;right:-6px;bottom:-14px;font-size:90px;opacity:.18;}
.agent-hero__t{font-size:26px;font-weight:900;}
.agent-hero__s{font-size:13px;opacity:.9;margin-top:4px;}
.agent-hero__badge{display:inline-block;margin-top:12px;background:#ffffff26;border:1px solid var(--gold-1);
  border-radius:20px;padding:6px 14px;font-weight:800;font-size:13px;}
.agent-code{background:#fffaf2;border:1px solid #f0dcbf;border-radius:16px;padding:18px;margin-bottom:16px;box-shadow:var(--shadow);}
.agent-code .l{font-size:12px;color:var(--muted);}
.agent-code__v{font-size:30px;font-weight:900;letter-spacing:3px;color:var(--red);font-style:italic;margin:4px 0 12px;}
.agent-code__btns{display:flex;gap:10px;margin-bottom:12px;}
.agent-code__btns button{flex:1;border:1.5px solid var(--red);background:#fff;color:var(--red);border-radius:10px;padding:10px;font-weight:800;cursor:pointer;}
.agent-code__btns button.gold{background:var(--gold-grad);border-color:var(--gold-2);color:var(--red-deep);}
.agent-code input{width:100%;border:1px dashed var(--gold-2);background:#f7f0e5;border-radius:10px;padding:10px;font-size:12px;color:var(--muted);font-family:monospace;}
.agent-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px;}
.agent-stats .card{background:#fffaf2;border:1px solid #f0dcbf;border-radius:14px;padding:14px;text-align:center;}
.agent-stats .card .l{font-size:12px;color:var(--muted);}
.agent-stats .card .v{font-size:22px;font-weight:900;color:var(--red);font-style:italic;margin-top:4px;}
.agent-est{background:#fbeede;border-radius:12px;padding:12px 16px;font-size:13px;color:var(--ink);margin-bottom:8px;}
.agent-est b{color:var(--red);font-size:16px;}

/* ===== 反水 ===== */
.rebate-top{background:var(--red-grad);color:#fff;border-radius:16px;padding:22px;text-align:center;margin-bottom:16px;box-shadow:0 8px 20px rgba(120,40,20,.3);}
.rebate-top .l{font-size:13px;opacity:.9;}
.rebate-top .v{font-size:34px;font-weight:900;font-style:italic;margin:4px 0 14px;}
.rebate-top button{background:var(--gold-grad);color:var(--red-deep);border:none;border-radius:24px;padding:11px 32px;font-weight:800;cursor:pointer;}
.rebate-cat{display:flex;align-items:center;gap:14px;background:#fffaf2;border:1px solid #f0dcbf;border-radius:14px;padding:16px;margin-bottom:12px;}
.rebate-cat .ic{width:46px;height:46px;border-radius:12px;background:#f3e8d6;display:grid;place-items:center;font-size:24px;flex:0 0 auto;}
.rebate-cat .info b{font-size:15px;color:var(--ink);}
.rebate-cat .info span{display:block;font-size:12px;color:var(--muted);margin-top:2px;}
.rebate-cat .amt{margin-left:auto;text-align:right;}
.rebate-cat .amt .n{color:#16a34a;font-weight:900;font-style:italic;font-size:16px;}
.rebate-cat .amt button{margin-top:6px;background:var(--red);color:#fff;border:none;border-radius:18px;padding:6px 16px;font-weight:700;cursor:pointer;font-size:12px;}
.rebate-cat .amt button:disabled{background:#d8c9b2;cursor:not-allowed;}

/* ===== 優惠活動 ===== */
.promo-tabs{display:flex;gap:8px;margin-bottom:16px;overflow-x:auto;scrollbar-width:none;}
.promo-tabs::-webkit-scrollbar{display:none;}
.promo-tabs button{border:1.5px solid #e6d6bd;background:#fffdf9;border-radius:20px;padding:8px 18px;font-weight:700;color:var(--muted);cursor:pointer;white-space:nowrap;}
.promo-tabs button.is-active{background:var(--red);color:#fff;border-color:var(--red);}
.promo-card{background:#fffaf2;border:1px solid #f0dcbf;border-radius:16px;overflow:hidden;margin-bottom:16px;box-shadow:var(--shadow);cursor:pointer;transition:.15s;}
.promo-card:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(120,40,20,.16);}
.promo-card__banner{height:130px;background:var(--red-grad);position:relative;display:flex;align-items:center;justify-content:center;color:#fff;}
.promo-card__banner img{width:100%;height:100%;object-fit:cover;}
.promo-card__banner .ph{font-size:40px;opacity:.5;}
.promo-card__tag{position:absolute;top:10px;left:10px;background:var(--gold-grad);color:var(--red-deep);font-size:11px;font-weight:800;padding:4px 12px;border-radius:14px;}
.promo-card__body{padding:16px 18px;}
.promo-card__body h4{font-size:17px;color:var(--ink);margin-bottom:6px;}
.promo-card__body p{font-size:13px;color:var(--muted);line-height:1.6;}
.promo-card__date{font-size:12px;color:#c9b89c;margin-top:10px;}
.promo-detail{background:#fffaf2;border:1px solid #f0dcbf;border-radius:14px;padding:18px;line-height:1.9;color:var(--ink);}

/* ===== 骰寶 大小單雙 ===== */
.sicbo{display:flex;flex-direction:column;gap:16px}
.sicbo-stage{display:flex;justify-content:center;gap:14px;padding:22px;background:linear-gradient(160deg,#2a1410,#3d1d15);border:1px solid var(--line,#5a3a22);border-radius:16px}
.sicbo-stage .dice{width:64px;height:64px;display:flex;align-items:center;justify-content:center;font-size:46px;line-height:1;background:#fff;color:#c0392b;border-radius:12px;box-shadow:0 4px 10px rgba(0,0,0,.35)}
.sicbo-result{text-align:center;font-size:14px;color:#e9d9b8;min-height:22px;padding:8px;border-radius:10px;background:rgba(255,255,255,.04)}
.sicbo-result.win{color:#ffd75e;background:rgba(255,196,0,.12);font-weight:700}
.sicbo-result.lose{color:#ff9c8a;background:rgba(255,80,60,.1)}
.sicbo-result b{color:#ffd75e}
.sicbo-picks{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.sicbo-picks .pick{display:flex;flex-direction:column;align-items:center;gap:2px;padding:14px 0;border:1.5px solid var(--line,#5a3a22);border-radius:12px;background:rgba(255,255,255,.03);color:#e9d9b8;cursor:pointer;transition:.15s}
.sicbo-picks .pick b{font-size:20px;color:#ffd75e}
.sicbo-picks .pick span{font-size:11px;opacity:.7}
.sicbo-picks .pick.is-active{border-color:#ffce5a;background:linear-gradient(160deg,#7a2017,#a8321f);box-shadow:0 0 0 2px rgba(255,206,90,.3)}
.sicbo-amt{display:flex;flex-direction:column;gap:8px}
.sicbo-amt label{font-size:13px;color:#c9b89c}
.sicbo-amt input{padding:12px 14px;border-radius:10px;border:1.5px solid var(--line,#5a3a22);background:rgba(0,0,0,.2);color:#fff;font-size:16px}
.sicbo-chips{display:flex;gap:8px;flex-wrap:wrap}
.sicbo-chips button{padding:7px 14px;border-radius:20px;border:1px solid var(--line,#5a3a22);background:rgba(255,255,255,.04);color:#e9d9b8;cursor:pointer}
.sicbo-chips button.is-active{background:#c8a24a;color:#3a1d10;border-color:#c8a24a;font-weight:700}
.sicbo-tip{font-size:11px;color:#9c8a6e;text-align:center;line-height:1.6}

/* ===== 投注紀錄 ===== */
.bet-list{display:flex;flex-direction:column;gap:10px}
.bet-row{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-radius:12px;background:rgba(255,255,255,.03);border:1px solid var(--line,#5a3a22);border-left:3px solid #888}
.bet-row.w{border-left-color:#ffce5a}
.bet-row.l{border-left-color:#a8321f}
.bet-row b{display:block;font-size:14px;color:#e9d9b8}
.bet-row span{font-size:11px;color:#9c8a6e}
.bet-amt{text-align:right}
.bet-amt span{font-size:12px;color:#c9b89c}
.bet-amt b.win{color:#ffd75e}
.bet-amt b.lose{color:#ff9c8a}

/* ===== 簽到活動主視覺 ===== */
.signin-hero{position:relative;overflow:hidden;border-radius:16px;padding:22px 20px;margin-bottom:18px;
  /* 放入 assets/promo/signin-banner.png 後自動顯示；無圖則退回漸層 */
  background:url(../assets/promo/signin-banner.png) right center/cover no-repeat, var(--red-grad,linear-gradient(135deg,#a8321f,#7a1d12));
  border:1px solid var(--gold-2,#e7c66b);box-shadow:var(--shadow);}
.signin-hero__txt{position:relative;z-index:2;max-width:80%;}
.signin-hero__txt .tag{margin-bottom:8px;}
.signin-hero__txt h2{color:#fff;font-size:21px;font-weight:900;margin:4px 0 6px;text-shadow:0 2px 6px rgba(0,0,0,.3);}
.signin-hero__txt p{color:#ffe9c2;font-size:13px;line-height:1.6;}
.signin-hero__txt b{color:#ffd75e;font-size:16px;}

/* ===== 活動規則卡 ===== */
.promo-rules{margin-top:18px;background:var(--card,#fff8ec);border:1px solid #f0dcbf;border-radius:14px;padding:16px 18px;}
.promo-rules h4{font-size:14px;color:var(--red-deep,#8a1d12);margin-bottom:10px;font-weight:800;}
.promo-rules ul{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:7px;}
.promo-rules li{font-size:12.5px;color:#6b5a44;line-height:1.6;}
.promo-rules b{color:var(--red-deep,#8a1d12);}

/* ===== 充值/提現 紀錄列表 ===== */
.rec-list{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.rec-row{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-radius:12px;
  background:var(--card,#fff8ec);border:1px solid #f0dcbf;border-left:3px solid #c8a24a}
.rec-row.ok{border-left-color:#16a34a}
.rec-row.fail{border-left-color:#dc2626}
.rec-row.pend{border-left-color:#e0a72e}
.rec-main b{display:block;font-size:14px;color:var(--red-deep,#8a1d12)}
.rec-main span{display:block;font-size:11px;color:#9c8a6e;margin-top:2px}
.rec-st{font-size:13px;font-weight:700;color:#6b5a44;white-space:nowrap}
.rec-row.ok .rec-st{color:#16a34a}
.rec-row.fail .rec-st{color:#dc2626}
.rec-row.pend .rec-st{color:#e0a72e}

/* ===== 專屬提示窗 toast ===== */
.toast-wrap{position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:9999;display:flex;flex-direction:column;gap:10px;align-items:center;pointer-events:none}
.toast{display:flex;align-items:center;gap:9px;max-width:86vw;padding:12px 18px;border-radius:12px;
  background:linear-gradient(135deg,#7a1d12,#a8321f);color:#fff5e0;font-size:14px;font-weight:600;
  border:1px solid var(--gold-2,#e7c66b);box-shadow:0 8px 24px rgba(0,0,0,.35);
  opacity:0;transform:translateY(-14px);transition:opacity .3s,transform .3s}
.toast.show{opacity:1;transform:translateY(0)}
.toast__ic{display:grid;place-items:center;width:22px;height:22px;border-radius:50%;background:var(--gold-grad,#e7c66b);color:#7a1d12;font-size:13px;font-weight:900;flex:0 0 auto}
.toast--success{background:linear-gradient(135deg,#1b7a44,#239b56)}
.toast--success .toast__ic{background:#d6f5e0;color:#198a4b}
.toast--error{background:linear-gradient(135deg,#8a1d12,#c0392b)}
.toast--error .toast__ic{background:#ffd9d2;color:#c0392b}

/* ===== 富內容對話框 ===== */
.app-modal{position:fixed;inset:0;z-index:9998;display:none;align-items:center;justify-content:center;background:rgba(20,8,5,.55);backdrop-filter:blur(2px);padding:24px}
.app-modal.show{display:flex}
.app-modal__box{width:100%;max-width:360px;background:var(--card,#fff8ec);border:1px solid var(--gold-2,#e7c66b);border-radius:16px;padding:22px;box-shadow:0 18px 50px rgba(0,0,0,.4);animation:modalPop .22s ease}
@keyframes modalPop{from{opacity:0;transform:scale(.94) translateY(8px)}to{opacity:1;transform:none}}
.app-modal__t{font-size:16px;font-weight:800;color:var(--red-deep,#8a1d12);margin-bottom:14px;text-align:center}
.app-modal__b{font-size:13px;color:#5b4a36;max-height:50vh;overflow:auto;line-height:1.7}
.app-modal__b .rec-line{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px dashed #ead9bb}
.app-modal__b .rec-line:last-child{border-bottom:0}
.app-modal__b .rec-line b{color:var(--red-deep,#8a1d12)}
.app-modal__ok{margin-top:18px;width:100%;padding:11px;border:none;border-radius:10px;background:var(--gold-grad,linear-gradient(135deg,#e7c66b,#caa23f));color:#5a2a10;font-weight:800;font-size:15px;cursor:pointer}

/* ===== 帳號設定彈窗 ===== */
.ac-mask{position:fixed;inset:0;z-index:9998;background:rgba(20,2,6,.55);backdrop-filter:blur(2px);
  display:grid;place-items:center;padding:20px;animation:acIn .15s ease;}
@keyframes acIn{from{opacity:0}to{opacity:1}}
.ac-modal{width:100%;max-width:360px;background:var(--card,#fff8ec);border:1px solid var(--gold-2,#e7c66b);
  border-radius:18px;padding:22px;box-shadow:0 20px 50px rgba(60,10,10,.4);}
.ac-modal h3{font-size:17px;color:var(--red-deep,#8a1d12);font-weight:900;margin-bottom:16px;text-align:center;}
.ac-fields{display:flex;flex-direction:column;gap:12px;}
.ac-field{display:flex;flex-direction:column;gap:6px;}
.ac-field span{font-size:12px;color:#6b5a44;font-weight:700;}
.ac-field input{padding:11px 13px;border:1.5px solid #e7d6b8;border-radius:10px;font-size:15px;background:#fff;color:#3a2a1a;}
.ac-field input:focus{outline:none;border-color:var(--gold-1,#d4af37);box-shadow:0 0 0 3px rgba(212,175,55,.18);}
.ac-acts{display:flex;gap:10px;margin-top:18px;}
.ac-acts button{flex:1;padding:11px;border-radius:10px;font-weight:800;font-size:14px;cursor:pointer;border:none;}
.ac-cancel{background:#efe3cf;color:#7a6a50;}
.ac-ok{background:var(--red-grad,linear-gradient(120deg,#c8102e,#7f0a1d));color:#fff;}
.ac-ok:active{transform:scale(.98);}

/* ===== 表單欄位錯誤提示（取代瀏覽器原生氣泡）===== */
.fld-err{min-height:16px;font-size:12px;color:#e23b3b;margin-top:5px;line-height:1.4;
  display:flex;align-items:center;gap:4px;transition:.15s;}
.fld-err:not(:empty)::before{content:"⚠";font-size:12px;}
.field input.invalid{border-color:#e23b3b !important;background:#fff5f5;}
.field input.invalid:focus{box-shadow:0 0 0 3px rgba(226,59,59,.15) !important;}

/* 出款帳戶刪除鈕 */
.addr-card{position:relative;}
.addr-del{margin-left:auto;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;
  color:#b08; background:rgba(200,16,46,.08);font-size:12px;cursor:pointer;flex:0 0 auto;}
.addr-del:hover{background:rgba(200,16,46,.18);}
