:root{--color-primary: #007354;--color-primary-hover: #005c43;--color-primary-light: #e6f2ee;--color-secondary: #5EA632;--color-secondary-hover:#4d8a29;--color-accent: #C0C411;--color-accent-hover: #a3a70e;--color-sidebar-bg: #0f2620;--color-sidebar-active: #007354;--color-bg: #f4f6f5;--color-surface: #ffffff;--color-surface-2: #f9fbfa;--color-border: #e2e8e5;--color-text: #1a2e28;--color-text-muted: #6b7c77;--color-text-light: #9aaba6;--color-error: #dc2626;--color-error-light: #fef2f2;--color-success: #5EA632;--color-warning: #C0C411;--radius-sm: 4px;--radius: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0,0,0,.05);--shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.06);--shadow-lg: 0 10px 15px rgba(0,0,0,.08), 0 4px 6px rgba(0,0,0,.05);--shadow-xl: 0 20px 25px rgba(0,0,0,.1), 0 10px 10px rgba(0,0,0,.04);--transition: .15s ease;--transition-slow: .28s cubic-bezier(.4,0,.2,1);--font-sans: "Inter", system-ui, -apple-system, sans-serif;--sidebar-width: 240px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}img{display:block;max-width:100%}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-light)}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes toastIn{0%{opacity:0;transform:translateY(100%) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(10%) scale(.95)}}.animate-fade-in{animation:fadeIn var(--transition-slow) both}.animate-fade-in-scale{animation:fadeInScale var(--transition-slow) both}.animate-slide-in-right{animation:slideInRight var(--transition-slow) both}
