:root{--green-900: #093E27;--green-700: #0B6B40;--green-600: #0E7C4A;--green-500: #149A5C;--green-100: #E8F3ED;--green-50: #F2F8F4;--bg: #EEF3F0;--surface: #ffffff;--ink: #122019;--muted: #6b7c73;--line: #e2ebe6;--blue: #1E55B8;--amber: #B9821A;--red: #C0392B;--radius: 14px;--radius-sm: 10px;--shadow: 0 6px 20px -10px rgba(9,62,39,.28);--shadow-lg: 0 24px 60px -20px rgba(9,62,39,.35);--font-ui: "IBM Plex Sans Thai", system-ui, sans-serif;--font-body: "Sarabun", system-ui, sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%}body{font-family:var(--font-body);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{font-family:var(--font-ui);cursor:pointer}h1,h2,h3,h4,.ui{font-family:var(--font-ui)}input,select,textarea{font-family:var(--font-body)}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:#cfdcd5;border-radius:8px}@media (prefers-reduced-motion: no-preference){@keyframes slideUp{0%{transform:translateY(14px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse{0%{transform:scale(.85);opacity:.7}70%{transform:scale(1.5);opacity:0}to{opacity:0}}}.app{display:flex;min-height:100vh}.sidebar{width:248px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.brand{padding:20px 18px;display:flex;gap:12px;align-items:center;border-bottom:1px solid var(--line)}.brand-logo{width:44px;height:44px;border-radius:11px;background:linear-gradient(155deg,var(--green-600),var(--green-900));display:grid;place-items:center;color:#fff;font-weight:700}.brand-name{font-family:var(--font-ui);font-weight:700;font-size:15px;line-height:1.2}.brand-sub{font-size:11.5px;color:var(--muted)}.nav{padding:12px 10px;display:flex;flex-direction:column;gap:3px;flex:1;overflow-y:auto}.nav-section{font-size:11px;color:var(--muted);font-weight:600;padding:12px 12px 6px;letter-spacing:.04em}.nav a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--radius-sm);font-family:var(--font-ui);font-size:14px;color:#3c4a43;font-weight:500}.nav a:hover{background:var(--green-50)}.nav a.active{background:var(--green-100);color:var(--green-700);font-weight:600}.nav a .badge{margin-left:auto}.userbox{padding:14px;border-top:1px solid var(--line);display:flex;align-items:center;gap:11px}.avatar{width:38px;height:38px;border-radius:50%;background:var(--green-100);color:var(--green-700);display:grid;place-items:center;font-family:var(--font-ui);font-weight:700;font-size:14px;flex-shrink:0}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{height:62px;background:var(--surface);border-bottom:1px solid var(--line);display:flex;align-items:center;padding:0 24px;gap:16px;position:sticky;top:0;z-index:20}.topbar h1{font-size:18px;margin:0}.content{padding:24px;max-width:1100px;width:100%;margin:0 auto}@media (prefers-reduced-motion: no-preference){.content{animation:fadeIn .25s ease}}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.card-pad{padding:20px}.grid{display:grid;gap:16px}.cols-2{grid-template-columns:repeat(2,1fr)}.cols-3{grid-template-columns:repeat(3,1fr)}.cols-4{grid-template-columns:repeat(4,1fr)}.stat{padding:18px 20px}.stat-label{font-size:13px;color:var(--muted)}.stat-value{font-family:var(--font-ui);font-size:30px;font-weight:700;margin-top:4px}.stat-foot{font-size:12px;color:var(--muted);margin-top:4px}.btn{border:none;border-radius:var(--radius-sm);padding:11px 18px;font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:8px;transition:filter .15s,background .15s}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--green-600);color:#fff}.btn-primary:hover:not(:disabled){background:var(--green-700)}.btn-ghost{background:var(--green-50);color:var(--green-700)}.btn-danger{background:#fdecea;color:var(--red)}.btn-blue{background:var(--blue);color:#fff}.btn-block{width:100%;justify-content:center}.btn-lg{padding:14px 22px;font-size:15px}.field{margin-bottom:14px}.field label{display:block;font-family:var(--font-ui);font-size:13px;font-weight:600;color:#50605a;margin-bottom:6px}.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:var(--radius-sm);padding:11px 13px;font-size:14px;outline:none;background:#fff;transition:border-color .15s,box-shadow .15s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--green-500);box-shadow:0 0 0 3px var(--green-100)}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:999px;font-family:var(--font-ui);font-size:12.5px;font-weight:600}.chip-pending{background:#fdf4e3;color:var(--amber)}.chip-approved{background:var(--green-100);color:var(--green-700)}.chip-rejected{background:#fdecea;color:var(--red)}.chip-cancelled{background:#eef1f0;color:var(--muted)}.chip-done{background:#e7f0fb;color:var(--blue)}table{width:100%;border-collapse:collapse}th{text-align:left;font-family:var(--font-ui);font-size:12.5px;color:var(--muted);font-weight:600;padding:10px 14px;border-bottom:1px solid var(--line)}td{padding:13px 14px;border-bottom:1px solid var(--line);font-size:14px}tr:last-child td{border-bottom:none}.section-title{font-family:var(--font-ui);font-size:16px;font-weight:700;margin:0 0 4px}.muted{color:var(--muted)}.row{display:flex;align-items:center;gap:12px}.spacer{flex:1}.toasts{position:fixed;right:20px;bottom:20px;display:flex;flex-direction:column;gap:10px;z-index:200}.toast{background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--green-600);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);padding:13px 16px;min-width:280px;max-width:360px}@media (prefers-reduced-motion: no-preference){.toast{animation:slideUp .25s ease}}.toast.info{border-left-color:var(--blue)}.toast.error{border-left-color:var(--red)}.toast-title{font-family:var(--font-ui);font-weight:600;font-size:14px}.toast-body{font-size:13px;color:var(--muted);margin-top:2px}.live{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;color:var(--muted)}.live .dot{position:relative;width:8px;height:8px;border-radius:50%;background:var(--green-500)}.live .dot:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;border:2px solid var(--green-500)}@media (prefers-reduced-motion: no-preference){.live .dot:after{animation:pulse 2s ease-out infinite}}.live.off .dot,.live.off .dot:after{background:#c2cdc7;border-color:#c2cdc7;animation:none}.mobile-nav{display:none}@media (max-width: 860px){.sidebar{display:none}.content{padding:16px 14px 84px}.cols-2,.cols-3,.cols-4{grid-template-columns:1fr 1fr}.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--line);padding:6px 4px env(safe-area-inset-bottom);z-index:50}.mobile-nav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:7px 0;font-family:var(--font-ui);font-size:10.5px;color:var(--muted)}.mobile-nav a.active{color:var(--green-700)}}.doc-wrap{max-width:800px;margin:0 auto}.doc-toolbar{display:flex;align-items:center;margin-bottom:16px}.doc{background:#fff;border:1px solid var(--line);border-radius:8px;padding:56px 64px;font-family:Sarabun,serif;color:#111;line-height:1.9;font-size:16px}.doc-garuda{width:64px;height:64px;margin:0 auto 6px;border:1px dashed #bbb;border-radius:50%;display:grid;place-items:center;font-size:11px;color:#999}.doc-title{text-align:center;font-family:Sarabun;font-weight:700;font-size:26px;letter-spacing:.06em;margin:0 0 22px}.doc-meta{font-size:16px;display:flex;flex-direction:column;gap:4px}.doc-meta b{font-weight:700}.doc-rule{border:none;border-top:1.5px solid #111;margin:10px 0 18px}.doc-body p{margin:0 0 12px}.doc-indent{text-indent:2.5em;text-align:justify}.doc-sign-requester{text-align:center;width:300px;margin:32px 0 8px auto}.doc-sign-requester div{margin-bottom:2px}.doc-approvals{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:28px}.doc-approval-box{border:1px solid #ccc;border-radius:6px;padding:14px 16px;font-size:15px}.doc-approval-label{font-weight:700;margin-bottom:6px}.doc-approval-decision{margin-bottom:6px}.doc-approval-comment{font-size:14px;color:#444;margin-bottom:10px}.doc-approval-sign{text-align:center;margin-top:14px;font-size:14.5px}.doc-approval-date{margin-top:4px}@media print{.sidebar,.topbar,.mobile-nav,.no-print,.toasts,.doc-toolbar{display:none!important}body{background:#fff}.app,.main,.content{display:block;padding:0;margin:0;max-width:none}.doc-wrap{max-width:none}.doc{border:none;border-radius:0;padding:0}.print-header{display:block!important;margin-bottom:12px}.card{box-shadow:none;border-color:#ccc}@page{size:A4;margin:18mm}}@media (max-width: 860px){.login-brand{display:none!important}.login-form{width:100%!important;max-width:100%!important}.doc{padding:28px 22px}.doc-approvals{grid-template-columns:1fr}}.switch{position:relative;width:50px;height:28px;border-radius:999px;border:none;background:#cfd8d3;padding:0;flex-shrink:0;transition:background .2s;cursor:pointer}.switch.on{background:var(--green-500)}.switch:disabled{opacity:.6;cursor:wait}.switch-knob{position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0000004d;transition:transform .2s}.switch.on .switch-knob{transform:translate(22px)}.banner{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius-sm);background:#fdf4e3;color:var(--amber);border:1px solid #f3e2bf;font-size:14px;margin-bottom:14px}.banner.muted-banner{background:#eef1f0;color:var(--muted);border-color:var(--line)}
