@import url("https://fonts.googleapis.com/css2?family=Be+Vietnam+Pro:wght@400;500;600;700&family=Noto+Serif:ital,wght@0,500;0,600;0,700&family=JetBrains+Mono:wght@400;500;600&display=swap&subset=vietnamese,latin,latin-ext");:root{--red-700:#a82a20;--red-600:#c93428;--red-500:#d6473c;--red-100:#fbeae8;--rose-400:#b98a8a;--rose-100:#f3e9e9;--amber-600:#f08920;--amber-100:#fdefdf;--ink-900:#1e2329;--ink-500:#5c6b7d;--ink-300:#93a0ae;--bg-page:#f6f6f6;--surface:#fff;--surface-2:#fafafb;--border:#e6e8eb;--border-strong:#d2d6dc;--success-600:#2e9e6b;--success-100:#e4f4ec;--warning-600:#e0a100;--warning-100:#fbf1d6;--danger-600:#c0392b;--danger-100:#f9e5e3;--info-600:#2c6fb5;--info-100:#e6eff8;--header-bg:var(--red-600);--header-fg:#fff;--header-fg-dim:hsla(0,0%,100%,.78);--text-strong:var(--ink-900);--text-body:#2a323b;--text-muted:var(--ink-500);--focus-ring:rgba(201,52,40,.3);--font-sans:"Be Vietnam Pro",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;--font-serif:"Noto Serif",Georgia,serif;--font-mono:"JetBrains Mono",ui-monospace,Menlo,monospace;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-pill:999px;--shadow-xs:0 1px 2px rgba(30,35,41,.06);--shadow-sm:0 1px 3px rgba(30,35,41,.08),0 1px 2px rgba(30,35,41,.04);--shadow-md:0 2px 8px rgba(30,35,41,.08),0 1px 3px rgba(30,35,41,.05);--shadow-lg:0 8px 24px rgba(30,35,41,.1),0 2px 8px rgba(30,35,41,.06);--shadow-pop:0 12px 40px rgba(30,35,41,.16);--shadow-focus:0 0 0 3px var(--focus-ring);--topbar-h:60px;--sidenav-w:240px;--content-max:1240px;--content-pad:24px;--fs-display:32px;--fs-h1:28px;--fs-h2:22px;--fs-h3:18px;--fs-lg:17px;--fs-md:16px;--fs-body:15px;--fs-sm:14px;--fs-label:13px;--fs-xs:12px;--fw-regular:400;--fw-medium:500;--fw-semibold:600;--fw-bold:700;--lh-tight:1.2;--lh-snug:1.35;--lh-normal:1.55;--ls-tight:-0.01em;--ls-wide:0.02em;--ls-caps:0.08em;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--cat-phapluat:#2b5bb8;--cat-chungchi:#c93428;--cat-khoahoc:#1f8a4c;--cat-huuich:#b5791a;--cat-thongbao:#5c6b7d;--footer-from:#a82a20;--footer-to:#7c1d15;--ease-out:cubic-bezier(.22,.61,.36,1);--ease-in-out:cubic-bezier(.45,0,.55,1);--dur-fast:120ms;--dur-base:200ms;--dur-slow:320ms;--z-sticky:100;--z-drawer:200;--z-modal:300;--z-toast:400;--text-on-brand:#fff;--text-link:var(--red-600);--border-default:var(--border);--border-focus:var(--red-600);--action-primary:var(--red-600);--action-primary-hover:var(--red-700);--action-primary-soft:var(--red-100);color-scheme:light}*,:after,:before{box-sizing:border-box}body,html{margin:0;padding:0}body{font-family:var(--font-sans);font-size:15px;line-height:1.55;color:var(--text-body);background:var(--bg-page);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3,h4{margin:0;color:var(--text-strong);line-height:1.2;font-weight:600}p{margin:0}a{color:var(--red-600);text-decoration:none}a:hover{text-decoration:underline}::selection{background:var(--red-100);color:var(--red-700)}:focus-visible{outline:2px solid var(--red-600);outline-offset:2px}.mono,.tnum{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1,"tnum"}.muted{color:var(--text-muted)}.shell{display:flex;flex-direction:column;min-height:100vh}.topbar{height:var(--topbar-h);background:var(--header-bg);color:var(--header-fg);gap:14px;padding:0 16px;box-shadow:var(--shadow-sm);position:-webkit-sticky;position:sticky;top:0;z-index:100}.topbar,.topbar .brand{display:flex;align-items:center}.topbar .brand{gap:10px;min-width:0}.topbar .brand img{height:34px;width:auto;display:block}.topbar .brand .sys{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar .brand .col{font-size:12px;color:var(--header-fg-dim);white-space:nowrap}.topbar .spacer{flex:1 1}.tb-btn{display:flex;align-items:center;justify-content:center;height:38px;min-width:38px;padding:0 8px;gap:6px;border:none;background:transparent;color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:background .12s;font-size:14px;font-weight:500}.tb-btn:hover{background:hsla(0,0%,100%,.14)}.tb-user{gap:10px;padding-left:6px}.tb-avatar,.tb-user{display:flex;align-items:center}.tb-avatar{width:32px;height:32px;border-radius:50%;background:hsla(0,0%,100%,.18);justify-content:center;flex:none}.tb-uname{font-size:14px;font-weight:600;white-space:nowrap}.tb-urole{font-size:11px;color:var(--header-fg-dim);white-space:nowrap}.shell-body{display:flex;flex:1 1;min-height:0}.sidenav{width:var(--sidenav-w);min-width:var(--sidenav-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:12px;gap:2px}.nav-item{position:relative;display:flex;align-items:center;gap:11px;width:100%;padding:9px 12px;border:none;cursor:pointer;background:transparent;color:var(--text-body);font-family:var(--font-sans);font-size:15px;font-weight:500;border-radius:var(--radius-md);text-align:left;transition:background .12s,color .12s}.nav-item:hover{background:var(--surface-2);color:var(--text-strong);text-decoration:none}.nav-item.active{background:var(--red-100);color:var(--red-700);font-weight:600}.nav-item.active:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:999px;background:var(--red-600)}.nav-item .ni-ic{color:var(--ink-500);display:flex}.nav-item.active .ni-ic{color:var(--red-600)}.nav-heading{font-size:11px;font-weight:600;color:var(--ink-300);text-transform:uppercase;letter-spacing:.07em;padding:14px 12px 6px}.content{flex:1 1;min-width:0;background:var(--bg-page)}.page-wrap{max-width:var(--content-max);margin:0 auto;padding:24px 24px 64px}.drawer-backdrop{display:none}@media(max-width:860px){.sidenav{position:fixed;top:var(--topbar-h);bottom:0;left:0;z-index:200;transform:translateX(-100%);transition:transform .2s}.sidenav.open{transform:translateX(0)}.drawer-backdrop.open{display:block;position:fixed;inset:var(--topbar-h) 0 0 0;background:rgba(30,35,41,.35);z-index:150}}@media(min-width:861px){.tb-menu{display:none}}.page-title{font-family:var(--font-serif);font-size:27px;font-weight:600;color:var(--ink-900);line-height:1.2}.page-sub{font-size:14px;color:var(--text-muted);margin-top:5px}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:40px;padding:0 16px;border-radius:var(--radius-md);border:1px solid transparent;font-family:var(--font-sans);font-size:14px;font-weight:600;cursor:pointer;transition:background var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast),transform .05s;white-space:nowrap}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.btn-primary{background:var(--red-600);color:#fff}.btn-primary:hover{background:var(--red-700)}.btn-secondary{background:#fff;color:var(--red-600);border-color:var(--red-600)}.btn-secondary:hover{background:var(--red-100)}.btn-ghost{background:transparent;color:var(--red-600)}.btn-ghost:hover{background:var(--red-100)}.btn-danger{background:var(--danger-600);color:#fff}.btn-danger:hover{background:#a5302440;background:#9d2a20}.btn-block{width:100%}.btn-sm{height:32px;padding:0 12px;font-size:13px}.btn-lg{height:48px;padding:0 22px;font-size:16px}.field{margin-bottom:14px}label{display:block;font-size:13px;color:var(--text-muted);margin:0 0 5px;font-weight:500}input,select,textarea{width:100%;height:40px;padding:0 12px;border-radius:var(--radius-md);border:1px solid var(--border);background:#fff;color:var(--ink-900);font-size:15px;font-family:var(--font-sans);transition:border-color .12s,box-shadow .12s}textarea{height:auto;padding:10px 12px}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--red-600);box-shadow:0 0 0 3px var(--focus-ring)}input::placeholder,textarea::placeholder{color:var(--ink-300)}input[type=file]{height:auto;padding:8px;font-size:13px}.err,.field-error{color:var(--danger-600);font-size:13px;margin-top:8px}.field-hint{color:var(--text-muted);font-size:12px;margin-top:6px}.msg{color:var(--success-600);font-size:13px;margin-top:8px}.row{display:grid;grid-template-columns:1fr 1fr;grid-gap:0 16px;gap:0 16px}@media(max-width:640px){.row{grid-template-columns:1fr}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:16px;overflow:hidden}.card-pad{padding:20px}.card-head{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--border)}.card-head .ch-ic{color:var(--red-600);display:flex}.card-head h2{font-size:16px;font-weight:600;flex:1 1}.card-body{padding:18px}.pill{display:inline-flex;align-items:center;gap:6px;height:22px;font-size:12px;font-weight:600;padding:0 10px;border-radius:var(--radius-pill);line-height:1;white-space:nowrap}.pill .pdot{width:6px;height:6px;border-radius:50%;background:currentColor}.pill.ok{background:var(--success-100);color:#1f7a50}.pill.warn{background:var(--warning-100);color:#9a7400}.pill.danger{background:var(--danger-100);color:var(--danger-600)}.pill.info{background:var(--info-100);color:var(--info-600)}.pill.brand{background:var(--red-100);color:var(--red-700)}.pill.neutral{background:#eef0f2;color:var(--ink-500)}.alert{display:flex;gap:11px;padding:13px 15px;border-radius:10px;font-size:14px;margin-bottom:16px;border:1px solid}.alert .a-ic{flex:none;margin-top:1px}.alert b{display:block;margin-bottom:2px}.alert.info{background:var(--info-100);border-color:#bcd6ef;color:#1f5a96}.alert.ok{background:var(--success-100);border-color:#b9e3cd;color:#1f7a50}.alert.warn{background:var(--warning-100);border-color:#ecdca0;color:#9a7400}.alert.danger{background:var(--danger-100);border-color:#eec4bf;color:var(--danger-600)}.progress{height:12px;background:#eaecef;border-radius:999px;overflow:hidden}.progress .bar{height:100%;background:var(--red-600);border-radius:999px;transition:width .4s var(--ease,ease)}.progress .bar.done{background:var(--success-600)}.progress-label{display:flex;justify-content:space-between;font-size:13px;margin-bottom:6px;color:var(--text-body)}.stat{gap:14px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-sm)}.stat,.stat .s-ic{display:flex;align-items:center}.stat .s-ic{width:46px;height:46px;border-radius:var(--radius-md);justify-content:center;flex:none}.stat .s-val{font-family:var(--font-mono);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-size:24px;font-weight:600;color:var(--ink-900);line-height:1.15}.stat .s-label{font-size:12px;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.04em}.stat .s-sub{font-size:12px;color:var(--ink-300);margin-top:2px}.stat .s-body{min-width:0}.tone-brand{background:var(--red-100);color:var(--red-600)}.tone-info{background:var(--info-100);color:var(--info-600)}.tone-success{background:var(--success-100);color:var(--success-600)}.tone-amber{background:var(--amber-100);color:var(--amber-600)}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border)}.tab{display:inline-flex;align-items:center;gap:7px;padding:10px 14px;background:transparent;cursor:pointer;font-size:15px;font-weight:500;color:var(--text-muted);border:none;border-bottom:2.5px solid transparent;margin-bottom:-1px;transition:color var(--dur-fast)}.tab:hover{color:var(--text-strong)}.tab.active{color:var(--red-700);border-bottom-color:var(--red-600);font-weight:600}.tbl{width:100%;border-collapse:collapse;font-size:14px}.tbl th{text-align:left;padding:10px 14px;color:var(--ink-500);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.04em}.tbl td,.tbl th{border-bottom:1px solid var(--border)}.tbl td{padding:11px 14px;color:var(--text-body)}.tbl tr:last-child td{border-bottom:none}.tbl tbody tr:hover{background:var(--red-100)}.tbl .num{text-align:right;font-family:var(--font-mono);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.tbl-wrap{overflow-x:auto}.dropzone{border:1.5px dashed var(--border-strong);border-radius:var(--radius-lg);padding:22px;text-align:center;background:var(--surface-2);transition:border-color .12s,background .12s}.dropzone:hover{border-color:var(--red-500);background:var(--red-100)}.auth-wrap{position:relative;min-height:100vh;display:grid;place-items:center;padding:32px 20px;background:var(--bg-page);overflow:hidden}.auth-wrap:before{content:"";position:absolute;top:0;left:0;right:0;height:440px;background:radial-gradient(1100px 380px at 50% -8%,rgba(201,52,40,.1),transparent 60%);pointer-events:none}.auth-wrap>*{position:relative}.auth-card{width:100%;max-width:440px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:28px}.auth-logo{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:20px;text-align:center}.auth-logo img{height:64px;width:auto}.auth-logo .t{font-family:var(--font-serif);font-size:19px;font-weight:600;color:var(--ink-900)}.auth-logo .s{font-size:13px;color:var(--text-muted)}.grid-stat{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));grid-gap:16px;gap:16px;margin-bottom:20px}.grid-2col{display:grid;grid-template-columns:1.6fr 1fr;grid-gap:16px;gap:16px;align-items:start}@media(max-width:900px){.grid-2col{grid-template-columns:1fr}}.flex{display:flex}.between{justify-content:space-between}.items-center{align-items:center}.gap{gap:12px}.wrap{flex-wrap:wrap}button:not([class]){display:inline-flex;align-items:center;justify-content:center;gap:8px;height:40px;padding:0 16px;border-radius:var(--radius-md);border:1px solid transparent;background:var(--red-600);color:#fff;font-family:var(--font-sans);font-size:14px;font-weight:600;cursor:pointer;transition:background .12s,transform .05s}button:not([class]):hover{background:var(--red-700)}button:not([class]):active{transform:translateY(1px)}button:not([class]):disabled{opacity:.55;cursor:not-allowed}button.ghost{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:40px;padding:0 14px;border-radius:var(--radius-md);border:1px solid transparent;background:transparent;color:var(--red-600);font-size:14px;font-weight:600;cursor:pointer}button.ghost:hover{background:var(--red-100)}.container{max-width:var(--content-max);margin:0 auto;padding:24px 16px 64px}.banner{display:flex;gap:11px;padding:13px 15px;border-radius:10px;font-size:14px;margin-bottom:16px;border:1px solid}.banner.ok{background:var(--success-100);border-color:#b9e3cd;color:#1f7a50}.banner.warn{background:var(--warning-100);border-color:#ecdca0;color:#8a6400}.nav{display:flex;gap:16px;align-items:center;padding:0 16px;height:var(--topbar-h);background:var(--red-600);color:#fff}.nav .brand{font-weight:700;color:#fff}.nav .spacer{flex:1 1}table{width:100%;border-collapse:collapse;font-size:14px}th{text-align:left;padding:10px 14px;color:var(--ink-500);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.04em}td,th{border-bottom:1px solid var(--border)}td{padding:11px 14px}tbody tr:hover{background:var(--red-100)}@media(max-width:640px){.tb-logout-label,.tb-uname,.tb-urole{display:none}}.grid-2{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px 16px;gap:12px 16px}@media(max-width:720px){.grid-2{grid-template-columns:1fr}}.items-end{align-items:flex-end}.tbl-compact td,.tbl-compact th{padding:7px 10px;font-size:13px}.cell-in{border:1px solid var(--border);border-radius:6px;padding:5px 7px;font:inherit;font-size:13px;width:100%;background:#fff}.cell-in:focus{outline:none;border-color:var(--red-600);box-shadow:0 0 0 2px var(--red-100)}.modal-backdrop{position:fixed;inset:0;background:rgba(30,35,41,.45);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:20px;animation:hnFade var(--dur-base) var(--ease-out)}.modal{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-pop);padding:18px;width:100%;max-width:560px;max-height:90vh;overflow:auto;animation:hnPop var(--dur-base) var(--ease-out)}@keyframes hnFade{0%{opacity:0}to{opacity:1}}@keyframes hnPop{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}.appshell{min-height:100vh;background:var(--bg-page)}.topnav{position:-webkit-sticky;position:sticky;top:0;z-index:40;background:hsla(0,0%,100%,.92);-webkit-backdrop-filter:saturate(180%) blur(12px);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--border)}.tn-inner{max-width:1240px;margin:0 auto;height:60px;padding:0 20px;display:flex;align-items:center;gap:18px}.tn-burger{display:none;background:none;border:none;cursor:pointer;color:var(--ink-900);padding:6px}.tn-brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink-900)}.tn-brand img{height:34px}.tn-bt{display:flex;flex-direction:column;line-height:1.15}.tn-bt b{font-size:15px;font-weight:700}.tn-bt small{font-size:11px;color:var(--ink-500)}.tn-links{display:flex;align-items:center;gap:4px;margin-left:8px}.tn-link{display:inline-flex;align-items:center;gap:5px;background:none;border:none;cursor:pointer;font:inherit;font-size:14.5px;font-weight:600;color:var(--ink-900);text-decoration:none;padding:8px 12px;border-radius:8px;transition:.14s;white-space:nowrap}.tn-link:hover{background:var(--red-100)}.tn-link.active,.tn-link.on,.tn-link:hover{color:var(--red-600)}.tn-link.on{background:var(--red-100)}.tn-caret{transition:.18s;opacity:.6;transform:rotate(-90deg)}.tn-link.on .tn-caret{transform:rotate(90deg)}.tn-right{margin-left:auto;display:flex;align-items:center;gap:10px}.tn-dd{position:relative}.tn-menu{position:absolute;top:46px;left:0;min-width:230px;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-pop);padding:8px;display:flex;flex-direction:column;gap:2px;z-index:50}.tn-menu-r{left:auto;right:0}.tn-mi{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:9px;text-decoration:none;color:var(--ink-900);font-size:14px;font-weight:500;background:none;border:none;cursor:pointer;width:100%;text-align:left}.tn-mi.active,.tn-mi:hover{background:var(--red-100)}.tn-logout,.tn-mi.active{color:var(--red-600)}.tn-logout{border-top:1px solid var(--border);margin-top:4px;padding-top:11px}.tn-acc{display:flex;align-items:center;gap:9px;background:none;border:none;cursor:pointer;padding:5px 8px;border-radius:10px;transition:.14s}.tn-acc:hover{background:var(--surface-2)}.tn-ava{width:34px;height:34px;border-radius:50%;background:var(--red-600);display:flex;align-items:center;justify-content:center;flex:none}.tn-accname{display:flex;flex-direction:column;line-height:1.15;text-align:left}.tn-accname b{font-size:13.5px;font-weight:600;color:var(--ink-900);max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tn-accname small{font-size:11px;color:var(--ink-500)}.tn-store{display:inline-flex;align-items:center;gap:7px;background:var(--red-600);color:#fff;text-decoration:none;font-weight:700;font-size:14px;padding:9px 18px;border-radius:999px;transition:.14s;box-shadow:0 2px 8px rgba(201,52,40,.3);white-space:nowrap}.tn-store:hover{transform:translateY(-1px)}.tn-store.on,.tn-store:hover{background:var(--red-700)}.appmain{max-width:1240px;margin:0 auto;padding:24px 20px 60px}.tn-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.4);opacity:0;pointer-events:none;transition:.2s;z-index:45}.tn-backdrop.open{opacity:1;pointer-events:auto}.tn-drawer{position:fixed;top:0;left:0;bottom:0;width:280px;max-width:84vw;background:#fff;z-index:46;transform:translateX(-100%);transition:.22s;padding:16px 12px;display:flex;flex-direction:column;gap:3px;overflow-y:auto;box-shadow:var(--shadow-pop)}.tn-drawer.open{transform:translateX(0)}.tn-dstore{gap:8px;background:var(--red-600);color:#fff;font-weight:700;padding:11px 14px;border-radius:12px;margin-bottom:8px}.tn-ditem,.tn-dstore{display:flex;align-items:center;text-decoration:none}.tn-ditem{gap:11px;padding:11px 12px;border-radius:10px;color:var(--ink-900);font-size:14.5px;font-weight:500;background:none;border:none;cursor:pointer;width:100%;text-align:left}.tn-ditem:hover{background:var(--surface-2)}.tn-ditem.active{background:var(--red-100);color:var(--red-600)}.tn-dsec{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-300);padding:12px 12px 4px}@media(max-width:900px){.tn-links{display:none}.tn-burger{display:inline-flex}.tn-accname,.tn-bt small{display:none}}.pub-top{position:-webkit-sticky;position:sticky;top:0;z-index:100;background:var(--red-600);color:#fff;box-shadow:var(--shadow-sm)}.pub-inner{max-width:1240px;margin:0 auto;height:60px;gap:14px;padding:0 20px}.pub-brand,.pub-inner{display:flex;align-items:center}.pub-brand{gap:10px;color:#fff}.pub-brand img{height:34px}.pub-brand b{font-size:16px;line-height:1.05;display:block}.pub-brand small{font-size:11px;opacity:.82}.pub-actions{margin-left:auto;display:flex;align-items:center;gap:10px}.pub-actions a{display:inline-flex;align-items:center;gap:6px;height:36px;padding:0 14px;border-radius:8px;font-weight:600;font-size:14px}.pub-login{color:#fff;border:1px solid hsla(0,0%,100%,.5)}.pub-login:hover{background:hsla(0,0%,100%,.12)}.pub-reg{background:#fff;color:var(--red-600)}.pub-store{background:var(--red-700);color:#fff}@media(max-width:640px){.pub-brand small,.pub-reg span,.pub-store span{display:none}}.hv-strip{flex-wrap:wrap;gap:14px;background:linear-gradient(100deg,var(--red-600),var(--red-700));color:#fff;border-radius:var(--radius-lg);padding:16px 20px;margin-bottom:22px;box-shadow:var(--shadow-md)}.hv-strip,.hv-strip .hv-ava{display:flex;align-items:center}.hv-strip .hv-ava{width:46px;height:46px;border-radius:50%;background:hsla(0,0%,100%,.18);justify-content:center;flex:0 0 auto}.hv-strip .hv-info b{font-size:17px;display:block}.hv-strip .hv-info small{opacity:.85;font-size:12.5px}.hv-strip .hv-mid{margin-left:auto;display:flex;gap:22px;align-items:center;flex-wrap:wrap}.hv-stat{text-align:center}.hv-stat .v{font-size:16px;font-weight:700}.hv-stat .l{font-size:11px;opacity:.82;text-transform:uppercase;letter-spacing:.03em}.hv-badge{background:hsla(0,0%,100%,.2);border:1px solid hsla(0,0%,100%,.35);padding:6px 12px;border-radius:999px;font-size:13px;font-weight:600}.hv-strip .hv-go{background:#fff;color:var(--red-600);height:36px;padding:0 16px;border-radius:8px;font-weight:700;display:inline-flex;align-items:center;gap:6px}.sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin:30px 0 14px}.sec-head h2{font-family:var(--font-serif);font-size:21px;font-weight:600;color:var(--ink-900)}.sec-head .more{font-size:13.5px;font-weight:600}.news-hero{display:grid;grid-template-columns:1.6fr 1fr;grid-gap:16px;gap:16px;margin-bottom:6px}.news-hero .side{gap:16px}.feat,.news-hero .side{display:flex;flex-direction:column}.feat{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:box-shadow .15s,transform .15s}.feat:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.feat-big{min-height:340px}.feat .ph{position:relative;background:linear-gradient(135deg,var(--red-600),var(--red-700));overflow:hidden}.feat-big .ph{flex:1 1;min-height:200px}.feat-side .ph{height:120px}.feat .ph img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}.feat .ph .ph-ic{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:hsla(0,0%,100%,.35)}.feat .bd{padding:16px 18px}.feat-big .bd{padding:20px 22px}.feat .bd h3{font-family:var(--font-serif);font-weight:600;color:var(--ink-900);line-height:1.3}.feat-big .bd h3{font-size:23px}.feat-side{flex-direction:row;min-height:120px}.feat-side .ph{width:140px;flex:0 0 140px}.feat-side .bd{flex:1 1;padding:14px 16px;display:flex;flex-direction:column;justify-content:center}.feat-side .bd h3{font-size:15.5px}.feat .bd p{color:var(--ink-500);font-size:14px;margin-top:8px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.nb{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:3px 9px;border-radius:999px;background:var(--red-100);color:var(--red-600)}.nb.dm-phap_luat{background:#eaf0fb;color:var(--cat-phapluat)}.nb.dm-cap_chung_chi{background:#fbeae8;color:var(--cat-chungchi)}.nb.dm-khoa_hoc{background:#e9f7ef;color:var(--cat-khoahoc)}.nb.dm-huu_ich{background:#fff4e0;color:var(--cat-huuich)}.nb.dm-thong_bao{background:#eff1f4;color:var(--cat-thongbao)}.news-meta{display:flex;align-items:center;gap:12px;margin-top:10px;font-size:12.5px;color:var(--ink-300)}.news-meta span{display:inline-flex;align-items:center;gap:4px}.cat-chips{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 4px}.chip{height:34px;padding:0 15px;border-radius:999px;border:1px solid var(--border-strong);background:#fff;color:var(--ink-500);font-size:13.5px;font-weight:600;cursor:pointer;transition:.12s}.chip:hover{border-color:var(--red-500);color:var(--red-600)}.chip.on{background:var(--red-600);color:#fff;border-color:var(--red-600)}.news-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:16px;gap:16px}.ncard{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow .15s,transform .15s}.ncard:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.ncard .ph{height:150px;position:relative;background:linear-gradient(135deg,var(--red-500),var(--red-700))}.ncard .ph img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}.ncard .ph .ph-ic{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:hsla(0,0%,100%,.4)}.ncard .bd{padding:14px 16px;display:flex;flex-direction:column;flex:1 1}.ncard .bd h3{font-size:15.5px;font-weight:600;color:var(--ink-900);line-height:1.35;margin-top:8px}.ncard .bd h3,.ncard .bd p{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.ncard .bd p{font-size:13.5px;color:var(--ink-500);margin-top:7px;line-height:1.5;flex:1 1}.art-wrap{max-width:820px;margin:0 auto}.art-cover{width:100%;height:300px;border-radius:var(--radius-lg);object-fit:cover;margin:18px 0;background:linear-gradient(135deg,var(--red-600),var(--red-700))}.art-title{font-family:var(--font-serif);font-size:30px;font-weight:700;color:var(--ink-900);line-height:1.25;margin:12px 0}.art-body{font-size:16.5px;line-height:1.8;color:var(--text-body);white-space:pre-wrap}.art-body p{margin-bottom:14px}.crumb{font-size:13.5px}.crumb,.crumb a{color:var(--ink-500)}.crumb a:hover{color:var(--red-600)}@media(max-width:900px){.news-hero{grid-template-columns:1fr}.news-grid{grid-template-columns:repeat(2,1fr)}.hv-strip .hv-mid{width:100%;margin-left:0;justify-content:flex-start}}@media(max-width:560px){.news-grid{grid-template-columns:1fr}.feat-side{flex-direction:column}.feat-side .ph{width:100%;height:140px}.art-title{font-size:24px}}.site-footer{background:linear-gradient(180deg,var(--footer-from),var(--footer-to));color:hsla(0,0%,100%,.82);margin-top:48px}.sf-inner{max-width:1240px;margin:0 auto;padding:40px 20px 28px;display:grid;grid-template-columns:1.7fr 1fr 1.4fr 1fr;grid-gap:32px;gap:32px}.sf-col h4{color:#fff;font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:14px}.sf-logo{display:flex;align-items:center;gap:11px;margin-bottom:12px}.sf-logo img{height:42px;width:auto;background:#fff;border-radius:8px;padding:3px}.sf-logo b{color:#fff;font-family:var(--font-serif);font-size:16px;display:block;line-height:1.2}.sf-logo span{font-size:12px;color:hsla(0,0%,100%,.7)}.sf-desc{font-size:13.5px;line-height:1.6;color:hsla(0,0%,100%,.78);max-width:340px}.sf-social{display:flex;gap:10px;margin-top:16px}.sf-social a{width:36px;height:36px;border-radius:50%;background:hsla(0,0%,100%,.14);display:flex;align-items:center;justify-content:center;color:#fff;transition:background .15s}.sf-social a:hover{background:hsla(0,0%,100%,.28);text-decoration:none}.sf-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-size:13.5px;line-height:1.5}.sf-list a{color:hsla(0,0%,100%,.85)}.sf-list a:hover{color:#fff;text-decoration:underline}.sf-cs{display:flex;gap:8px;align-items:flex-start}.sf-cs b{color:#fff}.sf-bar{border-top:1px solid hsla(0,0%,100%,.16);max-width:1240px;margin:0 auto;padding:14px 20px;display:flex;justify-content:center;flex-wrap:wrap;gap:8px;font-size:12.5px;color:hsla(0,0%,100%,.68)}.sf-bar a{color:hsla(0,0%,100%,.88);font-weight:600}.sf-bar a:hover{color:#fff;text-decoration:underline}.sp2-imgwrap{position:relative}.sp2-soldout{position:absolute;top:8px;left:8px;background:var(--ink-900);color:#fff;font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;z-index:1}.qr-embed{flex:none;line-height:0;overflow:hidden}.qr-embed svg,.the-qr svg{display:block;width:100%;height:100%}.cred-btn{display:inline-flex;align-items:center;height:30px;padding:0 12px;border-radius:7px;font-size:12.5px;font-weight:600;cursor:pointer}.cred-btn-light{background:hsla(0,0%,100%,.95);color:var(--red-700)}.cred-btn-light:hover{background:#fff;text-decoration:none}.cred-btn-outline{background:hsla(0,0%,100%,.16);color:#fff;border:1px solid hsla(0,0%,100%,.55)}.cred-btn-outline:hover{background:hsla(0,0%,100%,.28);text-decoration:none}@media(max-width:900px){.sf-inner{grid-template-columns:1fr 1fr;gap:26px}.sf-brand{grid-column:1/-1}}@media(max-width:560px){.sf-inner{grid-template-columns:1fr}.sf-bar{flex-direction:column;text-align:center;justify-content:center}}