*{box-sizing:border-box}body{margin:0;font-family:Arial,Helvetica,sans-serif;background:#0f172a;color:#e5e7eb}a{color:#38bdf8;text-decoration:none}a:hover{text-decoration:underline}.wrap{max-width:1180px;margin:0 auto;padding:22px}.top{background:#111827;border-bottom:1px solid #334155}.nav{display:flex;align-items:center;justify-content:space-between;gap:16px}.brand{font-weight:800;font-size:20px;color:#fff}.menu{display:flex;gap:12px;flex-wrap:wrap}.menu a,.btn{display:inline-block;border:0;border-radius:10px;padding:10px 14px;background:#2563eb;color:#fff;cursor:pointer;font-weight:700}.menu a.secondary,.btn.secondary{background:#334155}.btn.danger{background:#dc2626}.btn.small{padding:7px 10px;font-size:13px}.card{background:#1e293b;border:1px solid #334155;border-radius:16px;padding:18px;margin:14px 0;box-shadow:0 12px 30px rgba(0,0,0,.18)}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px}.stat{background:#111827;border:1px solid #334155;border-radius:14px;padding:16px}.stat .num{font-size:24px;font-weight:800;color:#fff;margin-top:6px}h1,h2,h3{color:#fff;margin:0 0 14px}.muted{color:#94a3b8}.balance{font-size:30px;color:#22c55e;font-weight:900}.form-row{margin-bottom:13px}label{display:block;margin-bottom:7px;font-weight:700}input,select,textarea{width:100%;border:1px solid #475569;border-radius:10px;background:#0f172a;color:#fff;padding:11px 12px;font-size:15px}textarea{min-height:110px}.inline{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.inline input[type=checkbox]{width:auto}table{width:100%;border-collapse:collapse;background:#111827;border-radius:12px;overflow:hidden}th,td{padding:11px 10px;border-bottom:1px solid #334155;text-align:left;vertical-align:top}th{background:#0f172a;color:#cbd5e1}.pill{display:inline-block;padding:4px 9px;border-radius:999px;font-size:12px;font-weight:800}.pill.ok{background:#14532d;color:#bbf7d0}.pill.bad{background:#7f1d1d;color:#fecaca}.pill.warn{background:#713f12;color:#fde68a}.pill.info{background:#1e3a8a;color:#bfdbfe}.alert{padding:12px 14px;border-radius:12px;margin:12px 0}.alert.ok{background:#14532d;color:#bbf7d0}.alert.bad{background:#7f1d1d;color:#fecaca}.alert.warn{background:#713f12;color:#fde68a}.login-box{max-width:480px;margin:8vh auto}.product{display:flex;flex-direction:column;gap:10px}.price{font-size:22px;font-weight:900;color:#fbbf24}.codebox{background:#020617;border:1px solid #334155;border-radius:12px;padding:12px;white-space:pre-wrap;font-family:Consolas,monospace}.footer{color:#64748b;text-align:center;padding:22px}.actions{display:flex;gap:8px;flex-wrap:wrap}.search{max-width:360px}.two{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media(max-width:760px){.two{grid-template-columns:1fr}.nav{align-items:flex-start;flex-direction:column}table{font-size:13px}.wrap{padding:14px}}
.product-desc{color:#cbd5e1;line-height:1.5;border-top:1px solid #334155;padding-top:10px}.price span{font-size:14px;color:#cbd5e1;font-weight:800}.buy-row{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}.buy-row .buy-qty{min-width:130px;flex:1}.buy-row button{white-space:nowrap;margin-bottom:0}.modal{display:none;position:fixed;z-index:999;inset:0;background:rgba(2,6,23,.78);padding:20px;align-items:center;justify-content:center}.modal.open,.modal[aria-hidden="false"]{display:flex!important}.modal-box{width:min(520px,100%);background:#1e293b;border:1px solid #475569;border-radius:16px;padding:20px;box-shadow:0 20px 60px rgba(0,0,0,.45);position:relative}.modal-close{position:absolute;right:12px;top:10px;border:0;background:#334155;color:#fff;border-radius:999px;width:34px;height:34px;font-size:24px;line-height:30px;cursor:pointer}@media(max-width:520px){.buy-row{align-items:stretch}.buy-row .buy-qty,.buy-row button{width:100%}}

body.modal-active{overflow:hidden}

/* FIX_POPUP_DEPOSIT_20260623_V2 */

.buy-modal.open{display:flex!important;visibility:visible!important;opacity:1!important}
.buy-modal[aria-hidden="false"]{display:flex!important}
.modal-box{z-index:1000}


/* FIX_POPUP_DEPOSIT_20260623_V3 */
.buy-open{position:relative;z-index:1}
.buy-modal{z-index:9999!important}
.buy-modal.open,.buy-modal[aria-hidden="false"]{display:flex!important;visibility:visible!important;opacity:1!important}
body.modal-active{overflow:hidden}
.modal-close{z-index:10001}

/* FIX_DEPOSIT_INVOICE_20260623_V5 */
.deposit-presets{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin:8px 0 16px}.deposit-preset{width:100%;text-align:center}.deposit-custom-row{margin-top:10px}.deposit-invoice{border-color:#f59e0b}.deposit-pay-amount{background:#111827;border:1px solid #334155;border-radius:14px;padding:16px;margin:12px 0}.deposit-pay-number{font-size:34px;line-height:1.2;font-weight:900;color:#fbbf24;margin-top:4px}.deposit-note{border-color:#f59e0b}button[disabled],.btn[disabled]{opacity:.55;cursor:not-allowed}


/* FIX_VIETQR_DEPOSIT_20260623_V8 */
.deposit-qr-box{background:#111827;border:1px solid #334155;border-radius:14px;padding:16px;margin:14px 0;text-align:center}.deposit-qr-img{display:block;max-width:min(100%,420px);height:auto;margin:8px auto;border-radius:14px;background:#fff;padding:8px}.deposit-qr-summary{background:#0f172a;border:1px solid #334155;border-radius:14px;padding:12px;margin-top:12px}.deposit-qr-summary p{margin:6px 0}


/* FIX_SEO_QR_MOBILE_20260623_V9 */
.deposit-invoice{overflow:hidden}.deposit-invoice table{margin-top:12px}.deposit-qr-box{max-width:560px;margin:14px auto;overflow:hidden}.deposit-qr-img{width:100%;max-width:340px;max-height:520px;object-fit:contain;box-shadow:0 10px 30px rgba(0,0,0,.25)}.deposit-qr-actions{justify-content:center;margin:10px 0 0}.deposit-pay-amount{overflow:hidden}.deposit-pay-number{word-break:break-word}.card table{display:table}
@media(max-width:760px){body{font-size:15px}.wrap{width:100%;max-width:100%;padding:12px}.card{border-radius:14px;padding:14px;margin:10px 0;overflow-x:auto}.grid{grid-template-columns:1fr;gap:10px}.menu{width:100%;gap:8px}.menu a,.btn{padding:9px 11px;font-size:14px}.actions{gap:7px}.deposit-presets{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.deposit-pay-amount{padding:12px}.deposit-pay-number{font-size:26px}.deposit-qr-box{padding:12px;margin:12px auto;max-width:100%}.deposit-qr-img{max-width:260px;max-height:390px;border-radius:12px;padding:6px}.deposit-qr-actions .btn{width:100%;text-align:center}table{display:block;overflow-x:auto;white-space:nowrap}th,td{padding:9px 8px}.deposit-invoice table{white-space:normal}.deposit-invoice th{min-width:130px}.deposit-invoice td{min-width:180px}.balance{font-size:24px}}
@media(max-width:420px){.deposit-presets{grid-template-columns:1fr}.deposit-qr-img{max-width:230px}.deposit-pay-number{font-size:24px}.brand{font-size:18px}h1{font-size:24px}h2{font-size:20px}}

/* FIX_ADMIN_DASHBOARD_STATS_20260624_V14 */
.dashboard-stats-card{overflow:hidden}.admin-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0 14px}.admin-tab{border:1px solid #475569;border-radius:999px;background:#0f172a;color:#cbd5e1;padding:10px 14px;font-weight:800;cursor:pointer}.admin-tab.active{background:#2563eb;border-color:#60a5fa;color:#fff}.admin-tab-panel{display:none}.admin-tab-panel.active{display:block}.dashboard-stats-card table td:nth-child(n+2),.dashboard-stats-card table th:nth-child(n+2){text-align:right}@media(max-width:760px){.admin-tabs{display:grid;grid-template-columns:1fr;gap:8px}.admin-tab{width:100%;border-radius:12px}.dashboard-stats-card table td:nth-child(n+2),.dashboard-stats-card table th:nth-child(n+2){text-align:left}}

/* Summernote / mô tả HTML sản phẩm */
.note-editor.note-frame{border:1px solid rgba(148,163,184,.35);border-radius:12px;overflow:hidden;background:#fff;color:#0f172a}
.note-editor .note-toolbar{background:#f8fafc;border-bottom:1px solid rgba(148,163,184,.25)}
.note-editor .note-editable{min-height:170px;color:#0f172a;background:#fff}
.product-desc a,.card a[target="_blank"]{text-decoration:underline;text-underline-offset:2px}
.product-desc p,.card .rich-text p{margin:.4rem 0}
.product-desc ul,.product-desc ol,.card .rich-text ul,.card .rich-text ol{margin:.4rem 0 .4rem 1.25rem}
.product-desc{overflow-wrap:anywhere}
@media(max-width:700px){.note-editor .note-toolbar{overflow-x:auto;white-space:nowrap}.note-editor .note-btn{padding:5px 7px}.note-editor .note-editable{min-height:150px}}

/* FIX_TEXT_CODE_COPY_USAGE_20260624_V16 */
.code-delivery-table code.order-code-text{display:block;white-space:pre-wrap;word-break:break-word;background:#020617;border:1px solid #334155;border-radius:10px;padding:8px;color:#e5e7eb;font-family:Consolas,monospace}
.code-delivery-table .copy-code-btn{min-width:78px;text-align:center}
.code-delivery-table td:nth-child(2),.code-delivery-table td:nth-child(3){white-space:nowrap}
@media(max-width:760px){.code-delivery-table{display:block;overflow-x:auto}.code-delivery-table th,.code-delivery-table td{white-space:normal}.code-delivery-table .copy-code-btn{width:100%}}


/* FIX_USER_HOME_UI_20260624_V19 */
.home-login-card{max-width:620px!important}
.user-summary-card{border-color:#2563eb}
.user-summary-main{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.user-summary-balance{background:#111827;border:1px solid #334155;border-radius:14px;padding:12px 14px;min-width:220px}
.deposit-guide-card{border-color:#38bdf8}
@media(max-width:760px){.user-summary-main{align-items:flex-start;flex-direction:column}.user-summary-balance{width:100%;min-width:0}.home-login-card{max-width:none!important}}

.ok-text{color:#16a34a;font-weight:700}.bad-text{color:#dc2626;font-weight:700}.deposit-countdown-line{margin-top:6px;font-size:15px}.deposit-countdown{font-variant-numeric:tabular-nums}.checkline{display:flex;align-items:center;gap:8px;margin:10px 0 14px;font-weight:600}.soft-card{background:rgba(148,163,184,.08);border:1px solid rgba(148,163,184,.25)}

/* FIX_SITE_IMAGES_PROMO_20260624_V22 */
.brand{display:flex;align-items:center;gap:10px}.site-logo{width:34px;height:34px;object-fit:contain;border-radius:8px;background:#fff;padding:2px;flex:0 0 auto}.home-banners{display:grid;gap:14px;margin:14px 0}.home-banner-item{border-radius:18px;overflow:hidden;border:1px solid #334155;background:#111827}.home-banner-item a{display:block}.home-banner-item img{display:block;width:100%;height:auto;max-height:360px;object-fit:cover}.admin-image-preview{display:inline-flex;align-items:center;justify-content:center;max-width:260px;background:#111827;border:1px solid #334155;border-radius:14px;padding:10px;margin:8px 0}.admin-image-preview img{display:block;max-width:100%;max-height:120px;object-fit:contain;border-radius:10px}.admin-image-preview.banner{display:flex;max-width:100%;width:100%}.admin-image-preview.banner img{width:100%;max-height:190px;object-fit:cover}.banner-admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px}.banner-admin-card{margin:0}.deposit-promo-card{border-color:#fbbf24;background:linear-gradient(135deg,rgba(113,63,18,.85),rgba(30,41,59,.95))}.promo-rule-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-top:12px}.promo-rule-item{background:#111827;border:1px solid rgba(251,191,36,.45);border-radius:14px;padding:12px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.promo-rule-item span{color:#cbd5e1}.promo-rule-item b{color:#fff}.promo-rule-item strong{margin-left:auto;color:#22c55e;font-size:20px}
@media(max-width:760px){.site-logo{width:30px;height:30px}.home-banner-item img{max-height:240px}.promo-rule-item strong{margin-left:0;width:100%}.admin-image-preview{max-width:100%}}

/* FIX_USER_LOGO_NAV_PROMO_20260624_V23 */
.brand{display:flex;align-items:center;gap:10px;min-width:0;max-width:320px;line-height:1.2;flex:0 1 auto}
.brand span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.site-logo{display:block;width:auto!important;height:auto!important;max-width:170px!important;max-height:42px!important;object-fit:contain!important;border-radius:0!important;background:transparent!important;padding:0!important;box-shadow:none!important;flex:0 0 auto}
.user-menu a{display:inline-flex;align-items:center;justify-content:center;gap:6px;line-height:1.2;white-space:nowrap}
.nav-ico{display:inline-flex;align-items:center;justify-content:center;width:1.15em;line-height:1;font-size:1.05em;flex:0 0 auto}
.promo-rule-item{gap:7px;justify-content:flex-start;white-space:normal}
.promo-rule-item .promo-gift{font-size:18px;line-height:1;color:#fbbf24}
.promo-rule-item strong{margin-left:2px;white-space:nowrap}
@media(max-width:760px){
  .nav{gap:10px}
  .brand{width:100%;max-width:100%;justify-content:flex-start;font-size:18px}
  .site-logo{max-width:150px!important;max-height:38px!important}
  .user-menu{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));width:100%;gap:8px}
  .user-menu a{width:100%;padding:10px 8px;text-align:center;min-height:42px}
  .promo-rule-grid{grid-template-columns:1fr}
  .promo-rule-item{display:flex;align-items:center;flex-wrap:nowrap;gap:6px;padding:11px 12px}
  .promo-rule-item b{white-space:nowrap}
  .promo-rule-item strong{width:auto!important;margin-left:auto!important;font-size:18px!important}
}
@media(max-width:420px){
  .site-logo{max-width:135px!important;max-height:34px!important}
  .brand{font-size:17px}
  .user-menu a{font-size:13px;padding:9px 6px}
  .nav-ico{font-size:1em}
}

/* SUPPORT_TICKETS_20260624_V24 */
.menu-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#ef4444;color:#fff;font-size:12px;font-weight:900;line-height:1;margin-left:3px}.support-create-card textarea{min-height:130px}.support-thread{display:flex;flex-direction:column;gap:12px}.ticket-message{display:flex;width:100%}.ticket-message.from-user{justify-content:flex-end}.ticket-message.from-admin{justify-content:flex-start}.ticket-bubble{max-width:min(760px,88%);background:#111827;border:1px solid #334155;border-radius:16px;padding:12px 14px;box-shadow:0 8px 22px rgba(0,0,0,.16)}.ticket-message.from-user .ticket-bubble{border-color:#2563eb;background:#172554}.ticket-message.from-admin .ticket-bubble{border-color:#475569}.ticket-meta{font-size:13px;color:#94a3b8;margin-bottom:7px}.ticket-text{white-space:normal;overflow-wrap:anywhere;line-height:1.55}.ticket-images{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}.ticket-images a{display:block;border-radius:12px;overflow:hidden;border:1px solid #334155;background:#020617}.ticket-images img{display:block;width:140px;height:110px;object-fit:cover}.support-thread+.card form{margin:0}.actions form{display:inline-block;margin:0}@media(max-width:760px){.ticket-bubble{max-width:96%;padding:11px 12px}.ticket-images img{width:112px;height:88px}.support-thread{overflow:visible}.menu-badge{min-width:18px;height:18px;font-size:11px;padding:0 5px}}

/* FIX_TICKET_UI_AUTOREFRESH_TELEGRAM_20260624_V25 */
.support-thread-card{background:linear-gradient(180deg,rgba(30,41,59,.98),rgba(15,23,42,.98));border-color:rgba(96,165,250,.35)}
.ticket-thread-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px;border-bottom:1px solid rgba(148,163,184,.2);padding-bottom:12px}
.ticket-thread-head h2{margin-bottom:4px}.ticket-thread-head .muted{margin:0}.ticket-refresh-status{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#0f172a;border:1px solid #334155;color:#cbd5e1;font-size:12px;font-weight:800;white-space:nowrap}.ticket-refresh-status.ok{background:#14532d;color:#bbf7d0;border-color:#16a34a}.ticket-refresh-status.bad{background:#7f1d1d;color:#fecaca;border-color:#dc2626}
.support-thread{display:flex;flex-direction:column;gap:16px;overflow:visible}.ticket-message{display:flex;width:100%;gap:10px;align-items:flex-end}.ticket-message.from-user{justify-content:flex-end}.ticket-message.from-admin{justify-content:flex-start}.ticket-message.from-user .ticket-avatar{order:2;background:linear-gradient(135deg,#2563eb,#60a5fa);color:#fff}.ticket-message.from-user .ticket-bubble{order:1}.ticket-message.from-admin .ticket-avatar{background:linear-gradient(135deg,#f59e0b,#facc15);color:#1e293b}.ticket-avatar{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:999px;font-weight:900;box-shadow:0 10px 20px rgba(0,0,0,.25);flex:0 0 34px}
.ticket-bubble{position:relative;max-width:min(760px,82%);border-radius:18px;padding:13px 15px;box-shadow:0 14px 34px rgba(0,0,0,.22);overflow:hidden}.ticket-message.from-user .ticket-bubble{background:linear-gradient(135deg,#1d4ed8,#172554);border:1px solid rgba(147,197,253,.42);border-bottom-right-radius:6px}.ticket-message.from-admin .ticket-bubble{background:linear-gradient(135deg,#111827,#1e293b);border:1px solid rgba(251,191,36,.28);border-bottom-left-radius:6px}.ticket-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:8px;color:#cbd5e1;font-size:12px}.ticket-sender{font-size:14px;font-weight:900;color:#fff}.ticket-role{display:inline-flex;align-items:center;padding:2px 7px;border-radius:999px;background:rgba(255,255,255,.1);color:#e2e8f0;font-size:11px;font-weight:800}.ticket-meta time{color:#94a3b8;font-variant-numeric:tabular-nums}.ticket-text{white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word;line-height:1.6;color:#f8fafc;font-size:15px}.ticket-images{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin-top:12px;max-width:560px}.ticket-image-link{display:flex;align-items:center;justify-content:center;aspect-ratio:4/3;border-radius:14px;overflow:hidden;border:1px solid rgba(148,163,184,.35);background:#020617;text-decoration:none!important}.ticket-images img{display:block!important;width:100%!important;height:100%!important;max-width:100%!important;max-height:170px!important;object-fit:contain!important;border-radius:0!important;background:#020617}.ticket-image-link:hover{border-color:#60a5fa;box-shadow:0 0 0 2px rgba(96,165,250,.2)}
@media(max-width:760px){.ticket-thread-head{flex-direction:column}.ticket-refresh-status{width:100%;justify-content:center}.support-thread{gap:14px}.ticket-avatar{width:30px;height:30px;flex-basis:30px;font-size:13px}.ticket-bubble{max-width:calc(100% - 44px);padding:12px;border-radius:15px}.ticket-meta{gap:6px}.ticket-role{display:none}.ticket-text{font-size:14px}.ticket-images{grid-template-columns:repeat(2,minmax(0,1fr));max-width:100%;gap:8px}.ticket-images img{max-height:135px!important}.ticket-message.from-user .ticket-bubble{border-bottom-right-radius:5px}.ticket-message.from-admin .ticket-bubble{border-bottom-left-radius:5px}}
@media(max-width:420px){.ticket-images{grid-template-columns:1fr}.ticket-images img{max-height:180px!important}.ticket-avatar{display:none}.ticket-bubble{max-width:100%}}


/* Ticket inbox badge and support history ordering polish */
.nav-support{position:relative;overflow:visible}.nav-support.has-ticket-unread{border-color:rgba(239,68,68,.85);box-shadow:0 0 0 1px rgba(239,68,68,.28),0 10px 26px rgba(239,68,68,.14);animation:ticketPulse 1.8s ease-in-out infinite}.ticket-mail-badge{gap:3px;min-width:auto;height:22px;padding:0 8px;background:linear-gradient(135deg,#ef4444,#f97316);box-shadow:0 6px 14px rgba(239,68,68,.32);white-space:nowrap}.ticket-unread-row{background:rgba(59,130,246,.08)}.ticket-unread-row td{border-top-color:rgba(96,165,250,.24)}.ticket-new-pill{display:inline-flex;align-items:center;margin-left:6px;padding:3px 8px;border-radius:999px;background:rgba(34,197,94,.14);border:1px solid rgba(34,197,94,.45);color:#86efac;font-size:12px;font-weight:900;white-space:nowrap}.support-history-card{border-color:rgba(96,165,250,.3)}@keyframes ticketPulse{0%,100%{transform:translateY(0)}50%{transform:translateY(-1px)}}@media(max-width:760px){.ticket-mail-badge{height:20px;padding:0 7px;font-size:11px}.nav-support.has-ticket-unread{animation:none}.ticket-new-pill{display:inline-flex;margin-top:5px;margin-left:0}}
