/* =========================================================
   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) + env(safe-area-inset-bottom) + 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}
.t-pink{background:#FDEAF1;color:#E0559A}

/* ---------- 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:calc(var(--nav-h) + env(safe-area-inset-bottom));
  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: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:calc(104px + env(safe-area-inset-bottom))}

/* 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/Premium) */
.tier-vip::after,.tier-vvip::after,.tier-premium::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}
/* VIP Premium — ทองหรู (ทุกคนได้) */
.tier-premium{color:#5A3A05;background:linear-gradient(135deg,#FFF6D8,#FBD469 40%,#E0A81B);
  border-color:rgba(255,244,200,.95);
  box-shadow:0 3px 14px rgba(224,168,27,.6),inset 0 1px 0 rgba(255,255,255,.85),0 0 0 1px rgba(224,168,27,.35)}
.tier-premium svg{color:#8A5A00}
/* ทั่วไป — เงิน */
.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,.tier-premium::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}
/* บรรทัดบัญชี v24: (โลโก้ธนาคาร) เลขบัญชี · (ไอคอน) รหัสสมาชิก — บรรทัดเดียว */
.acct-head{display:flex;align-items:center;flex-wrap:nowrap;gap:9px;opacity:.92;font-size:11px}
.acct-seg{display:inline-flex;align-items:center;gap:5px;white-space:nowrap;flex:none}
.acct-seg svg{opacity:.9;flex:none}
.acct-bank{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;
  background:#fff;border-radius:5px;padding:1.5px;flex:none;box-shadow:0 1px 2px rgba(0,0,0,.18)}
.acct-bank img{width:100%;height:100%;object-fit:contain}

/* =========================================================
   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}

/* --- แถบ % + คำเตือน หน้าเปลี่ยนรหัสผ่าน v12 --- */
.pw-strength-row{display:flex;justify-content:space-between;align-items:baseline;margin-top:8px}
.pw-strength-row .pw-label{margin-top:0}
.pw-pct{font-size:13px;font-weight:800;color:var(--ink-3)}
.pw-meter.lv1 .pw-pct{color:var(--red)}
.pw-meter.lv2 .pw-pct{color:#D88200}
.pw-meter.lv3 .pw-pct{color:var(--blue)}
.pw-meter.lv4 .pw-pct{color:var(--green)}
.pw-warn{list-style:none;margin:9px 0 0;padding:0;display:flex;flex-direction:column;gap:5px}
.pw-warn:empty{margin:0}
.pw-warn li{position:relative;padding-left:18px;font-size:11.5px;line-height:1.45;color:#B9741A}
.pw-warn li::before{content:"!";position:absolute;left:0;top:0;width:14px;height:14px;border-radius:50%;background:var(--o-100);color:var(--o-600);font-size:10px;font-weight:800;text-align:center;line-height:14px}

/* --- ปุ่มติดต่อ LINE v13 --- */
.btn-line{background:#06C755;color:#fff;box-shadow:0 8px 18px rgba(6,199,85,.35)}
.btn-line:active{filter:brightness(.96)}
.lock-badge{width:74px;height:74px;border-radius:50%;margin:0 auto 6px;display:grid;place-items:center;background:var(--o-50);color:var(--o-500)}
.mi.t-line{background:#E7F9EE;color:#06C755}

/* --- กล่องผลลัพธ์หน้าเทสสมัคร v14 --- */
.rt-out{margin-top:14px;padding:13px 14px;border-radius:12px;font-size:12px;line-height:1.5;white-space:pre-wrap;word-break:break-word;font-family:ui-monospace,Menlo,Consolas,monospace;border:1px solid var(--line);background:var(--bg);color:var(--ink)}
.rt-out.ok{background:var(--green-bg);border-color:#BFE6C5;color:#146c43}
.rt-out.err{background:var(--red-bg);border-color:#F5C2C7;color:#B02A31}

/* --- โลโก้ SpiniX FIN บน hero หน้า auth v15 --- */
.auth-logo{width:222px;max-width:66%;height:auto;display:block;margin:2px auto 0;filter:drop-shadow(0 6px 15px rgba(0,0,0,.28))}

/* ============================================================
   กาชาปอง v16 — ตู้โหลใส + คันโยก + ถาด + เปิดแคปซูลพรีเมียม
   ============================================================ */
.gacha-machine{width:262px;margin:0 auto;position:relative;display:flex;flex-direction:column;align-items:center;user-select:none}

/* --- โหลแก้วใส --- */
.gm-dome{position:relative;width:234px;height:234px;border-radius:50%;overflow:hidden;
  background:
    radial-gradient(circle at 36% 25%, rgba(255,255,255,.72), rgba(255,255,255,0) 42%),
    radial-gradient(circle at 62% 90%, rgba(110,170,222,.52), rgba(110,170,222,0) 56%),
    radial-gradient(circle at 50% 48%, rgba(233,246,255,.32), rgba(165,205,240,.52) 100%);
  border:3px solid rgba(255,255,255,.55);
  box-shadow:inset 0 -28px 52px rgba(50,100,168,.48),inset 0 22px 42px rgba(255,255,255,.8),inset 0 0 0 7px rgba(255,255,255,.09),0 18px 36px rgba(28,58,108,.3)}
/* แสงพื้นโหล (แก้วโปร่ง) */
.gm-dome::after{content:"";position:absolute;left:16%;right:16%;bottom:6%;height:20%;border-radius:50%;pointer-events:none;
  background:radial-gradient(closest-side,rgba(255,255,255,.5),rgba(255,255,255,0));filter:blur(3px)}
.gm-glass{position:absolute;inset:0;border-radius:50%;pointer-events:none;z-index:6;
  background:
    radial-gradient(46px 30px at 33% 22%, rgba(255,255,255,.98), rgba(255,255,255,0) 72%),
    radial-gradient(20px 13px at 70% 18%, rgba(255,255,255,.6), rgba(255,255,255,0) 76%)}
/* ส่วนโค้งแสงบนขอบแก้ว */
.gm-glass::after{content:"";position:absolute;left:15%;right:22%;top:7%;height:16%;border-radius:50%;
  background:linear-gradient(rgba(255,255,255,.6),rgba(255,255,255,0));filter:blur(1.5px);transform:rotate(-8deg)}
.gm-shine{position:absolute;top:-10%;left:0;width:55%;height:120%;pointer-events:none;z-index:5;
  background:linear-gradient(105deg,transparent 15%,rgba(255,255,255,.5) 50%,transparent 85%);
  transform:translate3d(-140%,0,0) skewX(-18deg);will-change:transform;
  animation:gmShine 5s cubic-bezier(.45,0,.55,1) infinite}
/* กวาดด้วย transform (GPU ลื่น) + ค้างนอกจอตอนพัก จะได้ไม่เห็นการกระตุก */
@keyframes gmShine{0%,58%{transform:translate3d(-140%,0,0) skewX(-18deg)}88%,100%{transform:translate3d(320%,0,0) skewX(-18deg)}}

/* ลูกบอลในโหล */
.gm-balls{position:absolute;inset:0}
.gm-ball{position:absolute;width:32px;height:32px;border-radius:50%;display:grid;place-items:center;
  font-size:11px;font-weight:800;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.55);
  background:
    radial-gradient(circle at 34% 27%, rgba(255,255,255,.95), rgba(255,255,255,0) 34%),
    radial-gradient(circle at 72% 80%, rgba(0,0,0,.5), rgba(0,0,0,0) 52%),
    var(--bc,#F5A524);
  box-shadow:0 3px 6px rgba(0,0,0,.35),inset 0 -4px 7px rgba(0,0,0,.32),inset 2px 3px 6px rgba(255,255,255,.3)}
/* จุดสะท้อนแสงคม (specular) */
.gm-ball::after{content:"";position:absolute;top:4px;left:7px;width:11px;height:8px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.98),rgba(255,255,255,0) 68%);transform:rotate(-18deg)}
.gm-ball.float{animation:gmFloat 3s ease-in-out infinite}
@keyframes gmFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}

/* แคปซูลที่ไหลลง */
.gm-drop{position:absolute;left:50%;top:60%;width:38px;height:38px;margin-left:-19px;border-radius:50%;z-index:5;
  background:linear-gradient(135deg,#FFE39A,#F5A524 55%,#E2731A);
  box-shadow:inset -5px -6px 10px rgba(0,0,0,.3),inset 5px 5px 9px rgba(255,255,255,.6),0 3px 7px rgba(0,0,0,.28);
  display:grid;place-items:center}
.gm-drop-q{color:#fff;font-weight:900;font-size:18px;text-shadow:0 1px 2px rgba(0,0,0,.4)}
.gm-drop.run{animation:gmDropRun 1.25s cubic-bezier(.5,.05,.35,1) forwards}
@keyframes gmDropRun{
  0%{top:58%;transform:rotate(0) scale(.7);opacity:0}
  12%{opacity:1;transform:rotate(40deg) scale(1)}
  55%{top:118%;transform:rotate(360deg) scale(1)}
  70%{top:150%;transform:rotate(520deg)}
  100%{top:172%;transform:rotate(720deg) scale(.9);opacity:0}
}

/* --- คอ + ตัวเครื่อง --- */
.gm-neck{width:120px;height:16px;margin-top:-4px;background:linear-gradient(#e9e4dc,#cfc7bb);border-radius:0 0 8px 8px;box-shadow:inset 0 -3px 5px rgba(0,0,0,.15)}
.gm-body{width:210px;margin-top:-2px;padding:14px 16px 0;border-radius:18px 18px 20px 20px;position:relative;
  background:linear-gradient(160deg,#FFB255,#F2741A 55%,#D95A08);
  box-shadow:0 12px 26px rgba(226,94,4,.34),inset 0 2px 3px rgba(255,255,255,.4),inset 0 -8px 16px rgba(0,0,0,.18)}
.gm-brand{text-align:center;color:#fff;font-weight:900;letter-spacing:1.5px;font-size:13px;text-shadow:0 1px 2px rgba(0,0,0,.3)}
.gm-brand span{color:#FFE39A}
.gm-panel{display:flex;align-items:center;justify-content:space-between;margin-top:10px;
  background:rgba(0,0,0,.14);border-radius:12px;padding:12px 14px}
.gm-slot{width:70px;height:12px;border-radius:8px;background:#3a2410;box-shadow:inset 0 2px 4px rgba(0,0,0,.6),0 1px 0 rgba(255,255,255,.15)}

/* คันโยก */
.gm-lever{position:relative;width:48px;height:48px;border-radius:50%;
  background:radial-gradient(circle at 38% 34%,#fff,#d7d2c8 60%,#a9a49a);
  box-shadow:inset -3px -3px 6px rgba(0,0,0,.25),inset 3px 3px 6px rgba(255,255,255,.7),0 3px 6px rgba(0,0,0,.3);
  cursor:pointer;transition:transform .12s}
.gm-lever-arm{position:absolute;top:50%;left:50%;width:8px;height:26px;margin:-4px 0 0 -4px;transform-origin:4px 4px;
  background:linear-gradient(#c0392b,#7d1f16);border-radius:6px;box-shadow:0 2px 3px rgba(0,0,0,.35)}
.gm-knob{position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border-radius:50%;
  background:radial-gradient(circle at 36% 32%,#ff7a6b,#c0392b 60%,#7d1f16);box-shadow:inset -2px -2px 4px rgba(0,0,0,.4),0 2px 4px rgba(0,0,0,.35)}
.gm-lever.turn{animation:gmLever .6s ease}
@keyframes gmLever{0%{transform:rotate(0)}45%{transform:rotate(150deg)}100%{transform:rotate(360deg)}}

/* ถาดรับ */
.gm-tray{margin:12px -16px 0;height:52px;border-radius:0 0 18px 18px;position:relative;
  background:linear-gradient(#8a4a12,#5e320b);box-shadow:inset 0 6px 12px rgba(0,0,0,.4)}
.gm-tray-hole{position:absolute;top:8px;left:50%;width:70px;height:20px;margin-left:-35px;border-radius:50%;
  background:radial-gradient(circle,rgba(28,15,4,0),#1c0f04);box-shadow:inset 0 3px 8px rgba(0,0,0,.8)}
.gm-capsule-tray{position:absolute;left:50%;bottom:9px;width:40px;height:40px;margin-left:-20px;border-radius:50%;cursor:pointer;
  background:linear-gradient(135deg,#FFE39A,#F5A524 55%,#E2731A);
  box-shadow:inset -5px -6px 10px rgba(0,0,0,.3),inset 5px 5px 9px rgba(255,255,255,.6),0 4px 10px rgba(0,0,0,.35);
  animation:gmTrayPop .4s ease, gmTrayBob 1.4s ease-in-out .4s infinite}
.gm-cap-shine{position:absolute;top:7px;left:9px;width:10px;height:7px;border-radius:50%;background:rgba(255,255,255,.85)}
@keyframes gmTrayPop{0%{transform:scale(0) translateY(-20px)}70%{transform:scale(1.15) translateY(0)}100%{transform:scale(1)}}
@keyframes gmTrayBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
.gm-foot{width:180px;height:14px;background:#b84e08;border-radius:0 0 16px 16px;box-shadow:0 8px 14px rgba(0,0,0,.2)}

/* ตารางรางวัลย่อ */
.gm-prizes{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.gm-chip{display:flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:5px 11px 5px 6px;font-size:12.5px;font-weight:700;color:var(--ink)}
.gm-chip i{width:16px;height:16px;border-radius:50%;flex:none;box-shadow:inset -2px -2px 3px rgba(0,0,0,.25)}

/* ============ overlay เปิดแคปซูล ============ */
.gm-reveal{position:fixed;inset:0;z-index:120;display:grid;place-items:center;overflow:hidden}
.gm-reveal-bg{position:absolute;inset:0;background:radial-gradient(circle at 50% 45%,rgba(40,20,60,.72),rgba(8,6,16,.94));animation:gmFade .3s ease}
@keyframes gmFade{from{opacity:0}to{opacity:1}}
.gm-rays{position:absolute;top:45%;left:50%;width:150vmax;height:150vmax;transform:translate(-50%,-50%);opacity:0;
  background:repeating-conic-gradient(from 0deg,rgba(255,214,120,0) 0deg,rgba(255,214,120,.16) 6deg,rgba(255,214,120,0) 12deg)}
.gm-rays.on{opacity:1;animation:gmRays 12s linear infinite}
@keyframes gmRays{to{transform:translate(-50%,-50%) rotate(360deg)}}
.gm-stage{position:relative;display:grid;place-items:center;z-index:2}

/* แคปซูลใหญ่ */
.gm-capsule{position:relative;width:150px;height:150px;border-radius:50%}
.gm-cap-half{position:absolute;left:0;width:150px;height:75px;overflow:hidden}
.gm-cap-top{top:0;border-radius:75px 75px 0 0;background:linear-gradient(160deg,#FFE7A6,#F5A524);box-shadow:inset 0 6px 14px rgba(255,255,255,.6),inset 0 -3px 8px rgba(0,0,0,.18)}
.gm-cap-bot{bottom:0;border-radius:0 0 75px 75px;background:linear-gradient(160deg,#F5A524,#D95A08);box-shadow:inset 0 -8px 16px rgba(0,0,0,.25)}
.gm-cap-band{position:absolute;top:50%;left:0;width:150px;height:12px;margin-top:-6px;background:rgba(255,255,255,.9);border-radius:6px;box-shadow:0 2px 5px rgba(0,0,0,.25)}
.gm-cap-q{position:absolute;inset:0;display:grid;place-items:center;color:#fff;font-size:60px;font-weight:900;text-shadow:0 3px 6px rgba(0,0,0,.35)}
.gm-capsule.spin{animation:gmSpin 1.05s cubic-bezier(.4,0,.2,1)}
@keyframes gmSpin{
  0%{transform:scale(.3) rotate(0);opacity:0}
  15%{opacity:1}
  70%{transform:scale(1.08) rotate(1440deg)}
  85%{transform:scale(1) rotate(1620deg)}
  100%{transform:scale(1) rotate(1620deg)}
}
.gm-capsule.shake{animation:gmShake .5s ease-in-out}
@keyframes gmShake{0%,100%{transform:rotate(0)}20%{transform:rotate(-9deg) scale(1.04)}40%{transform:rotate(9deg) scale(1.04)}60%{transform:rotate(-6deg)}80%{transform:rotate(6deg)}}
.gm-capsule.open .gm-cap-top{animation:gmCapTop .55s cubic-bezier(.4,0,.2,1) forwards}
.gm-capsule.open .gm-cap-bot{animation:gmCapBot .55s cubic-bezier(.4,0,.2,1) forwards}
.gm-capsule.open .gm-cap-band,.gm-capsule.open .gm-cap-q{animation:gmFadeOut .3s forwards}
@keyframes gmCapTop{to{transform:translateY(-160px) rotate(-40deg);opacity:0}}
@keyframes gmCapBot{to{transform:translateY(160px) rotate(40deg);opacity:0}}
@keyframes gmFadeOut{to{opacity:0}}

/* แสงระเบิด + ประกาย */
.gm-burst{position:absolute;width:10px;height:10px;pointer-events:none}
.gm-burst.go::before{content:"";position:absolute;left:50%;top:50%;width:24px;height:24px;margin:-12px 0 0 -12px;border-radius:50%;background:#fff;box-shadow:0 0 60px 40px rgba(255,240,190,.9);animation:gmFlash .6s ease-out forwards}
@keyframes gmFlash{0%{transform:scale(.2);opacity:1}100%{transform:scale(6);opacity:0}}
.gm-spark{position:absolute;left:50%;top:50%;width:9px;height:9px;border-radius:50%;background:#FFD766;box-shadow:0 0 8px 2px rgba(255,215,102,.9)}
.gm-spark.fly{animation:gmSpark .9s ease-out forwards}
@keyframes gmSpark{0%{transform:translate(0,0) scale(1);opacity:1}100%{transform:translate(var(--dx),var(--dy)) scale(.2);opacity:0}}

/* การ์ดรางวัล */
.gm-prizecard{position:relative;z-index:3;text-align:center;padding:0 24px;max-width:320px}
.gm-prizecard.in{animation:gmCardIn .5s cubic-bezier(.2,.8,.2,1.05)}
@keyframes gmCardIn{0%{transform:scale(.4) translateY(20px);opacity:0}100%{transform:scale(1) translateY(0);opacity:1}}
.gm-pc-badge{width:120px;height:120px;margin:0 auto 14px;border-radius:50%;display:grid;place-items:center;
  font-size:30px;font-weight:900;color:#fff;text-shadow:0 2px 5px rgba(0,0,0,.3);
  box-shadow:inset -6px -8px 14px rgba(0,0,0,.25),inset 6px 6px 12px rgba(255,255,255,.5),0 0 40px rgba(255,220,140,.6)}
.gm-pc-title{color:#fff;font-size:22px;font-weight:800}
.gm-pc-sub{color:rgba(255,255,255,.85);font-size:14px;margin-top:4px}
.gm-pc-code{margin-top:12px;display:inline-block;font-family:ui-monospace,Menlo,Consolas,monospace;font-weight:800;letter-spacing:3px;
  font-size:18px;color:#FFE39A;background:rgba(255,255,255,.1);border:1px dashed rgba(255,227,154,.6);border-radius:10px;padding:8px 16px}
.gm-tap-hint{position:absolute;bottom:12%;left:0;right:0;text-align:center;color:rgba(255,255,255,.85);font-size:14px;font-weight:600;z-index:3;animation:gmBlink 1.1s ease-in-out infinite}
@keyframes gmBlink{0%,100%{opacity:.4}50%{opacity:1}}
.gm-lose .gm-pc-badge{filter:grayscale(.65) brightness(.9)}

/* กัน display ใน class ทับ attribute hidden (เช่น .gm-reveal/.gm-drop display:grid) */
[hidden]{display:none!important}

/* เขย่าลูกในโหลตอนกดโยก (ลุ้น) v17 */
.gm-balls.shaking{animation:gmBallsShake .26s ease-in-out infinite}
@keyframes gmBallsShake{0%,100%{transform:translate(0,0) rotate(0)}20%{transform:translate(-9px,5px) rotate(-4deg)}40%{transform:translate(9px,-6px) rotate(4deg)}60%{transform:translate(-7px,-5px) rotate(-3deg)}80%{transform:translate(7px,6px) rotate(3deg)}}
.gm-balls.shaking .gm-ball{animation:gmBallJitter .18s ease-in-out infinite}
@keyframes gmBallJitter{0%,100%{margin-top:0}50%{margin-top:-6px}}

/* ลูกบอลกลิ้งวนสุ่มมั่วตอนโยก (สมจริงแบบตู้จริง) + โลโก้แบรนด์ v18 */
.gm-balls.tumbling{animation:gmBallsShake .2s ease-in-out infinite}
.gm-balls.tumbling .gm-ball{animation:gmTumble var(--tdur,.7s) linear infinite !important}
@keyframes gmTumble{
  0%{transform:translate(0,0) rotate(0)}
  25%{transform:translate(var(--t1x,0),var(--t1y,0)) rotate(140deg)}
  50%{transform:translate(var(--t2x,0),var(--t2y,0)) rotate(250deg)}
  75%{transform:translate(var(--t3x,0),var(--t3y,0)) rotate(330deg)}
  100%{transform:translate(0,0) rotate(360deg)}
}
.gm-logo{display:block;width:132px;max-width:82%;height:auto;margin:0 auto 2px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.32))}

/* การ์ดชวนเพื่อนรับแต้ม (หน้ากาชา) v19 */
.gm-share{margin-top:16px;background:#fff;border:1px solid var(--o-100);border-radius:16px;padding:15px 16px;box-shadow:0 4px 14px rgba(242,116,26,.1)}
.gm-share-h{font-size:15px;font-weight:800;color:var(--o-600)}
.gm-share-p{font-size:12.5px;color:var(--ink-2);line-height:1.5;margin-top:4px}
.gm-share-p b{color:var(--o-600)}
.gm-share-stat{display:flex;gap:8px;margin:12px 0}
.gm-share-stat>div{flex:1;background:var(--o-50);border-radius:12px;padding:9px 4px;text-align:center}
.gm-share-stat .v{font-size:19px;font-weight:800;color:var(--o-600);line-height:1}
.gm-share-stat .k{font-size:11px;color:var(--ink-3);margin-top:3px}
.gm-share-link{display:flex;gap:8px;margin-top:4px}
.gm-share-link input{flex:1;min-width:0;border:1px solid var(--line);border-radius:10px;padding:9px 11px;font-size:12px;color:var(--ink-2);background:var(--bg)}
.gm-share-link button{flex:none;border:0;border-radius:10px;background:var(--grad);color:#fff;font-weight:700;font-size:13px;padding:0 15px;cursor:pointer}
.gm-share-btns{display:flex;gap:8px;margin-top:10px}
.gm-share-btns a{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;height:42px;border-radius:11px;font-weight:700;font-size:13.5px;color:#fff;text-decoration:none}
.gm-share-btns .s-line{background:#06C755}
.gm-share-btns .s-fb{background:#1877F2}
.gm-share-btns .s-tg{background:#229ED9}

/* ปุ่มไลน์เรืองแสง + โลโก้บนหน้าเพจ (contact/register/forgot) v20 */
.btn-line-glow{animation:lineGlow 1.6s ease-in-out infinite}
@keyframes lineGlow{0%,100%{box-shadow:0 6px 16px rgba(6,199,85,.4),0 0 0 0 rgba(6,199,85,.5)}50%{box-shadow:0 8px 24px rgba(6,199,85,.6),0 0 26px 7px rgba(6,199,85,.5)}}
.page-logo{display:block;width:150px;max-width:52%;height:auto;margin:14px auto 4px;filter:drop-shadow(0 3px 9px rgba(226,94,4,.22))}
.tile.t-line{background:#E7F9EE;color:#06C755}

/* tile ติดต่อแอดมิน — เขียวสดเรืองแสง + ไอคอนกระดุกกระดิก v21 */
.tile.glow-line{background:#06C755 !important;color:#fff !important;animation:tileLineGlow 1.5s ease-in-out infinite}
@keyframes tileLineGlow{0%,100%{box-shadow:0 4px 10px rgba(6,199,85,.45),0 0 0 0 rgba(6,199,85,.55)}50%{box-shadow:0 6px 16px rgba(6,199,85,.6),0 0 18px 5px rgba(6,199,85,.65)}}
.tile.glow-line svg{transform-origin:center;animation:lineWiggle 1.1s ease-in-out infinite}
@keyframes lineWiggle{0%,100%{transform:rotate(0) scale(1)}12%{transform:rotate(-13deg) scale(1.12)}26%{transform:rotate(11deg) scale(1.12)}40%{transform:rotate(-8deg) scale(1.05)}54%{transform:rotate(6deg)}70%{transform:rotate(-3deg)}}

/* แบรนด์เกมปิดปรับปรุง — ภาพเทา + ป้ายคาดเฉียง v22 */
.game-card.maint{position:relative;overflow:hidden}
.game-card.maint img{filter:grayscale(1) brightness(.72);opacity:.85}
.game-card.maint::before{content:"";position:absolute;inset:0;background:rgba(90,95,110,.18);z-index:1}
.maint-ribbon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-16deg);z-index:2;pointer-events:none;
  background:#D9363E;color:#fff;font-size:10px;font-weight:800;letter-spacing:.5px;white-space:nowrap;
  padding:3px 12px;border-radius:3px;box-shadow:0 2px 7px rgba(0,0,0,.45),inset 0 1px 0 rgba(255,255,255,.25)}

/* lobby เกมย่อยปิดปรับปรุง (reactive) v23 */
.lobby-card.maint{position:relative;overflow:hidden}
.lobby-card.maint .lobby-thumb img{filter:grayscale(1) brightness(.72);opacity:.85}
.lobby-card.maint .lobby-name{opacity:.55}

/* v25: ไอคอน LINE ในเมนูโปรไฟล์ — เรืองแสง + กระดุกกระดิก เด่นชัด */
.mi.mi-line-glow{background:#06C755;color:#fff;animation:miLineGlow 1.8s ease-in-out infinite}
.mi.mi-line-glow svg{animation:miWiggle 1s ease-in-out infinite;transform-origin:50% 50%}
@keyframes miLineGlow{0%,100%{box-shadow:0 0 0 0 rgba(6,199,85,.45)}50%{box-shadow:0 0 15px 4px rgba(6,199,85,.8)}}
@keyframes miWiggle{0%,100%{transform:rotate(0)}20%{transform:rotate(-10deg)}60%{transform:rotate(10deg)}}
@media (prefers-reduced-motion:reduce){.mi.mi-line-glow,.mi.mi-line-glow svg{animation:none}}

/* v27: ตัวเลือกธนาคารแบบ dropdown เอง (โลโก้+ชื่อทุกตัวเลือก) */
.bank-pick{cursor:pointer;background:#fff;align-items:center}
.bank-menu{margin-top:7px;border:1px solid var(--line);border-radius:14px;background:#fff;box-shadow:var(--sh-2);max-height:288px;overflow:auto}
.bank-opt{display:flex;align-items:center;gap:12px;padding:11px 14px;cursor:pointer;border-bottom:1px solid var(--line)}
.bank-opt:last-child{border-bottom:0}
.bank-opt:active{background:var(--bg)}
.bank-opt img{width:26px;height:26px;object-fit:contain;flex:none}
.bank-opt span{font-size:14px;font-weight:500;color:var(--ink)}

/* v34: เอฟเฟกต์ฉลองกงล้อเต็มจอ */
.wheel-cele{position:fixed;inset:0;z-index:500;display:grid;place-items:center;overflow:hidden;
  background:radial-gradient(circle at 50% 40%,rgba(60,30,0,.5),rgba(10,8,15,.72));backdrop-filter:blur(3px);opacity:0;transition:opacity .3s}
.wheel-cele.show{opacity:1}
.wheel-cele .wc-card{position:relative;z-index:2;text-align:center;color:#fff;padding:0 30px;transform:scale(.55);transition:transform .5s cubic-bezier(.2,1.5,.4,1)}
.wheel-cele.show .wc-card{transform:scale(1)}
.wc-emoji{font-size:66px;line-height:1;filter:drop-shadow(0 5px 14px rgba(0,0,0,.45));animation:wcPop .6s ease}
.wc-title{font-size:30px;font-weight:800;margin-top:8px;text-shadow:0 3px 16px rgba(0,0,0,.55)}
.wheel-cele.win .wc-prize{font-size:46px;font-weight:900;margin:12px 0 6px;letter-spacing:.5px;
  background:linear-gradient(180deg,#FFE9A8,#FFB01F);-webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 3px 10px rgba(255,160,20,.55));animation:wcGlow 1.2s ease-in-out infinite}
.wheel-cele.nowin .wc-prize{font-size:26px;font-weight:700;margin:12px 0 6px;opacity:.92}
.wc-sub{font-size:14px;opacity:.9}
@keyframes wcPop{0%{transform:scale(0)}70%{transform:scale(1.28)}100%{transform:scale(1)}}
@keyframes wcGlow{0%,100%{filter:drop-shadow(0 3px 10px rgba(255,160,20,.5))}50%{filter:drop-shadow(0 3px 24px rgba(255,205,70,.95))}}
.wc-confetti{position:absolute;top:-12vh;width:10px;height:15px;background:var(--h);border-radius:2px;opacity:.95;
  transform:translateX(var(--x));animation:wcFall 2.8s linear var(--d) forwards}
@keyframes wcFall{0%{top:-12vh;transform:translateX(var(--x)) rotate(0)}100%{top:114vh;transform:translateX(calc(var(--x) * 3)) rotate(760deg)}}
@media (prefers-reduced-motion:reduce){.wc-confetti{display:none}.wc-emoji,.wheel-cele.win .wc-prize,.wheel-cele .wc-card{animation:none;transition:none}}

/* v35: ticker ผู้ชนะล่าสุด (สด) */
.live-dot{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:800;color:#fff;background:#E11D48;padding:2px 7px;border-radius:20px;vertical-align:middle;margin-left:6px}
.live-dot::before{content:"";width:6px;height:6px;border-radius:50%;background:#fff;animation:liveBlink 1s ease-in-out infinite}
@keyframes liveBlink{0%,100%{opacity:1}50%{opacity:.25}}
.wheel-win.just-won{animation:winSlide .5s cubic-bezier(.2,1.1,.4,1)}
@keyframes winSlide{0%{opacity:0;transform:translateY(-14px) scale(.96);background:rgba(242,116,26,.14)}100%{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.wheel-win.just-won{animation:none}.live-dot::before{animation:none}}

/* v38: PWA เพิ่มลงหน้าจอโฮม — banner + modal */
.a2hs-banner{position:fixed;left:50%;bottom:calc(var(--nav-h) + 12px);transform:translateX(-50%) translateY(160%);
  width:calc(100% - 22px);max-width:var(--app-w);z-index:600;display:flex;align-items:center;gap:11px;
  background:#fff;border:1px solid var(--line);border-radius:16px;padding:10px 12px;
  box-shadow:0 10px 30px rgba(0,0,0,.22);transition:transform .38s cubic-bezier(.2,1,.3,1)}
.a2hs-banner.show{transform:translateX(-50%) translateY(0)}
.a2hs-banner>img{width:44px;height:44px;border-radius:12px;flex:none}
.a2hs-txt{flex:1;min-width:0;line-height:1.25}
.a2hs-txt b{display:block;font-size:14px;color:var(--ink)}
.a2hs-txt span{font-size:11.5px;color:var(--ink-3)}
.a2hs-go{flex:none;background:var(--grad);color:#fff;font-weight:800;font-size:13px;border-radius:11px;padding:9px 16px;box-shadow:0 3px 10px rgba(226,94,4,.4)}
.a2hs-x{flex:none;width:28px;height:28px;border-radius:50%;background:var(--bg);color:var(--ink-3);font-size:13px;line-height:1}
.a2hs-modal{position:fixed;inset:0;z-index:620;background:rgba(0,0,0,.5);backdrop-filter:blur(2px);display:grid;place-items:center;padding:24px}
.a2hs-card{background:#fff;border-radius:22px;padding:24px 22px;max-width:340px;width:100%;text-align:center;box-shadow:0 20px 50px rgba(0,0,0,.35)}
.a2hs-ic{width:66px;height:66px;border-radius:17px;margin:0 auto 12px;box-shadow:0 6px 16px rgba(226,94,4,.3)}
.a2hs-h{font-size:19px;font-weight:800;color:var(--ink)}
.a2hs-sub{font-size:13px;color:var(--ink-3);margin:5px 0 16px;line-height:1.5}
.a2hs-steps{text-align:left;margin:0 0 18px;padding:0;list-style:none;counter-reset:s}
.a2hs-steps li{counter-increment:s;position:relative;padding:9px 0 9px 40px;font-size:13.5px;color:var(--ink-2);line-height:1.5;border-bottom:1px solid var(--line)}
.a2hs-steps li:last-child{border-bottom:0}
.a2hs-steps li::before{content:counter(s);position:absolute;left:0;top:8px;width:26px;height:26px;border-radius:50%;background:var(--grad);color:#fff;font-weight:800;font-size:13px;display:grid;place-items:center}
@media (prefers-reduced-motion:reduce){.a2hs-banner{transition:none}}

/* v39: เด้งออกจาก in-app browser (LINE/FB…) */
.ext-browser{position:fixed;inset:0;z-index:700;background:linear-gradient(180deg,#FFF3E9,#fff);display:grid;place-items:center;padding:26px}
.ext-browser .ext-card{max-width:360px;width:100%;text-align:center}
.ext-ic{width:76px;height:76px;border-radius:19px;margin:0 auto 14px;box-shadow:0 8px 22px rgba(226,94,4,.32)}
.ext-h{font-size:21px;font-weight:800;color:var(--ink);line-height:1.35}
.ext-sub{font-size:13.5px;color:var(--ink-2);margin:9px 0 0;line-height:1.6}
.ext-steps{font-size:13px;color:var(--ink-2);background:#fff;border:1px dashed var(--o-300);border-radius:14px;padding:13px 15px;margin:16px 0 18px;line-height:1.7;text-align:left}
.ext-steps b{color:var(--o-600)}
.ext-skip{display:block;margin:14px auto 0;background:none;color:var(--ink-3);font-size:13px;text-decoration:underline}

/* v42: ปุ่มคูปอง — ไฟวิ่งรอบไอคอน (chase light) + เรืองแสง */
@property --cpRun{syntax:"<angle>";initial-value:0deg;inherits:false}
.tile.run-light{position:relative;isolation:isolate;animation:cpGlow 1.5s ease-in-out infinite}
.tile.run-light::after{content:"";position:absolute;inset:-3px;border-radius:18px;padding:3px;pointer-events:none;z-index:5;
  background:conic-gradient(from var(--cpRun),#FF7A1A 0deg,#FFC93C 60deg,#FFF6D0 90deg,#FFC93C 120deg,#FF7A1A 180deg,rgba(255,122,26,.25) 300deg,#FF7A1A 360deg);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;
  mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude;
  animation:cpRun 1.3s linear infinite}
@keyframes cpRun{to{--cpRun:360deg}}
@keyframes cpGlow{0%,100%{box-shadow:0 2px 10px rgba(242,116,26,.35)}50%{box-shadow:0 3px 18px rgba(255,180,60,.8)}}
@media (prefers-reduced-motion:reduce){.tile.run-light,.tile.run-light::after{animation:none}}
