:root{--sidebar-w: 232px;--sidebar-w-collapsed: 56px;--topbar-h: 56px;--color-brand-amber: #f59e0b;--color-brand-red: #ef4444;--color-dark: #0f172a;--color-navy: #1e293b;--color-surface: #f8fafc;--color-card: #ffffff;--color-border: #e2e8f0;--color-text-primary: #0f172a;--color-text-muted: #64748b;--transition-sidebar: width .22s cubic-bezier(.4,0,.2,1), transform .25s cubic-bezier(.4,0,.2,1);--radius-card: 16px;--radius-btn: 10px;--shadow-card: 0 4px 20px rgba(15,23,42,.08);--shadow-modal: 0 24px 60px rgba(15,23,42,.2)}.dark{--color-surface: #0f172a;--color-card: #1e293b;--color-border: #334155;--color-text-primary: #f1f5f9;--color-text-muted: #94a3b8}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%}body{font-family:DM Sans,Segoe UI,sans-serif;background:#f8fafc;color:#1e293b;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}button,input,select,textarea{font-family:DM Sans,Segoe UI,sans-serif}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.text-safe{overflow-wrap:break-word;word-break:break-word}img,video,canvas,svg{max-width:100%;height:auto}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a99;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:90}.sidebar-drawer{flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto;overflow-x:hidden;transition:var(--transition-sidebar);z-index:var(--sidebar-z, 100)}@media (max-width: 767px){.sidebar-overlay{display:block}.sidebar-drawer{position:fixed!important;top:0;left:0;width:var(--sidebar-w)!important;min-width:var(--sidebar-w)!important;height:100dvh;transform:translate(-110%);z-index:100}.sidebar-drawer.open{transform:translate(0);box-shadow:8px 0 40px #0f172a4d}.main-content{margin-left:0!important;width:100%!important;min-width:0}.mobile-menu-btn{display:flex!important}.topbar-title{font-size:15px!important}.content-area{padding:12px 10px!important}.toast-container{left:12px!important;right:12px!important;bottom:16px!important;width:auto!important;max-width:none!important}.modal-sheet{border-radius:20px 20px 0 0!important;position:fixed!important;bottom:0!important;inset-inline:0!important;max-width:100%!important;max-height:92dvh!important;overflow-y:auto}}@media (min-width: 768px) and (max-width: 1023px){.content-area{padding:16px 14px!important}.topbar-title{font-size:16px!important}.mobile-menu-btn{display:none!important}}@media (min-width: 1024px){.mobile-menu-btn{display:none!important}.content-area{padding:22px 24px}}.module-fade-in{animation:moduleFadeIn .45s cubic-bezier(.16,1,.3,1) forwards}@keyframes moduleFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes pulse-radar{0%{r:30;opacity:.4}to{r:80;opacity:0}}.pulse-anim{animation:pulse-radar 2s infinite}@keyframes attritionBlink{0%,to{opacity:1}50%{opacity:.3}}.blink-alert{animation:attritionBlink 1.4s infinite}.recharts-wrapper,.recharts-surface{max-width:100%!important;overflow:visible}.table-responsive{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:12px}.table-responsive table{min-width:500px;width:100%}.card-grid{display:grid;gap:16px;grid-template-columns:1fr}@media (min-width: 480px){.card-grid-2{grid-template-columns:repeat(2,1fr)}}@media (min-width: 768px){.card-grid{grid-template-columns:repeat(2,1fr)}.card-grid-3{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1024px){.card-grid-4{grid-template-columns:repeat(4,1fr)}}.stat-card{min-width:0;overflow:hidden}.stat-card-number{font-size:clamp(20px,4vw,32px);font-weight:700;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{opacity:.6}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid #f59e0b;outline-offset:1px}
