:root{--bg: #f1f5f9;--card: #ffffff;--ink: #0f172a;--muted: #64748b;--line: #e2e8f0;--bg2: var(--bg2);--bg3: var(--bg3);--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}*{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:#0f172a;color:#cbd5e1;position:fixed;inset:0 auto 0 0;display:flex;flex-direction:column;padding:16px 10px;gap:4px;z-index:40}.sidebar .brand{color:#fff;font-weight:700;font-size:18px;padding:8px 12px 16px}.navlink{display:flex;align-items:center;gap:10px;padding:11px 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.active,.navlink:hover{background:#1e293b;color:#fff}.navlink .ic{width:20px;text-align:center}.logout-btn{color:#94a3b8;margin-top:4px}.logout-btn:hover{background:#ef444429;color:#fecaca;transform:translate(2px)}.main{flex:1;margin-left:var(--nav-w);display:flex;flex-direction:column;min-width:0}.topbar{height:58px;background:var(--card);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 18px;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}.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;font-variant-numeric:tabular-nums;letter-spacing:.5px;min-width:104px;text-align:center}.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)}@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}.route-anim .card{animation:fadeInUp .4s ease both}.route-anim .kpis .card:nth-child(1){animation-delay:.02s}.route-anim .kpis .card:nth-child(2){animation-delay:.08s}.route-anim .kpis .card:nth-child(3){animation-delay:.14s}.route-anim .kpis .card:nth-child(4){animation-delay:.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);box-shadow:0 10px 24px #0f172a1f}.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{transition:color .15s,transform .12s}.bottomnav a.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,tbody tr{animation:none!important;transition: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:0 12px;gap:6px}.clock-time{min-width:88px;padding:4px 8px}.modal-card{max-height:96vh}}@media (max-width: 820px){.sidebar{display:none}.main{margin-left:0}.content{padding:12px 12px 78px}.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 8px;z-index:50}.bottomnav a{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:11px;color:var(--muted);padding:4px 8px}.bottomnav a.active{color:var(--brand)}.bottomnav .ic{font-size:20px}.hide-mobile,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}}
