:root{
  --bg:#031411;
  --bg2:#071f1b;
  --panel:rgba(3,22,18,.88);
  --panel2:rgba(8,35,29,.74);
  --gold:#d7a94a;
  --gold2:#f4d58a;
  --gold-dim:rgba(215,169,74,.28);
  --green:#0f3d34;
  --emerald:#114a3f;
  --text:#f3ead5;
  --muted:#9b917d;
  --danger:#d66868;
  --success:#7fd0a6;
  --line:rgba(215,169,74,.22);
}
*{box-sizing:border-box}
body{margin:0;background:radial-gradient(circle at 15% 0%,rgba(215,169,74,.09),transparent 34%),radial-gradient(circle at 88% 10%,rgba(29,101,82,.22),transparent 32%),linear-gradient(135deg,#020d0b 0%,#041814 48%,#020b09 100%);color:var(--text);font-family:Inter,system-ui,sans-serif;min-height:100vh}
a{color:inherit}.portal-shell{display:grid;grid-template-columns:292px 1fr;min-height:100vh}.member-sidebar{position:sticky;top:0;height:100vh;border-right:1px solid var(--line);background:linear-gradient(180deg,rgba(5,22,18,.96),rgba(1,9,8,.95));padding:22px;display:flex;flex-direction:column;gap:20px}.brand-mark{display:flex;align-items:center;gap:12px;padding-bottom:18px;border-bottom:1px solid var(--line)}.dragon-seal{width:54px;height:54px;border:1px solid var(--gold);border-radius:50%;display:grid;place-items:center;color:var(--gold2);font-size:30px;background:radial-gradient(circle,rgba(215,169,74,.18),transparent 68%);box-shadow:0 0 24px rgba(215,169,74,.15)}.brand-mark strong{display:block;color:var(--gold);letter-spacing:2px;font-family:'Playfair Display',serif;font-size:18px}.brand-mark span{font-size:10px;color:var(--muted);letter-spacing:1.8px}.side-profile{border:1px solid var(--line);border-radius:18px;padding:16px;background:linear-gradient(145deg,rgba(215,169,74,.07),rgba(11,47,40,.38));min-height:145px}.side-avatar{width:48px;height:48px;border-radius:50%;border:1px solid var(--gold);display:grid;place-items:center;color:var(--gold2);font-family:'Playfair Display',serif;font-size:22px;margin-bottom:12px}.side-profile h3{margin:0 0 4px;color:var(--gold2);font-family:'Playfair Display',serif}.side-profile p{margin:0;color:var(--muted);font-size:12px}.side-tier{display:inline-flex;margin-top:12px;padding:6px 10px;border:1px solid var(--gold-dim);border-radius:999px;color:var(--gold);font-size:11px;text-transform:uppercase;letter-spacing:1px}.side-nav{display:flex;flex-direction:column;gap:8px}.side-nav button{background:transparent;border:1px solid transparent;color:#b5ac98;text-align:left;padding:12px 14px;border-radius:12px;cursor:pointer;font-weight:600;transition:.2s}.side-nav button:hover,.side-nav button.active{border-color:var(--gold-dim);background:rgba(215,169,74,.08);color:var(--gold2)}.sidebar-actions{margin-top:auto;display:flex;flex-direction:column;gap:10px}.soft-link{text-decoration:none;color:var(--gold);font-size:13px}.ghost-btn,.gold-btn{border:1px solid var(--gold-dim);border-radius:12px;padding:12px 16px;background:rgba(215,169,74,.07);color:var(--gold2);font-weight:800;letter-spacing:.8px;cursor:pointer}.gold-btn{background:linear-gradient(135deg,#a97926,#f4d58a,#b9842f);color:#120d05;border:0;box-shadow:0 10px 28px rgba(215,169,74,.18)}.gold-btn.compact{padding:10px 14px}.member-main{padding:26px 32px 60px;min-width:0}.portal-header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:22px}.mini-label{color:var(--gold);font-size:11px;letter-spacing:3px;text-transform:uppercase;font-weight:800}.portal-header h1,.gate-card h1{font-family:'Playfair Display',serif;color:var(--gold2);font-size:36px;margin:6px 0 8px;line-height:1.1}.portal-header p,.gate-card p{color:var(--muted);margin:0;line-height:1.7}.header-actions{display:flex;gap:10px;align-items:center}.portal-section{display:none}.active-section{display:block}.hero-grid{display:grid;grid-template-columns:1.1fr 1fr .9fr;gap:18px;margin-bottom:18px}.digital-card,.progress-card,.notice-card,.lux-panel,.stat-card{border:1px solid var(--line);border-radius:22px;background:linear-gradient(145deg,rgba(7,31,27,.84),rgba(2,12,10,.92));box-shadow:0 18px 50px rgba(0,0,0,.24),inset 0 1px 0 rgba(244,213,138,.06)}.digital-card{min-height:275px;padding:26px;position:relative;overflow:hidden}.digital-card:before{content:"";position:absolute;inset:-80px -40px auto auto;width:240px;height:240px;border-radius:50%;border:1px solid var(--gold-dim);background:radial-gradient(circle,rgba(215,169,74,.18),transparent 68%)}.digital-card:after{content:"♛";position:absolute;right:30px;bottom:10px;color:rgba(215,169,74,.1);font-size:145px;font-family:'Playfair Display',serif}.card-top{display:flex;justify-content:space-between;position:relative;z-index:1}.member-tier-name{font-family:'Playfair Display',serif;font-size:26px;color:var(--gold2);margin:16px 0 6px}.member-id{color:var(--muted);font-size:12px;letter-spacing:2px}.member-points{position:absolute;left:26px;bottom:26px;z-index:1}.member-points span{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:2px}.member-points strong{display:block;font-size:30px;color:var(--gold2);font-family:'Playfair Display',serif}.qr-chip{width:78px;height:78px;border:1px solid var(--gold);border-radius:10px;background:repeating-linear-gradient(45deg,rgba(215,169,74,.85) 0 4px,transparent 4px 8px);opacity:.9}.progress-card,.notice-card{padding:22px}.progress-title{display:flex;justify-content:space-between;gap:10px;color:var(--gold2);font-weight:800}.progress-number{font-family:'Playfair Display',serif;font-size:44px;color:var(--gold2);margin:12px 0}.progress-track{height:13px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid var(--gold-dim);overflow:hidden}.progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#845c21,#e4b657,#fff0af);box-shadow:0 0 18px rgba(215,169,74,.35)}.progress-meta{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}.mini-stat{border:1px solid var(--line);border-radius:14px;padding:12px;background:rgba(255,255,255,.025)}.mini-stat span{display:block;color:var(--muted);font-size:11px}.mini-stat strong{display:block;margin-top:4px;color:var(--gold2)}.notice-list{display:flex;flex-direction:column;gap:10px;margin-top:14px}.notice-item{padding:12px;border:1px solid var(--line);border-radius:14px;background:rgba(215,169,74,.05);font-size:13px;color:#d7ccb7}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}.stat-card{padding:18px}.stat-card span{display:block;color:var(--muted);font-size:11px;letter-spacing:1.4px;text-transform:uppercase}.stat-card strong{display:block;color:var(--gold2);font-size:24px;margin-top:8px;font-family:'Playfair Display',serif}.stat-card small{color:#7c725e}.two-col{display:grid;grid-template-columns:1.25fr .85fr;gap:18px}.lux-panel{padding:20px}.panel-title{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:16px}.panel-title span{color:var(--gold2);font-weight:800}.panel-title small{color:var(--muted);font-size:11px}.monthly-chart{display:grid;grid-template-columns:repeat(12,1fr);gap:8px;align-items:end;height:220px;padding-top:15px}.month-bar{display:flex;flex-direction:column;align-items:center;gap:8px;height:100%;justify-content:flex-end}.bar-shell{width:100%;height:160px;background:rgba(255,255,255,.04);border:1px solid rgba(215,169,74,.12);border-radius:999px;position:relative;overflow:hidden}.bar-fill{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(180deg,#f4d58a,#9f6d25);border-radius:999px 999px 0 0;min-height:3px}.month-bar small{font-size:10px;color:var(--muted);transform:rotate(-45deg)}.section-head{margin:28px 0 18px}.section-head h2{font-family:'Playfair Display',serif;color:var(--gold2);font-size:31px;margin:0 0 8px}.section-head p{color:var(--muted);margin:0}.filter-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}.filter{background:rgba(215,169,74,.06);border:1px solid var(--line);color:var(--muted);padding:9px 12px;border-radius:999px;cursor:pointer}.filter.active{color:#140f06;background:linear-gradient(135deg,#b9842f,#f4d58a);border:0;font-weight:800}.history-list{display:flex;flex-direction:column;gap:12px}.history-row{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center;border:1px solid var(--line);border-radius:18px;padding:16px;background:rgba(255,255,255,.025)}.history-row h3{margin:0 0 6px;color:var(--gold2);font-size:15px}.history-row p{margin:0;color:var(--muted);font-size:12px;line-height:1.6}.history-amount{text-align:right}.history-amount strong{display:block;color:var(--gold2);font-size:18px}.status-pill{display:inline-flex;padding:5px 9px;border-radius:999px;border:1px solid var(--line);font-size:10px;color:var(--gold);text-transform:uppercase;letter-spacing:1px;margin-top:8px}.wallet-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:18px}.lux-input{width:100%;background:rgba(0,0,0,.28);border:1px solid var(--line);border-radius:12px;color:var(--text);padding:13px 14px;margin-bottom:10px;outline:none}.lux-input:focus{border-color:var(--gold)}.session-card,.pending-card{border:1px solid var(--line);border-radius:16px;padding:14px;background:rgba(215,169,74,.05);margin-top:12px}.session-card img{max-width:170px;border-radius:12px;background:#fff;padding:8px;display:block;margin:12px auto}.countdown{color:var(--gold2);font-weight:900}.mt-18{margin-top:18px}.compact-history .history-row{grid-template-columns:auto 1fr auto}.ledger-icon{width:36px;height:36px;border:1px solid var(--gold-dim);border-radius:50%;display:grid;place-items:center;color:var(--gold2)}.tier-roadmap{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.tier-card{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:22px;padding:22px;min-height:285px;background:linear-gradient(145deg,rgba(7,31,27,.88),rgba(2,12,10,.92))}.tier-card.current{border-color:rgba(244,213,138,.75);box-shadow:0 0 0 1px rgba(244,213,138,.16),0 20px 48px rgba(215,169,74,.08)}.tier-card.locked{opacity:.62}.tier-crest{font-family:'Playfair Display',serif;font-size:46px;color:var(--gold2)}.tier-card h3{font-family:'Playfair Display',serif;color:var(--gold2);font-size:24px;margin:10px 0}.tier-card p{color:var(--muted);font-size:13px;line-height:1.6}.tier-benefits{padding:0;margin:14px 0 0;list-style:none}.tier-benefits li{font-size:12px;color:#cbbf99;margin-bottom:8px}.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.benefit-card{border:1px solid var(--line);border-radius:18px;padding:18px;background:rgba(255,255,255,.025)}.benefit-card.unlocked{background:linear-gradient(145deg,rgba(215,169,74,.1),rgba(255,255,255,.02));border-color:rgba(215,169,74,.35)}.benefit-card h3{margin:0 0 7px;color:var(--gold2);font-size:16px}.benefit-card p{margin:0;color:var(--muted);font-size:12px;line-height:1.6}.benefit-tag{display:inline-flex;margin-bottom:12px;padding:5px 8px;border-radius:999px;border:1px solid var(--line);font-size:10px;color:var(--gold);text-transform:uppercase}.referral-panel{display:grid;grid-template-columns:.85fr 1.15fr;gap:18px}.ref-card{border:1px solid var(--line);border-radius:22px;padding:22px;background:linear-gradient(145deg,rgba(215,169,74,.08),rgba(2,12,10,.9))}.ref-code{font-family:'Playfair Display',serif;color:var(--gold2);font-size:30px;letter-spacing:2px;border:1px dashed var(--gold-dim);padding:16px;border-radius:16px;text-align:center;margin:14px 0}.downline-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid rgba(215,169,74,.12);color:#cabf9d}.timeline{position:relative;display:flex;flex-direction:column;gap:14px}.timeline-item{display:grid;grid-template-columns:48px 1fr;gap:14px}.timeline-dot{width:42px;height:42px;border-radius:50%;border:1px solid var(--gold);display:grid;place-items:center;color:var(--gold2);background:rgba(215,169,74,.08)}.timeline-content{border:1px solid var(--line);border-radius:18px;padding:14px;background:rgba(255,255,255,.025)}.timeline-content h3{margin:0 0 6px;color:var(--gold2);font-size:15px}.timeline-content p{margin:0;color:var(--muted);font-size:12px}.login-gate{min-height:calc(100vh - 52px);display:grid;place-items:center}.gate-card{width:min(520px,100%);border:1px solid var(--line);border-radius:28px;padding:34px;background:linear-gradient(145deg,rgba(7,31,27,.95),rgba(2,12,10,.96));box-shadow:0 30px 80px rgba(0,0,0,.35)}.form-message{color:var(--danger);font-size:13px;min-height:20px;margin:8px 0}.member-toast{position:fixed;right:24px;bottom:24px;background:#0b211d;border:1px solid var(--gold-dim);color:var(--gold2);padding:14px 18px;border-radius:14px;box-shadow:0 18px 40px rgba(0,0,0,.35);transform:translateY(30px);opacity:0;pointer-events:none;transition:.22s}.member-toast.show{opacity:1;transform:translateY(0)}.skeleton-soft{animation:pulse 1.4s infinite alternate}@keyframes pulse{from{opacity:.55}to{opacity:1}}@media(max-width:1100px){.portal-shell{grid-template-columns:1fr}.member-sidebar{position:relative;height:auto}.side-nav{display:grid;grid-template-columns:repeat(3,1fr)}.hero-grid,.two-col,.wallet-grid,.referral-panel{grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(2,1fr)}.tier-roadmap,.benefits-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:680px){.member-main{padding:18px}.side-nav{grid-template-columns:1fr 1fr}.portal-header{flex-direction:column}.hero-grid,.stat-grid,.tier-roadmap,.benefits-grid{grid-template-columns:1fr}.monthly-chart{gap:4px}.history-row{grid-template-columns:1fr}.history-amount{text-align:left}.portal-header h1{font-size:28px}.member-sidebar{padding:16px}}


/* ================= V13.1 MOBILE ELITE POLISH ================= */
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body { padding-top: 0; }
.mobile-member-topbar, .mobile-bottom-nav { display: none; }
.side-nav button, .ghost-btn, .gold-btn, .lux-input, .filter { min-height: 44px; }
.history-row, .ref-code, .downline-row, .lux-input, .notice-item, .timeline-content p { overflow-wrap: anywhere; word-break: break-word; }
.portal-section { scroll-margin-top: 78px; }
.member-toast { bottom: calc(28px + env(safe-area-inset-bottom)); }
@media (max-width: 860px) {
  body { padding-top: calc(58px + env(safe-area-inset-top)); padding-bottom: calc(82px + env(safe-area-inset-bottom)); }
  body.auth-mode { padding-bottom: 0; }
  body.auth-mode .member-sidebar, body.auth-mode .mobile-bottom-nav { display: none !important; }
  body.auth-mode .portal-shell { display: block; min-height: 100dvh; }
  body.auth-mode .member-main { padding: 18px 16px calc(24px + env(safe-area-inset-bottom)); min-height: calc(100dvh - 58px); display: grid; place-items: center; }
  body.auth-mode .login-gate { width: 100%; min-height: auto; }
  body.auth-mode .gate-card { width: min(100%, 470px); margin: 0 auto; }
  .mobile-member-topbar { display: flex; position: fixed; left: 0; right: 0; top: 0; height: calc(58px + env(safe-area-inset-top)); padding: env(safe-area-inset-top) 14px 0; align-items: center; justify-content: space-between; gap: 12px; z-index: 80; background: linear-gradient(180deg, rgba(2,13,11,.98), rgba(5,24,20,.94)); border-bottom: 1px solid var(--line); backdrop-filter: blur(16px); }
  .mobile-member-topbar strong { display:block; color: var(--gold2); font-family:'Playfair Display',serif; letter-spacing: 1.6px; line-height: 1; }
  .mobile-member-topbar span { display:block; color: var(--muted); font-size: 10px; letter-spacing: 1.4px; text-transform: uppercase; margin-top: 4px; }
  .mobile-back, .mobile-refresh { width: 42px; height: 42px; border-radius: 999px; border: 1px solid var(--gold-dim); background: rgba(215,169,74,.06); color: var(--gold2); font-size: 18px; }
  .portal-shell { display: block; min-height: auto; }
  .member-sidebar { position: relative; top: auto; height: auto; border-right: 0; border-bottom: 1px solid var(--line); padding: 14px 16px; gap: 12px; }
  .brand-mark, .side-nav, .sidebar-actions { display: none; }
  .side-profile { min-height: 0; display: grid; grid-template-columns: 48px 1fr auto; align-items: center; column-gap: 12px; padding: 12px; border-radius: 16px; }
  .side-avatar { margin: 0; }
  .side-profile h3, .side-profile p { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .side-tier { margin-top: 0; align-self: center; white-space: nowrap; }
  .member-main { padding: 16px 14px 28px; }
  .portal-header { margin-bottom: 16px; }
  .portal-header h1 { font-size: 28px; }
  .portal-header p { font-size: 13px; }
  .header-actions { position: sticky; top: calc(62px + env(safe-area-inset-top)); z-index: 20; width: 100%; justify-content: stretch; background: rgba(4,20,17,.76); border: 1px solid var(--line); border-radius: 16px; padding: 8px; backdrop-filter: blur(12px); }
  .header-actions button { flex: 1; padding: 11px 10px; }
  .hero-grid { grid-template-columns: 1fr; gap: 14px; }
  .digital-card { min-height: 220px; padding: 20px; }
  .digital-card:after { font-size: 105px; }
  .member-points { left: 20px; bottom: 20px; }
  .member-points strong { font-size: 26px; }
  .progress-number { font-size: 36px; }
  .progress-meta, .stat-grid, .wallet-grid, .two-col, .tier-roadmap, .benefits-grid, .referral-panel { grid-template-columns: 1fr !important; }
  .stat-grid { gap: 10px; }
  .stat-card { padding: 14px; }
  .stat-card strong { font-size: 21px; }
  .monthly-chart { height: 170px; gap: 5px; overflow-x: auto; padding-bottom: 8px; }
  .month-bar { min-width: 28px; }
  .bar-shell { height: 112px; }
  .section-head { margin: 22px 0 14px; }
  .section-head h2 { font-size: 26px; }
  .filter-row { overflow-x: auto; flex-wrap: nowrap; padding-bottom: 6px; -webkit-overflow-scrolling: touch; }
  .filter { flex: 0 0 auto; }
  .history-row { grid-template-columns: 1fr; gap: 10px; padding: 14px; }
  .history-amount { text-align: left; }
  .compact-history .history-row { grid-template-columns: 42px 1fr; }
  .compact-history .history-amount { grid-column: 2; }
  .topup-panel { position: relative; }
  .session-card img, .pending-card img { max-width: 148px; }
  .tier-card { min-height: 0; padding: 18px; }
  .tier-benefits { padding-left: 18px; }
  .timeline { padding-left: 8px; }
  .timeline-item { grid-template-columns: 42px 1fr; }
  .mobile-bottom-nav { display: grid; grid-template-columns: repeat(5, 1fr); position: fixed; left: 0; right: 0; bottom: 0; height: calc(68px + env(safe-area-inset-bottom)); padding: 7px 8px env(safe-area-inset-bottom); z-index: 90; background: linear-gradient(180deg, rgba(5,24,20,.92), rgba(1,8,7,.98)); border-top: 1px solid var(--line); box-shadow: 0 -12px 36px rgba(0,0,0,.34); backdrop-filter: blur(16px); }
  .mobile-bottom-nav button { min-width: 0; min-height: 54px; border: 1px solid transparent; border-radius: 16px; background: transparent; color: var(--muted); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px; font-size: 16px; }
  .mobile-bottom-nav button b { font-size: 10px; font-weight: 800; letter-spacing: .2px; white-space: nowrap; }
  .mobile-bottom-nav button.active { color: var(--gold2); border-color: var(--gold-dim); background: rgba(215,169,74,.1); }
  .member-toast { width: calc(100vw - 24px); left: 12px; right: 12px; bottom: calc(82px + env(safe-area-inset-bottom)); transform: translateY(16px); text-align: center; white-space: normal; }
  .member-toast.show { transform: translateY(0); }
}
@media (max-width: 430px) {
  .qr-chip { width: 62px; height: 62px; }
  .portal-header { display: block; }
  .header-actions { margin-top: 12px; }
  .progress-meta { gap: 8px; }
  .mini-stat { padding: 10px; }
  .ref-code { font-size: 22px; }
  .lux-panel, .progress-card, .notice-card { padding: 16px; border-radius: 18px; }
}


/* V16.11 Daily check-in center */
.checkin-panel{display:grid;gap:16px}.checkin-grid{display:grid;grid-template-columns:1.15fr .75fr 1fr;gap:16px}.checkin-card{border:1px solid var(--line);border-radius:22px;padding:22px;background:linear-gradient(145deg,rgba(215,169,74,.09),rgba(2,12,10,.9));box-shadow:0 18px 46px rgba(0,0,0,.24)}.checkin-card.main{position:relative;overflow:hidden}.checkin-card.main:after{content:'✓';position:absolute;right:22px;bottom:-18px;font-size:150px;color:rgba(215,169,74,.08);font-family:'Playfair Display',serif}.checkin-card h3{margin:0 0 10px;color:var(--gold2);font-family:'Playfair Display',serif;font-size:26px}.checkin-card p{color:var(--muted);line-height:1.65;font-size:13px}.checkin-number{font-family:'Playfair Display',serif;font-size:48px;color:var(--gold2);line-height:1;margin:18px 0 2px}.checkin-card small{display:block;color:var(--muted);margin-bottom:16px}.checkin-card .gold-btn:disabled{opacity:.55;filter:grayscale(.4);cursor:not-allowed}.streak-meter{display:flex;align-items:end;gap:8px;margin:18px 0}.streak-meter strong{font-family:'Playfair Display',serif;color:var(--gold2);font-size:58px;line-height:.9}.streak-meter span{color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.08em}@media(max-width:1100px){.checkin-grid{grid-template-columns:1fr}}@media(max-width:860px){.mobile-bottom-nav{grid-template-columns:repeat(6,1fr)}.mobile-bottom-nav button b{font-size:9px}.checkin-card{padding:18px}.checkin-card h3{font-size:22px}}

/* V16.12: unified Vietnamese UTF-8 font rendering and mobile portal polish */
html,body,button,input,textarea,select,a,p,span,small,b,strong,li,td,th,label{font-family:'Be Vietnam Pro','Inter','Noto Sans Vietnamese','Noto Sans','Segoe UI',Roboto,Arial,sans-serif;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}
.brand-mark strong,.side-avatar,.side-profile h3,.portal-header h1,.gate-card h1,.member-tier-name,.member-points strong,.digital-card:after{font-family:Georgia,'Times New Roman','Noto Serif',serif;letter-spacing:.02em;}
@media(max-width:1024px){.portal-shell{grid-template-columns:1fr}.member-sidebar{position:relative;height:auto}.member-main{padding:20px 18px 48px}.hero-grid{grid-template-columns:1fr 1fr}.portal-header{flex-direction:column}.header-actions{width:100%;flex-wrap:wrap}}
@media(max-width:680px){.hero-grid,.progress-meta,.stat-grid,.two-col-grid{grid-template-columns:1fr!important}.member-main{padding:16px 12px 42px}.portal-header h1,.gate-card h1{font-size:28px}.side-nav{display:grid;grid-template-columns:1fr 1fr}.side-nav button{font-size:12px;padding:10px}.digital-card{min-height:235px}.member-points strong{font-size:25px}}

.gate-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px}.gate-actions .gold-btn{width:100%;text-align:center;text-decoration:none}.secondary-register{background:rgba(215,169,74,.08)!important;color:var(--gold2)!important;border:1px solid var(--gold-dim)!important;box-shadow:none!important}
@media(max-width:560px){.gate-actions{grid-template-columns:1fr}}

/* V16.20: Vietnamese font + member exclusive products + reward projection */
html,body,button,input,textarea,select,a,p,span,small,b,strong,li,td,th,label,h1,h2,h3,h4,h5,h6,.font-serif,.brand-mark strong,.side-avatar,.side-profile h3,.portal-header h1,.gate-card h1,.member-tier-name,.member-points strong,.digital-card:after,.section-head h2,.checkin-card h3,.stat-card strong{font-family:'Be Vietnam Pro','Noto Sans Vietnamese','Noto Sans','Segoe UI',Roboto,Arial,sans-serif!important;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}
.wallet-overview-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;margin:0 0 18px}.wallet-mini-card{border:1px solid var(--line);border-radius:20px;padding:16px;background:linear-gradient(145deg,rgba(215,169,74,.075),rgba(2,12,10,.9));box-shadow:0 14px 36px rgba(0,0,0,.18)}.wallet-mini-card small{color:var(--gold);font-weight:900;letter-spacing:.16em}.wallet-mini-card h3{margin:8px 0 5px;color:var(--gold2);font-size:15px}.wallet-mini-card strong{display:block;color:#fff1be;font-size:20px;margin-bottom:8px}.wallet-mini-card p{margin:0;color:var(--muted);font-size:12px;line-height:1.55}.reward-projection-panel{border:1px solid var(--line);border-radius:24px;background:radial-gradient(circle at 82% 12%,rgba(215,169,74,.14),transparent 28%),linear-gradient(145deg,rgba(8,35,29,.9),rgba(2,12,10,.95));padding:20px;margin:0 0 18px;box-shadow:0 18px 50px rgba(0,0,0,.24)}.reward-panel-main{display:flex;justify-content:space-between;gap:20px;align-items:flex-start}.reward-panel-main h3{margin:6px 0 8px;color:var(--gold2);font-size:24px}.reward-panel-main p{margin:0;color:#d7ccb7;line-height:1.65}.reward-big{text-align:right;min-width:270px}.reward-big span,.reward-big small{display:block;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.12em}.reward-big strong{display:block;color:var(--gold2);font-size:32px;margin:7px 0}.reward-progress-row{display:grid;grid-template-columns:260px 1fr 55px;gap:12px;align-items:center;margin:18px 0}.reward-progress-copy b{display:block;color:var(--gold2)}.reward-progress-copy span{color:var(--muted);font-size:12px}.reward-progress-track{height:14px;border:1px solid var(--gold-dim);border-radius:999px;background:rgba(255,255,255,.045);overflow:hidden}.reward-progress-track i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#8d6021,#f4d58a,#fff2b4);box-shadow:0 0 18px rgba(215,169,74,.38)}.reward-progress-row em{font-style:normal;color:var(--gold2);font-weight:900}.reward-target-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.reward-target-grid div{border:1px solid rgba(215,169,74,.18);border-radius:14px;padding:12px;background:rgba(0,0,0,.16)}.reward-target-grid span{display:block;color:var(--muted);font-size:11px}.reward-target-grid b{display:block;color:var(--gold2);margin-top:5px}.exclusive-products-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.member-product-card{border:1px solid var(--line);border-radius:24px;background:linear-gradient(145deg,rgba(7,31,27,.88),rgba(2,12,10,.94));overflow:hidden;box-shadow:0 18px 48px rgba(0,0,0,.24)}.member-product-img{aspect-ratio:4/3;border-bottom:1px solid var(--line);background:radial-gradient(circle,rgba(215,169,74,.14),rgba(0,0,0,.22));display:grid;place-items:center;position:relative;color:var(--gold2);font-weight:900;letter-spacing:.12em}.member-product-img img{width:100%;height:100%;object-fit:cover;display:block}.member-product-img b{position:absolute;top:12px;left:12px;border-radius:999px;background:linear-gradient(135deg,#f4d58a,#a97926);color:#120d05;padding:6px 10px;font-size:12px}.member-product-info{padding:18px;display:grid;gap:10px}.member-product-info small{color:var(--gold);font-weight:900;letter-spacing:.16em}.member-product-info h3{margin:0;color:var(--gold2);font-size:20px}.member-product-info p{margin:0;color:var(--muted);line-height:1.6;font-size:13px}.member-price{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.member-price strong{color:#fff0bd;font-size:22px}.member-price del{color:#81745d}
@media(max-width:1180px){.wallet-overview-grid,.reward-target-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.exclusive-products-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.reward-panel-main{display:grid}.reward-big{text-align:left}.reward-progress-row{grid-template-columns:1fr}}
@media(max-width:860px){.mobile-bottom-nav{grid-template-columns:repeat(7,1fr)}.mobile-bottom-nav button b{font-size:8px}.wallet-overview-grid,.reward-target-grid,.exclusive-products-grid{grid-template-columns:1fr}.reward-projection-panel{padding:16px}.reward-big strong{font-size:26px}}


/* V16.27: Member login dragon welcome overlay */
.dragon-welcome{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;overflow:hidden;background:radial-gradient(circle at 50% 44%,rgba(18,80,64,.58),rgba(1,8,7,.94) 62%,rgba(0,0,0,.98));opacity:0;visibility:hidden;pointer-events:none;transition:opacity .55s ease,visibility .55s ease}.dragon-welcome.show{opacity:1;visibility:visible}.dragon-aura{position:absolute;inset:-18%;background:radial-gradient(circle at 50% 48%,rgba(244,213,138,.24),transparent 28%),radial-gradient(circle at 26% 28%,rgba(3,121,91,.28),transparent 24%),radial-gradient(circle at 76% 68%,rgba(215,169,74,.2),transparent 26%);filter:blur(2px);animation:dragonAura 4.2s ease both}.dragon-gold-rain{position:absolute;inset:0;opacity:.72;background-image:radial-gradient(circle,rgba(244,213,138,.92) 0 1px,transparent 1.8px),radial-gradient(circle,rgba(255,255,255,.65) 0 1px,transparent 1.7px);background-size:92px 92px,137px 137px;background-position:0 0,44px 28px;animation:goldRain 4.2s linear both}.dragon-stage{width:min(920px,94vw);min-height:min(560px,82vh);display:grid;place-items:center;position:relative;transform:translateY(22px) scale(.94);opacity:0;animation:dragonStage 4.2s cubic-bezier(.2,.9,.2,1) both}.welcome-dragon{width:min(900px,94vw);height:auto;overflow:visible;filter:drop-shadow(0 0 16px rgba(244,213,138,.22)) drop-shadow(0 22px 46px rgba(0,0,0,.42))}.dragon-line{fill:none;stroke:url(#dragonGold);stroke-width:18;stroke-linecap:round;stroke-linejoin:round;filter:url(#dragonSoftGlow);stroke-dasharray:1200;stroke-dashoffset:1200;animation:drawDragon 2.35s ease-out .25s forwards}.dragon-line.secondary{stroke-width:9;opacity:.82;animation-delay:.55s}.dragon-line.thin{stroke-width:6;opacity:.82;stroke-dasharray:420;stroke-dashoffset:420;animation:drawDragon 1.55s ease-out 1.05s forwards}.dragon-halo{opacity:0;animation:dragonPulse 3.2s ease .35s both}.dragon-scale{fill:none;stroke:#ffe9a6;stroke-width:5;stroke-linecap:round;stroke-linejoin:round;opacity:0;animation:scaleFlash 1.4s ease 1.35s forwards}.dragon-eye{fill:#fff6c7;filter:drop-shadow(0 0 12px #f4d58a);opacity:0;animation:eyeIgnite .55s ease 1.5s forwards}.dragon-pearl{fill:rgba(244,213,138,.16);stroke:#ffe8a0;stroke-width:3;filter:drop-shadow(0 0 20px rgba(244,213,138,.85));opacity:0;animation:pearlRise 1.25s ease 1.55s forwards}.dragon-pearl.core{fill:#fff1b5;stroke:none}.dragon-welcome-copy{position:absolute;left:50%;bottom:8%;width:min(720px,90vw);transform:translateX(-50%) translateY(20px);text-align:center;opacity:0;animation:welcomeCopy 1.2s ease 2.05s forwards}.dragon-welcome-copy span{display:inline-flex;letter-spacing:.24em;text-transform:uppercase;color:#f4d58a;font-size:12px;font-weight:900;padding:8px 14px;border:1px solid rgba(244,213,138,.35);border-radius:999px;background:rgba(1,8,7,.32);backdrop-filter:blur(10px)}.dragon-welcome-copy strong{display:block;margin:14px 0 8px;color:#fff2bd;font-size:clamp(28px,5vw,58px);line-height:1.04;font-weight:900;text-shadow:0 0 24px rgba(244,213,138,.28)}.dragon-welcome-copy p{margin:0;color:#f0e4c2;font-size:clamp(14px,2vw,18px);font-weight:600}.dragon-welcome.show:after{content:'✦ ✧ ✦';position:absolute;top:18%;left:50%;transform:translateX(-50%);color:#fff2bd;letter-spacing:38px;font-size:22px;opacity:0;animation:crestSpark 2.1s ease 1.65s forwards}@keyframes drawDragon{to{stroke-dashoffset:0}}@keyframes dragonStage{0%{opacity:0;transform:translateY(36px) scale(.9) rotate(-1deg)}14%,82%{opacity:1;transform:translateY(0) scale(1) rotate(0)}100%{opacity:0;transform:translateY(-28px) scale(1.04)}}@keyframes dragonAura{0%{transform:scale(.92) rotate(0);opacity:0}20%,82%{opacity:1}100%{transform:scale(1.08) rotate(8deg);opacity:0}}@keyframes goldRain{0%{background-position:0 -120px,44px -60px;opacity:0}24%,78%{opacity:.72}100%{background-position:0 160px,44px 240px;opacity:0}}@keyframes dragonPulse{0%{opacity:0;transform:scale(.86)}35%,80%{opacity:.95;transform:scale(1)}100%{opacity:0;transform:scale(1.08)}}@keyframes scaleFlash{0%{opacity:0;stroke-dasharray:140;stroke-dashoffset:140}100%{opacity:.95;stroke-dashoffset:0}}@keyframes eyeIgnite{to{opacity:1}}@keyframes pearlRise{0%{opacity:0;transform:translateY(20px) scale(.6)}60%,100%{opacity:1;transform:translateY(0) scale(1)}}@keyframes welcomeCopy{to{opacity:1;transform:translateX(-50%) translateY(0)}}@keyframes crestSpark{0%{opacity:0;letter-spacing:18px;transform:translateX(-50%) translateY(15px) scale(.75)}50%{opacity:1}100%{opacity:0;letter-spacing:56px;transform:translateX(-50%) translateY(-15px) scale(1.08)}}
@media(max-width:680px){.dragon-stage{min-height:72vh}.welcome-dragon{width:116vw;transform:translateX(-5vw)}.dragon-line{stroke-width:14}.dragon-line.secondary{stroke-width:7}.dragon-welcome-copy{bottom:10%}.dragon-welcome-copy span{font-size:10px;letter-spacing:.18em}.dragon-welcome-copy strong{font-size:32px}.dragon-welcome-copy p{font-size:13px;padding:0 12px}}
@media(prefers-reduced-motion:reduce){.dragon-welcome,.dragon-aura,.dragon-gold-rain,.dragon-stage,.dragon-line,.dragon-halo,.dragon-scale,.dragon-eye,.dragon-pearl,.dragon-welcome-copy{animation:none!important;transition:none!important}.dragon-welcome.show{opacity:0;visibility:hidden}}


/* V16.27.1: replay dragon animation only when overlay opens */
.dragon-welcome:not(.show) .dragon-aura,.dragon-welcome:not(.show) .dragon-gold-rain,.dragon-welcome:not(.show) .dragon-stage,.dragon-welcome:not(.show) .dragon-line,.dragon-welcome:not(.show) .dragon-halo,.dragon-welcome:not(.show) .dragon-scale,.dragon-welcome:not(.show) .dragon-eye,.dragon-welcome:not(.show) .dragon-pearl,.dragon-welcome:not(.show) .dragon-welcome-copy{animation:none!important}.dragon-welcome.show .dragon-aura{animation:dragonAura 4.2s ease both}.dragon-welcome.show .dragon-gold-rain{animation:goldRain 4.2s linear both}.dragon-welcome.show .dragon-stage{animation:dragonStage 4.2s cubic-bezier(.2,.9,.2,1) both}.dragon-welcome.show .dragon-line{animation:drawDragon 2.35s ease-out .25s forwards}.dragon-welcome.show .dragon-line.secondary{animation-delay:.55s}.dragon-welcome.show .dragon-line.thin{animation:drawDragon 1.55s ease-out 1.05s forwards}.dragon-welcome.show .dragon-halo{animation:dragonPulse 3.2s ease .35s both}.dragon-welcome.show .dragon-scale{animation:scaleFlash 1.4s ease 1.35s forwards}.dragon-welcome.show .dragon-eye{animation:eyeIgnite .55s ease 1.5s forwards}.dragon-welcome.show .dragon-pearl{animation:pearlRise 1.25s ease 1.55s forwards}.dragon-welcome.show .dragon-welcome-copy{animation:welcomeCopy 1.2s ease 2.05s forwards}
@media(prefers-reduced-motion:reduce){.dragon-welcome.show .dragon-aura,.dragon-welcome.show .dragon-gold-rain,.dragon-welcome.show .dragon-stage,.dragon-welcome.show .dragon-line,.dragon-welcome.show .dragon-halo,.dragon-welcome.show .dragon-scale,.dragon-welcome.show .dragon-eye,.dragon-welcome.show .dragon-pearl,.dragon-welcome.show .dragon-welcome-copy{animation:none!important}.dragon-welcome.show{opacity:0!important;visibility:hidden!important}}


/* V16.28: uploaded dragon image + upward lotus light welcome */
.dragon-welcome .dragon-stage{width:min(980px,94vw);min-height:min(640px,84vh);padding:34px 0 116px;}
.welcome-dragon-wrap{position:relative;width:min(440px,54vw);max-width:100%;display:grid;place-items:center}
.dragon-image-aura{position:absolute;inset:13% 6% 7%;background:radial-gradient(circle at 50% 36%,rgba(255,240,180,.42),transparent 35%),radial-gradient(circle at 50% 74%,rgba(244,213,138,.34),transparent 40%),radial-gradient(circle at 50% 50%,rgba(3,121,91,.18),transparent 54%);filter:blur(18px);opacity:0;z-index:1;animation:imageAura 3.2s ease .35s both}
.dragon-light-floor{position:absolute;left:50%;bottom:1.5%;width:58%;height:8%;transform:translateX(-50%);border-radius:50%;background:radial-gradient(circle,rgba(255,245,204,.76) 0%,rgba(244,213,138,.52) 38%,rgba(244,213,138,.12) 62%,transparent 76%);filter:blur(11px);opacity:0;z-index:0;animation:floorGlow 2.8s ease .6s both}
.dragon-light-orb{position:absolute;left:50%;bottom:5%;width:17%;aspect-ratio:1;transform:translateX(-50%);border-radius:50%;background:radial-gradient(circle,rgba(255,248,225,.98) 0%,rgba(255,224,130,.76) 28%,rgba(244,213,138,.18) 62%,transparent 78%);filter:blur(5px);opacity:0;z-index:2;animation:orbIgnite 2.4s ease .75s both}
.dragon-light-beam{position:absolute;left:50%;bottom:8%;border-radius:999px 999px 0 0;transform-origin:50% 100%;opacity:0;filter:blur(8px);mix-blend-mode:screen;z-index:2}
.dragon-light-beam.beam-core{width:16%;height:74%;transform:translateX(-50%);background:linear-gradient(180deg,rgba(255,248,220,0) 0%,rgba(255,248,220,.12) 20%,rgba(255,248,220,.65) 58%,rgba(244,213,138,.82) 84%,rgba(244,213,138,0) 100%);animation:beamCore 2.6s ease .65s both}
.dragon-light-beam.beam-left{width:20%;height:70%;transform:translateX(-50%) rotate(-14deg);background:linear-gradient(180deg,rgba(255,230,150,0) 0%,rgba(255,230,150,.13) 28%,rgba(255,218,125,.5) 66%,rgba(244,213,138,0) 100%);animation:beamSideLeft 2.8s ease .72s both}
.dragon-light-beam.beam-right{width:20%;height:70%;transform:translateX(-50%) rotate(14deg);background:linear-gradient(180deg,rgba(255,230,150,0) 0%,rgba(255,230,150,.13) 28%,rgba(255,218,125,.5) 66%,rgba(244,213,138,0) 100%);animation:beamSideRight 2.8s ease .72s both}
.welcome-dragon-image{position:relative;display:block;width:100%;height:auto;z-index:4;opacity:0;transform:translateY(28px) scale(.92);filter:drop-shadow(0 0 10px rgba(255,240,185,.28)) drop-shadow(0 0 34px rgba(244,213,138,.22)) drop-shadow(0 24px 50px rgba(0,0,0,.42));animation:dragonImage 4.2s cubic-bezier(.2,.9,.2,1) both}
@keyframes imageAura{0%{opacity:0;transform:scale(.9)}24%,80%{opacity:1;transform:scale(1)}100%{opacity:0;transform:scale(1.06)}}
@keyframes floorGlow{0%{opacity:0;transform:translateX(-50%) scale(.55)}30%,84%{opacity:1;transform:translateX(-50%) scale(1)}100%{opacity:0;transform:translateX(-50%) scale(1.18)}}
@keyframes orbIgnite{0%{opacity:0;transform:translateX(-50%) scale(.4)}28%,82%{opacity:1;transform:translateX(-50%) scale(1)}100%{opacity:0;transform:translateX(-50%) scale(1.1)}}
@keyframes beamCore{0%{opacity:0;transform:translateX(-50%) scaleY(.2)}22%,80%{opacity:.95;transform:translateX(-50%) scaleY(1)}100%{opacity:0;transform:translateX(-50%) scaleY(1.06)}}
@keyframes beamSideLeft{0%{opacity:0;transform:translateX(-50%) rotate(-18deg) scaleY(.15)}26%,78%{opacity:.7;transform:translateX(-50%) rotate(-14deg) scaleY(1)}100%{opacity:0;transform:translateX(-50%) rotate(-10deg) scaleY(1.02)}}
@keyframes beamSideRight{0%{opacity:0;transform:translateX(-50%) rotate(18deg) scaleY(.15)}26%,78%{opacity:.7;transform:translateX(-50%) rotate(14deg) scaleY(1)}100%{opacity:0;transform:translateX(-50%) rotate(10deg) scaleY(1.02)}}
@keyframes dragonImage{0%{opacity:0;transform:translateY(28px) scale(.92);filter:brightness(.85) drop-shadow(0 0 0 rgba(0,0,0,0))}18%,82%{opacity:1;transform:translateY(0) scale(1)}34%{filter:brightness(1.16) drop-shadow(0 0 18px rgba(255,245,200,.28)) drop-shadow(0 0 42px rgba(244,213,138,.24)) drop-shadow(0 24px 50px rgba(0,0,0,.42))}100%{opacity:0;transform:translateY(-22px) scale(1.03)}}
.dragon-welcome:not(.show) .dragon-image-aura,.dragon-welcome:not(.show) .dragon-light-floor,.dragon-welcome:not(.show) .dragon-light-orb,.dragon-welcome:not(.show) .dragon-light-beam,.dragon-welcome:not(.show) .welcome-dragon-image{animation:none!important}
.dragon-welcome.show .dragon-image-aura{animation:imageAura 3.2s ease .35s both}.dragon-welcome.show .dragon-light-floor{animation:floorGlow 2.8s ease .6s both}.dragon-welcome.show .dragon-light-orb{animation:orbIgnite 2.4s ease .75s both}.dragon-welcome.show .dragon-light-beam.beam-core{animation:beamCore 2.6s ease .65s both}.dragon-welcome.show .dragon-light-beam.beam-left{animation:beamSideLeft 2.8s ease .72s both}.dragon-welcome.show .dragon-light-beam.beam-right{animation:beamSideRight 2.8s ease .72s both}.dragon-welcome.show .welcome-dragon-image{animation:dragonImage 4.2s cubic-bezier(.2,.9,.2,1) both}
.reward-rule-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:14px}.reward-rule-card{border:1px solid rgba(215,169,74,.18);border-radius:16px;padding:13px;background:linear-gradient(145deg,rgba(255,255,255,.045),rgba(0,0,0,.16))}.reward-rule-card span{display:block;color:var(--gold);font-size:10px;text-transform:uppercase;letter-spacing:.14em;font-weight:900}.reward-rule-card b{display:block;color:var(--gold2);font-size:15px;margin:6px 0}.reward-rule-card p{margin:0;color:var(--muted);font-size:11px;line-height:1.55}
@media(max-width:1180px){.reward-rule-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:680px){.welcome-dragon-wrap{width:90vw}.dragon-welcome .dragon-stage{min-height:76vh;padding:24px 0 138px}.reward-rule-grid{grid-template-columns:1fr}}

/* V16.29: Member fireworks, business academy and Vietnam member map */
.member-counter-pill{display:flex;align-items:center;gap:5px;min-height:42px;padding:9px 13px;border:1px solid rgba(244,213,138,.28);border-radius:999px;background:linear-gradient(135deg,rgba(244,213,138,.12),rgba(14,63,52,.18));color:#f4d58a;font-size:12px;font-weight:800;white-space:nowrap;box-shadow:0 12px 28px rgba(0,0,0,.18)}
.member-counter-pill b{font-size:16px;color:#fff2bd}.member-counter-pill small{color:#c9f8e8;border-left:1px solid rgba(244,213,138,.22);padding-left:8px}.member-counter-pill span{color:#dfd4b6}
.fireworks-layer{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:3}.fireworks-layer i{position:absolute;width:6px;height:6px;border-radius:50%;background:#fff4cc;box-shadow:0 0 0 3px rgba(244,213,138,.18),0 0 22px rgba(244,213,138,.72);opacity:0;animation:fireworkBurst 1.8s ease-out both}.dragon-welcome.show .fireworks-layer i:nth-child(1){left:22%;top:25%;animation-delay:.65s}.dragon-welcome.show .fireworks-layer i:nth-child(2){left:72%;top:22%;animation-delay:.85s}.dragon-welcome.show .fireworks-layer i:nth-child(3){left:18%;top:58%;animation-delay:1.05s}.dragon-welcome.show .fireworks-layer i:nth-child(4){left:79%;top:55%;animation-delay:1.2s}.dragon-welcome.show .fireworks-layer i:nth-child(5){left:51%;top:18%;animation-delay:1.35s}.dragon-welcome.show .fireworks-layer i:nth-child(6){left:50%;top:72%;animation-delay:1.55s}@keyframes fireworkBurst{0%{opacity:0;transform:scale(.2)}14%{opacity:1}55%{opacity:.95;box-shadow:0 -42px 0 #fff4cc,34px -24px 0 #f4d58a,34px 26px 0 #fff4cc,0 44px 0 #f4d58a,-36px 26px 0 #fff4cc,-36px -24px 0 #f4d58a,0 0 34px rgba(244,213,138,.9)}100%{opacity:0;transform:scale(1.75);box-shadow:0 -74px 0 transparent,58px -42px 0 transparent,58px 42px 0 transparent,0 76px 0 transparent,-60px 42px 0 transparent,-60px -42px 0 transparent,0 0 0 transparent}}
.academy-tabs{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 18px}.academy-tabs button{border:1px solid var(--gold-dim);background:rgba(215,169,74,.06);color:var(--gold2);border-radius:999px;padding:10px 14px;font-weight:800;cursor:pointer}.academy-tabs button.active,.academy-tabs button:hover{background:linear-gradient(135deg,#f4d58a,#b9842f);color:#120d05;border-color:transparent}.academy-content-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.academy-card{border:1px solid var(--line);border-radius:22px;background:linear-gradient(145deg,rgba(7,31,27,.86),rgba(2,12,10,.94));box-shadow:0 18px 50px rgba(0,0,0,.22);overflow:hidden;position:relative}.academy-card>img{width:100%;height:168px;object-fit:cover;background:rgba(255,255,255,.04)}.academy-badge{position:absolute;top:12px;left:12px;z-index:2;padding:6px 10px;border-radius:999px;background:rgba(1,8,7,.72);border:1px solid rgba(244,213,138,.28);color:#f4d58a;font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.12em}.academy-media-icon{height:168px;display:grid;place-items:center;font-size:44px;color:#f4d58a;background:radial-gradient(circle,rgba(244,213,138,.18),rgba(11,47,40,.2) 62%,rgba(0,0,0,.16))}.academy-card-body{padding:18px}.academy-card-body small{color:var(--gold);font-weight:900;letter-spacing:.12em;text-transform:uppercase;font-size:10px}.academy-card-body h3{color:var(--gold2);font-family:'Playfair Display',serif;margin:9px 0;font-size:20px}.academy-card-body p{color:var(--muted);line-height:1.7;margin:0 0 14px;font-size:13px}.academy-link{display:inline-flex;color:#f4d58a;text-decoration:none;font-weight:900;font-size:13px;margin-right:10px}.map-summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:16px}.map-summary-grid article,.region-grid article{border:1px solid var(--line);border-radius:20px;background:linear-gradient(145deg,rgba(7,31,27,.86),rgba(2,12,10,.92));padding:18px}.map-summary-grid span,.region-grid span{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.12em}.map-summary-grid strong,.region-grid b{display:block;color:var(--gold2);font-family:'Playfair Display',serif;font-size:28px;margin:7px 0}.map-summary-grid small{color:var(--muted)}.member-map-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:18px}.vietnam-map-visual{min-height:560px;position:relative;border:1px solid var(--line);border-radius:28px;background:radial-gradient(circle at 48% 32%,rgba(244,213,138,.16),transparent 26%),linear-gradient(160deg,rgba(14,63,52,.62),rgba(1,8,7,.92));overflow:hidden}.map-spine{position:absolute;left:48%;top:8%;width:92px;height:82%;border-radius:55% 48% 48% 52%;border-left:3px solid rgba(244,213,138,.5);border-right:1px solid rgba(132,255,224,.18);transform:rotate(11deg);filter:drop-shadow(0 0 18px rgba(244,213,138,.26))}.map-dot{position:absolute;display:flex;align-items:center;gap:6px;border:0;background:transparent;color:#fff2bd;font-size:11px;font-weight:900;text-shadow:0 1px 8px #000}.map-dot i{width:14px;height:14px;border-radius:50%;background:#f4d58a;box-shadow:0 0 0 5px rgba(244,213,138,.16),0 0 28px rgba(244,213,138,.64)}.map-dot span{white-space:nowrap;background:rgba(0,0,0,.28);border:1px solid rgba(244,213,138,.22);padding:4px 7px;border-radius:999px}.dot-1{left:48%;top:68%}.dot-2{left:43%;top:14%}.dot-3{left:45%;top:78%}.dot-4{left:49%;top:49%}.dot-5{left:55%;top:70%}.dot-6{left:57%;top:74%}.dot-7{left:50%;top:18%}.dot-8{left:38%;top:76%}.dot-9{left:35%;top:82%}.dot-10{left:50%;top:83%}.dot-11{left:55%;top:80%}.dot-12{left:39%;top:87%}.province-list{border:1px solid var(--line);border-radius:28px;background:linear-gradient(145deg,rgba(7,31,27,.86),rgba(2,12,10,.94));padding:18px}.province-list h3{margin:0 0 14px;color:var(--gold2);font-family:'Playfair Display',serif}.province-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:11px 0;border-bottom:1px solid rgba(244,213,138,.08)}.province-row:last-child{border-bottom:0}.province-row b{display:block;color:#f3e7c3}.province-row span{display:block;color:var(--muted);font-size:11px;margin-top:2px}.province-row strong{color:var(--gold2)}.province-row em{grid-column:1/3;height:7px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden}.province-row em i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#845c21,#f4d58a,#fff0af)}.region-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:16px}.region-grid b{font-size:20px}.member-map-panel .fine-note{margin-top:14px;color:var(--muted)}
@media(max-width:1100px){.academy-content-grid{grid-template-columns:repeat(2,1fr)}.member-map-grid{grid-template-columns:1fr}.region-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.member-counter-pill{width:100%;justify-content:center}.academy-content-grid,.map-summary-grid,.region-grid{grid-template-columns:1fr}.vietnam-map-visual{min-height:460px}.map-dot span{display:none}.academy-card>img,.academy-media-icon{height:138px}}


/* V16.35: TM-based member compensation plan - final policy sync */
.toggle-line{display:flex;align-items:center;gap:9px;margin:10px 0 14px;color:var(--muted);font-size:12px;line-height:1.5}.toggle-line input{accent-color:#d7a94a}.vip-cost-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin:12px 0}.vip-cost-grid span{border:1px solid rgba(244,213,138,.16);border-radius:14px;padding:10px;background:rgba(255,255,255,.035);color:var(--muted);font-size:12px}.vip-cost-grid b{display:block;color:#fff2bd;margin-top:3px}.vip-cost-grid .wide{grid-column:1/-1}.vip-cost-grid .ok{color:#bffff0;border-color:rgba(132,255,224,.32)}.vip-cost-grid .bad{color:#ffd1c5;border-color:rgba(255,120,90,.32)}.bv-convert-result .session-card{margin-top:12px}.compensation-plan-panel{display:grid;gap:18px}.comp-hero{display:flex;justify-content:space-between;gap:16px;align-items:center;border:1px solid rgba(244,213,138,.22);border-radius:28px;padding:22px;background:radial-gradient(circle at 20% 0,rgba(244,213,138,.18),transparent 34%),linear-gradient(145deg,rgba(7,31,27,.92),rgba(2,12,10,.96));box-shadow:0 26px 70px rgba(0,0,0,.26)}.comp-hero h3{margin:6px 0;color:var(--gold2);font-family:'Playfair Display',serif;font-size:30px}.comp-hero p{margin:0;color:var(--muted);line-height:1.65}.comp-wallet-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.comp-wallet-grid article{border:1px solid rgba(244,213,138,.16);border-radius:20px;padding:15px;background:linear-gradient(145deg,rgba(255,255,255,.045),rgba(0,0,0,.18))}.comp-wallet-grid span{display:inline-grid;place-items:center;min-width:44px;height:30px;border-radius:999px;background:rgba(244,213,138,.13);color:#fff2bd;font-weight:900}.comp-wallet-grid p{margin:10px 0 0;color:var(--muted);font-size:12px;line-height:1.6}.comp-package-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.comp-package-card{position:relative;overflow:hidden;border:1px solid rgba(244,213,138,.18);border-radius:24px;padding:18px;background:linear-gradient(150deg,rgba(14,63,52,.88),rgba(1,8,7,.96));box-shadow:0 18px 50px rgba(0,0,0,.2)}.comp-package-card:before{content:"";position:absolute;inset:-60% auto auto -50%;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(244,213,138,.22),transparent 62%);pointer-events:none}.comp-package-top{display:flex;justify-content:space-between;gap:8px;align-items:center}.comp-package-top small,.comp-package-top em{position:relative;z-index:1;color:var(--gold);font-size:10px;text-transform:uppercase;letter-spacing:.12em;font-weight:900;font-style:normal}.comp-package-top em{border:1px solid rgba(244,213,138,.2);border-radius:999px;padding:5px 8px;color:#c9f8e8}.comp-package-card h3{position:relative;z-index:1;margin:10px 0;color:var(--gold2);font-family:'Playfair Display',serif;font-size:24px}.comp-money{position:relative;z-index:1;border:1px solid rgba(244,213,138,.14);border-radius:18px;padding:12px;background:rgba(0,0,0,.18);margin:0 0 12px}.comp-money b{display:block;color:#fff2bd;font-size:20px}.comp-money span{color:var(--muted);font-size:11px}.comp-badges{position:relative;z-index:1;display:flex;gap:7px;flex-wrap:wrap;margin-bottom:12px}.comp-badges span{border:1px solid rgba(244,213,138,.15);border-radius:999px;padding:6px 8px;color:#eaddb7;background:rgba(255,255,255,.04);font-size:11px;font-weight:800}.comp-package-card p{position:relative;z-index:1;margin:0;color:var(--muted);font-size:12px;line-height:1.65}.comp-rule-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.comp-rule-grid>article{border:1px solid rgba(244,213,138,.17);border-radius:24px;padding:18px;background:linear-gradient(145deg,rgba(7,31,27,.9),rgba(2,12,10,.96))}.comp-rule-grid h3{margin:0 0 12px;color:var(--gold2);font-family:'Playfair Display',serif}.comp-rule-grid ul{margin:0;padding-left:18px;color:var(--muted);line-height:1.8;font-size:13px}.comp-rule-grid li b{color:#fff2bd}.comp-rule-grid p{color:var(--muted);line-height:1.65}.comp-mini-list{display:grid;gap:10px}.comp-mini-list article{border:1px solid rgba(244,213,138,.12);border-radius:16px;padding:12px;background:rgba(255,255,255,.035)}.comp-mini-list span{color:var(--gold);font-weight:900;letter-spacing:.1em}.comp-mini-list b{display:block;color:#fff2bd;margin:4px 0}.comp-mini-list p{margin:0;color:var(--muted);font-size:12px}.mobile-bottom-nav{overflow-x:auto;scrollbar-width:none}.mobile-bottom-nav::-webkit-scrollbar{display:none}
@media(max-width:1180px){.comp-package-grid,.comp-rule-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.comp-wallet-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:760px){.comp-hero{display:block}.comp-package-grid,.comp-rule-grid,.comp-wallet-grid{grid-template-columns:1fr}.comp-hero h3{font-size:25px}.vip-cost-grid{grid-template-columns:1fr}.mobile-bottom-nav{grid-auto-flow:column;grid-auto-columns:minmax(86px,1fr);grid-template-columns:none!important}}


/* V18.3.6 · Member full frontend information panel, TM-TL-TTL payment display */
.member-full-info{margin:0 0 18px;padding:20px;border:1px solid rgba(215,169,74,.22);border-radius:22px;background:linear-gradient(145deg,rgba(7,31,27,.78),rgba(2,12,10,.92));box-shadow:0 18px 50px rgba(0,0,0,.24),inset 0 1px 0 rgba(244,213,138,.06)}
.member-info-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.member-info-grid article{border:1px solid rgba(215,169,74,.16);border-radius:15px;padding:12px;background:rgba(255,255,255,.025);min-height:76px}
.member-info-grid span{display:block;color:rgba(244,232,207,.58);font-size:10px;letter-spacing:1px;text-transform:uppercase;margin-bottom:6px}
.member-info-grid b{display:block;color:var(--gold2);font-size:13px;line-height:1.35;word-break:break-word}
@media(max-width:1100px){.member-info-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:640px){.member-info-grid{grid-template-columns:1fr}.member-full-info{padding:14px;border-radius:18px}}

/* V18.3.7 · Restore full member sidebar and old-style full dashboard info */
.member-sidebar{max-height:100vh;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(215,169,74,.46) rgba(0,0,0,.12);}
.member-sidebar::-webkit-scrollbar{width:7px}.member-sidebar::-webkit-scrollbar-thumb{background:rgba(215,169,74,.42);border-radius:999px}.member-sidebar::-webkit-scrollbar-track{background:rgba(0,0,0,.12)}
.full-member-nav{display:grid;gap:8px;padding-bottom:8px}.full-member-nav button{display:flex!important;align-items:center;gap:9px;min-height:42px;text-align:left;white-space:normal;line-height:1.25}.full-member-nav button span{width:22px;height:22px;border-radius:999px;display:grid;place-items:center;background:rgba(215,169,74,.1);border:1px solid rgba(215,169,74,.18);font-size:12px;flex:0 0 auto}.full-member-nav button.active span{background:rgba(0,0,0,.16);border-color:rgba(0,0,0,.1)}
.member-feature-panel{margin:0 0 18px;padding:18px;border:1px solid rgba(215,169,74,.22);border-radius:22px;background:linear-gradient(145deg,rgba(7,31,27,.72),rgba(2,12,10,.9));box-shadow:0 18px 50px rgba(0,0,0,.22)}.member-feature-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.member-feature-grid button{border:1px solid rgba(215,169,74,.18);border-radius:16px;background:rgba(255,255,255,.03);color:#e8deca;padding:12px;text-align:left;cursor:pointer;min-height:92px}.member-feature-grid button:hover{border-color:rgba(244,213,138,.52);transform:translateY(-1px)}.member-feature-grid b{display:block;color:var(--gold2);font-size:13px;margin-bottom:6px}.member-feature-grid span{display:block;color:var(--muted);font-size:11px;line-height:1.45}.member-info-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.member-info-grid article{min-height:74px}.member-info-grid article b{word-break:break-word}@media(max-width:1180px){.member-feature-grid,.member-info-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.member-feature-grid,.member-info-grid{grid-template-columns:1fr}.mobile-bottom-nav{overflow-x:auto;justify-content:flex-start}.mobile-bottom-nav button{min-width:66px}}

/* V18.4.1 — Restore member module sections + exclusive product columns */
.member-diagram-section{border:1px solid rgba(244,213,138,.18);border-radius:26px;padding:18px;background:linear-gradient(145deg,rgba(7,31,27,.72),rgba(2,12,10,.94))}.member-payment-flow{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.member-payment-flow article{position:relative;min-height:170px;border:1px solid rgba(244,213,138,.18);border-radius:22px;padding:16px;background:radial-gradient(circle at 18% 0,rgba(244,213,138,.13),transparent 42%),rgba(0,0,0,.16);overflow:hidden}.member-payment-flow article:after{content:"";position:absolute;right:-30px;bottom:-30px;width:92px;height:92px;border-radius:50%;background:rgba(244,213,138,.055)}.member-payment-flow span{display:inline-grid;place-items:center;width:38px;height:28px;border:1px solid rgba(244,213,138,.24);border-radius:999px;color:#fff2bd;background:rgba(244,213,138,.09);font-weight:900;font-size:11px}.member-payment-flow b{display:block;color:var(--gold2);font-size:18px;margin:12px 0 8px}.member-payment-flow p{color:var(--muted);font-size:12px;line-height:1.62;margin:0 0 12px}.member-payment-flow strong{display:block;color:#fff2bd;font-size:17px}.elite-exclusive-card{display:grid;grid-template-rows:auto 1fr}.exclusive-meta-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:7px}.exclusive-meta-grid span{border:1px solid rgba(244,213,138,.13);border-radius:12px;padding:8px;background:rgba(255,255,255,.03);color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.08em}.exclusive-meta-grid b{display:block;color:#fff2bd;margin-top:4px;font-size:12px;text-transform:none;letter-spacing:0}.exclusive-tags{display:flex;gap:6px;flex-wrap:wrap}.exclusive-tags em{font-style:normal;border:1px solid rgba(244,213,138,.16);border-radius:999px;padding:5px 8px;color:#e7d8ad;background:rgba(244,213,138,.05);font-size:10px;font-weight:800}.benefits-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.portal-section:not(.active-section){display:none!important}.portal-section.active-section{display:block}@media(max-width:1180px){.member-payment-flow,.benefits-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.exclusive-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:760px){.member-payment-flow,.benefits-grid{grid-template-columns:1fr}.exclusive-products-grid{grid-template-columns:1fr}.exclusive-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}


/* V18.4.2 · Restore full member operational diagrams from stable branch */
.reward-target-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin-top:14px}.reward-target-grid>div{border:1px solid rgba(215,169,74,.17);border-radius:16px;padding:12px;background:rgba(255,255,255,.035)}.reward-target-grid span{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.09em}.reward-target-grid b{display:block;color:var(--gold2);margin-top:5px}.comp-rule-grid li{margin-bottom:4px}.compensation-plan-panel .member-diagram-section{margin:14px 0}.full-member-nav button{min-height:42px}.side-nav button[data-section]{cursor:pointer}@media(max-width:1180px){.reward-target-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:680px){.reward-target-grid{grid-template-columns:1fr}}
