*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
@font-face{font-family:'NotoThai';src:url(../fonts/NotoSansThai-Medium.ttf);font-weight:500}
@font-face{font-family:'NotoThai';src:url(../fonts/NotoSansThai-Bold.ttf);font-weight:700}
@font-face{font-family:'NotoThai';src:url(../fonts/NotoSansThai-Regular.ttf);font-weight:400}

:root{
  --bg-primary:#0b0e17;
  --bg-card:rgba(15,20,40,.85);
  --bg-glass:rgba(255,255,255,.04);
  --accent:#6c5ce7;
  --accent2:#a29bfe;
  --gold:#ffd32a;
  --gold2:#ff9f1a;
  --cyan:#00cec9;
  --red:#ff4757;
  --green:#2ed573;
  --text:#e8e8e8;
  --text-dim:#8a8fa8;
  --border:rgba(255,255,255,.08);
  --radius:16px;
  --shadow:0 8px 32px rgba(0,0,0,.4);
}

body{
  font-family:'NotoThai','Noto Sans Thai',sans-serif;
  background:var(--bg-primary);
  color:var(--text);
  min-height:100vh;
  overflow-x:hidden;
  background-image:
    radial-gradient(ellipse at 20% 0%,rgba(108,92,231,.15) 0%,transparent 60%),
    radial-gradient(ellipse at 80% 100%,rgba(0,206,201,.1) 0%,transparent 60%);
}

/* ===== PARTICLES BG ===== */
.bg-particles{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.bg-particles span{position:absolute;border-radius:50%;background:rgba(108,92,231,.3);animation:float 6s ease-in-out infinite}
.bg-particles span:nth-child(1){width:4px;height:4px;top:20%;left:10%;animation-delay:0s}
.bg-particles span:nth-child(2){width:6px;height:6px;top:60%;left:80%;animation-delay:1s}
.bg-particles span:nth-child(3){width:3px;height:3px;top:40%;left:50%;animation-delay:2s}
.bg-particles span:nth-child(4){width:5px;height:5px;top:80%;left:25%;animation-delay:3s}
.bg-particles span:nth-child(5){width:4px;height:4px;top:10%;left:70%;animation-delay:4s}
@keyframes float{0%,100%{transform:translateY(0) scale(1);opacity:.5}50%{transform:translateY(-40px) scale(1.5);opacity:1}}

/* ===== LAYOUT ===== */
.app-wrapper{position:relative;z-index:1;max-width:1100px;margin:0 auto;padding:20px 16px 40px}

/* ===== TOP BAR ===== */
.top-bar{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;
  background:var(--bg-card);backdrop-filter:blur(20px);border:1px solid var(--border);
  border-radius:var(--radius);margin-bottom:24px}
.top-bar .logo{display:flex;align-items:center;gap:12px}
.top-bar .logo-icon{width:42px;height:42px;border-radius:12px;
  background:linear-gradient(135deg,var(--accent),var(--cyan));
  display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff}
.top-bar .logo-text h1{font-size:18px;font-weight:700;color:#fff;line-height:1.2}
.top-bar .logo-text span{font-size:12px;color:var(--text-dim)}
.top-bar .user-info{display:flex;align-items:center;gap:12px}
.top-bar .username{text-align:right}
.top-bar .username h3{font-size:14px;font-weight:600;color:var(--accent2)}
.top-bar .username span{font-size:11px;color:var(--text-dim)}
.btn-logout{background:rgba(255,71,87,.15);color:var(--red);border:1px solid rgba(255,71,87,.3);
  padding:8px 18px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;transition:.3s}
.btn-logout:hover{background:var(--red);color:#fff}

/* ===== STAT CARDS ===== */
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:28px}
.stat-card{background:var(--bg-card);backdrop-filter:blur(20px);border:1px solid var(--border);
  border-radius:var(--radius);padding:20px 24px;display:flex;align-items:center;gap:16px;transition:.3s}
.stat-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.stat-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px}
.stat-icon.cash{background:linear-gradient(135deg,rgba(255,211,42,.2),rgba(255,159,26,.2));color:var(--gold)}
.stat-icon.ticket{background:linear-gradient(135deg,rgba(108,92,231,.2),rgba(162,155,254,.2));color:var(--accent2)}
.stat-info .stat-label{font-size:12px;color:var(--text-dim);margin-bottom:2px}
.stat-info .stat-value{font-size:22px;font-weight:700;color:#fff}
.stat-info .stat-value small{font-size:13px;color:var(--text-dim);font-weight:400}

/* ===== TABS ===== */
.tab-nav{display:flex;gap:6px;margin-bottom:24px;background:var(--bg-card);padding:6px;
  border-radius:14px;border:1px solid var(--border);overflow-x:auto}
.tab-btn{flex:1;padding:12px 20px;border:none;background:transparent;color:var(--text-dim);
  font-size:14px;font-weight:600;border-radius:10px;cursor:pointer;transition:.3s;
  white-space:nowrap;font-family:inherit}
.tab-btn.active{background:linear-gradient(135deg,var(--accent),#5a4bd1);color:#fff;
  box-shadow:0 4px 15px rgba(108,92,231,.4)}
.tab-btn:hover:not(.active){color:#fff;background:var(--bg-glass)}

/* ===== TAB CONTENT ===== */
.tab-content{display:none}
.tab-content.active{display:block;animation:fadeUp .4s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ===== PACKAGE GRID ===== */
.packages-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.pkg-card{position:relative;background:var(--bg-card);backdrop-filter:blur(20px);
  border:1px solid var(--border);border-radius:var(--radius);padding:24px;
  transition:.3s;cursor:pointer;overflow:hidden}
.pkg-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 12px 40px rgba(108,92,231,.2)}
.pkg-card.promo{border-color:var(--gold)}
.pkg-card.promo::before{content:'PROMO';position:absolute;top:12px;right:-28px;
  background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;font-size:10px;
  font-weight:700;padding:4px 32px;transform:rotate(45deg);letter-spacing:1px}
.pkg-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.pkg-number{font-size:11px;color:var(--text-dim);background:var(--bg-glass);
  padding:4px 10px;border-radius:6px;border:1px solid var(--border)}
.pkg-price{font-size:28px;font-weight:700;color:#fff}
.pkg-price span{font-size:14px;color:var(--text-dim);font-weight:400}
.pkg-details{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.pkg-detail{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-dim)}
.pkg-detail i{font-size:16px;width:20px;text-align:center}
.pkg-detail .val{color:#fff;font-weight:600}
.pkg-detail i.fa-diamond{color:var(--gold)}
.pkg-detail i.fa-gift{color:var(--cyan)}
.pkg-detail i.fa-star{color:var(--accent2)}
.btn-buy{width:100%;padding:12px;border:none;border-radius:12px;font-size:14px;font-weight:700;
  cursor:pointer;transition:.3s;font-family:inherit;
  background:linear-gradient(135deg,var(--accent),#5a4bd1);color:#fff}
.btn-buy:hover{transform:scale(1.02);box-shadow:0 6px 20px rgba(108,92,231,.5)}
.pkg-card.promo .btn-buy{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000}

/* ===== HISTORY TABLE ===== */
.history-card{background:var(--bg-card);backdrop-filter:blur(20px);border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden}
.history-card table{width:100%;border-collapse:collapse}
.history-card th{padding:14px 16px;font-size:12px;text-transform:uppercase;letter-spacing:.5px;
  color:var(--text-dim);background:rgba(0,0,0,.3);text-align:center;font-weight:600}
.history-card td{padding:14px 16px;font-size:13px;text-align:center;
  border-top:1px solid var(--border);color:var(--text)}
.history-card tr:hover td{background:var(--bg-glass)}
.badge-status{padding:4px 12px;border-radius:20px;font-size:11px;font-weight:600}
.badge-wait{background:rgba(255,211,42,.15);color:var(--gold)}
.badge-success{background:rgba(46,213,115,.15);color:var(--green)}
.badge-expired{background:rgba(255,71,87,.15);color:var(--red)}
.no-data{text-align:center;padding:40px;color:var(--text-dim);font-size:14px}

/* ===== NOTES ===== */
.notes-box{margin-top:20px;background:rgba(255,71,87,.08);border:1px solid rgba(255,71,87,.2);
  border-radius:var(--radius);padding:20px 24px}
.notes-box h4{font-size:14px;font-weight:700;color:var(--red);margin-bottom:10px}
.notes-box li{font-size:12px;color:var(--text-dim);margin-bottom:6px;list-style:none;padding-left:16px;position:relative}
.notes-box li::before{content:'';position:absolute;left:0;top:7px;width:6px;height:6px;
  border-radius:50%;background:var(--red)}

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
  .top-bar{flex-direction:column;gap:12px;text-align:center}
  .top-bar .user-info{flex-direction:column}
  .packages-grid{grid-template-columns:1fr}
  .stats-row{grid-template-columns:1fr}
  .tab-nav{flex-wrap:nowrap;overflow-x:auto}
}

.offline{color:var(--red)}
.online{color:var(--green)}