:root{--navy: #1e3a5f;--navy-700: #16304f;--blue: #2563eb;--blue-700: #1d4ed8;--bg: #f7f8fa;--card: #ffffff;--border: #e6e8ec;--text: #0f172a;--muted: #64748b;--green: #16a34a;--green-bg: #e9f7ef;--red: #c0392b;--orange: #ea580c;--amber-bg: #fff7e6;--net-bg: #eef4ff}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{font-family:Inter,-apple-system,"system-ui",Segoe UI,Noto Sans Thai,sans-serif;background:var(--bg);color:var(--text);font-size:14px;-webkit-font-smoothing:antialiased}a{color:var(--navy)}.topbar{background:#fff;color:var(--text);display:flex;align-items:center;gap:14px;padding:0 24px;height:60px;position:sticky;top:0;z-index:20;border-bottom:1px solid var(--border)}.brand{display:flex;align-items:center;gap:10px}.brand .sq{background:#1e293b;color:#fff;width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;letter-spacing:1px}.brand .name{font-weight:700;font-size:16px;line-height:1.1}.brand .tag{font-size:11px;color:var(--muted);letter-spacing:.12em}.topbar .spacer{flex:1}.user-menu{position:relative}.user-btn{background:#fff;color:var(--text);border:1px solid var(--border);padding:8px 14px;border-radius:9px;cursor:pointer;font-weight:600;font-size:14px;display:flex;align-items:center;gap:6px;line-height:1.2}.user-btn:hover{background:var(--bg)}.user-btn .who{font-size:11px;color:var(--muted)}.user-pop{position:absolute;right:0;top:50px;background:#fff;color:var(--text);border:1px solid var(--border);border-radius:12px;min-width:240px;box-shadow:0 12px 32px #0f172a24;overflow:hidden;padding:6px}.user-pop .pophead{padding:8px 12px 6px;color:var(--muted);font-size:12px;border-bottom:1px solid var(--border);margin-bottom:4px}.user-pop button{display:block;width:100%;text-align:left;background:none;border:0;padding:10px 12px;cursor:pointer;font-size:14px;border-radius:8px;color:var(--text)}.user-pop button:hover{background:var(--bg)}.user-pop button.active{background:#eef2f8;font-weight:600}.page{padding:22px 28px 56px;max-width:1240px;margin:0 auto}.h1{font-size:26px;font-weight:700;margin:4px 0 2px}.sub{color:var(--muted);margin-bottom:16px;font-size:14px}.card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px;margin-bottom:18px}.section-title{font-size:16px;font-weight:700;margin:0 0 12px}.row{display:flex;gap:12px;flex-wrap:wrap}.btn{background:var(--navy);color:#fff;border:0;padding:9px 16px;border-radius:9px;cursor:pointer;font-weight:600;font-size:14px}.btn:hover{background:var(--navy-700)}.btn.blue{background:var(--blue)}.btn.blue:hover{background:var(--blue-700)}.btn.ghost{background:#fff;color:var(--navy);border:1px solid var(--border)}.btn.ghost:hover{background:var(--bg)}.btn.danger{background:#fff;color:var(--red);border:1px solid #f0c4be}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.sm{padding:6px 11px;font-size:13px}.btn.icon{padding:7px 9px;font-size:14px}input,select{font:inherit;padding:9px 11px;border:1px solid var(--border);border-radius:9px;background:#fff;color:var(--text)}input:focus,select:focus{outline:2px solid #c7d6ea;border-color:#9fb6d6}.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:18px}.metric{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:16px 18px}.metric .label{color:var(--muted);font-size:13px}.metric .value{font-size:28px;font-weight:700;margin:4px 0 8px}.metric .value.sm{font-size:22px}.metric .foot{font-size:12px;color:var(--muted)}.metric .foot.up{color:var(--green)}.metric .foot.up:before{content:"↑ "}.tbl-wrap{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden}.tbl-scroll{overflow:auto;max-height:620px}table.tbl{width:100%;border-collapse:collapse;font-size:13px}table.tbl th,table.tbl td{padding:11px 12px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle}table.tbl th{background:#f3f5f8;font-weight:700;font-size:11px;letter-spacing:.03em;color:#475569;text-transform:uppercase;position:sticky;top:0}table.tbl td.num,table.tbl th.num{text-align:right;font-variant-numeric:tabular-nums}table.tbl tr.total td{background:var(--amber-bg);font-weight:700}table.tbl tr.zero td{background:#fdecec}table.tbl tbody tr:hover td{background:#f8fafc}.muted{color:var(--muted)}.mono{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:11px;color:var(--muted)}.warn-num{color:var(--orange);font-weight:700}.net-badge{background:var(--net-bg);color:var(--navy);padding:6px 10px;border-radius:8px;font-weight:700;display:inline-block}.pill-tag{background:#eef2f8;border-radius:999px;padding:3px 10px;font-size:12px;color:#475569}.doc-ico{width:30px;height:36px;border:1px solid var(--border);border-radius:5px;display:inline-flex;align-items:center;justify-content:center;color:#94a3b8;background:#fafbfc}.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:12px;flex-wrap:wrap}.toolbar .grow{flex:1;min-width:220px}.seg{display:inline-flex;border:1px solid var(--border);border-radius:9px;overflow:hidden}.seg button{border:0;background:#fff;padding:9px 13px;cursor:pointer;color:var(--muted)}.seg button.on{background:var(--blue);color:#fff}.tabs{display:flex;gap:4px;border-bottom:2px solid var(--border);margin-bottom:18px}.tab{background:none;border:0;padding:11px 18px;cursor:pointer;font-weight:600;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-2px}.tab.active{color:var(--navy);border-bottom-color:var(--navy)}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:#fff;border-radius:16px;padding:24px;width:min(560px,92vw)}.login-wrap{display:flex;align-items:flex-start;justify-content:center;min-height:100vh;background:var(--bg);padding-top:16vh}.login-box{width:380px}.login-brand{display:flex;align-items:center;gap:12px;margin:0 0 18px 6px}.login-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:26px;box-shadow:0 8px 28px #0f172a0f}.login-card .field{margin-bottom:16px}.login-card label{display:block;font-size:13px;color:var(--text);margin-bottom:6px;font-weight:600}.login-card .pw{position:relative}.login-card .pw input{width:100%;padding-right:42px}.login-card .pw .eye{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:0;cursor:pointer;font-size:16px;padding:4px}.login-card input{width:100%}.err{color:var(--red);font-size:13px;margin-top:10px}.flash{background:var(--green-bg);color:var(--green);border:1px solid #b9e3c9;border-radius:10px;padding:11px 14px;margin-bottom:14px}.flash.error{background:#fdecea;color:var(--red);border-color:#f5c6c0}.flash.info{background:#eef4ff;color:var(--navy);border-color:#c7d6ea}.loading{padding:48px;text-align:center;color:var(--muted)}.editable{width:96px;padding:5px 7px}.warn{color:var(--orange);font-weight:700}
