/* =========================================================
   SpinixFin — Design System (orange + white, TrueMoney-style polish)
   Aesthetic reference only. Branding is SpinixFin's own.
   ========================================================= */

/* ---------- Tokens ---------- */
:root{
  /* Brand orange scale */
  --o-50:#FFF4EC; --o-100:#FFE7D6; --o-200:#FFCBA6; --o-300:#FFAB72;
  --o-400:#FB8C3C; --o-500:#F2741A; --o-600:#E25E04; --o-700:#BB4E08;
  --grad:linear-gradient(135deg,#FFA84D 0%,#F2741A 48%,#E85D04 100%);
  --grad-soft:linear-gradient(135deg,#FFB866 0%,#F8852B 100%);

  /* Neutrals */
  --ink:#16181D; --ink-2:#5B6270; --ink-3:#9AA0AC; --ink-4:#C3C7CF;
  --line:#ECEEF2; --bg:#F4F6F8; --surface:#FFFFFF;

  /* Status */
  --green:#16B57A; --green-bg:#E7F8F1;
  --red:#F2545B;   --red-bg:#FDECEC;
  --blue:#3B82F6;  --gold:#F5B301;  --line-brand:#06C755;

  /* Radius */
  --r-xs:8px; --r-sm:10px; --r:14px; --r-lg:18px; --r-xl:24px; --r-pill:999px;

  /* Shadow */
  --sh-1:0 1px 2px rgba(16,24,40,.04),0 2px 6px rgba(16,24,40,.06);
  --sh-2:0 6px 20px rgba(16,24,40,.09);
  --sh-3:0 14px 40px rgba(16,24,40,.14);
  --sh-o:0 10px 24px rgba(242,116,26,.38);

  --app-w:430px;
  --nav-h:68px;
  /* Prompt first (if available/self-hosted), then strong Thai-capable system fallbacks */
  --ff:'Prompt','Kanit','Leelawadee UI','Segoe UI',system-ui,-apple-system,'Noto Sans Thai',Tahoma,Arial,sans-serif;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  font-family:var(--ff);
  color:var(--ink);
  background:#E9ECF1;
  font-size:15px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:0;background:none}
input{font-family:inherit}

/* ---------- App shell (phone frame) ---------- */
.app{
  position:relative;
  width:100%;
  max-width:var(--app-w);
  min-height:100vh;
  margin:0 auto;
  background:var(--bg);
  overflow:hidden;
}
@media(min-width:480px){
  body{padding:24px 0}
  .app{
    min-height:calc(100vh - 48px);
    border-radius:30px;
    box-shadow:var(--sh-3);
    overflow:hidden;
  }
}
.screen{padding-bottom:calc(var(--nav-h) + 24px)}
.pad{padding:0 18px}

/* ---------- Headers ---------- */
.appbar{
  position:relative;background:var(--grad);color:#fff;
  padding:18px 18px 16px;
}
.appbar-row{display:flex;align-items:center;gap:12px}
.appbar h1{font-size:18px;font-weight:600;margin:0}
.iconbtn{
  width:40px;height:40px;border-radius:var(--r-pill);
  display:grid;place-items:center;color:#fff;background:rgba(255,255,255,.16);
  flex:none;transition:.15s;
}
.iconbtn:active{transform:scale(.92)}
.iconbtn.dark{background:var(--o-50);color:var(--o-600)}

/* white inner-page header */
.topbar{
  display:flex;align-items:center;gap:10px;
  padding:16px 14px;background:var(--surface);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:20;
}
.topbar .back{
  width:40px;height:40px;border-radius:var(--r-pill);display:grid;place-items:center;
  color:var(--ink);background:var(--bg);
}
.topbar h1{font-size:17px;font-weight:600;margin:0;flex:1}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:52px;padding:0 22px;border-radius:var(--r-pill);
  font-weight:600;font-size:16px;color:#fff;background:var(--grad);
  box-shadow:var(--sh-o);transition:.15s;white-space:nowrap;
}
.btn:active{transform:translateY(1px) scale(.99);box-shadow:0 4px 12px rgba(242,116,26,.3)}
.btn[disabled]{opacity:.5;box-shadow:none;pointer-events:none}
.btn-block{display:flex;width:100%}
.btn-lg{height:56px;font-size:17px}
.btn-ghost{background:var(--o-50);color:var(--o-600);box-shadow:none}
.btn-outline{background:#fff;color:var(--ink);border:1.5px solid var(--line);box-shadow:none}
.btn-line{background:var(--line-brand);box-shadow:0 8px 18px rgba(6,199,85,.32)}
.btn-sm{height:38px;font-size:14px;padding:0 16px}

/* ---------- Cards ---------- */
.card{background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--sh-1);padding:18px}
.card-flat{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--line)}

/* ---------- Inputs ---------- */
.field{margin-bottom:14px}
.field > label{display:block;font-size:13px;font-weight:500;color:var(--ink-2);margin:0 0 7px 4px}
.inputwrap{
  display:flex;align-items:center;gap:10px;
  background:var(--bg);border:1.5px solid transparent;border-radius:var(--r);
  padding:0 14px;height:54px;transition:.15s;
}
.inputwrap:focus-within{border-color:var(--o-400);background:#fff;box-shadow:0 0 0 4px var(--o-50)}
.inputwrap .lead{color:var(--ink-3);display:grid;place-items:center;flex:none}
.inputwrap input{
  flex:1;border:0;background:none;outline:none;font-size:16px;color:var(--ink);min-width:0;
}
.inputwrap input::placeholder{color:var(--ink-4)}
.inputwrap .trail{color:var(--ink-3);flex:none;display:grid;place-items:center}
.prefix{color:var(--ink-2);font-weight:500;font-size:15px;padding-right:8px;border-right:1px solid var(--line);flex:none}

/* ---------- Misc text ---------- */
.muted{color:var(--ink-2)}
.tiny{font-size:12px}
.sm{font-size:13px}
.center{text-align:center}
.link{color:var(--o-600);font-weight:500}
.section-title{display:flex;align-items:center;justify-content:space-between;margin:22px 0 12px}
.section-title h2{font-size:15px;font-weight:600;margin:0}
.divider{display:flex;align-items:center;gap:12px;color:var(--ink-3);font-size:13px;margin:18px 0}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--line)}

/* ---------- Balance card ---------- */
.balance{
  position:relative;color:#fff;border-radius:var(--r-xl);
  background:var(--grad);padding:20px;overflow:hidden;
  box-shadow:var(--sh-o);
}
.balance::after{
  content:"";position:absolute;right:-40px;top:-50px;width:170px;height:170px;
  background:radial-gradient(circle,rgba(255,255,255,.22),transparent 70%);border-radius:50%;
}
.balance::before{
  content:"";position:absolute;right:18px;bottom:-50px;width:130px;height:130px;
  background:radial-gradient(circle,rgba(255,255,255,.12),transparent 70%);border-radius:50%;
}
.balance .lbl{font-size:13px;opacity:.9;display:flex;align-items:center;gap:7px}
.balance .amt{font-size:34px;font-weight:700;letter-spacing:-.5px;margin:4px 0 2px}
.balance .amt small{font-size:18px;font-weight:600;opacity:.85}
.balance .acct{font-size:12.5px;opacity:.88;letter-spacing:.3px}
.balance-actions{display:flex;gap:10px;margin-top:16px;position:relative;z-index:1}
.balance-actions .btn{flex:1;height:46px;font-size:15px;background:#fff;color:var(--o-600);box-shadow:0 6px 14px rgba(0,0,0,.12)}
.balance-actions .btn.alt{background:rgba(255,255,255,.18);color:#fff;backdrop-filter:blur(4px)}

/* pill stats under balance */
.stat-strip{display:flex;gap:10px;margin-top:14px}
.stat-strip .stat{flex:1;background:var(--surface);border-radius:var(--r);padding:12px;box-shadow:var(--sh-1);display:flex;align-items:center;gap:10px}
.stat .ic{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;flex:none}
.stat .v{font-weight:600;font-size:15px;line-height:1.1}
.stat .k{font-size:11.5px;color:var(--ink-3)}

/* ---------- Quick menu grid ---------- */
.qgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px 4px}
.qitem{display:flex;flex-direction:column;align-items:center;gap:7px;padding:10px 4px;border-radius:var(--r);transition:.12s}
.qitem:active{background:var(--o-50);transform:scale(.96)}
.qitem .tile{width:50px;height:50px;border-radius:16px;display:grid;place-items:center}
.qitem span{font-size:11.5px;color:var(--ink-2);font-weight:500;text-align:center;line-height:1.2}
.t-orange{background:var(--o-50);color:var(--o-600)}
.t-green{background:var(--green-bg);color:var(--green)}
.t-blue{background:#E8F1FE;color:var(--blue)}
.t-gold{background:#FEF6E0;color:#D69A00}
.t-red{background:var(--red-bg);color:var(--red)}
.t-purple{background:#F0EBFE;color:#7C53E0}

/* ---------- Banner ---------- */
.banner{
  border-radius:var(--r-lg);padding:18px;color:#fff;position:relative;overflow:hidden;
  background:linear-gradient(120deg,#3A2A18,#6E4318);box-shadow:var(--sh-1);
}
.banner.promo{background:linear-gradient(120deg,#F2741A,#E85D04)}
.banner h3{margin:0 0 4px;font-size:16px;font-weight:600}
.banner p{margin:0;font-size:12.5px;opacity:.9}
.banner .pill{position:absolute;top:14px;right:14px;background:rgba(255,255,255,.2);padding:3px 10px;border-radius:var(--r-pill);font-size:11px;font-weight:600}

/* ---------- List rows ---------- */
.list{background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--sh-1);overflow:hidden}
.row{display:flex;align-items:center;gap:13px;padding:14px 16px;border-bottom:1px solid var(--line)}
.row:last-child{border-bottom:0}
.row .ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex:none}
.row .body{flex:1;min-width:0}
.row .t{font-weight:500;font-size:14.5px}
.row .s{font-size:12px;color:var(--ink-3)}
.row .amt{font-weight:600;font-size:15px;text-align:right;white-space:nowrap}
.row .chev{color:var(--ink-4);flex:none}
.amt.up{color:var(--green)} .amt.down{color:var(--red)}

/* ---------- Chips / amount presets ---------- */
.chips{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.chip{
  height:50px;border-radius:var(--r);background:var(--surface);border:1.5px solid var(--line);
  display:grid;place-items:center;font-weight:600;font-size:15px;color:var(--ink);transition:.12s;
}
.chip:active{transform:scale(.97)}
.chip.active{border-color:var(--o-500);background:var(--o-50);color:var(--o-600);box-shadow:0 0 0 3px var(--o-50)}

/* method select */
.method{display:flex;align-items:center;gap:13px;padding:15px;border:1.5px solid var(--line);border-radius:var(--r);background:#fff;margin-bottom:12px;transition:.12s}
.method.active{border-color:var(--o-500);box-shadow:0 0 0 3px var(--o-50)}
.method .logo{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-weight:700;color:#fff;flex:none}
.method .body{flex:1}
.method .body .t{font-weight:600;font-size:15px}
.method .body .s{font-size:12px;color:var(--ink-3)}
.radio{width:22px;height:22px;border-radius:50%;border:2px solid var(--line-,#D7DBE2);flex:none;display:grid;place-items:center}
.method.active .radio{border-color:var(--o-500)}
.method.active .radio::after{content:"";width:11px;height:11px;border-radius:50%;background:var(--o-500)}

/* ---------- Bottom nav ---------- */
.bottom-nav{
  position:fixed;left:50%;transform:translateX(-50%);bottom:0;
  width:100%;max-width:var(--app-w);height:var(--nav-h);
  background:rgba(255,255,255,.92);backdrop-filter:blur(12px);
  border-top:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-around;
  padding-bottom:max(0px,env(safe-area-inset-bottom));z-index:50;
}
.bottom-nav a{display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--ink-3);font-size:11px;font-weight:500;flex:1;padding-top:4px}
.bottom-nav a.active{color:var(--o-600)}
.bottom-nav a.center{flex:none;margin-top:-26px}
.bottom-nav a.center .fab{
  width:58px;height:58px;border-radius:50%;background:var(--grad);color:#fff;
  display:grid;place-items:center;box-shadow:var(--sh-o);border:4px solid #fff;
}
.bottom-nav svg{width:24px;height:24px}

/* ---------- Logo ---------- */
.brand{display:flex;align-items:center;gap:11px}
.brand .mark{
  width:46px;height:46px;border-radius:14px;background:#fff;
  display:grid;place-items:center;font-weight:800;color:var(--o-600);
  font-size:19px;letter-spacing:-1px;box-shadow:0 6px 16px rgba(0,0,0,.12);
}
.brand .wm{font-size:21px;font-weight:700;letter-spacing:-.5px;line-height:1}
.brand .wm b{font-weight:700}
.brand .wm small{display:block;font-size:11px;font-weight:400;opacity:.85;letter-spacing:1.5px}

/* hero curve for auth pages */
.auth-hero{
  background:var(--grad);color:#fff;padding:46px 24px 70px;
  border-radius:0 0 36px 36px;text-align:center;position:relative;overflow:hidden;
}
.auth-hero::after{content:"";position:absolute;left:-30px;top:-40px;width:160px;height:160px;background:radial-gradient(circle,rgba(255,255,255,.18),transparent 70%);border-radius:50%}
.auth-card{margin:-46px 18px 0;position:relative;z-index:2}

/* helpers */
.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}.mt20{margin-top:20px}.mt24{margin-top:24px}
.row-between{display:flex;align-items:center;justify-content:space-between}
.gap8{display:flex;gap:8px}
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:var(--r-pill)}
.badge.green{background:var(--green-bg);color:var(--green)}
.badge.orange{background:var(--o-50);color:var(--o-600)}
.fade-up{animation:fadeUp .4s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.fade-up{animation:none}}

/* sticky bottom CTA */
.cta-bar{
  position:fixed;left:50%;transform:translateX(-50%);bottom:0;
  width:100%;max-width:var(--app-w);background:#fff;
  border-top:1px solid var(--line);padding:14px 18px calc(14px + env(safe-area-inset-bottom));
  box-shadow:0 -6px 20px rgba(16,24,40,.06);z-index:40;
}
.with-cta{padding-bottom:104px}

/* big amount input */
.amount-box{text-align:center;padding:22px 0 6px}
.amount-box .cur{font-size:22px;font-weight:600;color:var(--ink-3);vertical-align:18px;margin-right:4px}
.amount-box input{border:0;outline:none;font-family:inherit;font-size:46px;font-weight:700;width:100%;text-align:center;color:var(--ink);letter-spacing:-1px;background:none}
.amount-box input::placeholder{color:var(--ink-4)}
/* ช่องยอดถอนถูกล็อก (disabled) — โชว์เด่นเหมือนเดิม ไม่ดูจาง */
.amount-box input:disabled,.amount-box input[readonly]{
  color:var(--o-600);-webkit-text-fill-color:var(--o-600);opacity:1;cursor:default;
}

/* segmented tabs */
.tabs{display:flex;background:var(--bg);border-radius:var(--r-pill);padding:4px;gap:4px;margin:14px 0}
.tabs button{flex:1;height:38px;border-radius:var(--r-pill);font-weight:500;font-size:13.5px;color:var(--ink-2)}
.tabs button.active{background:#fff;color:var(--o-600);font-weight:600;box-shadow:var(--sh-1)}

/* settings menu rows */
.menu{background:#fff;border-radius:var(--r-lg);box-shadow:var(--sh-1);overflow:hidden}
.menu a{display:flex;align-items:center;gap:14px;padding:15px 16px;border-bottom:1px solid var(--line)}
.menu a:last-child{border-bottom:0}
.menu .mi{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;flex:none}
.menu .mt{flex:1;font-weight:500;font-size:14.5px}
.menu .ms{font-size:12px;color:var(--ink-3)}

/* lucky wheel */
.wheel-wrap{position:relative;width:280px;height:280px;margin:10px auto 0}
.wheel{width:100%;height:100%;border-radius:50%;border:8px solid #fff;box-shadow:0 12px 30px rgba(0,0,0,.18),inset 0 0 0 4px var(--o-200);
  background:conic-gradient(#F2741A 0 45deg,#FFB866 45deg 90deg,#F2741A 90deg 135deg,#FFB866 135deg 180deg,#F2741A 180deg 225deg,#FFB866 225deg 270deg,#F2741A 270deg 315deg,#FFB866 315deg 360deg);}
.wheel-hub{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:50%;background:#fff;box-shadow:0 6px 16px rgba(0,0,0,.2);display:grid;place-items:center;font-weight:800;color:var(--o-600);font-size:13px}
.wheel-ptr{position:absolute;top:-6px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:14px solid transparent;border-right:14px solid transparent;border-top:24px solid var(--red);filter:drop-shadow(0 2px 2px rgba(0,0,0,.25));z-index:3}
.wheel-seg{position:absolute;top:50%;left:50%;font-size:12.5px;font-weight:700;color:#fff;
  transform-origin:center;white-space:nowrap;text-align:center;line-height:1}

/* เงื่อนไขการหมุนวงล้อ */
.cond-highlight{display:flex;align-items:center;gap:12px;border-radius:var(--r-lg);
  background:var(--grad);color:#fff;padding:15px 16px;box-shadow:var(--sh-o);font-size:14px;line-height:1.45}
.cond-highlight svg{flex:none;opacity:.95}
.cond-list{display:flex;flex-direction:column;gap:10px}
.cond-item{position:relative;padding-left:24px;font-size:13.5px;line-height:1.6;color:var(--ink-2)}
.cond-item::before{content:"";position:absolute;left:4px;top:8px;width:8px;height:8px;border-radius:50%;
  background:var(--o-500);box-shadow:0 0 0 3px var(--o-50)}
.cond-item b{color:var(--green)}
.cond-note{margin-top:14px;padding:11px 13px;border-radius:var(--r);background:var(--red-bg);
  color:#B0353B;font-size:12px;line-height:1.55}

/* =========================================================
   v2 — interactivity polish: toast / spinner / skeleton / empty
   ========================================================= */

/* toast */
.sf-toast{
  position:fixed;left:50%;top:18px;
  transform:translateX(-50%) translateY(-24px);
  max-width:calc(var(--app-w) - 48px);
  background:#1f2330;color:#fff;font-size:13.5px;font-weight:500;
  padding:12px 18px;border-radius:var(--r-pill);box-shadow:var(--sh-3);
  z-index:200;opacity:0;pointer-events:none;transition:.28s cubic-bezier(.22,1,.36,1);
  display:flex;align-items:center;gap:8px;white-space:nowrap;
}
.sf-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.sf-toast.ok{background:linear-gradient(120deg,#13A86F,#0E9460)}
.sf-toast.err{background:linear-gradient(120deg,#F2545B,#D63A41)}
.sf-toast.ok::before{content:"✓";font-weight:800}
.sf-toast.err::before{content:"!";font-weight:800;width:18px;height:18px;border-radius:50%;border:2px solid #fff;display:grid;place-items:center;font-size:11px}

/* button spinner / loading */
.spinner{
  width:20px;height:20px;border-radius:50%;display:inline-block;
  border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;
  animation:spin .6s linear infinite;
}
.btn.is-loading{pointer-events:none}
@keyframes spin{to{transform:rotate(360deg)}}

/* skeleton shimmer */
.sk{position:relative;overflow:hidden;background:#EAEDF1;border-radius:8px}
.sk::after{content:"";position:absolute;inset:0;transform:translateX(-100%);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.65),transparent);
  animation:sheen 1.2s infinite}
@keyframes sheen{100%{transform:translateX(100%)}}
.sk-ic{width:42px;height:42px;border-radius:12px;flex:none}
.sk-line{height:12px;width:60%;margin:4px 0}
.sk-line.sm{width:38%;height:10px}
.sk-amt{width:54px;height:14px}

/* empty state */
.empty{padding:34px 16px;text-align:center;color:var(--ink-3);font-size:13.5px}
.empty::before{content:"";display:block;width:46px;height:46px;margin:0 auto 10px;border-radius:14px;background:var(--o-50);
  background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" fill="none" stroke="%23F2741A" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M22 12h-6l-2 3h-4l-2-3H2"/><path d="M5.45 5.11 2 12v6a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2v-6l-3.45-6.89A2 2 0 0 0 16.76 4H7.24a2 2 0 0 0-1.79 1.11z"/></svg>');
  background-repeat:no-repeat;background-position:center}

/* stagger entrance */
.stagger > *{animation:fadeUp .45s ease both}
@media (prefers-reduced-motion:reduce){.stagger > *{animation:none}}

/* balance shine sweep (beautify) */
.balance::after{animation:none}
.balance .shine{position:absolute;top:0;left:-60%;width:50%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.28),transparent);
  transform:skewX(-18deg);animation:sweep 4.5s ease-in-out infinite;z-index:0}
@keyframes sweep{0%,60%{left:-60%}85%,100%{left:120%}}

/* link button as submit */
button.btn{width:auto}
button.btn.btn-block{width:100%}

/* =========================================================
   v3 — home hero: รวมแถบทักทาย + ยอดเงิน เป็นก้อนส้มเดียว (เลิกซ้อนทับ)
   ========================================================= */
.home-hero{
  position:relative;overflow:hidden;color:#fff;
  background:var(--grad);border-radius:0 0 28px 28px;
  padding:14px 14px 22px;box-shadow:0 10px 26px rgba(242,116,26,.30);
}
/* แผงกระจกใส (frosted) ครอบทุกอย่างตั้งแต่คำทักทายลงมา */
.hero-glass{
  position:relative;z-index:1;border-radius:22px;padding:16px 16px 18px;overflow:hidden;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.28);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.4),0 8px 22px rgba(120,50,0,.14);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
}
/* แสงวิ้งๆ กวาดผ่านทั้งแผงกระจก — บางๆ ไม่บังตัวเลข */
.hero-glass .hero-shine{
  position:absolute;top:0;left:-70%;width:45%;height:100%;z-index:0;pointer-events:none;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.2),transparent);
  transform:skewX(-18deg);animation:sweep 5.5s ease-in-out infinite;
}
.hero-glass > *:not(.hero-shine){position:relative;z-index:1}
@media (prefers-reduced-motion:reduce){.hero-glass .hero-shine{animation:none;display:none}}
.home-hero::after{content:"";position:absolute;right:-40px;top:-50px;width:180px;height:180px;
  background:radial-gradient(circle,rgba(255,255,255,.20),transparent 70%);border-radius:50%}
.home-hero::before{content:"";position:absolute;left:-30px;bottom:-60px;width:150px;height:150px;
  background:radial-gradient(circle,rgba(255,255,255,.12),transparent 70%);border-radius:50%}
.home-hero .appbar-row{position:relative;z-index:1}
/* ยอดเงินอยู่ใน hero โดยตรง — เอาพื้น/เงา/ขอบของการ์ดเดิมออก เหลือแค่ layout */
.home-hero .balance{
  background:none;box-shadow:none;border-radius:0;padding:0;margin-top:18px;
  position:relative;z-index:1;
}
.home-hero .balance::after,.home-hero .balance::before{display:none}
/* stats ใต้ยอดเงิน — แผงกระจกใสแผงเดียว เนียนคลุมเต็มความกว้าง (มีเส้นคั่นกลาง) */
/* stats อยู่ในแผงกระจกเดียวกัน — เป็นแถวคั่นด้วยเส้นบน ไม่ต้องมีพื้นซ้อน */
.hero-stats{display:flex;margin-top:14px;padding-top:13px;position:relative;z-index:1;
  border-top:1px solid rgba(255,255,255,.28)}
.hero-stats .hstat{flex:1;display:flex;align-items:center;gap:10px;padding:4px 8px;min-width:0}
.hero-stats .hstat+.hstat{border-left:1px solid rgba(255,255,255,.2)}
.hero-stats .ic{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;flex:none}
.hero-stats .v{font-weight:700;font-size:16px;line-height:1.1;color:#fff}
.hero-stats .k{font-size:11px;color:rgba(255,255,255,.85);margin-top:1px}

/* ป้ายระดับสมาชิก 3 ระดับ — ทั่วไป(เงิน) / VIP(ทอง) / VVIP(เพชร-ดำทอง) */
.tier-badge{position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:5px;
  font-size:12px;font-weight:800;letter-spacing:.4px;line-height:1;white-space:nowrap;
  padding:7px 14px;border-radius:var(--r-pill);border:1px solid transparent}
.tier-badge svg{width:15px;height:15px;flex:none}
/* ประกายวิ่ง (เฉพาะ VIP/VVIP) */
.tier-vip::after,.tier-vvip::after{content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.7),transparent);
  transform:skewX(-20deg);animation:vipShine 3.6s ease-in-out infinite}
/* ทั่วไป — เงิน */
.tier-normal{color:#3A4150;background:linear-gradient(135deg,#F4F6F9,#D7DCE4 60%,#B9C0CC);
  border-color:rgba(255,255,255,.7);box-shadow:0 2px 8px rgba(120,130,150,.32),inset 0 1px 0 rgba(255,255,255,.85)}
.tier-normal svg{color:#7A8294}
/* VIP — ทอง */
.tier-vip{color:#5A3A05;background:linear-gradient(135deg,#FFF1C2,#F7CD5C 42%,#E3A718);
  border-color:rgba(255,239,184,.9);box-shadow:0 3px 12px rgba(214,154,0,.55),inset 0 1px 0 rgba(255,255,255,.75)}
.tier-vip svg{color:#7A5200}
/* VVIP — เพชร/ดำทอง สุดพรีเมียม */
.tier-vvip{color:#FFE7A0;background:linear-gradient(135deg,#2C2356,#3C2E70 45%,#15101F);
  border-color:rgba(214,178,90,.75);
  box-shadow:0 4px 14px rgba(30,22,60,.6),inset 0 1px 0 rgba(255,220,140,.4),0 0 0 1px rgba(214,178,90,.35)}
.tier-vvip svg{color:#FFD55E}
@keyframes vipShine{0%,55%{left:-60%}82%,100%{left:130%}}
@media (prefers-reduced-motion:reduce){.tier-vip::after,.tier-vvip::after{animation:none}}
/* เลขบัญชีใต้ชื่อ (ส่วนหัว) — เล็ก พอดี ยาวไปขึ้นบรรทัดใหม่ */
.acct-head{margin-top:3px;font-size:11.5px;line-height:1.35;opacity:.82;
  letter-spacing:.2px;white-space:normal;word-break:break-word}

/* =========================================================
   v5 — กริดเกม (โปรไวเดอร์) + แท็บหมวด สไตล์การ์ดเข้ม
   ========================================================= */
/* แท็บหมวดเกม — แบ่งกว้างเท่ากันพอดีจอ (แสดงครบ 5 อัน ไม่ตกขอบ), ชิปมีกรอบชัด */
.game-tabs{flex-wrap:nowrap;background:none;padding:0;gap:6px;margin:16px 0 14px}
.game-tabs button{flex:1 1 0;min-width:0;height:42px;padding:0 4px;border-radius:var(--r-pill);
  background:#fff;border:2px solid #DDE1E8;color:var(--ink-2);font-weight:600;font-size:13.5px;
  transition:.16s;white-space:nowrap;text-align:center}
.game-tabs button:active{transform:scale(.96)}
.game-tabs button.active{background:var(--grad);color:#fff;border:2px solid var(--o-600);
  box-shadow:var(--sh-o)}
.game-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-top:4px}
.game-card{
  position:relative;aspect-ratio:1;border-radius:16px;overflow:hidden;cursor:pointer;
  background:linear-gradient(160deg,#23262F 0%,#15171E 100%);
  border:1px solid rgba(255,255,255,.06);
  box-shadow:0 4px 12px rgba(16,24,40,.14);
  display:grid;place-items:center;transition:transform .12s,box-shadow .12s;
}
.game-card:active{transform:scale(.95)}
.game-card img{width:78%;height:78%;object-fit:contain;display:block}
.game-card.locked{opacity:.45}
.game-card.locked::after{content:"ปิดปรับปรุง";position:absolute;bottom:6px;left:0;right:0;text-align:center;font-size:9px;color:#fff;opacity:.8}
.game-grid .sk{background:#23262F}
@media(max-width:360px){.game-grid{grid-template-columns:repeat(3,1fr)}}

/* แผ่นเลือกเกมย่อย (bottom sheet) */
#gameSheet{position:fixed;inset:0;z-index:300;display:none}
#gameSheet.show{display:block}
#gameSheet .gs-backdrop{position:absolute;inset:0;background:rgba(10,12,18,.55);backdrop-filter:blur(2px);animation:fadeIn .2s}
#gameSheet .gs-panel{
  position:absolute;left:50%;transform:translateX(-50%);bottom:0;
  width:100%;max-width:var(--app-w);max-height:82vh;display:flex;flex-direction:column;
  background:#14161E;border-radius:22px 22px 0 0;padding:16px 16px calc(16px + env(safe-area-inset-bottom));
  box-shadow:0 -10px 40px rgba(0,0,0,.5);animation:sheetUp .28s cubic-bezier(.22,1,.36,1)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes sheetUp{from{transform:translate(-50%,100%)}to{transform:translate(-50%,0)}}
#gameSheet .gs-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
#gameSheet .gs-title{flex:1;color:#fff;font-weight:700;font-size:17px}
#gameSheet .gs-title .muted{color:#8A90A0;font-weight:400}
#gameSheet .gs-close{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.1);color:#fff;font-size:15px;flex:none}
#gameSheet .gs-search{height:42px;border-radius:var(--r-pill);border:0;background:#23262F;color:#fff;
  padding:0 16px;font-size:14px;margin-bottom:14px;outline:none}
#gameSheet .gs-search::placeholder{color:#8A90A0}
#gameSheet .gs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;overflow-y:auto;padding-bottom:8px}
#gameSheet .sg-card{background:#23262F;border-radius:13px;overflow:hidden;cursor:pointer;
  display:flex;flex-direction:column;transition:transform .1s}
#gameSheet .sg-card:active{transform:scale(.95)}
#gameSheet .sg-card img{width:100%;aspect-ratio:1;object-fit:cover;display:block;background:#1A1C24}
#gameSheet .sg-card span{font-size:11px;color:#D7DBE2;padding:7px 6px;text-align:center;line-height:1.25;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
#gameSheet .empty{color:#8A90A0;grid-column:1/-1}

/* =========================================================
   v6 — หน้ารายการเกมย่อย (lobby) เต็มหน้า การ์ดทรงคงที่ไม่ยุบ
   ========================================================= */
.lobby-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.lobby-card{background:var(--surface);border-radius:14px;overflow:hidden;cursor:pointer;
  box-shadow:var(--sh-1);transition:transform .1s}
.lobby-card:active{transform:scale(.95)}
/* thumb เป็น div + aspect-ratio (จองพื้นที่เสมอ แม้รูปยังไม่โหลด/โหลดพัง) */
.lobby-thumb{width:100%;aspect-ratio:1;background:#EDEFF3 center/cover no-repeat;position:relative;display:block}
.lobby-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.lobby-thumb::before{content:"🎰";position:absolute;inset:0;display:grid;place-items:center;font-size:26px;opacity:.25}
.lobby-name{font-size:11.5px;color:var(--ink);padding:7px 6px;text-align:center;line-height:1.25;font-weight:500;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:32px}
.lobby-grid .lobby-thumb.sk{border-radius:0}
@media(max-width:360px){.lobby-grid{grid-template-columns:repeat(2,1fr)}}

/* =========================================================
   v7 — ป๊อปอัปประกาศ (สไลด์หลายป้าย)
   ========================================================= */
#annModal{position:fixed;inset:0;z-index:400;display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .25s}
#annModal.show{opacity:1;pointer-events:auto}
#annModal .ann-backdrop{position:absolute;inset:0;background:rgba(10,12,18,.6);backdrop-filter:blur(3px)}
#annModal .ann-card{position:relative;width:calc(100% - 48px);max-width:355px;background:#fff;
  border-radius:24px;overflow:hidden;box-shadow:var(--sh-3);
  transform:translateY(14px) scale(.94);transition:transform .3s cubic-bezier(.22,1,.36,1)}
#annModal.show .ann-card{transform:translateY(0) scale(1)}
#annModal .ann-close{position:absolute;top:12px;right:12px;z-index:3;width:32px;height:32px;border-radius:50%;
  background:rgba(0,0,0,.14);color:#fff;font-size:14px;display:grid;place-items:center;transition:.15s}
#annModal .ann-close:active{transform:scale(.9)}
#annModal .ann-viewport{overflow:hidden}
#annModal .ann-track{display:flex;transition:transform .35s cubic-bezier(.22,1,.36,1)}
#annModal .ann-slide{flex:0 0 100%;box-sizing:border-box;padding:40px 26px 18px;text-align:center}
#annModal .ann-ic{width:60px;height:60px;border-radius:19px;margin:0 auto 16px;display:grid;place-items:center;font-size:28px}
#annModal .ann-slide h3{font-size:18px;font-weight:700;margin:0 0 9px;color:var(--ink)}
#annModal .ann-slide p{font-size:14px;color:var(--ink-2);line-height:1.65;margin:0;white-space:pre-line;
  min-height:66px;max-height:200px;overflow:auto}
/* สีตามชนิดประกาศ */
#annModal .c-normal .ann-ic{background:var(--o-50);color:var(--o-600)}
#annModal .c-success .ann-ic{background:var(--green-bg);color:var(--green)}
#annModal .c-info .ann-ic{background:#E8F1FE;color:var(--blue)}
#annModal .c-warning .ann-ic{background:#FEF6E0;color:#D69A00}
/* จุดสไลด์ */
#annModal .ann-dots{display:flex;gap:7px;justify-content:center;padding:6px 0 4px}
#annModal .ann-dot{width:7px;height:7px;border-radius:50%;background:var(--line);cursor:pointer;transition:.25s}
#annModal .ann-dot.active{width:22px;border-radius:4px;background:var(--o-500)}
/* ไม่แสดงอีกวันนี้ */
#annModal .ann-foot{display:flex;align-items:center;justify-content:center;gap:8px;
  font-size:12.5px;color:var(--ink-3);padding:12px 0 18px;cursor:pointer}
#annModal .ann-foot input{accent-color:var(--o-500);width:15px;height:15px}

/* ช่องค้นหาเกม — เด่น ไม่กลืนพื้นหลัง */
.search-hero{
  height:54px;background:#fff;border:2px solid var(--o-300);border-radius:var(--r-pill);
  box-shadow:0 6px 18px rgba(242,116,26,.16);padding:0 18px;gap:12px;
}
.search-hero:focus-within{border-color:var(--o-500);box-shadow:0 0 0 4px var(--o-50),0 6px 18px rgba(242,116,26,.2)}
.search-hero .lead{color:var(--o-500)}
.search-hero input{font-size:15.5px;font-weight:500;color:var(--ink)}
.search-hero input::placeholder{color:var(--ink-3);font-weight:400}

/* =========================================================
   v8 — วิซาร์ดสมัครสมาชิก: ตัวบอกขั้น / วัดรหัสผ่าน / หน้าสำเร็จ
   ========================================================= */
.stepper{display:flex;align-items:flex-start}
.stepper .stp{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative}
.stepper .stp span{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
  font-weight:700;font-size:14px;background:#fff;color:var(--ink-3);border:2px solid var(--line);
  position:relative;z-index:1;transition:.2s}
.stepper .stp label{font-size:11px;color:var(--ink-3);font-weight:500}
.stepper .stp.active span{background:var(--grad);color:#fff;border-color:transparent;box-shadow:var(--sh-o)}
.stepper .stp.active label{color:var(--o-600);font-weight:700}
.stepper .stp.done span{background:var(--o-50);color:var(--o-600);border-color:var(--o-200)}
.stepper .stp::before{content:"";position:absolute;top:16px;left:-50%;width:100%;height:2px;background:var(--line);z-index:0}
.stepper .stp:first-child::before{display:none}
.stepper .stp.active::before,.stepper .stp.done::before{background:var(--o-300)}

/* แถบความแข็งแรงรหัสผ่าน */
.pw-meter{margin-top:12px}
.pw-bars{display:flex;gap:6px}
.pw-bars span{flex:1;height:6px;border-radius:3px;background:var(--line);transition:.25s}
.pw-label{font-size:12px;color:var(--ink-3);margin-top:8px;font-weight:600}
.pw-meter.lv1 .pw-bars span:nth-child(-n+1){background:var(--red)}
.pw-meter.lv2 .pw-bars span:nth-child(-n+2){background:#F5A623}
.pw-meter.lv3 .pw-bars span:nth-child(-n+3){background:var(--blue)}
.pw-meter.lv4 .pw-bars span:nth-child(-n+4){background:var(--green)}
.pw-meter.lv1 .pw-label{color:var(--red)}
.pw-meter.lv2 .pw-label{color:#D88200}
.pw-meter.lv3 .pw-label{color:var(--blue)}
.pw-meter.lv4 .pw-label{color:var(--green)}

/* หน้าสมัครสำเร็จ */
.reg-success-ic{width:92px;height:92px;border-radius:50%;margin:0 auto;display:grid;place-items:center;
  background:var(--green-bg);color:var(--green);box-shadow:0 10px 30px rgba(22,181,122,.3);
  animation:popIn .45s cubic-bezier(.22,1.5,.4,1) both}
.reg-success-ic svg{width:46px;height:46px}
@keyframes popIn{from{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}
@media (prefers-reduced-motion:reduce){.reg-success-ic{animation:none}}

/* การ์ดข้อมูลรอบค่าคอม (แนะนำเพื่อน) */
.ref-info{background:var(--bg);border-radius:var(--r);padding:6px 4px;margin:16px 0 14px}
.ref-info-row{display:flex;align-items:center;gap:12px;padding:10px 12px}
.ref-info-row+.ref-info-row{border-top:1px solid var(--line)}
.ref-info-row .ic{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;flex:none}
.ref-info-row .bd{flex:1;min-width:0}
.ref-info-row .k{font-size:11.5px;color:var(--ink-3)}
.ref-info-row .v{font-size:15px;font-weight:700;color:var(--ink);margin-top:1px}

/* ปุ่มแชร์โซเชียล */
.share-row{display:flex;justify-content:center;gap:14px}
.share-btn{width:50px;height:50px;border-radius:50%;display:grid;place-items:center;color:#fff;
  box-shadow:0 4px 12px rgba(16,24,40,.16);transition:.14s}
.share-btn:active{transform:scale(.9)}
.share-btn svg{width:26px;height:26px}
.share-btn.fb{background:#1877F2}
.share-btn.x{background:#000}
.share-btn.line{background:#06C755}
.share-btn.tg{background:linear-gradient(180deg,#37AEE2,#1E96C8)}
.share-btn.ig{background:linear-gradient(45deg,#feda75 0%,#fa7e1e 28%,#d62976 55%,#962fbf 78%,#4f5bd5 100%)}
@media(max-width:360px){.share-row{gap:10px}.share-btn{width:46px;height:46px}.share-btn svg{width:23px;height:23px}}

/* =========================================================
   v9 — popup แจ้งเตือน (กำหนดรับเครดิต/ค่าคอม)
   ========================================================= */
#notifyModal{position:fixed;inset:0;z-index:410;display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .25s}
#notifyModal.show{opacity:1;pointer-events:auto}
#notifyModal .nm-backdrop{position:absolute;inset:0;background:rgba(10,12,18,.6);backdrop-filter:blur(3px)}
#notifyModal .nm-card{position:relative;width:calc(100% - 48px);max-width:340px;background:#fff;
  border-radius:24px;padding:26px 22px 22px;box-shadow:var(--sh-3);text-align:center;
  transform:translateY(14px) scale(.94);transition:transform .3s cubic-bezier(.22,1,.36,1)}
#notifyModal.show .nm-card{transform:translateY(0) scale(1)}
#notifyModal .nm-bell{width:62px;height:62px;border-radius:50%;margin:0 auto 14px;display:grid;place-items:center;
  background:var(--o-50);color:var(--o-600);box-shadow:0 6px 18px rgba(242,116,26,.22)}
#notifyModal .nm-bell svg{width:30px;height:30px}
#notifyModal .nm-title{font-size:18px;font-weight:700;margin:0 0 16px;color:var(--ink)}
#notifyModal .nm-msg{font-size:14px;color:var(--ink-2);line-height:1.6;margin:0 0 18px}
#notifyModal .nm-rows{text-align:left;background:var(--bg);border-radius:var(--r);padding:6px 4px;margin-bottom:18px}
#notifyModal .nm-row{display:flex;align-items:center;gap:12px;padding:11px 12px}
#notifyModal .nm-row+.nm-row{border-top:1px solid var(--line)}
#notifyModal .nm-row .ic{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;flex:none}
#notifyModal .nm-row .ic svg{width:19px;height:19px}
#notifyModal .nm-row .k{font-size:11.5px;color:var(--ink-3)}
#notifyModal .nm-row .v{font-size:15px;font-weight:700;color:var(--ink);margin-top:1px}

/* =========================================================
   v10 — โปรโมชั่น (เนื้อหา HTML) + คูปอง
   ========================================================= */
.promo-content{font-size:14px;line-height:1.7;color:var(--ink-2)}
.promo-content h1,.promo-content h2,.promo-content h3{font-size:15.5px;font-weight:700;color:var(--ink);
  margin:16px 0 8px;padding-left:12px;border-left:3px solid var(--o-500);line-height:1.4}
.promo-content h1:first-child,.promo-content h2:first-child,.promo-content h3:first-child{margin-top:0}
.promo-content ul{margin:6px 0;padding-left:20px}
.promo-content ul ul{margin:4px 0}
.promo-content li{margin:4px 0;position:relative}
.promo-content p{margin:4px 0}
.promo-content a{color:var(--o-600);font-weight:500}
.promo-content img{border-radius:var(--r);margin:8px 0}
.promo-content strong,.promo-content b{color:var(--ink)}

/* การ์ดคูปอง */
.coupon-hero{display:flex;align-items:center;gap:16px;border-radius:var(--r-lg);overflow:hidden;
  background:var(--grad);color:#fff;padding:18px;box-shadow:var(--sh-o);position:relative}
.coupon-hero::after{content:"";position:absolute;left:78px;top:-10px;bottom:-10px;width:2px;
  background:repeating-linear-gradient(#fff 0 6px,transparent 6px 12px);opacity:.5}
.coupon-hero .cp-left{width:60px;height:60px;border-radius:16px;background:rgba(255,255,255,.18);
  display:grid;place-items:center;flex:none}
.coupon-hero .cp-right{flex:1;padding-left:6px}

/* รายการข้อมูล (โปรไฟล์) */
.info-list{padding:2px 2px}
.info-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 14px}
.info-row+.info-row{border-top:1px solid var(--line)}
.info-row .k{font-size:13px;color:var(--ink-3);flex:none}
.info-row .v{font-size:14px;font-weight:600;color:var(--ink);text-align:right;word-break:break-word;min-width:0}
.info-row .copyable{cursor:pointer;display:inline-flex;align-items:center;gap:5px}
.info-row .copyable::after{content:"⧉";opacity:.45;font-size:13px}
.info-row .copyable:active{opacity:.6}

/* =========================================================
   v4 — การ์ดบัญชีโอนเงิน (deposit) แบบพาเนลเข้ม + ชื่อ/เลขบัญชีนีออนเด่น
   ========================================================= */
.bank-neon{
  position:relative;overflow:hidden;border-radius:var(--r-lg);
  background:linear-gradient(150deg,#1b1f2b 0%,#262b3a 55%,#1b1f2b 100%);
  padding:18px 18px 16px;margin-bottom:12px;
  box-shadow:0 10px 26px rgba(16,24,40,.22),inset 0 0 0 1px rgba(255,170,80,.25);
}
.bank-neon::after{content:"";position:absolute;right:-50px;top:-60px;width:180px;height:180px;
  background:radial-gradient(circle,rgba(255,150,40,.18),transparent 70%);border-radius:50%}
.bank-neon .bn-head{display:flex;align-items:center;gap:10px;position:relative;z-index:1}
.bank-neon .bn-logo{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;
  font-weight:800;color:#fff;font-size:13px;flex:none;overflow:hidden;
  background:linear-gradient(135deg,#7C53E0,#5B33C0);box-shadow:0 0 14px rgba(124,83,224,.7)}
.bank-neon .bn-logo.has-img{background:#fff;padding:6px;box-shadow:0 0 16px rgba(255,255,255,.55)}
.bank-neon .bn-logo img{display:block}
.bank-neon .bn-bank{font-size:13.5px;font-weight:600;color:#fff}
.bank-neon .bn-status{font-size:11px;color:#7CF6B0;text-shadow:0 0 8px rgba(40,230,140,.8)}
/* ชื่อบัญชี — ตัวใหญ่ นีออนเขียวมิ้นต์ */
.bank-neon .bn-name{
  margin-top:14px;font-size:21px;font-weight:800;letter-spacing:.3px;color:#EAFBF2;
  text-shadow:0 0 8px rgba(120,246,176,.9),0 0 20px rgba(40,230,140,.7),0 0 36px rgba(20,200,120,.5);
}
/* เลขบัญชี — ตัวใหญ่สุด นีออนส้มทอง */
.bank-neon .bn-acct{
  margin-top:6px;font-size:30px;font-weight:800;letter-spacing:1.5px;line-height:1.05;
  color:#FFF3E2;font-variant-numeric:tabular-nums;
  text-shadow:0 0 8px rgba(255,224,178,.95),0 0 20px rgba(255,150,40,.85),0 0 40px rgba(242,116,26,.65);
  animation:neonPulse 2.6s ease-in-out infinite;
}
.bank-neon .bn-copy{
  margin-top:14px;width:100%;height:46px;border-radius:var(--r-pill);
  font-weight:700;font-size:15px;color:#fff;display:flex;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(135deg,#FFA84D,#E85D04);box-shadow:0 0 18px rgba(242,116,26,.6);
}
.bank-neon .bn-copy:active{transform:translateY(1px) scale(.99)}
@keyframes neonPulse{0%,100%{filter:brightness(1)}50%{filter:brightness(1.16)}}
@media (prefers-reduced-motion:reduce){.bank-neon .bn-acct{animation:none}}


/* --- การ์ดความคืบหน้าโปรคูปอง (เติมสะสม ฿300 ช่วง 16-22 น.) v11 --- */
.cpp-card{background:#fff;border:1px solid var(--o-100);border-radius:16px;padding:14px 15px;box-shadow:0 4px 14px rgba(242,116,26,.10)}
.cpp-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:9px}
.cpp-title{font-size:13.5px;font-weight:700;color:var(--ink)}
.cpp-win{font-size:11px;font-weight:600;color:var(--o-600);background:var(--o-50);padding:3px 9px;border-radius:999px}
.cpp-amount{font-size:27px;font-weight:800;color:var(--o-600);line-height:1}
.cpp-target{font-size:14px;font-weight:600;color:var(--ink-3);margin-left:5px}
.cpp-bar{height:9px;border-radius:999px;background:#F1ECE7;overflow:hidden;margin:10px 0 9px}
.cpp-bar>span{display:block;height:100%;border-radius:999px;background:var(--grad-soft);transition:width .55s cubic-bezier(.4,0,.2,1)}
.cpp-status{font-size:12.5px;line-height:1.55;color:var(--ink-2)}
.cpp-status b{color:var(--o-600)}
.cpp-card.done{border-color:#BFE6C5;box-shadow:0 4px 14px rgba(46,180,80,.15)}
.cpp-card.done .cpp-amount{color:#1F9E45}
.cpp-card.done .cpp-status b{color:#1F9E45}
.cpp-card.done .cpp-bar>span{background:linear-gradient(90deg,#56D97A,#22B24F)}
.cpp-card.done .cpp-win{background:#E5F6E9;color:#1F9E45}
