:root{--green:#16803c;--dark:#111827;--muted:#64748b;--bg:#f6fbf6;--line:#e2e8f0;--card:#fff;--red:#dc2626;--amber:#d97706;--blue:#2563eb}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:#0f172a}.app{min-height:100vh}.auth{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#064e3b,#047857)}.auth-card{width:min(430px,92vw);background:#fff;border-radius:28px;padding:30px;box-shadow:0 24px 80px rgba(0,0,0,.25);text-align:center}.logo{width:58px;height:58px;border-radius:16px;object-fit:cover}.auth-card h1{font-size:25px;line-height:1.2;margin:14px 0 6px}.auth-card p{margin:0 0 18px;color:var(--muted);font-weight:700}.field{display:flex;flex-direction:column;gap:7px;text-align:left}.field label{font-size:12px;text-transform:uppercase;font-weight:900;color:#475569}.field input,.field select,.field textarea{width:100%;border:1px solid #dbe4ec;border-radius:14px;padding:13px 14px;font:inherit;font-weight:750;background:#fff}.field textarea{min-height:90px}.formgrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.full{grid-column:1/-1}.btn{border:0;border-radius:14px;background:var(--green);color:#fff;font-weight:950;padding:12px 16px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;justify-content:center}.btn:hover{filter:brightness(.96)}.btn.light{background:#eef2f7;color:#0f172a}.btn.red{background:var(--red)}.btn.blue{background:var(--blue)}.btn:disabled{background:#cbd5e1;cursor:not-allowed}.layout{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.side{background:#111827;color:#cbd5e1;padding:18px 14px;position:sticky;top:0;height:100vh;overflow:auto}.brand{display:flex;gap:10px;align-items:center;margin-bottom:18px}.brand strong{display:block;color:#fff;font-size:17px;line-height:1.15}.brand small{font-size:11px;color:#94a3b8}.userbox{background:#eafff0;color:#064e3b;border-radius:18px;padding:14px;margin:12px 0 14px;font-weight:850}.side .quick{width:100%;margin:0 0 10px}.nav{display:flex;flex-direction:column;gap:5px}.nav button{border:0;background:transparent;color:#cbd5e1;border-radius:14px;padding:12px 14px;text-align:left;display:flex;gap:12px;align-items:center;font-weight:850;font-size:15px;cursor:pointer}.nav button:hover,.nav button.active{background:var(--green);color:#fff}.nav svg{width:19px;height:19px;flex:none}.logout{margin-top:14px;width:100%;background:#2b1720;color:#fecaca}.main{min-width:0}.topbar{height:82px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 32px;position:sticky;top:0;z-index:30}.topbar h2{margin:0;font-size:25px}.topbar small{display:block;color:var(--muted);font-weight:800;margin-top:4px}.content{padding:28px 32px}.cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px}.card{background:var(--card);border:1px solid var(--line);border-radius:22px;padding:18px;box-shadow:0 10px 28px rgba(15,23,42,.04)}.kpi small{font-weight:950;color:#64748b;text-transform:uppercase;font-size:12px}.kpi b{display:block;margin-top:10px;font-size:27px;color:#087a34}.section{background:#fff;border:1px solid var(--line);border-radius:24px;padding:18px;margin:18px 0;box-shadow:0 10px 30px rgba(15,23,42,.04)}.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}.section h3{margin:0 0 4px;font-size:22px}.section p{margin:0;color:var(--muted);font-weight:700}.filters{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;margin:12px 0}.tablewrap{overflow:auto;border:1px solid var(--line);border-radius:18px}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:13px 14px;border-bottom:1px solid #edf2f7;text-align:left;vertical-align:top}.table th{background:#f8fafc;color:#475569;font-size:12px;text-transform:uppercase}.badge{display:inline-flex;border-radius:999px;padding:6px 10px;background:#dcfce7;color:#067a35;font-weight:900;font-size:12px}.badge.warn{background:#fef3c7;color:#92400e}.badge.red{background:#fee2e2;color:#991b1b}.actions{display:flex;gap:8px;flex-wrap:wrap}.linkbtn{border:0;background:transparent;color:#0f7a35;font-weight:950;cursor:pointer;padding:5px}.muted{color:var(--muted)}.empty{padding:28px;text-align:center;color:#64748b;font-weight:850}.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);background:#15803d;color:#fff;border-radius:14px;padding:12px 18px;font-weight:900;z-index:9999;box-shadow:0 18px 50px rgba(0,0,0,.25)}.toast.bad{background:#dc2626}.modal-bg{position:fixed;inset:0;background:rgba(15,23,42,.56);z-index:1000;display:flex;align-items:center;justify-content:center;padding:18px}.modal{width:min(860px,96vw);max-height:92vh;overflow:auto;background:#fff;border-radius:24px;box-shadow:0 26px 90px 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)}.modal-head h3{margin:0;font-size:23px}.x{border:0;width:36px;height:36px;border-radius:50%;font-weight:1000;cursor:pointer;background:#f1f5f9}.modal-body{padding:20px 22px}.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--line);background:#f8fafc;border-radius:0 0 24px 24px}.checks{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;max-height:230px;overflow:auto;border:1px solid #dbe4ec;border-radius:14px;padding:10px}.checks label{display:flex;gap:8px;align-items:center;font-weight:750}.product-picker{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;max-height:300px;overflow:auto}.prod-card{border:1px solid var(--line);border-radius:16px;padding:10px;display:flex;gap:10px;align-items:center;cursor:pointer}.prod-card:hover{border-color:#16a34a;background:#f0fdf4}.prod-card img{width:54px;height:54px;object-fit:cover;border-radius:12px;background:#f1f5f9}.mobile-toggle{display:none}.detailbox{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:16px;padding:12px;margin-top:10px;white-space:pre-wrap}.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.tabs button{border:1px solid var(--line);background:#fff;border-radius:999px;padding:9px 13px;font-weight:850;cursor:pointer}.tabs button.active{background:#0f172a;color:#fff}@media(max-width:1000px){.layout{grid-template-columns:1fr}.side{position:fixed;z-index:60;left:-290px;transition:.2s;width:280px}.side.open{left:0}.mobile-toggle{display:inline-flex}.topbar{padding:0 16px}.content{padding:18px 14px}.cards{grid-template-columns:1fr 1fr}.filters{grid-template-columns:1fr 1fr}.formgrid{grid-template-columns:1fr}.checks{grid-template-columns:1fr}.product-picker{grid-template-columns:1fr}.table th,.table td{font-size:13px;padding:10px}.side-scrim{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:50}}@media(max-width:560px){.cards{grid-template-columns:1fr}.filters{grid-template-columns:1fr}.topbar h2{font-size:19px}.content{padding-bottom:80px}}
/* V36: dashboard cá nhân + chỉnh font/hiển thị */
body{font-family:'Inter','Segoe UI',Roboto,Arial,sans-serif;font-size:15px;letter-spacing:-.01em}.topbar h2,.section h3,.auth-card h1{font-weight:950;letter-spacing:-.035em}.nav button{font-size:14px;font-weight:900}.card{border-radius:20px}.card h3{font-size:20px;line-height:1.15}.kpi b{font-size:25px;line-height:1.1}.section p,.muted{line-height:1.45}.personal-hero{background:linear-gradient(135deg,#12b981,#057a55);color:#fff;border-radius:28px;padding:26px 30px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;gap:18px;box-shadow:0 16px 36px rgba(5,122,85,.22)}.personal-hero small{text-transform:uppercase;font-weight:950;opacity:.85}.personal-hero h2{font-size:32px;margin:8px 0 6px;letter-spacing:-.04em}.personal-hero p{margin:0;font-weight:800;opacity:.9;max-width:760px}.level-pill{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);padding:14px 18px;border-radius:18px;font-weight:950;white-space:nowrap}.table th{font-size:11px;letter-spacing:.02em}.table td{font-size:14px}.field label{letter-spacing:.02em}@media(max-width:760px){.personal-hero{display:block;padding:22px}.personal-hero h2{font-size:26px}.level-pill{display:inline-flex;margin-top:14px}.kpi b{font-size:22px}.card h3{font-size:18px}}

/* V37: dashboard cá nhân đẹp hơn + phân quyền rõ */
:root{--soft:#f1fbf4;--emerald:#0f8f4b;--emerald2:#11b981}.content{max-width:1540px;margin:0 auto;width:100%}.member-dash{max-width:1220px;margin:0 auto}.member-hero{background:linear-gradient(135deg,#16c784 0%,#0b7a50 58%,#075c43 100%);color:#fff;border-radius:30px;padding:28px 32px;margin-bottom:18px;display:flex;align-items:stretch;justify-content:space-between;gap:22px;box-shadow:0 22px 54px rgba(6,95,70,.22);position:relative;overflow:hidden}.member-hero:after{content:"";position:absolute;right:-120px;top:-120px;width:310px;height:310px;border-radius:50%;background:rgba(255,255,255,.12)}.member-hero .eyebrow{text-transform:uppercase;font-size:12px;font-weight:1000;letter-spacing:.08em;opacity:.82}.member-hero h2{font-size:34px;margin:7px 0 8px;letter-spacing:-.045em}.member-hero p{font-weight:800;line-height:1.5;margin:0;opacity:.93;max-width:700px}.rank-card{position:relative;z-index:1;min-width:230px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.24);border-radius:22px;padding:18px;display:flex;flex-direction:column;justify-content:center;box-shadow:inset 0 1px 0 rgba(255,255,255,.18)}.rank-card small{text-transform:uppercase;font-weight:950;opacity:.82}.rank-card b{font-size:22px;margin:8px 0 4px;line-height:1.15}.rank-card span{font-weight:950;color:#dbffe9}.progress-panel{background:#fff;border:1px solid var(--line);border-radius:24px;padding:18px 20px;margin-bottom:18px;box-shadow:0 14px 34px rgba(15,23,42,.055)}.progress-panel>div:first-child{display:flex;justify-content:space-between;gap:12px;font-weight:950;color:#0f172a}.progress-panel span{color:#64748b}.progress{height:13px;border-radius:999px;background:#e6f4ea;overflow:hidden;margin:12px 0 8px}.progress i{display:block;height:100%;background:linear-gradient(90deg,#16a34a,#22c55e);border-radius:999px;min-width:2%}.progress-panel p{margin:0;color:#0f7a35;font-weight:900}.member-cards .card{background:linear-gradient(180deg,#fff,#fbfffc);border-color:#dbeee3}.mini-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:18px 0}.mini-stat{background:#fff;border:1px solid var(--line);border-radius:18px;padding:16px;box-shadow:0 10px 26px rgba(15,23,42,.045)}.mini-stat small{display:block;color:#64748b;font-size:12px;text-transform:uppercase;font-weight:950}.mini-stat b{display:block;font-size:24px;margin-top:7px;color:#0f172a}.mini-stat.ok{background:#effdf5;border-color:#c6f6d5}.mini-stat.ok b{color:#07803d}.mini-stat.warn{background:#fffbeb;border-color:#fde68a}.mini-stat.warn b{color:#b45309}.mini-stat.bad{background:#fff1f2;border-color:#fecdd3}.mini-stat.bad b{color:#be123c}.mini-stat.money b{color:#0f8f4b}.tasks{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.tasks span{background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:13px 14px;font-weight:900;color:#334155}.smart-section{background:linear-gradient(180deg,#fff,#f8fffb)}.cards{align-items:stretch}.kpi{cursor:pointer;transition:.18s transform,.18s box-shadow}.kpi:hover{transform:translateY(-2px);box-shadow:0 16px 36px rgba(15,23,42,.08)}@media(max-width:980px){.member-hero{display:block}.rank-card{margin-top:16px;min-width:0}.mini-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.tasks{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:560px){.member-hero{padding:22px;border-radius:24px}.member-hero h2{font-size:27px}.mini-grid,.tasks{grid-template-columns:1fr}.progress-panel>div:first-child{display:block}.progress-panel span{display:block;margin-top:6px}}

/* V38: tốc độ, game hóa và CRM khách hàng */
.game-section{background:linear-gradient(180deg,#ffffff,#f3fff8);border-color:#cfeedd}.xp-pill{background:#0f8f4b;color:#fff;border-radius:999px;padding:10px 14px;font-weight:1000;white-space:nowrap}.game-grid{display:grid;grid-template-columns:1fr 2fr;gap:14px;margin:12px 0}.game-card{background:#ecfdf5;border:1px solid #bbf7d0;border-radius:18px;padding:16px}.game-card small{font-weight:950;text-transform:uppercase;color:#047857}.game-card b{display:block;font-size:22px;margin:6px 0;color:#064e3b}.badges{display:flex;gap:10px;flex-wrap:wrap;align-content:flex-start}.badges span,.tasks span.done{background:#dcfce7;color:#065f46;border-color:#bbf7d0}.badges span{border-radius:999px;padding:10px 12px;font-weight:950;border:1px solid #bbf7d0}.commission-preview{margin-top:12px;background:#f8fafc;border:1px dashed #bbf7d0;border-radius:16px;padding:12px;color:#065f46;font-weight:900}.prod-card b{font-size:13px;line-height:1.25}.content{scroll-behavior:smooth}.section,.card,.modal{animation:ecoFade .16s ease-out}@keyframes ecoFade{from{opacity:.72;transform:translateY(3px)}to{opacity:1;transform:none}}@media(max-width:760px){.game-grid{grid-template-columns:1fr}.xp-pill{display:inline-flex;margin-top:8px}.badges span{font-size:13px}}
