@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap";:root{--font-sans:"Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--bg-app:#080b11;--bg-sidebar:#0f1524;--bg-surface:#151c2e;--bg-card-hover:#1e263d;--primary:#6366f1;--primary-hover:#4f46e5;--secondary:#0ea5e9;--text-main:#f8fafc;--text-muted:#94a3b8;--border:#ffffff14;--border-focus:#6366f180;--shadow:0 4px 20px -2px #0006;--shadow-hover:0 10px 30px -4px #6366f126;--transition-fast:.2s cubic-bezier(.4, 0, .2, 1);--transition-normal:.3s cubic-bezier(.4, 0, .2, 1);--color-success:#10b981;--color-success-bg:#10b98126;--color-danger:#ef4444;--color-danger-bg:#ef444426;--color-warning:#f59e0b;--color-warning-bg:#f59e0b26;--color-info:#3b82f6;--color-info-bg:#3b82f626}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-app);color:var(--text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}.app-layout{min-height:100vh;display:flex}.sidebar{background-color:var(--bg-sidebar);border-right:1px solid var(--border);flex-direction:column;width:260px;height:100vh;padding:24px 16px;display:flex;position:sticky;top:0}.sidebar-header{margin-bottom:32px;padding-left:8px}.sidebar-title{background:linear-gradient(135deg, #fff 30%, var(--primary) 100%);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;font-size:1.25rem;font-weight:800}.sidebar-user{color:var(--text-muted);word-break:break-all;margin-top:4px;font-size:.85rem}.nav-menu{flex-direction:column;gap:6px;display:flex}.nav-link{color:var(--text-muted);transition:all var(--transition-fast);border-radius:8px;align-items:center;padding:10px 14px;font-size:.95rem;font-weight:500;text-decoration:none;display:flex}.nav-link svg{color:var(--text-muted);transition:color var(--transition-fast);margin-right:12px}.nav-link:hover{color:var(--text-main);background-color:#ffffff0a}.nav-link:hover svg{color:var(--text-main)}.nav-link.active{color:#fff;background-color:var(--primary);box-shadow:0 4px 14px #6366f166}.nav-link.active svg{color:#fff}.btn-logout{color:var(--text-muted);border:1px solid var(--border);cursor:pointer;font-family:var(--font-sans);transition:all var(--transition-fast);background-color:#0000;border-radius:8px;justify-content:center;align-items:center;gap:8px;margin-top:auto;padding:10px;font-size:.9rem;font-weight:600;display:flex}.btn-logout:hover{color:#fff;border-color:var(--color-danger);background-color:var(--color-danger-bg)}.main-content{background-color:var(--bg-app);flex:1;padding:40px;overflow-y:auto}.page-header{margin-bottom:32px}.page-title{letter-spacing:-.5px;margin-bottom:8px;font-size:1.75rem;font-weight:700}.page-subtitle{color:var(--text-muted);font-size:.95rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:36px;display:grid}.stat-card{background-color:var(--bg-surface);border:1px solid var(--border);box-shadow:var(--shadow);transition:all var(--transition-normal);border-radius:12px;padding:24px;position:relative;overflow:hidden}.stat-card:after{content:"";background:linear-gradient(90deg, var(--primary), var(--secondary));opacity:0;width:100%;height:4px;transition:opacity var(--transition-fast);position:absolute;top:0;left:0}.stat-card:hover{box-shadow:var(--shadow-hover);border-color:#ffffff26;transform:translateY(-4px)}.stat-card:hover:after{opacity:1}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:.85rem;font-weight:600}.stat-value{color:#fff;font-size:2.25rem;font-weight:800;line-height:1}.table-container{background-color:var(--bg-surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:12px;margin-top:16px;overflow:hidden}.custom-table{border-collapse:collapse;text-align:left;width:100%}.custom-table th{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border);background-color:#0003;padding:16px;font-size:.85rem;font-weight:700}.custom-table td{border-bottom:1px solid var(--border);color:var(--text-main);transition:background-color var(--transition-fast);padding:16px;font-size:.95rem}.custom-table tr:last-child td{border-bottom:none}.custom-table tbody tr:hover td{background-color:#ffffff05}.no-data{font-style:italic;text-align:center!important;color:var(--text-muted)!important;padding:32px!important}.btn{font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);border:none;border-radius:6px;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:.9rem;font-weight:600;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-success{background-color:var(--color-success-bg);color:var(--color-success);border:1px solid #10b9814d}.btn-success:hover:not(:disabled){background-color:var(--color-success);color:#fff;transform:translateY(-1px)}.btn-danger{background-color:var(--color-danger-bg);color:var(--color-danger);border:1px solid #ef44444d}.btn-danger:hover:not(:disabled){background-color:var(--color-danger);color:#fff;transform:translateY(-1px)}.action-buttons{gap:8px;display:flex}.badge{text-transform:uppercase;letter-spacing:.5px;border-radius:9999px;align-items:center;padding:4px 10px;font-size:.75rem;font-weight:700;display:inline-flex}.badge-pending{background-color:var(--color-warning-bg);color:var(--color-warning)}.badge-approved{background-color:var(--color-success-bg);color:var(--color-success)}.badge-rejected{background-color:var(--color-danger-bg);color:var(--color-danger)}.badge-info{background-color:var(--color-info-bg);color:var(--color-info)}.alert{border:1px solid #0000;border-radius:8px;align-items:center;gap:8px;margin-bottom:20px;padding:12px 16px;font-size:.95rem;animation:.3s ease-out slideDown;display:flex}.alert-success{background-color:var(--color-success-bg);color:var(--color-success);border-color:#10b98133}.alert-error{background-color:var(--color-danger-bg);color:var(--color-danger);border-color:#ef444433}.login-container{background:radial-gradient(circle at top right, #6366f11a, transparent 40%), radial-gradient(circle at bottom left, #0ea5e90d, transparent 40%), var(--bg-app);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background-color:var(--bg-surface);border:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;width:100%;max-width:420px;padding:40px;animation:.4s ease-out fadeIn;box-shadow:0 20px 40px -15px #0009}.login-header{text-align:center;margin-bottom:32px}.login-logo{background:linear-gradient(135deg, #fff 40%, var(--primary) 100%);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;margin-bottom:8px;font-size:1.75rem;font-weight:800}.login-subtitle{color:var(--text-muted);font-size:.95rem}.form-group{margin-bottom:20px}.form-label{color:var(--text-muted);margin-bottom:8px;font-size:.85rem;font-weight:600;display:block}.form-input{border:1px solid var(--border);color:#fff;width:100%;font-family:var(--font-sans);transition:all var(--transition-fast);background-color:#0003;border-radius:8px;padding:12px 16px;font-size:.95rem}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--border-focus);background-color:#0000004d;outline:none}.form-input::placeholder{color:var(--text-muted);opacity:.6}.login-btn{width:100%;margin-top:8px;padding:12px;font-size:.95rem}.custom-select{background-color:var(--bg-app);border:1px solid var(--border);color:var(--text-main);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);border-radius:6px;outline:none;padding:6px 12px;font-size:.85rem;font-weight:500}.custom-select:focus{border-color:var(--primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
