
:root{
  --wine:#5b0710; --wine-2:#8d111d; --wine-3:#b01828;
  --gold:#d6a93c; --gold-2:#ffe7a0; --gold-3:#9d7422;
  --ivory:#fff9ef; --cream:#f7efe3; --paper:#fffdf8;
  --ink:#211313; --muted:#7e6b63; --line:rgba(124,75,36,.16);
  --green:#12a56a; --red:#d84646; --blue:#1769ff;
  --shadow:0 22px 60px rgba(70,20,20,.14); --soft:0 12px 30px rgba(101,24,24,.10);
  --radius:24px; --radius-sm:14px;
  --container:1180px;
}
*{box-sizing:border-box} html{scroll-behavior:smooth}
body{margin:0;background:
  radial-gradient(circle at 15% 0%, rgba(255,225,150,.42), transparent 26%),
  radial-gradient(circle at 85% 10%, rgba(164,22,35,.13), transparent 32%),
  linear-gradient(180deg,#fffaf1 0%,#f7efe3 55%,#fff9ef 100%);color:var(--ink);font-family:"Inter","Segoe UI",Arial,sans-serif;overflow-x:hidden;}
a{color:inherit;text-decoration:none} button,input,textarea,select{font:inherit} button{cursor:pointer;border:0}
.container{width:min(var(--container),calc(100% - 32px));margin:auto}.hide{display:none!important}.text-gold{color:var(--gold)}
.lux-bg{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}.orb{position:absolute;border-radius:50%;filter:blur(5px);opacity:.5;animation:floaty 11s ease-in-out infinite}.orb.one{width:300px;height:300px;background:rgba(214,169,60,.24);left:-80px;top:160px}.orb.two{width:260px;height:260px;background:rgba(141,17,29,.18);right:-70px;top:90px;animation-delay:2s}.orb.three{width:220px;height:220px;background:rgba(255,231,160,.25);left:55%;bottom:80px;animation-delay:4s}
@keyframes floaty{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(22px,-28px,0) scale(1.05)}}
.lux-top{background:linear-gradient(90deg,var(--wine),#260407,var(--wine));color:#fff5d8;font-size:13px;letter-spacing:.06em;border-bottom:1px solid rgba(255,215,105,.24)}.lux-top .container{height:40px;display:flex;align-items:center;justify-content:space-between;gap:12px}.lux-top__right{display:flex;gap:20px;align-items:center}.lux-top a:hover{color:var(--gold-2)}
.header{position:sticky;top:0;z-index:60;background:rgba(255,249,239,.82);backdrop-filter:blur(18px);border-bottom:1px solid rgba(118,73,40,.14);box-shadow:0 8px 28px rgba(50,8,8,.06)}.header__row{height:86px;display:grid;grid-template-columns:300px 1fr 320px;align-items:center;gap:22px}.brand{display:flex;align-items:center;gap:12px}.brand__mark{width:58px;height:58px;display:grid;place-items:center;border:1.5px solid var(--gold);color:var(--gold-2);background:linear-gradient(135deg,#35070a,#9b101d 58%,#2c0406);box-shadow:inset 0 0 25px rgba(255,229,141,.18),0 10px 28px rgba(80,10,10,.18);border-radius:16px;font:900 26px Georgia,serif}.brand__name{font-family:Georgia,serif;font-size:22px;font-weight:900;letter-spacing:.04em;color:#3b1212}.brand__tag{font-size:10px;letter-spacing:.24em;color:var(--gold-3);font-weight:800;margin-top:4px;text-transform:uppercase}.search{position:relative}.search input{width:100%;height:50px;border:1px solid rgba(112,61,27,.18);background:rgba(255,255,255,.74);border-radius:999px;padding:0 56px 0 20px;outline:none;box-shadow:var(--soft)}.search input:focus{border-color:rgba(214,169,60,.75);box-shadow:0 0 0 4px rgba(214,169,60,.13)}.search button{position:absolute;right:7px;top:7px;width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--wine),var(--wine-3));color:#fff5d8}.actions{display:flex;align-items:center;justify-content:flex-end;gap:10px}.icon-btn{width:45px;height:45px;border-radius:50%;background:#fff;border:1px solid rgba(116,72,38,.14);box-shadow:var(--soft);display:grid;place-items:center;position:relative;color:var(--wine);font-weight:900}.badge{position:absolute;right:-2px;top:-6px;min-width:22px;height:22px;border-radius:999px;background:var(--wine-3);color:white;font-size:12px;display:grid;place-items:center;border:2px solid #fff}.login-pill{display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,#fff,#fff7e4);border:1px solid rgba(214,169,60,.25);border-radius:999px;padding:8px 14px 8px 8px;box-shadow:var(--soft);min-width:130px}.avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--wine),var(--wine-3));color:#fff5d8}.login-pill strong{font-size:13px;display:block}.login-pill span{font-size:12px;color:var(--gold-3);font-weight:800}.mobile-menu{display:none}.nav{background:rgba(255,255,255,.45);border-bottom:1px solid rgba(118,73,40,.10)}.nav__row{min-height:60px;display:flex;align-items:center;justify-content:space-between;gap:16px}.nav__links{display:flex;align-items:center;gap:22px;font-size:14px;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.nav__links a{position:relative}.nav__links a:after{content:"";position:absolute;left:0;right:0;bottom:-8px;height:2px;background:linear-gradient(90deg,var(--gold),transparent);transform:scaleX(0);transform-origin:left;transition:.25s}.nav__links a:hover:after{transform:scaleX(1)}.support{display:flex;gap:18px;color:var(--muted);font-size:13px}.support b{color:var(--wine)}
.hero{position:relative;min-height:590px;display:grid;align-items:center;overflow:hidden;background:linear-gradient(140deg,#4b070b 0%,#830e1a 44%,#bd2631 100%);color:#fff5e8}.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 75% 20%,rgba(255,225,120,.28),transparent 25%),linear-gradient(90deg,rgba(20,0,0,.55),rgba(20,0,0,.08));}.hero:after{content:"";position:absolute;inset:auto 0 0 0;height:180px;background:linear-gradient(0deg,#fff9ef,transparent)}.hero__inner{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center}.eyebrow{color:var(--gold-2);letter-spacing:.32em;text-transform:uppercase;font-weight:900;font-size:12px;margin-bottom:18px}.hero h1{font-family:Georgia,serif;font-weight:800;font-size:clamp(46px,8vw,104px);line-height:.92;margin:0 0 22px;text-shadow:0 12px 34px rgba(0,0,0,.22)}.hero h1 em{display:block;color:#ffdc68;font-style:italic}.hero p{font-size:18px;line-height:1.7;color:#fff3dd;max-width:620px}.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}.btn{border-radius:999px;padding:14px 22px;font-weight:950;letter-spacing:.04em;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:.25s;border:1px solid transparent}.btn-primary{background:linear-gradient(135deg,var(--gold-2),var(--gold));color:#3d0b0b;box-shadow:0 14px 35px rgba(214,169,60,.28)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 48px rgba(214,169,60,.35)}.btn-ghost{background:rgba(255,255,255,.08);border-color:rgba(255,230,160,.35);color:#fff7df}.btn-light{background:#fff;color:var(--wine);border-color:rgba(214,169,60,.22);box-shadow:var(--soft)}.btn-danger{background:#fff0f0;color:var(--red);border-color:rgba(216,70,70,.22)}.btn-small{padding:9px 14px;font-size:13px}.hero-card{background:rgba(255,255,255,.12);border:1px solid rgba(255,228,150,.28);border-radius:32px;padding:28px;backdrop-filter:blur(14px);box-shadow:0 30px 100px rgba(0,0,0,.24);animation:rise 900ms ease both}.hero-card__logo{width:110px;height:110px;margin:auto;border-radius:24px;border:2px solid var(--gold);display:grid;place-items:center;font:900 44px Georgia,serif;color:var(--gold-2);background:rgba(31,0,0,.32)}.hero-card h2{font-family:Georgia,serif;text-align:center;font-size:36px;letter-spacing:.18em;margin:22px 0 10px}.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:22px}.hero-stats div{background:rgba(255,255,255,.12);border-radius:18px;padding:15px;text-align:center}.hero-stats b{display:block;color:var(--gold-2);font-size:22px}.reveal{opacity:0;transform:translateY(24px);animation:rise .8s ease forwards}.delay-1{animation-delay:.12s}.delay-2{animation-delay:.24s}.delay-3{animation-delay:.36s}@keyframes rise{to{opacity:1;transform:none}}
.section{padding:58px 0}.section-head{display:flex;align-items:end;justify-content:space-between;gap:18px;margin-bottom:24px}.section-title{font-family:Georgia,serif;font-size:clamp(30px,4vw,54px);line-height:1;margin:0;color:#3c1111}.section-kicker{color:var(--gold-3);font-weight:950;letter-spacing:.22em;text-transform:uppercase;font-size:12px;margin-bottom:10px}.muted{color:var(--muted)}.notice-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:18px}.notice{background:rgba(255,255,255,.76);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--soft)}.notice.warning{border-left:5px solid var(--wine-3)}.notice.info{border-left:5px solid var(--gold)}.notice h3{margin:0 0 10px;font-size:20px}.notice p{line-height:1.7;margin:8px 0}.toolbar{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0 24px}.chip{border-radius:999px;padding:11px 15px;background:#fff;border:1px solid var(--line);font-weight:850;color:#5b3a2f}.chip.active,.chip:hover{background:linear-gradient(135deg,var(--wine),var(--wine-3));color:#fff7df;border-color:transparent}.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.card{background:rgba(255,255,255,.82);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--soft);overflow:hidden}.product{display:flex;flex-direction:column;transition:.25s}.product:hover{transform:translateY(-5px);box-shadow:var(--shadow)}.product__visual{height:175px;display:grid;place-items:center;background:radial-gradient(circle at 30% 20%,rgba(255,230,160,.5),transparent 35%),linear-gradient(135deg,#4b070b,#b61627);color:#ffe9a9;font:900 42px Georgia,serif;position:relative;overflow:hidden}.product__visual:after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 20%,rgba(255,255,255,.2),transparent 40%);transform:translateX(-120%);animation:shine 4s infinite}@keyframes shine{60%,100%{transform:translateX(120%)}}.product__body{padding:18px}.product h3{font-size:18px;line-height:1.35;margin:0 0 8px;text-transform:uppercase}.product__meta{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}.tag{display:inline-flex;align-items:center;border-radius:999px;padding:6px 10px;background:#fff5df;border:1px solid rgba(214,169,60,.25);color:#724c18;font-size:12px;font-weight:900}.price-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto}.price{font-weight:950;color:var(--wine-3);font-size:20px}.old-price{text-decoration:line-through;color:#9a8a84;font-size:14px;margin-right:6px}.product__actions{display:grid;grid-template-columns:1fr 44px;gap:10px;margin-top:14px}.square{width:44px;height:44px;border-radius:14px;background:#fff;border:1px solid var(--line);color:var(--wine);font-weight:900}.panel{background:rgba(255,255,255,.84);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}.table-wrap{overflow:auto}.table{width:100%;border-collapse:collapse;min-width:760px}.table th,.table td{text-align:left;padding:14px;border-bottom:1px solid var(--line);vertical-align:top}.table th{font-size:12px;color:var(--gold-3);text-transform:uppercase;letter-spacing:.08em}.table tr:hover td{background:rgba(255,247,229,.55)}.status{display:inline-flex;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:900}.status.active,.status.approved,.status.paid{background:#eafff5;color:#0c7c50}.status.pending{background:#fff6d8;color:#966b00}.status.rejected,.status.sold{background:#fff0f0;color:#b82828}.form{display:grid;gap:14px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.field label{display:block;font-weight:900;margin-bottom:7px;color:#4e261f}.field input,.field textarea,.field select{width:100%;border:1px solid var(--line);border-radius:16px;padding:13px 14px;background:#fff;outline:none}.field textarea{min-height:120px;resize:vertical}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--gold);box-shadow:0 0 0 4px rgba(214,169,60,.13)}.page-hero{padding:46px 0;background:linear-gradient(135deg,#fff5e4,#fffdf8);border-bottom:1px solid var(--line)}.page-hero h1{
  font-family:"Be Vietnam Pro", Arial, sans-serif;
  font-size:clamp(40px,5vw,66px);
  line-height:1.12;
  margin:0;
  letter-spacing:-0.04em;
  word-break:normal;
  overflow-wrap:normal;
}.layout{display:grid;grid-template-columns:260px 1fr;gap:20px}.side{position:sticky;top:165px;align-self:start}.side a{display:flex;padding:13px 14px;border-radius:16px;font-weight:900;color:#5f3028}.side a.active,.side a:hover{background:linear-gradient(135deg,var(--wine),var(--wine-3));color:#fff7df}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.kpi{padding:20px;border-radius:22px;background:linear-gradient(135deg,#fff,#fff5dd);border:1px solid var(--line);box-shadow:var(--soft)}.kpi span{display:block;color:var(--muted);font-weight:800;font-size:13px}.kpi b{display:block;margin-top:8px;color:var(--wine);font-size:26px}.empty{padding:30px;text-align:center;color:var(--muted)}.code-box{background:#2a090b;color:#ffe6a0;border:1px solid rgba(214,169,60,.25);border-radius:16px;padding:14px;white-space:pre-wrap;word-break:break-word}.toast-wrap{position:fixed;right:20px;bottom:20px;z-index:120;display:grid;gap:10px}.toast{background:#2b090d;color:#fff7df;border:1px solid rgba(255,225,120,.25);box-shadow:var(--shadow);border-radius:18px;padding:14px 16px;min-width:260px;animation:toast .25s ease}.toast.success{border-left:5px solid var(--green)}.toast.error{border-left:5px solid var(--red)}@keyframes toast{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.footer{background:linear-gradient(135deg,#2b0507,#5b0710);color:#fff0d0;margin-top:60px;padding:48px 0 0}.footer__grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:30px}.footer a:hover{color:var(--gold-2)}.copyright{margin-top:34px;border-top:1px solid rgba(255,222,140,.16);padding:18px;text-align:center;color:#d9c8b1}.modal{position:fixed;inset:0;background:rgba(23,5,6,.66);z-index:100;display:none;align-items:center;justify-content:center;padding:18px}.modal.active{display:flex}.modal__box{width:min(680px,100%);max-height:88vh;overflow:auto;background:#fffdf8;border-radius:26px;border:1px solid rgba(214,169,60,.35);box-shadow:0 30px 100px rgba(0,0,0,.35)}.modal__head{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line);font-weight:950}.modal__body{padding:22px}.close{font-size:24px;background:transparent;color:var(--wine)}.login-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.login-tabs button{padding:14px;border-radius:18px;background:#fff3dd;color:#6d3b20;font-weight:950}.login-tabs button.active{background:linear-gradient(135deg,var(--wine),var(--wine-3));color:#fff7df}.floating{position:fixed;right:20px;bottom:20px;z-index:50;display:flex;gap:10px;align-items:center}.floating a{background:#fff;color:var(--wine);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:999px;padding:12px 16px;font-weight:950}.float-zalo{width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,#0ba8ff,#005fe8);color:white;display:grid;place-items:center;font-weight:950;box-shadow:0 0 0 8px rgba(0,118,255,.12)}
@media(max-width:1000px){.header__row{grid-template-columns:1fr auto;min-height:82px;height:auto;padding:12px 0}.search{grid-column:1/-1;order:3}.nav__row{display:none}.mobile-menu{display:grid}.actions{gap:8px}.support{display:none}.hero__inner,.notice-grid,.layout{grid-template-columns:1fr}.side{position:static}.grid{grid-template-columns:repeat(2,1fr)}.kpi-grid{grid-template-columns:repeat(2,1fr)}.hero{min-height:auto;padding:70px 0}.hero-card{display:none}.nav.mobile-open .nav__row{display:block;padding:16px 0}.nav.mobile-open .nav__links{display:grid;gap:12px}.nav.mobile-open .support{display:flex;margin-top:14px}}
@media(max-width:640px){.lux-top{display:none}.brand__name{font-size:17px}.brand__mark{width:48px;height:48px}.login-pill{padding:7px;min-width:auto}.login-pill div:last-child{display:none}.icon-btn{width:41px;height:41px}.hero h1{font-size:46px}.hero p{font-size:15px}.hero__cta .btn{width:100%}.grid,.footer__grid,.form-grid,.kpi-grid{grid-template-columns:1fr}.section{padding:38px 0}.section-head{display:block}.product__visual{height:150px}.table{min-width:650px}.floating a{display:none}.modal__box{border-radius:18px}.login-tabs{grid-template-columns:1fr}.page-hero{padding:30px 0}.panel{padding:16px}}
.admin-live-alert {
  position: fixed;
  right: 24px;
  bottom: 115px;
  z-index: 9999;
  min-width: 260px;
  max-width: 340px;
  padding: 16px 18px;
  border-radius: 22px;
  background: linear-gradient(135deg, #6d0610, #b50f24);
  color: #fff7dd;
  box-shadow: 0 18px 45px rgba(109, 6, 16, 0.35);
  border: 1px solid rgba(255, 221, 142, 0.45);
  cursor: pointer;
  animation: adminAlertPulse 1.4s ease-in-out infinite;
}

.admin-live-alert strong {
  display: block;
  font-size: 16px;
  margin-bottom: 4px;
}

.admin-live-alert span {
  display: block;
  font-size: 13px;
  opacity: 0.9;
}

.admin-live-alert.hide {
  display: none;
}

@keyframes adminAlertPulse {
  0%, 100% {
    transform: translateY(0);
    box-shadow: 0 18px 45px rgba(109, 6, 16, 0.35);
  }

  50% {
    transform: translateY(-4px);
    box-shadow: 0 24px 55px rgba(109, 6, 16, 0.5);
  }
}

@media (max-width: 768px) {
  .admin-live-alert {
    left: 18px;
    right: 18px;
    bottom: 95px;
    max-width: none;
  }
}
.qr-demo {
  width: 160px;
  height: 160px;
  border-radius: 26px;
  border: 2px solid rgba(171, 25, 39, 0.22);
  background:
    linear-gradient(90deg, rgba(109, 6, 16, .12) 12px, transparent 12px) 0 0 / 28px 28px,
    linear-gradient(rgba(109, 6, 16, .12) 12px, transparent 12px) 0 0 / 28px 28px,
    #fff7e7;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  box-shadow: 0 18px 40px rgba(109, 6, 16, 0.12);
}

.qr-demo div {
  width: 62px;
  height: 62px;
  border-radius: 18px;
  background: linear-gradient(135deg, #6d0610, #b30d21);
  color: #ffe58a;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  font-weight: 900;
  margin-bottom: 10px;
}

.qr-demo small {
  font-weight: 800;
  color: #6d0610;
  letter-spacing: 1px;
}

.qr-demo.crypto div {
  background: linear-gradient(135deg, #10291f, #168a5b);
}

@media (max-width: 768px) {
  .qr-demo {
    width: 130px;
    height: 130px;
  }
}
.code-box {
  display: inline-block;
  max-width: 100%;
  min-width: 180px;
  padding: 12px 16px;
  border-radius: 14px;
  background: #3b0508;
  color: #ffe58a;
  font-weight: 700;
  white-space: normal;
  word-break: break-word;
  overflow-wrap: anywhere;
  line-height: 1.45;
}

.table td {
  vertical-align: top;
}
.payment-qr-img {
  width: 180px;
  height: 180px;
  object-fit: contain;
  border-radius: 22px;
  border: 1px solid #f0d9d9;
  background: #fff;
  padding: 8px;
  box-shadow: 0 18px 40px rgba(70, 20, 20, 0.12);
}
.admin-alert-grid {
  display: grid;
  gap: 14px;
  margin-top: 18px;
}

.admin-alert-card {
  padding: 18px 20px;
  border-radius: 22px;
  border: 1px solid #f3d5d5;
  background: linear-gradient(135deg, #fff7e3, #fff);
  box-shadow: 0 18px 40px rgba(70, 20, 20, 0.12);
  cursor: pointer;
  transition: 0.2s ease;
}

.admin-alert-card:hover {
  transform: translateY(-2px);
}

.admin-alert-card b {
  display: block;
  color: #7a0711;
  font-size: 18px;
  margin-bottom: 6px;
}

.admin-alert-card span {
  color: #8b7770;
}

.product__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.upload-preview {
  margin-top: 12px;
  min-height: 90px;
  border: 1px dashed #e1c8bb;
  border-radius: 18px;
  padding: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #8b7770;
  background: #fffaf2;
}
.upload-preview img {
  max-width: 220px;
  max-height: 150px;
  border-radius: 16px;
  object-fit: contain;
}
.static-content h2 {
  margin-top: 24px;
  color: #3c1111;
}
.static-content p {
  line-height: 1.85;
}
.admin-live-alert-ctv {
  bottom: 176px;
  background: linear-gradient(135deg, #8f0614, #cb1530);
}
@media (max-width: 768px) {
  .admin-live-alert-ctv { bottom: 156px; }
}


/* Popup + Verify CTV */
.mmo-popup-backdrop{position:fixed;inset:0;background:rgba(30,5,8,.55);z-index:9999;display:flex;align-items:center;justify-content:center;padding:18px;backdrop-filter:blur(6px)}
.mmo-popup{width:min(720px,96vw);max-height:92vh;overflow:auto;border-radius:26px;background:linear-gradient(180deg,#fffaf0,#fff);box-shadow:0 30px 90px rgba(34,4,8,.35);border:1px solid #f3d5bd;position:relative;padding:18px;color:#2a1111}
.mmo-popup-close{position:absolute;right:16px;top:14px;width:36px;height:36px;border-radius:50%;border:0;background:#fff0f0;color:#7a0711;font-size:28px;line-height:1;cursor:pointer}
.mmo-popup-logo{text-align:center;padding:10px 0 4px}.mmo-popup-logo img{width:150px;height:90px;object-fit:cover;object-position:center;border-radius:18px;box-shadow:0 12px 30px rgba(90,10,20,.18)}
.mmo-popup-section{border-radius:22px;padding:22px;margin:14px 0;text-align:center;border:1px solid #f0d3c0}.mmo-popup-section.important{background:#fff}.mmo-popup-section.sale{color:#fff;background:linear-gradient(135deg,#8d49db,#4e84f6);box-shadow:inset 0 0 0 1px rgba(255,255,255,.2)}
.mmo-popup-section h2{margin:0 0 12px;font-size:24px}.popup-actions,.mmo-popup-footer{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:14px}.sale-box{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.28);padding:16px;border-radius:18px;font-weight:800;color:#ffe16a}.sale-box span{display:block;color:#fff;font-size:14px;margin-top:6px}.popup-countdown{display:flex;gap:12px;justify-content:center}.popup-countdown b{background:rgba(255,255,255,.2);border-radius:14px;min-width:62px;padding:12px 10px;font-size:22px}.btn-danger{background:#b91527;color:#fff;border:0}.verify-card{text-align:center}.verify-card.verified{border:1px solid #bdebd2;background:linear-gradient(135deg,#f3fff8,#fff)}.verify-card.danger{border:1px solid #ffd0d0;background:linear-gradient(135deg,#fff7f7,#fff)}.verify-badge{width:62px;height:62px;border-radius:50%;display:grid;place-items:center;margin:0 auto 10px;background:#e3fff0;color:#009b5a;font-size:34px;font-weight:900}.verify-badge.danger{background:#fff0f0;color:#c7192c}.blue-tick{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:50%;background:#178bff;color:#fff;font-size:10px;vertical-align:middle}.floating a{display:inline-flex;align-items:center;gap:7px}.only-user-hidden-percent{display:none!important}

/* === 2026-05 UI hotfixes / CTV upgrade === */
.brand__mark {
  padding: 0 !important;
  overflow: hidden;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.brand__mark img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.hero-card__logo {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px;
  background: rgba(255,255,255,0.08);
}

.hero-card__logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.checkout-shell {
  display: grid;
  grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
  gap: 28px;
  align-items: start;
}

.coupon-panel, .order-panel {
  min-height: 100%;
}

.order-table .order-name { font-weight: 700; }
.old-price.red, .red.old-price {
  color: #c62828 !important;
  text-decoration-color: #c62828 !important;
}
.old-price.big { font-size: 1.1rem; }
.order-summary-box {
  background: rgba(113, 19, 25, 0.04);
  border: 1px solid rgba(113, 19, 25, 0.08);
  border-radius: 18px;
  padding: 18px;
  margin: 18px 0;
}
.summary-line {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 10px 0;
  border-bottom: 1px dashed rgba(113, 19, 25, 0.16);
}
.summary-line:last-child { border-bottom: 0; }
.total-line { font-size: 1.15rem; }

.mmo-popup.popup-premium {
  max-width: 760px;
  border-radius: 28px;
  background: linear-gradient(180deg, #fffdf7 0%, #fff7ef 100%);
}
.mmo-popup-logo {
  width: 160px;
  height: auto;
  margin: 0 auto 18px;
}
.mmo-popup-logo img {
  width: 100%;
  height: auto;
  object-fit: contain;
  display: block;
}
.mmo-popup-section.sale.red-gold {
  background: linear-gradient(135deg, #7b000f 0%, #b5171f 45%, #f1b832 100%);
  color: #fff9ea;
  border: 1px solid rgba(255,255,255,0.16);
}
.mmo-popup-section.sale.red-gold h2,
.mmo-popup-section.sale.red-gold p { color: inherit; }
.popup-hot-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 16px;
}
.popup-hot-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 16px;
  border-radius: 18px;
  text-decoration: none;
  background: rgba(255, 249, 234, 0.12);
  color: #fffdf6;
  border: 1px solid rgba(255,255,255,0.18);
}
.popup-hot-card:hover { transform: translateY(-2px); }
.hot-name { font-weight: 700; line-height: 1.45; }
.hot-prices { display:flex; flex-direction:column; gap:4px; }
.hot-prices small { color: rgba(255,249,234,0.9); }
.popup-bottom-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 20px;
}
.popup-pill, .popup-hide-session {
  border-radius: 999px;
  padding: 14px 24px;
  text-decoration: none;
  border: 1px solid rgba(173, 130, 35, 0.24);
  background: #fff;
  color: #6e0d16;
  font-weight: 700;
}
.popup-pill.telegram, .popup-pill.zalo {
  min-width: 150px;
  text-align: center;
}
.popup-hide-session {
  background: #c41728;
  color: #fff;
  border-color: #c41728;
  cursor: pointer;
  flex: 1;
}

.ctv-celebration-popup {
  position: relative;
  overflow: hidden;
  max-width: 650px;
  background: linear-gradient(180deg, #fffdf6 0%, #fff3e2 100%);
}
.ctv-confetti-zone {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}
.ctv-confetti-piece {
  position: absolute;
  top: -30px;
  width: 10px;
  height: 18px;
  border-radius: 2px;
  background: linear-gradient(180deg, #f1b832, #d4142a);
  animation: ctvConfettiFall 3.2s linear forwards;
}
@keyframes ctvConfettiFall {
  0% { transform: translateY(0) rotate(0deg); opacity: 1; }
  100% { transform: translateY(420px) rotate(540deg); opacity: 0; }
}
.ctv-win-box { text-align: center; }
.ctv-win-box h2 { margin-bottom: 10px; }
.ctv-win-amount {
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 800;
  color: #a30818;
  margin: 12px 0;
}

@media (max-width: 960px) {
  .checkout-shell { grid-template-columns: 1fr; }
  .popup-hot-grid { grid-template-columns: 1fr; }
}

/* === Quick checkout + auto coupon + extra animation update === */
.animated-gradient-text {
  background: linear-gradient(90deg, #fff7d8, #f2bd3c, #ffffff, #f2bd3c, #fff7d8);
  background-size: 260% auto;
  color: transparent;
  -webkit-background-clip: text;
  background-clip: text;
  animation: shimmerText 3.2s linear infinite, textPop 2.8s ease-in-out infinite;
}

.text-pop { animation-name: shimmerText, textPop; }
.text-float { animation: softFloatText 3.4s ease-in-out infinite; }
.stat-bounce { animation: statBounce 2.6s ease-in-out infinite; }
.delay-mini { animation-delay: .25s; }
.delay-mini-2 { animation-delay: .5s; }
.hero-card { animation: heroGlowMove 5s ease-in-out infinite; }
.hero-card__logo img { animation: logoPulse 2.8s ease-in-out infinite; }
.btn-primary { position: relative; overflow: hidden; }
.btn-primary:after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, transparent 0%, rgba(255,255,255,.28) 45%, transparent 70%);
  transform: translateX(-130%);
  animation: buttonSweep 3.4s ease-in-out infinite;
  pointer-events: none;
}

@keyframes shimmerText { to { background-position: 260% center; } }
@keyframes textPop { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.025); } }
@keyframes softFloatText { 0%, 100% { transform: translateY(0); opacity: .95; } 50% { transform: translateY(-4px); opacity: 1; } }
@keyframes statBounce { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-6px); } }
@keyframes heroGlowMove { 0%, 100% { box-shadow: 0 22px 70px rgba(92,7,16,.25); transform: translateY(0); } 50% { box-shadow: 0 30px 95px rgba(214,169,60,.2); transform: translateY(-5px); } }
@keyframes logoPulse { 0%,100% { transform: scale(1); filter: drop-shadow(0 0 0 rgba(214,169,60,0)); } 50% { transform: scale(1.06); filter: drop-shadow(0 0 14px rgba(214,169,60,.5)); } }
@keyframes buttonSweep { 0%, 55% { transform: translateX(-130%); } 100% { transform: translateX(130%); } }

.summary-original-normal {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 12px;
  border-radius: 999px;
  background: #211313;
  color: #ffe7a0;
  text-decoration: none !important;
  font-weight: 950;
}

.quick-checkout-popup {
  width: min(1080px, calc(100vw - 32px));
  max-height: 92vh;
  overflow: auto;
  background: linear-gradient(180deg, #fffdf8 0%, #fff5e4 100%);
}

.quick-checkout-popup h2 {
  text-align: center;
  margin: 8px 0 8px;
  font-size: clamp(28px, 4vw, 44px);
}

.quick-checkout-popup > .muted {
  text-align: center;
  margin-bottom: 18px;
}

.quick-checkout-grid {
  display: grid;
  grid-template-columns: minmax(260px, 360px) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

.quick-order-table { min-width: 620px; }
.mini-coupon-panel,
.mini-order-panel {
  box-shadow: var(--soft);
}

@media (max-width: 900px) {
  .quick-checkout-grid { grid-template-columns: 1fr; }
}

/* =========================================================
   MOBILE RESPONSIVE PACK V4
   Tối ưu giao diện điện thoại cho User / Admin / CTV
   Không cần chạy thêm MySQL
   ========================================================= */

html, body {
  max-width: 100%;
}

img, video, canvas {
  max-width: 100%;
}

.table-wrap {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.table-wrap::-webkit-scrollbar,
.side::-webkit-scrollbar,
.nav__links::-webkit-scrollbar {
  height: 6px;
}

.table-wrap::-webkit-scrollbar-thumb,
.side::-webkit-scrollbar-thumb,
.nav__links::-webkit-scrollbar-thumb {
  background: rgba(141,17,29,.28);
  border-radius: 999px;
}

.product__visual img,
.payment-qr-img,
.upload-preview img {
  max-width: 100%;
  height: auto;
}

/* Tablet */
@media (max-width: 1024px) {
  :root {
    --container: 940px;
    --radius: 20px;
  }

  .container {
    width: min(var(--container), calc(100% - 28px));
  }

  .header__row {
    grid-template-columns: 1fr auto;
    height: auto;
    min-height: 78px;
    padding: 12px 0;
  }

  .brand {
    min-width: 0;
  }

  .brand__name {
    line-height: 1.05;
  }

  .search {
    grid-column: 1 / -1;
    order: 3;
  }

  .actions {
    flex-wrap: nowrap;
  }

  .mobile-menu {
    display: grid !important;
  }

  .nav__row {
    display: none;
  }

  .nav.mobile-open .nav__row {
    display: block;
    padding: 14px 0 16px;
  }

  .nav.mobile-open .nav__links {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .nav.mobile-open .nav__links a {
    background: rgba(255,255,255,.72);
    border: 1px solid rgba(124,75,36,.14);
    border-radius: 16px;
    padding: 12px 14px;
    box-shadow: 0 8px 18px rgba(101,24,24,.07);
  }

  .nav.mobile-open .support {
    display: flex;
    margin-top: 12px;
    flex-wrap: wrap;
    gap: 10px;
  }

  .hero {
    min-height: auto;
    padding: 64px 0 82px;
  }

  .hero__inner,
  .notice-grid,
  .layout,
  .checkout-shell,
  .quick-checkout-grid {
    grid-template-columns: 1fr !important;
  }

  .hero-card {
    width: min(520px, 100%);
    margin: 10px auto 0;
  }

  .grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .side.panel {
    position: sticky;
    top: 96px;
    z-index: 30;
    display: flex;
    flex-direction: row;
    gap: 10px;
    overflow-x: auto;
    white-space: nowrap;
    padding: 12px;
    border-radius: 20px;
    background: rgba(255,253,248,.92);
    backdrop-filter: blur(12px);
  }

  .side.panel a {
    flex: 0 0 auto;
    border-radius: 999px;
    padding: 11px 16px;
    min-width: max-content;
  }

  .panel {
    overflow: hidden;
  }

  .table {
    min-width: 760px;
  }

  .form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mmo-popup,
  .quick-checkout-popup {
    width: min(760px, calc(100vw - 24px));
  }
}

/* Phone */
@media (max-width: 720px) {
  :root {
    --radius: 18px;
  }

  body {
    font-size: 14px;
    padding-bottom: 70px;
  }

  .container {
    width: calc(100% - 24px);
  }

  .lux-top {
    display: none;
  }

  .header {
    top: 0;
  }

  .header__row {
    grid-template-columns: 1fr auto;
    gap: 10px;
    padding: 10px 0;
  }

  .brand {
    gap: 9px;
  }

  .brand__mark {
    width: 46px !important;
    height: 46px !important;
    border-radius: 13px;
    flex: 0 0 46px;
  }

  .brand__name {
    font-size: 16px;
    letter-spacing: .02em;
    max-width: 150px;
  }

  .brand__tag {
    font-size: 8px;
    letter-spacing: .18em;
  }

  .actions {
    gap: 6px;
  }

  .icon-btn {
    width: 39px;
    height: 39px;
    font-size: 15px;
  }

  .badge {
    min-width: 19px;
    height: 19px;
    font-size: 10px;
  }

  .login-pill {
    min-width: 0;
    padding: 6px;
    gap: 0;
  }

  .login-pill .avatar {
    width: 34px;
    height: 34px;
  }

  .login-pill div:last-child {
    display: none;
  }

  .search input {
    height: 46px;
    padding-left: 16px;
  }

  .search button {
    width: 34px;
    height: 34px;
    top: 6px;
  }

  .nav.mobile-open {
    position: sticky;
    top: 114px;
    z-index: 55;
    background: rgba(255,249,239,.96);
    box-shadow: 0 14px 30px rgba(50,8,8,.08);
  }

  .nav.mobile-open .nav__links {
    grid-template-columns: 1fr 1fr;
    max-height: 52vh;
    overflow-y: auto;
  }

  .nav.mobile-open .nav__links a {
    font-size: 12px;
    padding: 11px 12px;
  }

  .nav.mobile-open .support {
    display: none;
  }

  .page-hero {
    padding: 34px 0;
  }

  .page-hero h1,
  .hero h1 {
    font-size: clamp(38px, 12vw, 58px);
    line-height: .96;
  }

  .hero {
    padding: 42px 0 66px;
  }

  .hero__inner {
    gap: 24px;
  }

  .hero p {
    font-size: 15px;
    line-height: 1.65;
  }

  .hero__cta {
    gap: 10px;
  }

  .hero__cta .btn,
  .btn.block-mobile {
    width: 100%;
  }

  .hero-card {
    display: block !important;
    padding: 20px;
    border-radius: 24px;
  }

  .hero-card__logo {
    width: 86px;
    height: 86px;
    border-radius: 20px;
  }

  .hero-card h2 {
    font-size: 25px;
    letter-spacing: .12em;
  }

  .hero-stats {
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
  }

  .hero-stats div {
    padding: 12px 8px;
    border-radius: 15px;
  }

  .hero-stats b {
    font-size: 18px;
  }

  .section {
    padding: 34px 0;
  }

  .section-head {
    display: block;
  }

  .section-title {
    font-size: 34px;
  }

  .toolbar {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 4px;
  }

  .chip {
    flex: 0 0 auto;
  }

  .grid,
  .footer__grid,
  .form-grid,
  .kpi-grid,
  .notice-grid {
    grid-template-columns: 1fr !important;
  }

  .product__visual {
    height: 156px;
  }

  .product__body {
    padding: 15px;
  }

  .product h3 {
    font-size: 16px;
  }

  .product__actions,
  .hero__cta,
  .popup-actions,
  .mmo-popup-footer,
  .popup-bottom-bar {
    display: grid;
    grid-template-columns: 1fr;
  }

  .product__actions .btn,
  .product__actions .square {
    width: 100%;
  }

  .square {
    height: 44px;
    border-radius: 999px;
  }

  .layout {
    gap: 14px;
  }

  .side.panel {
    top: 108px;
    margin-bottom: 12px;
    padding: 10px;
    border-radius: 18px;
  }

  .side.panel a {
    font-size: 13px;
    padding: 10px 14px;
  }

  .panel,
  .notice,
  .card,
  .modal__box {
    border-radius: 18px;
    padding: 16px;
  }

  .panel h2,
  .notice h3 {
    font-size: 21px;
  }

  .kpi {
    min-height: 92px;
  }

  .kpi b {
    font-size: 22px;
  }

  .table {
    min-width: 720px;
    font-size: 13px;
  }

  .table th,
  .table td {
    padding: 11px 10px;
    vertical-align: top;
  }

  .code-box {
    word-break: break-word;
  }

  input,
  select,
  textarea {
    min-height: 46px;
  }

  textarea {
    min-height: 96px;
  }

  .auth-card,
  .login-card {
    width: 100%;
    padding: 18px;
    border-radius: 20px;
  }

  .login-tabs {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .payment-box,
  .payment-info,
  .bank-card,
  .crypto-card {
    grid-template-columns: 1fr !important;
  }

  .payment-qr-img {
    width: min(240px, 100%) !important;
    height: auto !important;
    margin: 0 auto 12px;
  }

  .checkout-shell,
  .quick-checkout-grid {
    grid-template-columns: 1fr !important;
    gap: 14px;
  }

  .coupon-panel {
    order: 1;
  }

  .order-panel {
    order: 2;
  }

  .order-summary-box {
    padding: 14px;
  }

  .summary-line {
    align-items: flex-start;
  }

  .summary-line b {
    text-align: right;
  }

  .quick-checkout-popup,
  .mmo-popup {
    width: calc(100vw - 18px);
    max-height: 88vh;
    border-radius: 22px;
    padding: 14px;
  }

  .quick-checkout-popup h2 {
    font-size: 28px;
  }

  .quick-order-table {
    min-width: 650px;
  }

  .mmo-popup-logo {
    width: 132px;
    margin-bottom: 12px;
  }

  .mmo-popup-logo img {
    height: auto !important;
    object-fit: contain !important;
  }

  .mmo-popup-section {
    padding: 17px;
    border-radius: 18px;
  }

  .mmo-popup-section h2 {
    font-size: 20px;
  }

  .popup-hot-grid {
    grid-template-columns: 1fr !important;
  }

  .popup-pill,
  .popup-hide-session {
    width: 100%;
    min-width: 0;
  }

  .floating {
    position: fixed;
    left: 10px;
    right: 10px;
    bottom: 10px;
    z-index: 70;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    pointer-events: none;
  }

  .floating a {
    display: inline-flex !important;
    justify-content: center;
    pointer-events: auto;
    padding: 12px 10px;
    border-radius: 999px;
    background: rgba(255,255,255,.94);
    box-shadow: 0 12px 28px rgba(60,8,8,.16);
    font-size: 13px;
  }

  .footer {
    padding-bottom: 88px;
  }

  .footer__grid {
    gap: 20px;
    text-align: left;
  }

  .copyright {
    padding: 18px 12px;
    font-size: 12px;
  }

  .admin-live-alert,
  .admin-live-alert-ctv {
    left: 12px !important;
    right: 12px !important;
    bottom: 76px !important;
    width: auto !important;
    max-width: none !important;
  }
}

/* Small phone */
@media (max-width: 430px) {
  .container {
    width: calc(100% - 18px);
  }

  .brand__name {
    font-size: 14px;
    max-width: 132px;
  }

  .brand__tag {
    display: none;
  }

  .brand__mark {
    width: 40px !important;
    height: 40px !important;
    flex-basis: 40px;
  }

  .icon-btn {
    width: 36px;
    height: 36px;
  }

  .login-pill .avatar {
    width: 31px;
    height: 31px;
  }

  .nav.mobile-open {
    top: 106px;
  }

  .nav.mobile-open .nav__links {
    grid-template-columns: 1fr;
  }

  .hero h1,
  .page-hero h1 {
    font-size: 38px;
  }

  .hero-card h2 {
    font-size: 21px;
  }

  .hero-stats {
    grid-template-columns: 1fr;
  }

  .section-title {
    font-size: 29px;
  }

  .btn {
    padding: 13px 16px;
  }

  .panel,
  .notice,
  .card {
    padding: 14px;
  }

  .table {
    min-width: 680px;
  }

  .side.panel {
    top: 102px;
  }

  .summary-line {
    display: grid;
    grid-template-columns: 1fr;
    gap: 5px;
  }

  .summary-line b {
    text-align: left;
  }

  .mmo-popup,
  .quick-checkout-popup {
    width: calc(100vw - 12px);
    padding: 12px;
  }
}

/* === Mobile V5: admin withdraw alert + count-up stats === */
.admin-live-alert-withdraw {
  bottom: 198px;
  background: linear-gradient(135deg, #8a0714, #d1162d);
}

@media (min-width: 769px) {
  .admin-live-alert-deposit { bottom: 115px; }
  .admin-live-alert-ctv { bottom: 176px; }
  .admin-live-alert-withdraw { bottom: 237px; }
}

@media (max-width: 768px) {
  .admin-live-alert-deposit { bottom: 76px !important; }
  .admin-live-alert-ctv { bottom: 148px !important; }
  .admin-live-alert-withdraw { bottom: 220px !important; }
}

.hero-count-stats .stat-count {
  animation: none !important;
  position: relative;
  transform: none !important;
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
}

.hero-count-stats .stat-count:hover {
  transform: translateY(-4px) !important;
  background: rgba(255,255,255,.16);
  box-shadow: 0 16px 38px rgba(0,0,0,.18);
}

.hero-count-stats .count-up {
  display: inline-block;
  min-width: 1.2em;
  font-variant-numeric: tabular-nums;
  animation: countGlow 1.5s ease-in-out infinite;
}

.hero-count-stats .count-finished {
  animation: countFinishPop .45s ease both;
}

@keyframes countGlow {
  0%, 100% { text-shadow: 0 0 0 rgba(255,231,160,0); }
  50% { text-shadow: 0 0 18px rgba(255,231,160,.65); }
}

@keyframes countFinishPop {
  0% { transform: scale(1); }
  45% { transform: scale(1.18); }
  100% { transform: scale(1); }
}

/* === V6: quick checkout quantity stepper + admin CTV cleanup === */
.qty-stepper {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 6px;
  border-radius: 999px;
  background: rgba(113, 13, 22, 0.06);
  border: 1px solid rgba(113, 13, 22, 0.1);
}
.qty-stepper button {
  width: 30px;
  height: 30px;
  border: 0;
  border-radius: 999px;
  cursor: pointer;
  font-weight: 900;
  color: #6e0d16;
  background: linear-gradient(135deg, #ffe898, #d9a62f);
  box-shadow: 0 8px 18px rgba(113, 13, 22, 0.14);
}
.qty-stepper button:hover {
  transform: translateY(-1px);
}
.qty-stepper b {
  min-width: 22px;
  text-align: center;
  color: #211313;
}
@media (max-width: 720px) {
  .qty-stepper {
    gap: 5px;
    padding: 4px;
  }
  .qty-stepper button {
    width: 28px;
    height: 28px;
  }
}


/* === V7 CTV Verify avatar + blue badge === */
.verify-avatar-wrap {
  position: relative;
  width: 118px;
  height: 118px;
  margin: 0 auto 18px;
}

.verify-avatar {
  width: 118px;
  height: 118px;
  border-radius: 999px;
  object-fit: cover;
  display: block;
  border: 4px solid #fff;
  box-shadow: 0 18px 45px rgba(0, 0, 0, .14);
  background: #fff7e8;
}

.verify-blue-badge {
  position: absolute;
  width: 34px;
  height: 34px;
  right: -4px;
  bottom: 6px;
  border-radius: 999px;
  object-fit: contain;
  background: #fff;
  padding: 2px;
  box-shadow: 0 8px 20px rgba(24, 119, 242, .22);
}

.inline-blue-badge {
  width: 24px;
  height: 24px;
  vertical-align: -4px;
  object-fit: contain;
  margin-left: 8px;
}

.ctv-avatar-preview {
  width: 82px;
  height: 82px;
  border-radius: 999px;
  overflow: hidden;
  border: 3px solid rgba(221, 172, 65, .45);
  box-shadow: 0 12px 30px rgba(70, 20, 20, .12);
  margin: 8px 0 12px;
  background: #fff;
}

.ctv-avatar-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* === V8 category + image fit === */
/* Đã bỏ phần ép font theo taphoasieure để trả font web về như bản cũ. */

.symbol-helper-box {
  margin-top: 6px;
}

.symbol-palette {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.symbol-chip {
  border-radius: 999px;
  padding: 8px 12px;
  background: #fff;
  color: var(--wine);
  border: 1px solid rgba(214, 169, 60, .28);
  box-shadow: var(--soft);
  font-weight: 800;
}

.symbol-chip:hover {
  transform: translateY(-1px);
  border-color: var(--gold);
  background: #fff7df;
}

.upload-preview-product {
  width: fit-content;
  max-width: 100%;
  min-height: 0;
  padding: 0;
  border: 0;
  background: transparent;
  justify-content: flex-start;
}

.upload-preview-product img {
  width: auto;
  max-width: min(100%, 520px);
  height: auto;
  max-height: 360px;
  object-fit: contain;
  border-radius: 18px;
  box-shadow: var(--soft);
}

.product__visual:has(img) {
  height: auto !important;
  min-height: 0;
  display: block;
  padding: 0;
  background: transparent !important;
  border: none !important;
  box-shadow: none;
}

.product__visual:has(img)::after {
  display: none !important;
}

.product__visual:has(img) img {
  display: block;
  width: 100%;
  height: auto !important;
  object-fit: contain !important;
  border-radius: inherit;
}

.card.product .product__visual:has(img) {
  background: #fff !important;
  border-radius: var(--radius) var(--radius) 0 0;
}

.card.product .product__visual:has(img) img {
  max-height: 240px;
  object-fit: contain !important;
}

@media (max-width: 640px) {
  .symbol-palette { gap: 6px; }
  .symbol-chip { padding: 7px 10px; }
  .upload-preview-product img { max-height: 260px; }
}

/* === V9: category sections visible to users === */
.category-user-menu {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 10px;
  margin: 18px 0 28px;
}

.category-user-chip {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 52px;
  padding: 12px 16px;
  border-radius: 12px;
  background: linear-gradient(135deg, #2a0b0d, #4b070b);
  color: #fff8e8;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .02em;
  text-decoration: none;
  box-shadow: 0 12px 24px rgba(74,7,11,.16);
  border: 1px solid rgba(255, 224, 150, .12);
  transition: .2s ease;
}

.category-user-chip span {
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: rgba(255,255,255,.12);
  color: #ffe28a;
  flex: 0 0 auto;
}

.category-user-chip:hover,
.category-user-chip.active {
  transform: translateY(-2px);
  background: linear-gradient(135deg, var(--wine), var(--red));
  color: #fff8e8;
}

.category-group-list {
  display: grid;
  gap: 36px;
}

.category-product-section {
  display: grid;
  gap: 16px;
}

.category-red-strip {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 58px;
  padding: 12px 18px;
  border-radius: 14px;
  background: linear-gradient(135deg, #5a0509, #8c0b16 46%, #c0182a);
  color: #fff7df;
  font-size: clamp(18px, 2.4vw, 25px);
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .03em;
  box-shadow: 0 14px 30px rgba(120, 12, 22, .22);
  border: 1px solid rgba(255, 230, 170, .24);
}

.category-red-icon {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 9px;
  background: rgba(255,255,255,.14);
  color: #ffe28a;
  flex: 0 0 auto;
}

.product-category-label {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  border-radius: 999px;
  padding: 6px 11px;
  margin-bottom: 10px;
  background: #fff5df;
  border: 1px solid rgba(214,169,60,.28);
  color: #795018;
  font-size: 12px;
  font-weight: 950;
  line-height: 1.2;
}

.category-product-grid .product__visual:has(img) {
  background: #fff;
}

.category-product-grid .product__visual img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  background: #fff;
}

@media(max-width: 720px) {
  .category-user-menu {
    grid-template-columns: 1fr;
  }

  .category-red-strip {
    border-radius: 12px;
    font-size: 16px;
    min-height: 50px;
  }

  .category-red-icon {
    width: 30px;
    height: 30px;
  }
}

/* === V10: category image upload / user visible category icons === */
.category-user-chip span,
.category-red-icon,
.admin-category-thumb {
  overflow: hidden;
  background: rgba(255,255,255,.14);
}

.category-user-chip span img,
.category-red-icon img,
.admin-category-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.category-user-chip span {
  border-radius: 7px;
  border: 1px solid rgba(255, 224, 150, .22);
}

.category-red-icon {
  width: 34px;
  height: 34px;
  display: inline-grid;
  place-items: center;
  border-radius: 8px;
  flex: 0 0 auto;
  border: 1px solid rgba(255, 224, 150, .28);
}

.admin-category-thumb {
  width: 46px;
  height: 46px;
  display: inline-grid;
  place-items: center;
  border-radius: 10px;
  color: #ffe28a;
  background: linear-gradient(135deg, #2a0b0d, #5b0710);
  border: 1px solid rgba(255, 224, 150, .24);
  font-weight: 900;
}

.category-upload-preview {
  margin-top: 12px;
  min-height: 0;
}

.category-upload-preview img {
  width: 92px;
  height: 62px;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid rgba(113, 19, 25, .18);
  box-shadow: 0 10px 24px rgba(70, 20, 20, .12);
}

/* V12 - Admin chỉnh sửa danh mục */
.table tr.editing-row {
  background: rgba(224, 176, 64, 0.12) !important;
  outline: 2px solid rgba(224, 176, 64, 0.35);
  outline-offset: -2px;
}
.category-upload-preview img {
  max-width: 220px;
  max-height: 140px;
  object-fit: contain;
  border-radius: 16px;
  border: 1px solid rgba(124, 75, 36, 0.16);
  background: #fff;
  padding: 8px;
  box-shadow: 0 12px 30px rgba(70, 20, 18, 0.08);
}
.admin-category-thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
