:root{--font-heading:"Kantumruy Pro","Noto Sans Khmer","Khmer OS",system-ui,sans-serif;--font-body:"Noto Sans Khmer","Khmer OS",system-ui,sans-serif;--line-height-khmer:1.8}body{font-family:var(--font-body);line-height:var(--line-height-khmer)}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);line-height:1.4}.khmer-text,[lang=km]{word-break:keep-all;overflow-wrap:break-word;line-break:strict}*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--color-primary:#05f;--color-primary-dark:#03a;--color-primary-light:#37f;--color-gold:#c8a951;--color-gold-light:#f5d98a;--color-green:#2d7d46;--color-green-light:#d1fae5;--role-teacher:#2563eb;--role-director:#7c3aed;--role-poe_officer:#0891b2;--role-trainer_dev:#d97706;--role-moeys_admin:#dc2626;--role-sys_admin:#374151;--color-background:#f8fafc;--color-surface:#fff;--color-surface-2:#f1f5f9;--color-text:#000;--color-text-muted:#475569;--color-border:#e2e8f0;--color-border-dark:#cbd5e1;--color-success:#16a34a;--color-warning:#d97706;--color-danger:#dc2626;--color-info:#0891b2;--sp-1:0.25rem;--sp-2:0.5rem;--sp-3:0.75rem;--sp-4:1rem;--sp-5:1.25rem;--sp-6:1.5rem;--sp-8:2rem;--sp-10:2.5rem;--sp-12:3rem;--sp-16:4rem;--radius-sm:0.25rem;--radius:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-full:9999px;--shadow-sm:0 1px 2px rgba(0,0,0,.06);--shadow:0 1px 8px rgba(0,0,0,.1);--shadow-md:0 4px 16px rgba(0,0,0,.12);--shadow-lg:0 8px 32px rgba(0,0,0,.15);--sidebar-w:240px;--sidebar-w-collapsed:68px;--topbar-h:60px;--transition:150ms ease;--transition-slow:300ms ease}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:var(--font-body,"Noto Sans Khmer","Khmer OS",system-ui,sans-serif);line-height:1.7;color:var(--color-text);background-color:var(--color-background);-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading,"Kantumruy Pro","Noto Sans Khmer",system-ui,sans-serif)}[lang=km]{word-break:keep-all;line-break:strict}a{color:var(--color-primary-light);text-decoration:none;transition:color var(--transition)}a:hover{text-decoration:underline}img,svg{display:block;max-width:100%}button{cursor:pointer;font-family:inherit;border:none;background:none}input,select,textarea{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border-dark);border-radius:var(--radius-full)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;clip:rect(0,0,0,0);border:0}.sr-only,.truncate{overflow:hidden;white-space:nowrap}.truncate{text-overflow:ellipsis}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{to{transform:rotate(1turn)}}.animate-fadeIn{animation:fadeIn .3s ease forwards}.animate-slideIn{animation:slideInRight .3s ease forwards}.animate-pulse{animation:pulse 1.5s ease infinite}.animate-spin{animation:spin .7s linear infinite}