@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Plus+Jakarta+Sans:wght@600;700;800&display=swap";:root{--navy: #0F172A;--green: #22C55E;--green-dark: #16A34A;--lime: #84CC16;--blue: #2563EB;--blue-dark: #1D4ED8;--bg: #F8FAFC;--bg-elev: #FFFFFF;--text: #111827;--muted: #6B7280;--border: #E5E7EB;--border-soft: #EEF2F7;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04), 0 1px 1px rgba(15, 23, 42, .03);--shadow-md: 0 12px 28px -16px rgba(15, 23, 42, .18);--shadow-lg: 0 26px 60px -28px rgba(15, 23, 42, .35);--radius: 14px;--radius-lg: 22px;--primary: var(--green);--secondary: var(--blue)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}img{max-width:100%;display:block}h1,h2,h3,h4{font-family:Plus Jakarta Sans,Inter,sans-serif;letter-spacing:-.02em;color:var(--navy)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;border-radius:12px;font-weight:600;font-size:14px;border:1px solid transparent;transition:all .15s ease;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--green-dark));color:#fff;box-shadow:0 12px 24px -10px #22c55e8c}.btn-primary:hover{filter:brightness(1.05);transform:translateY(-1px)}.btn-secondary{background:#fff;color:var(--navy);border-color:var(--border)}.btn-secondary:hover{border-color:var(--navy)}.btn-ghost{background:transparent;color:var(--navy)}.btn-ghost:hover{background:var(--border-soft)}.btn-danger{background:#fee2e2;color:#991b1b;border-color:#fca5a5}.btn-danger:hover{background:#fecaca}.btn-sm{padding:8px 12px;font-size:13px;border-radius:10px}.btn-lg{padding:14px 22px;font-size:15px;border-radius:14px}.btn-block{width:100%}.btn:disabled{opacity:.55;cursor:not-allowed}.card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm)}.card-pad-lg{padding:28px}.card h3{margin:0 0 4px;font-size:16px}.card .label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}.field{margin-bottom:14px}.field label{display:block;font-size:13px;font-weight:600;color:var(--navy);margin-bottom:6px}.input,.select,.textarea{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:#fff;font-size:14px;font-family:inherit;color:var(--text);transition:border-color .15s,box-shadow .15s;outline:none}.input:focus,.select:focus,.textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px #22c55e1f}.textarea{resize:vertical;min-height:90px}.row{display:grid;gap:14px}.row-2{grid-template-columns:1fr 1fr}.row-3{grid-template-columns:repeat(3,1fr)}.row-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 720px){.row-2,.row-3,.row-4{grid-template-columns:1fr}}.field .hint{font-size:12px;color:var(--muted);margin-top:5px}.field .req{color:#dc2626;margin-left:2px}.input-affix{position:relative}.input-affix .affix-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:transparent;border:0;color:var(--muted);padding:6px;border-radius:8px;display:grid;place-items:center}.input-affix .affix-btn:hover{color:var(--navy);background:var(--border-soft)}.form-section{padding:22px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-elev);margin-bottom:18px}.form-section+.form-section{margin-top:0}.form-section-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:18px}.form-section-head .ico{width:42px;height:42px;flex:none;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,#22c55e29,#2563eb24);color:var(--primary)}.form-section-head h3{margin:0;font-size:16px}.form-section-head p{margin:2px 0 0;font-size:13px;color:var(--muted)}.form-footer{position:sticky;bottom:0;z-index:5;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:14px 18px;margin-top:4px;background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.form-footer .hint-left{font-size:13px;color:var(--muted)}@media (max-width: 980px){.form-footer{position:static}}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:600;border-radius:999px;background:var(--border-soft);color:var(--navy)}.badge.green{background:#dcfce7;color:#166534}.badge.blue{background:#dbeafe;color:#1e40af}.badge.amber{background:#fef3c7;color:#92400e}.badge.red{background:#fee2e2;color:#991b1b}.badge.slate{background:#e2e8f0;color:#1e293b}.badge.purple{background:#ede9fe;color:#5b21b6}.badge .dot{width:6px;height:6px;border-radius:99px;background:currentColor}.app-shell{display:grid;grid-template-columns:264px 1fr;min-height:100vh;background:var(--bg)}.sidebar{background:linear-gradient(180deg,#22c55e0a,#fff0 220px),#fff;border-right:1px solid var(--border);padding:18px 14px 16px;display:flex;flex-direction:column;gap:2px;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar .brand{display:flex;align-items:center;gap:10px;padding:6px 8px 16px;margin-bottom:8px;border-bottom:1px solid var(--border-soft)}.sidebar .nav-scroll{display:flex;flex-direction:column;gap:2px;flex:1}.sidebar a{position:relative;display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:12px;color:#475569;font-weight:500;font-size:14px;transition:background .15s ease,color .15s ease,transform .08s ease}.sidebar a .icon{width:34px;height:34px;flex:none;display:grid;place-items:center;border-radius:10px;background:#f1f5f9;color:#64748b;transition:all .15s ease}.sidebar a:hover{background:#f8fafc;color:var(--navy)}.sidebar a:hover .icon{background:#e8edf3;color:var(--navy)}.sidebar a:active{transform:scale(.99)}.sidebar a.active{background:linear-gradient(135deg,#22c55e1f,#2563eb14);color:var(--navy);font-weight:600}.sidebar a.active .icon{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;box-shadow:0 6px 14px -6px #22c55eb3}.sidebar a.active:before{content:"";position:absolute;left:-14px;top:50%;transform:translateY(-50%);width:4px;height:22px;border-radius:0 4px 4px 0;background:linear-gradient(180deg,var(--primary),var(--secondary))}.sidebar .section-label{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:#94a3b8;padding:16px 12px 6px;font-weight:700}.sidebar .side-user{margin-top:10px;padding-top:12px;border-top:1px solid var(--border-soft);display:flex;flex-direction:column;gap:8px}.sidebar .side-user .who{display:flex;align-items:center;gap:10px;padding:8px;border-radius:12px;background:#f8fafc;border:1px solid var(--border-soft)}.sidebar .side-user .who .meta{line-height:1.15;min-width:0}.sidebar .side-user .who .meta .nm{font-size:13px;font-weight:700;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar .side-user .who .meta .rl{font-size:11px;color:var(--muted)}.sidebar .side-logout{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;color:#dc2626;font-weight:600;font-size:14px;background:transparent;border:1px solid transparent;width:100%;transition:all .15s ease}.sidebar .side-logout:hover{background:#fef2f2;border-color:#fecaca}.topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;padding:14px 28px;background:#ffffffd9;-webkit-backdrop-filter:saturate(180%) blur(10px);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--border)}.topbar .search{display:flex;align-items:center;gap:8px;padding:9px 14px;background:var(--bg);border:1px solid var(--border);border-radius:12px;width:320px;max-width:50vw}.topbar .search input{border:0;background:transparent;outline:0;font-size:14px;width:100%}.topbar .user{display:flex;align-items:center;gap:10px;cursor:pointer;padding:6px 12px 6px 6px;border-radius:999px;border:1px solid var(--border);background:#fff}.avatar{width:36px;height:36px;border-radius:999px;background:linear-gradient(135deg,var(--primary),var(--secondary));display:grid;place-items:center;color:#fff;font-weight:700;overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover}.avatar.sm{width:28px;height:28px;font-size:12px}.avatar.lg{width:64px;height:64px;font-size:22px}.page{padding:28px;max-width:1400px;margin:0 auto}.page-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}.page-header h1{font-size:26px;margin:0}.page-header p{color:var(--muted);margin:4px 0 0;font-size:14px}.mobile-nav{display:none;position:fixed;left:0;right:0;bottom:0;z-index:50;background:#fffffff5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--border);padding:8px 8px calc(8px + env(safe-area-inset-bottom));justify-content:space-around}.mobile-nav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;font-size:11px;color:var(--muted);font-weight:500}.mobile-nav a.active,.mobile-nav a.active .icon{color:var(--primary)}@media (max-width: 980px){.app-shell{grid-template-columns:1fr}.sidebar{display:none}.topbar{padding:14px 16px}.topbar .search{display:none}.page{padding:18px 14px 96px}.mobile-nav{display:flex}}.stat-grid{display:grid;gap:16px;grid-template-columns:repeat(4,1fr)}@media (max-width: 1180px){.stat-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.stat-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden}.stat-card .icon-wrap{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;background:var(--border-soft);color:var(--navy)}.stat-card .value{font-size:28px;font-weight:800;color:var(--navy)}.stat-card .label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}.stat-card .trend{font-size:12px;color:var(--green-dark);font-weight:600}.stat-card .trend.down{color:#dc2626}.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border);background:#fff}table.fm{width:100%;border-collapse:collapse;min-width:600px}table.fm th,table.fm td{text-align:left;padding:14px 16px;font-size:14px;border-bottom:1px solid var(--border-soft)}table.fm thead th{background:#f8fafc;color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.06em}table.fm tbody tr:hover{background:#f8fafc}table.fm tr:last-child td{border-bottom:0}.modal-back{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:#fff;border-radius:22px;max-width:640px;width:100%;padding:28px;box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto}.modal h2{margin:0 0 6px;font-size:20px}.modal .sub{color:var(--muted);margin-bottom:18px;font-size:14px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}.toast-wrap{position:fixed;right:18px;bottom:18px;z-index:200;display:flex;flex-direction:column;gap:10px}.toast{padding:12px 16px;border-radius:12px;min-width:240px;font-size:14px;color:var(--navy);background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-md);animation:slide-in .2s ease}.toast.success{border-left:4px solid var(--green)}.toast.error{border-left:4px solid #DC2626}.toast.info{border-left:4px solid var(--blue)}@keyframes slide-in{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}.skeleton{background:linear-gradient(90deg,#eef2f7,#f6f8fb,#eef2f7);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:10px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty{text-align:center;padding:36px 16px;color:var(--muted);background:#fff;border:1px dashed var(--border);border-radius:var(--radius-lg)}.empty .ico{width:64px;height:64px;border-radius:18px;background:linear-gradient(135deg,#22c55e26,#2563eb1f);display:grid;place-items:center;margin:0 auto 12px;color:var(--primary)}.empty h3{margin:0 0 4px;color:var(--navy)}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mt-8{margin-top:32px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.text-sm{font-size:13px}.text-xs{font-size:12px}.text-muted{color:var(--muted)}.text-center{text-align:center}.grid-2{display:grid;gap:16px;grid-template-columns:1fr 1fr}.grid-3{display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}@media (max-width: 980px){.grid-2,.grid-3{grid-template-columns:1fr}.hide-mobile{display:none!important}}.divider{height:1px;background:var(--border);margin:16px 0}.qa-grid{display:grid;gap:14px;grid-template-columns:repeat(4,1fr)}@media (max-width: 1100px){.qa-grid{grid-template-columns:repeat(2,1fr)}}.qa{background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:transform .12s,box-shadow .12s}.qa:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.qa .ico{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,#22c55e26,#2563eb26);color:var(--primary)}.qa h4{margin:0;font-size:14px;color:var(--navy)}.qa p{margin:2px 0 0;font-size:12px;color:var(--muted)}.landing{background:#fff}.landing .nav{display:flex;justify-content:space-between;align-items:center;padding:18px 28px;position:sticky;top:0;background:#ffffffd9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:30;border-bottom:1px solid rgba(15,23,42,.06)}.landing .nav .actions{display:flex;gap:10px;align-items:center}.landing .hero{position:relative;overflow:hidden;padding:80px 28px;background:radial-gradient(900px 480px at 90% -10%,rgba(34,197,94,.18) 0%,transparent 60%),radial-gradient(800px 480px at 0% 120%,rgba(37,99,235,.16) 0%,transparent 60%)}.landing .hero .wrap{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.05fr 1fr;gap:60px;align-items:center}.landing .hero h1{font-size:56px;line-height:1.05;margin:0 0 16px}.landing .hero h1 .grad{background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;background-clip:text;color:transparent}.landing .hero p{font-size:18px;color:var(--muted);max-width:540px;margin-bottom:26px}.landing .hero .cta-row{display:flex;gap:12px;flex-wrap:wrap}.landing .hero .badge-row{display:flex;gap:8px;margin-bottom:18px}.landing .preview{position:relative;background:#fff;border:1px solid var(--border);border-radius:26px;padding:18px;box-shadow:var(--shadow-lg)}.landing .preview .ph{border-radius:18px;background:linear-gradient(135deg,#0f172a,#1e293b);color:#fff;padding:22px;min-height:320px;position:relative;overflow:hidden}.landing .preview .row3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px}.landing .preview .row3 .mini{background:#ffffff0f;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:12px}.landing .preview .row3 .mini b{font-size:22px}.landing .preview .row3 .mini span{display:block;font-size:11px;opacity:.75}@media (max-width: 980px){.landing .hero .wrap{grid-template-columns:1fr;gap:40px}.landing .hero h1{font-size:38px}.landing .hero{padding:48px 18px}}.section{padding:80px 28px}.section .wrap{max-width:1200px;margin:0 auto}.section h2{font-size:36px;margin:0 0 8px}.section .lead{color:var(--muted);margin:0 0 40px;max-width:600px;font-size:16px}.feature-grid{display:grid;gap:18px;grid-template-columns:repeat(3,1fr)}@media (max-width: 900px){.feature-grid{grid-template-columns:1fr}}.feature{background:#fff;border:1px solid var(--border);border-radius:18px;padding:22px;transition:transform .12s,box-shadow .12s}.feature:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.feature .ico{width:44px;height:44px;border-radius:14px;background:linear-gradient(135deg,#22c55e2e,#2563eb2e);color:var(--primary);display:grid;place-items:center;margin-bottom:12px}.feature h3{font-size:18px;margin:0 0 4px}.feature p{margin:0;color:var(--muted);font-size:14px}.footer{border-top:1px solid var(--border);padding:32px 28px;color:var(--muted);font-size:13px}.footer .wrap{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}.auth-shell{min-height:100vh;display:grid;grid-template-columns:1.05fr 1fr;background:var(--bg)}.auth-side{background:linear-gradient(135deg,#0f172a,#1e293b);color:#fff;padding:50px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}.auth-side:after{content:"";position:absolute;inset:auto -120px -120px auto;width:380px;height:380px;background:radial-gradient(circle,rgba(34,197,94,.35),transparent 60%);filter:blur(20px)}.auth-form{display:flex;align-items:center;justify-content:center;padding:40px 20px}.auth-form .box{width:100%;max-width:420px}@media (max-width: 900px){.auth-shell{grid-template-columns:1fr}.auth-side{display:none}}.chart-card{padding:18px}.chart-card h3{margin:0 0 4px;font-size:16px}.chart-card .sub{color:var(--muted);font-size:12px;margin-bottom:12px}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}
