@import url(https://fonts.googleapis.com/css2?family=Sarabun:wght@300;400;500;600;700&display=swap);*{box-sizing:border-box}body{margin:0;font-family:'Sarabun',sans-serif;background:#f5f8f6;color:#1f2937}a{text-decoration:none;color:inherit}.app{display:flex;min-height:100vh}.sidebar{width:260px;background:linear-gradient(180deg,#0f5132,#198754);color:#fff;padding:20px 16px;position:fixed;inset:0 auto 0 0}.logo{display:flex;gap:10px;align-items:center;font-size:20px;margin-bottom:28px}.logo span{font-size:30px}.sidebar nav{display:grid;gap:8px}.sidebar a{padding:12px 14px;border-radius:16px;display:flex;gap:10px;align-items:center;color:#eafff3}.sidebar a.active,.sidebar a:hover{background:rgba(255,255,255,.18)}.main{margin-left:260px;width:calc(100% - 260px);padding:22px}.topbar{display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:24px;padding:20px 22px;margin-bottom:18px;box-shadow:0 8px 22px rgba(15,81,50,.06)}.topbar h1{margin:0;font-size:25px;color:#0f5132}.topbar p{margin:4px 0 0;color:#64748b}.userbox{display:flex;gap:14px;align-items:center}.userbox a{color:#dc2626}.grid{display:grid;gap:16px}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.card{background:#fff;border:1px solid #e5e7eb;border-radius:24px;padding:20px;box-shadow:0 8px 22px rgba(15,81,50,.06);margin-bottom:16px}.stat{display:flex;justify-content:space-between;align-items:center}.stat .num{font-size:30px;font-weight:700;color:#0f5132}.stat .label{color:#64748b}.stat .icon{font-size:34px;background:#ecfdf5;border-radius:18px;padding:10px}.toolbar{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:14px}.btn,button{border:0;background:#198754;color:#fff;border-radius:14px;padding:10px 16px;font-family:inherit;cursor:pointer}.btn.secondary{background:#334155}.btn.danger{background:#dc2626}.btn.light{background:#e2e8f0;color:#0f172a}.table-wrap{overflow:auto;border-radius:18px;border:1px solid #e5e7eb}table{width:100%;border-collapse:collapse;background:#fff}th,td{padding:12px 14px;border-bottom:1px solid #e5e7eb;text-align:left;vertical-align:top}th{background:#f0fdf4;color:#14532d;font-weight:700;white-space:nowrap}tr:hover td{background:#fbfffd}.badge{display:inline-flex;border-radius:999px;padding:4px 10px;font-size:13px;background:#e2e8f0}.badge.green{background:#dcfce7;color:#166534}.badge.yellow{background:#fef9c3;color:#854d0e}.badge.red{background:#fee2e2;color:#991b1b}.form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.form-grid .full{grid-column:1/-1}label{display:block;margin-bottom:6px;color:#475569;font-size:14px}input,select,textarea{width:100%;border:1px solid #cbd5e1;border-radius:14px;padding:10px 12px;font-family:inherit;background:#fff}textarea{min-height:82px}.alert{padding:12px 14px;border-radius:16px;margin-bottom:14px}.alert.success{background:#dcfce7;color:#166534}.alert.error{background:#fee2e2;color:#991b1b}.footer{text-align:center;color:#64748b;margin:22px 0 6px}.login-page{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#ecfdf5,#f8fafc)}.login-card{width:min(440px,92vw);background:#fff;border-radius:28px;padding:30px;box-shadow:0 20px 60px rgba(15,81,50,.15);border:1px solid #e5e7eb}.brand-icon{font-size:48px}.login-card h1{font-size:24px;color:#0f5132;margin:4px 0}.login-card p{color:#64748b}.login-card form{display:grid;gap:10px;margin-top:18px}.login-card button{margin-top:8px;width:100%;font-size:16px}.filters{display:flex;gap:10px;flex-wrap:wrap}.filters input,.filters select{width:auto;min-width:170px}.print-only{display:none}@media (max-width:900px){.sidebar{position:relative;width:100%;inset:auto}.app{display:block}.main{margin-left:0;width:100%;padding:14px}.grid-4,.grid-3,.grid-2,.form-grid{grid-template-columns:1fr}.topbar{display:block}.filters input,.filters select{width:100%}}@media print{.sidebar,.topbar,.toolbar,.btn,.filters,.footer{display:none!important}.main{margin:0;width:100%;padding:0}.card{box-shadow:none;border:0}.print-only{display:block}body{background:#fff;font-size:12px}th,td{padding:6px 8px}}