@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--primary:#2563eb;--primary-hover:#1d4ed8;--primary-light:#eff6ff;--success:#10b981;--success-light:#ecfdf5;--danger:#ef4444;--danger-light:#fef2f2;--warning:#f59e0b;--warning-light:#fffbeb;--bg-app:#f8fafc;--bg-card:#fff;--text-main:#0f172a;--text-muted:#64748b;--border-color:#e2e8f0;--border-focus:#93c5fd;--font-family:"Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--sidebar-width:260px;--header-height:70px;--transition:all .25s cubic-bezier(.4, 0, .2, 1);--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #00000014, 0 2px 4px -1px #0000000a;--shadow-lg:0 10px 15px -3px #0000000f, 0 4px 6px -2px #00000008;--border-radius:12px;--border-radius-sm:8px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-app);color:var(--text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.5}#root{flex-direction:column;min-height:100vh;display:flex}.app-container{width:100%;min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);border-right:1px solid var(--border-color);z-index:100;transition:var(--transition);background-color:#fff;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{height:var(--header-height);border-bottom:1px solid var(--border-color);align-items:center;padding:0 24px;display:flex}.sidebar-logo-text{color:var(--primary);align-items:center;gap:10px;font-size:1.25rem;font-weight:700;display:flex}.sidebar-menu{flex-direction:column;flex-grow:1;gap:8px;padding:24px 16px;list-style:none;display:flex;overflow-y:auto}.sidebar-item a{color:var(--text-muted);border-radius:var(--border-radius-sm);transition:var(--transition);align-items:center;gap:12px;padding:12px 16px;font-weight:500;text-decoration:none;display:flex}.sidebar-item a:hover{background-color:var(--primary-light);color:var(--primary)}.sidebar-item.active a{background-color:var(--primary);color:#fff}.sidebar-footer{border-top:1px solid var(--border-color);background-color:#fafafa;padding:20px 16px}.user-profile{align-items:center;gap:12px;margin-bottom:16px;display:flex}.user-avatar{background-color:var(--primary-light);width:40px;height:40px;color:var(--primary);border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;font-weight:600;display:flex}.user-info{flex-direction:column;display:flex;overflow:hidden}.user-name{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.user-role{color:var(--text-muted);text-transform:capitalize;font-size:.75rem}.logout-btn{border:1px solid var(--border-color);border-radius:var(--border-radius-sm);width:100%;color:var(--danger);cursor:pointer;transition:var(--transition);background-color:#fff;justify-content:center;align-items:center;gap:8px;padding:10px;font-size:.85rem;font-weight:600;display:flex}.logout-btn:hover{background-color:var(--danger-light)}.main-content{margin-left:var(--sidebar-width);min-height:100vh;transition:var(--transition);flex-direction:column;flex-grow:1;display:flex}.main-header{height:var(--header-height);border-bottom:1px solid var(--border-color);z-index:90;background-color:#fff;justify-content:space-between;align-items:center;padding:0 32px;display:flex;position:sticky;top:0}.page-title{color:var(--text-main);font-size:1.5rem;font-weight:700}.menu-toggle{color:var(--text-main);cursor:pointer;background:0 0;border:none;padding:8px;display:none}.content-wrapper{flex-grow:1;width:100%;max-width:1200px;margin:0 auto;padding:32px}.login-wrapper{background:radial-gradient(circle at top right, var(--primary-light), #fff 70%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);width:100%;max-width:440px;box-shadow:var(--shadow-lg);flex-direction:column;gap:24px;padding:40px;display:flex}.login-header{text-align:center}.login-logo{color:var(--primary);margin-bottom:8px;font-size:2.2rem;font-weight:800}.login-subtitle{color:var(--text-muted);font-size:.95rem}.form-group{text-align:left;flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.form-label{color:var(--text-main);font-size:.85rem;font-weight:600}.form-input{border:1px solid var(--border-color);border-radius:var(--border-radius-sm);width:100%;transition:var(--transition);outline:none;padding:12px 16px;font-family:inherit;font-size:.95rem}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb26}.btn{border-radius:var(--border-radius-sm);cursor:pointer;transition:var(--transition);border:none;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-family:inherit;font-size:.95rem;font-weight:600;display:inline-flex}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover{background-color:var(--primary-hover);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-block{width:100%}.alert{border-radius:var(--border-radius-sm);margin-bottom:16px;padding:12px 16px;font-size:.85rem;font-weight:500}.alert-danger{background-color:var(--danger-light);color:var(--danger);border:1px solid #ef444433}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:32px;display:grid}.metric-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-sm);transition:var(--transition);align-items:center;gap:20px;padding:24px;display:flex}.metric-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.metric-icon{border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.metric-icon.blue{background-color:var(--primary-light);color:var(--primary)}.metric-icon.red{background-color:var(--danger-light);color:var(--danger)}.metric-icon.green{background-color:var(--success-light);color:var(--success)}.metric-icon.orange{background-color:var(--warning-light);color:var(--warning)}.metric-info{flex-direction:column;display:flex}.metric-label{color:var(--text-muted);font-size:.85rem;font-weight:500}.metric-value{color:var(--text-main);font-size:1.8rem;font-weight:700;line-height:1.2}.card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-sm);margin-bottom:32px;padding:32px}.card-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.card-title{color:var(--text-main);font-size:1.25rem;font-weight:700}.filter-bar{flex-wrap:wrap;gap:16px;margin-bottom:24px;display:flex}.search-input-wrapper{flex-grow:1;max-width:400px;position:relative}.search-input{border:1px solid var(--border-color);border-radius:var(--border-radius-sm);outline:none;width:100%;padding:10px 16px;font-family:inherit;font-size:.9rem}.search-input:focus{border-color:var(--primary)}.table-responsive{border:1px solid var(--border-color);border-radius:var(--border-radius-sm);width:100%;overflow-x:auto}.table-custom{border-collapse:collapse;text-align:left;width:100%;font-size:.9rem}.table-custom th{color:var(--text-muted);border-bottom:1px solid var(--border-color);white-space:nowrap;background-color:#f8fafc;padding:14px 20px;font-weight:600}.table-custom td{border-bottom:1px solid var(--border-color);color:var(--text-main);padding:16px 20px}.table-custom tr:last-child td{border-bottom:none}.table-custom tr:hover{background-color:#f8fafc}.badge{text-transform:capitalize;border-radius:9999px;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-success{background-color:var(--success-light);color:var(--success)}.badge-danger{background-color:var(--danger-light);color:var(--danger)}.badge-warning{background-color:var(--warning-light);color:var(--warning)}.badge-primary{background-color:var(--primary-light);color:var(--primary)}.loading-container{background-color:var(--bg-app);flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;display:flex}.spinner{border:4px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=768px){.sidebar{box-shadow:var(--shadow-lg);transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.menu-toggle{display:block}.content-wrapper{padding:16px}.main-header{padding:0 16px}.login-card{padding:24px}.card{padding:20px}}
