:root{--bg: #f1f5f9;--card: #ffffff;--ink: #0f172a;--muted: #64748b;--line: #e2e8f0;--bg2: #e5eaf1;--bg3: #eef2f8;--chip: #e2e8f0;--chip-ink: #334155;--brand: #2563eb;--brand-d: #1d4ed8;--ok: #22c55e;--warn: #f59e0b;--bad: #ef4444;--nav-w: 230px;--radius: 14px;--shadow: 0 1px 3px rgba(0,0,0,.08)}[data-theme=dark]{--bg: #0b1220;--card: #131c2e;--ink: #e6edf7;--muted: #94a3b8;--line: #243044;--bg2: #1a2436;--bg3: #1e293b;--chip: #243044;--chip-ink: #cbd5e1;--shadow: 0 1px 3px rgba(0,0,0,.5);color-scheme:dark}[data-theme=dark] input,[data-theme=dark] select,[data-theme=dark] textarea{color:var(--ink)}[data-theme=dark] .badge,[data-theme=dark] .btn{color:#fff}[data-theme=mms]{--bg: #0b0d10;--card: #15181d;--ink: #e7ebf0;--muted: #8a93a0;--line: #262b33;--bg2: #1b1f25;--bg3: #21262e;--chip: #21262e;--chip-ink: #cbd5e1;--brand: #15c8b5 !important;--brand-d: #0fb5a3 !important;--ok: #2ecc71;--warn: #f1c40f;--bad: #e74c3c;--radius: 16px;--shadow: 0 12px 30px -16px rgba(0,0,0,.7), 0 1px 0 rgba(255,255,255,.04) inset;color-scheme:dark}[data-theme=mms] input,[data-theme=mms] select,[data-theme=mms] textarea{color:var(--ink)}[data-theme=mms] .badge{color:#fff}[data-theme=mms] .btn{color:#04211e;font-weight:700}[data-theme=mms] .btn.ok,[data-theme=mms] .btn.warn,[data-theme=mms] .btn.bad{color:#fff}[data-theme=mms] .card{background:linear-gradient(160deg,#191e26,#14181f);border-color:#ffffff0f}[data-theme=mms] .sidebar{background:linear-gradient(185deg,#10151c,#0a0d12)}[data-theme=mms] .topbar{background:linear-gradient(180deg,#15181d,#11151a)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Sarabun,system-ui,sans-serif;background:var(--bg);color:var(--ink);font-size:15px}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}.shell{display:flex;min-height:100%}.sidebar{width:var(--nav-w);background:linear-gradient(185deg,#101a30,#0a1120);color:#cbd5e1;position:fixed;inset:0 auto 0 0;display:flex;flex-direction:column;padding:14px 10px;gap:2px;z-index:40;border-right:1px solid rgba(148,163,184,.09);padding-top:calc(14px + env(safe-area-inset-top));padding-left:calc(10px + env(safe-area-inset-left))}.brand{display:flex;align-items:center;gap:10px;padding:4px 6px 14px}.brand-logo{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex:0 0 auto;background:color-mix(in srgb,var(--brand) 28%,#0f172a);box-shadow:inset 0 0 0 1px #94a3b81f}.brand-name{color:#fff;font-weight:800;font-size:17px;letter-spacing:.2px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drawer-close{background:none;border:none;color:#94a3b8;font-size:18px;cursor:pointer;padding:4px 9px;border-radius:8px}.drawer-close:hover{background:#1e293b;color:#fff}.navlink{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:#cbd5e1;font-weight:500;font-size:inherit;font-family:inherit;background:transparent;border:none;width:100%;text-align:left}.navlink .ic{width:20px;text-align:center}.navscroll{flex:1;overflow-y:auto;margin:2px -4px;padding:2px 4px}.navscroll::-webkit-scrollbar{width:5px}.navscroll::-webkit-scrollbar-thumb{background:#334155;border-radius:3px}.nav-group{margin-bottom:2px;border-radius:12px;transition:background .2s}.nav-group.open{background:#94a3b80d;padding-bottom:6px}.nav-group-hd{position:relative;display:flex;align-items:center;gap:11px;width:100%;padding:8px 10px;border:none;background:transparent;color:#cbd5e1;font-weight:700;font-size:14px;font-family:inherit;text-align:left;border-radius:11px;cursor:pointer;transition:background .18s,color .18s}.nav-group-hd:hover{background:#1e293b;color:#fff}.nav-group.open>.nav-group-hd,.nav-group-hd.has-active{color:#fff}.nav-group-hd .ic{width:30px;height:30px;border-radius:9px;background:#1e293b;display:inline-grid;place-items:center;font-size:15px;flex:0 0 auto;transition:background .18s}.nav-group.open>.nav-group-hd .ic,.nav-group-hd.has-active .ic{background:color-mix(in srgb,var(--brand) 34%,#1e293b)}.nav-group-label{flex:1}.nav-count{font-size:10px;font-weight:700;color:#94a3b8;background:#1e293b;border-radius:9px;padding:1px 7px}.nav-group.open .nav-count{display:none}.nav-chev{font-size:10px;opacity:.55;width:12px;text-align:center;transition:transform .2s}.nav-group.open .nav-chev{color:var(--brand);opacity:1}.nav-group .navlink.sub{position:relative;margin:1px 4px 1px 12px;width:auto;padding:8px 12px 8px 30px;font-size:13.5px;font-weight:500;color:#94a3b8;border-radius:9px}.nav-group .navlink.sub:before{content:"";position:absolute;left:14px;top:50%;transform:translateY(-50%);width:5px;height:5px;border-radius:50%;background:#475569;transition:background .15s,box-shadow .15s,width .15s,height .15s}.nav-group .navlink.sub .ic{font-size:13px;width:16px}.nav-group .navlink.sub:hover{color:#e2e8f0;background:#1e293b}.nav-group .navlink.sub:hover:before{background:#64748b}.nav-group .navlink.sub.active{color:#fff;font-weight:600;background:color-mix(in srgb,var(--brand) 20%,transparent)}.nav-group .navlink.sub.active:before{background:var(--brand);width:7px;height:7px;box-shadow:0 0 8px var(--brand)}.sidebar-foot{display:flex;align-items:center;gap:10px;margin-top:4px;padding:10px 8px;border-top:1px solid rgba(148,163,184,.1);padding-bottom:calc(4px + env(safe-area-inset-bottom))}.sb-avatar{width:34px;height:34px;font-size:15px}.sb-user{flex:1;display:flex;flex-direction:column;line-height:1.25;min-width:0}.sb-user strong{color:#fff;font-size:13.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sb-user .muted{color:#94a3b8;font-size:11.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sb-logout{background:none;border:none;color:#94a3b8;font-size:17px;cursor:pointer;padding:6px 8px;border-radius:9px;flex:0 0 auto}.sb-logout:hover{background:#ef444429;color:#fecaca}.hamburger{background:none;border:none;color:var(--ink);font-size:22px;cursor:pointer;padding:2px 8px;border-radius:8px;line-height:1}.hamburger:hover{background:var(--bg3)}.nav-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0206178c;z-index:55;animation:fadeInUp .18s ease both}.main{flex:1;margin-left:var(--nav-w);display:flex;flex-direction:column;min-width:0}.topbar{min-height:58px;box-sizing:border-box;background:var(--card);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:env(safe-area-inset-top) 18px 0;position:sticky;top:0;z-index:30}.content{padding:22px clamp(18px,3vw,40px);width:100%;max-width:1760px;margin:0 auto}.bottomnav{display:none}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.grid{display:grid;gap:16px}.kpis{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}.kpi{padding:20px 22px}.kpi .v{font-size:32px;font-weight:700}.kpi .l{color:var(--muted);font-size:13px}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.spacer{flex:1}.btn{background:var(--brand);color:#fff;border:none;padding:10px 16px;border-radius:10px;font-weight:600}.btn:hover{background:var(--brand-d)}.btn.sec{background:var(--card);color:var(--ink);border:1px solid var(--line)}.btn.ok{background:var(--ok)}.btn.bad{background:var(--bad)}.btn.warn{background:var(--warn)}.btn:disabled{opacity:.5;cursor:not-allowed}.input,select{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:var(--card);font:inherit}.field{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}.field label{font-size:13px;color:var(--muted);font-weight:500}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:13px 16px;border-bottom:1px solid var(--line)}th{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}tr:hover td{background:var(--bg2)}.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;color:#fff}.tag{background:var(--chip);color:var(--chip-ink);padding:2px 8px;border-radius:6px;font-size:12px}.h1{font-size:22px;font-weight:700;margin:0 0 14px}.muted{color:var(--muted)}.langtoggle{border:1px solid var(--line);border-radius:8px;overflow:hidden;display:flex}.langtoggle button{border:none;background:var(--card);padding:6px 12px;font-weight:600;color:var(--muted)}.langtoggle button.on{background:var(--brand);color:#fff}.pill-list{display:flex;flex-wrap:wrap;gap:8px}.login-wrap{min-height:100%;display:grid;place-items:center;background:linear-gradient(135deg,#1e3a8a,#0f172a);padding:20px}.login-card{width:100%;max-width:380px;padding:28px}.login-card h1{text-align:center;margin:0 0 6px}.line-btn{background:#06c755;color:#fff;border:none;width:100%;padding:12px;border-radius:10px;font-weight:700}.scan-box{max-width:420px;margin:0 auto}.br-page{width:100%}.br-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}@media (max-width: 820px){.br-grid{grid-template-columns:1fr}}#qr-reader{width:100%;border-radius:12px;overflow:hidden}.scan-item{display:flex;justify-content:space-between;align-items:center;padding:12px;border-bottom:1px solid var(--line)}.sticky-confirm{position:sticky;bottom:14px;width:100%;padding:16px;font-size:17px;box-shadow:0 6px 20px #22c55e59;z-index:20}.ss-btn{display:flex;align-items:center;justify-content:space-between;text-align:left;cursor:pointer}.ss-btn:disabled{opacity:.5;cursor:not-allowed}.ss-pop{padding:6px;display:flex;flex-direction:column;max-height:300px;box-shadow:0 12px 30px #0f172a59}.ss-search{margin-bottom:6px}.ss-list{overflow-y:auto}.ss-opt{padding:8px 10px;border-radius:8px;cursor:pointer;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ss-opt:hover{background:var(--bg2)}.ss-opt.on{background:var(--brand);color:#fff}.scroll-y{overflow-y:auto;overscroll-behavior:contain}.scroll-y::-webkit-scrollbar{width:7px;height:7px}.scroll-y::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px}.scroll-y::-webkit-scrollbar-track{background:transparent}.clock{display:flex;align-items:center;gap:12px;font-weight:600;color:var(--ink)}.clock-date{color:var(--muted);font-size:14px}.clock-time{background:#0f172a;color:#fff;padding:5px 12px;border-radius:9px;white-space:nowrap;font-variant-numeric:tabular-nums;letter-spacing:.5px;min-width:104px;text-align:center}.avatar{width:30px;height:30px;border-radius:50%;background:var(--brand);color:#fff;font-weight:700;display:inline-flex;align-items:center;justify-content:center;font-size:14px;flex:0 0 auto}.only-mobile{display:none}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;z-index:100;display:grid;place-items:center;padding:16px;animation:fadeInUp .18s ease both;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-card{background:var(--card);border-radius:16px;width:100%;max-height:92vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.modal-head{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;border-bottom:1px solid var(--line)}.modal-body{padding:18px;overflow-y:auto}.row-item{display:flex;gap:8px;align-items:center;margin-bottom:8px}.pg-btn{padding:7px 12px;min-width:38px;font-weight:600}.pg-btn.on{background:var(--brand);color:#fff;border-color:var(--brand)}.perm-wrap{overflow:auto;max-height:74vh;border:1px solid var(--line);border-radius:12px;background:var(--card)}.perm-matrix{border-collapse:separate;border-spacing:0;width:max-content;min-width:100%;font-size:13px}.perm-matrix th,.perm-matrix td{border-bottom:1px solid var(--line);border-right:1px solid var(--line)}.perm-matrix th:last-child,.perm-matrix td:last-child{border-right:none}.perm-matrix thead th{position:sticky;top:0;z-index:3;background:var(--bg2);padding:9px 10px;text-align:center;vertical-align:bottom}.perm-matrix .rowhead{position:sticky;left:0;z-index:2;background:var(--card);text-align:left;padding:8px 14px;min-width:200px;max-width:300px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.perm-matrix thead .rowhead{z-index:5;background:var(--bg2)}.perm-cat>td{background:var(--bg2);font-weight:700}.perm-cat .rowhead{background:var(--bg2);font-size:13.5px}.perm-cell{text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;min-width:88px;padding:8px 6px;font-weight:700;font-size:15px;line-height:1;color:transparent}.perm-cell:hover{background:color-mix(in srgb,var(--brand) 9%,transparent)}.perm-cell.on{background:color-mix(in srgb,var(--brand) 12%,transparent);color:var(--brand)}.perm-cell.locked{cursor:default;color:var(--muted);background:color-mix(in srgb,var(--muted) 12%,transparent)}.perm-cell.locked:hover{background:color-mix(in srgb,var(--muted) 12%,transparent)}.perm-row:hover .rowhead,.perm-row:hover .perm-cell:not(.on):not(.locked){background:color-mix(in srgb,var(--muted) 8%,transparent)}.perm-catcell{text-align:center;cursor:pointer;min-width:88px;padding:5px 6px}.perm-catcell:hover .catbox{border-color:var(--brand)}.perm-catcell.locked{cursor:default}.catbox{display:inline-flex;align-items:center;justify-content:center;width:19px;height:19px;border-radius:5px;border:1.5px solid var(--muted);color:transparent;font-size:12px;font-weight:800;line-height:1}.catbox.all{background:var(--brand);border-color:var(--brand);color:#fff}.catbox.some{border-color:var(--brand);color:var(--brand)}.role-col-hd{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:84px}.role-col-hd .nm{font-weight:700;white-space:nowrap}.role-col-hd .meta{font-size:11px;color:var(--muted);font-weight:500}.role-col-hd .ctl{display:flex;gap:2px}.role-col-hd .ctl button{background:none;border:none;cursor:pointer;font-size:12px;padding:1px 3px;opacity:.65;border-radius:5px}.role-col-hd .ctl button:hover{opacity:1;background:var(--bg3)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}@keyframes popIn{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}@keyframes floaty{0%,to{transform:translateY(0)}50%{transform:translateY(-7px)}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:none}}@keyframes pulseGlow{0%,to{box-shadow:0 0 #2563eb00}50%{box-shadow:0 0 0 4px #2563eb1f}}.route-anim{animation:fadeInUp .34s cubic-bezier(.22,.61,.36,1) both}.page-in{animation:fadeInUp .34s ease both}.pop-in{animation:popIn .4s cubic-bezier(.34,1.56,.64,1) both}.logo-float{animation:floaty 3.5s ease-in-out infinite}@keyframes cardBreathe{0%,to{box-shadow:0 2px 10px #0f172a1a}50%{box-shadow:0 6px 22px color-mix(in srgb,var(--brand) 30%,transparent)}}.card:not(.pop-in){animation:cardBreathe 5s ease-in-out infinite}.card:not(.pop-in):nth-child(3n){animation-delay:-1.1s}.card:not(.pop-in):nth-child(3n+1){animation-delay:-2.6s}.card:not(.pop-in):nth-child(4n){animation-delay:-3.8s}@keyframes sweepX{0%{transform:translate(-140%)}55%,to{transform:translate(260%)}}.shimmer{position:relative;overflow:hidden}.shimmer:after{content:"";position:absolute;top:0;bottom:0;left:0;width:55%;pointer-events:none;background:linear-gradient(100deg,transparent 0%,rgba(255,255,255,.55) 50%,transparent 100%);transform:translate(-140%);animation:sweepX 3s ease-in-out infinite}.route-anim .card{animation:fadeInUp .4s ease both,cardBreathe 5s ease-in-out infinite}.route-anim .card:nth-child(3n){animation-delay:0s,-1.1s}.route-anim .card:nth-child(3n+1){animation-delay:0s,-2.6s}.route-anim .card:nth-child(4n){animation-delay:0s,-3.8s}.route-anim .kpis .card:nth-child(1){animation-delay:.02s,-.4s}.route-anim .kpis .card:nth-child(2){animation-delay:.08s,-1.7s}.route-anim .kpis .card:nth-child(3){animation-delay:.14s,-3s}.route-anim .kpis .card:nth-child(4){animation-delay:.2s,-4.2s}tbody tr{animation:slideInLeft .25s ease both}tbody tr:nth-child(1){animation-delay:.01s}tbody tr:nth-child(2){animation-delay:.03s}tbody tr:nth-child(3){animation-delay:.05s}tbody tr:nth-child(4){animation-delay:.07s}tbody tr:nth-child(5){animation-delay:.09s}tbody tr:nth-child(6){animation-delay:.11s}tbody tr:nth-child(7){animation-delay:.13s}tbody tr:nth-child(8){animation-delay:.15s}.btn{transition:background .15s,transform .08s,box-shadow .15s}.btn:hover{box-shadow:0 4px 14px #2563eb47;transform:translateY(-1px)}.btn:active{transform:translateY(1px) scale(.98)}.navlink{transition:background .18s,color .18s,transform .12s,padding-left .18s}.navlink:hover{transform:translate(2px)}.navlink.active{padding-left:16px}.card{transition:box-shadow .2s,transform .2s}.hover-lift:hover,.kpi:hover{transform:translateY(-3px)!important;box-shadow:0 12px 26px #2563eb47!important}.card.flat{animation:none!important}.list-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;border-bottom:1px solid var(--line);border-radius:6px;transition:background .14s}.list-row:last-child{border-bottom:none}.list-row:hover{background:var(--bg3)}.list-row.today{box-shadow:inset 3px 0 0 var(--warn);background:#f59e0b0f}.input,select{transition:border-color .15s,box-shadow .15s}.input:focus,select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px #2563eb26}tr:hover td{transition:background .15s}.badge,.tag{transition:transform .12s}.bottomnav a,.bottomnav button{transition:color .15s,transform .12s}.bottomnav a.active .ic,.bottomnav button.active .ic{transform:translateY(-2px) scale(1.12)}a,.langtoggle button{transition:color .15s,background .15s}.spinner{width:22px;height:22px;border:3px solid var(--line);border-top-color:var(--brand);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.skeleton{background:linear-gradient(90deg,var(--bg3) 25%,#e2e8f0 37%,var(--bg3) 63%);background-size:800px 100%;animation:shimmer 1.3s infinite linear;border-radius:8px}@media (prefers-reduced-motion: reduce){*,.route-anim,.route-anim .card,.card,tbody tr{animation:none!important;transition:none!important}.shimmer:after{display:none!important}}@media (max-width: 1100px){:root{--nav-w: 200px}.content{padding:18px 16px}.kpis{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.kpi{padding:16px}.kpi .v{font-size:26px}.grid{gap:12px}}@media (max-width: 560px){.kpis{grid-template-columns:1fr 1fr;gap:10px}.kpi{padding:13px 14px}.kpi .v{font-size:21px}.h1{font-size:19px}.topbar{padding:env(safe-area-inset-top) 12px 0;gap:6px}.clock-time{min-width:88px;padding:4px 8px}.modal-card{max-height:96vh}}@media (max-width: 820px){.sidebar{width:268px;transform:translate(-100%);transition:transform .26s cubic-bezier(.4,0,.2,1);z-index:60}.sidebar.open{transform:translate(0);box-shadow:12px 0 50px #0000008c}.nav-backdrop{display:block}.main{margin-left:0}.content{padding:12px 12px calc(80px + env(safe-area-inset-bottom))}.bottomnav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--card);border-top:1px solid var(--line);justify-content:space-around;padding:6px 0 calc(8px + env(safe-area-inset-bottom));z-index:50}.bottomnav a,.bottomnav button{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:11px;color:var(--muted);padding:4px 8px;background:none;border:none;font-family:inherit;cursor:pointer}.bottomnav a.active,.bottomnav button.active{color:var(--brand)}.bottomnav .ic{font-size:20px}.hide-mobile{display:none}.only-mobile{display:inline-flex}.topbar{flex-wrap:nowrap;justify-content:flex-start;gap:8px}.topbar .row{flex-wrap:nowrap;gap:6px;margin-left:auto}.topbar .btn.sec{padding:6px 9px}.langtoggle button{padding:5px 9px}.clock{gap:8px}table.responsive thead{display:none}table.responsive tr{display:block;border:1px solid var(--line);border-radius:10px;margin-bottom:10px;padding:6px}table.responsive td{display:flex;justify-content:space-between;border:none;padding:6px 8px}table.responsive td:before{content:attr(data-l);color:var(--muted);font-size:12px;font-weight:600}}
