@tailwind base;@tailwind components;@tailwind utilities;:root{font-feature-settings:"cv02", "cv03", "cv04", "cv11";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--sidebar-bg:#0b0d14;--sidebar-border:#ffffff0f;--sidebar-width:240px;--sidebar-text:#8b8fa8;--sidebar-text-active:#fff;--accent:#9f5df5;--accent-light:#b980ff;--accent-dim:#9f5df526;--accent-border:#9f5df566;--bg:#f4f5f9;--surface:#fff;--border:#e5e7f0;--text:#4b5066;--text-h:#111827;--text-muted:#9ca3af;--status-pending-bg:#f59e0b1f;--status-pending-text:#d97706;--status-pending-border:#f59e0b4d;--status-approved-bg:#10b9811f;--status-approved-text:#059669;--status-approved-border:#10b9814d;--status-declined-bg:#ef44441f;--status-declined-text:#dc2626;--status-declined-border:#ef44444d;--status-blocked-bg:#6b72801f;--status-blocked-text:#6b7280;--status-blocked-border:#6b72804d;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 16px #00000014, 0 2px 4px #0000000a;--shadow-lg:0 10px 40px #0000001f, 0 4px 8px #0000000f;--shadow-accent:0 8px 30px #9f5df540;font-family:Inter,system-ui,-apple-system,sans-serif}*,:before,:after{box-sizing:border-box}html,body{background:var(--bg);height:100%;color:var(--text);margin:0;padding:0}#app{width:100%;min-height:100vh;display:flex}h1,h2,h3,h4,h5,h6{color:var(--text-h);margin:0;font-weight:600;line-height:1.3}p{margin:0}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-light)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#d1d5db}.dashboard-layout{width:100%;min-height:100vh;display:flex}.dashboard-sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);z-index:40;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.dashboard-main{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.dashboard-topbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:30;height:64px;box-shadow:var(--shadow-sm);align-items:center;gap:16px;padding:0 28px;display:flex;position:sticky;top:0}.dashboard-content{flex:1;width:100%;max-width:1400px;padding:28px}.card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:12px}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:20px 24px;display:flex}.card-body{padding:24px}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:14px;font-weight:500;line-height:1;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 2px 8px #9f5df54d}.btn-primary:hover:not(:disabled){background:var(--accent-light);box-shadow:var(--shadow-accent);transform:translateY(-1px)}.btn-secondary{background:var(--surface);color:var(--text-h);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg);border-color:#d1d5db}.btn-danger{color:#dc2626;background:#ef44441a;border:1px solid #ef444440}.btn-danger:hover:not(:disabled){background:#ef44442e}.btn-success{color:#059669;background:#10b9811a;border:1px solid #10b98140}.btn-success:hover:not(:disabled){background:#10b9812e}.btn-sm{padding:5px 10px;font-size:13px}.btn-icon{border-radius:8px;padding:7px}.form-group{flex-direction:column;gap:6px;display:flex}label{color:var(--text-h);font-size:13px;font-weight:500}.form-control{background:var(--bg);border:1px solid var(--border);height:40px;color:var(--text-h);border-radius:8px;outline:none;width:100%;padding:0 12px;font-family:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}.form-control:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);background:var(--surface)}.form-control::placeholder{color:var(--text-muted)}textarea.form-control{resize:vertical;height:auto;min-height:80px;padding:10px 12px}select.form-control{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:16px;padding-right:36px}.form-error{color:#dc2626;font-size:12px}.badge{border:1px solid #0000;border-radius:20px;align-items:center;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.badge-pending{background:var(--status-pending-bg);color:var(--status-pending-text);border-color:var(--status-pending-border)}.badge-approved{background:var(--status-approved-bg);color:var(--status-approved-text);border-color:var(--status-approved-border)}.badge-declined{background:var(--status-declined-bg);color:var(--status-declined-text);border-color:var(--status-declined-border)}.badge-blocked{background:var(--status-blocked-bg);color:var(--status-blocked-text);border-color:var(--status-blocked-border)}.data-table{border-collapse:collapse;width:100%;font-size:14px}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:var(--bg);border-bottom:1px solid var(--border);white-space:nowrap;padding:11px 16px;font-size:11px;font-weight:600}.data-table td{border-bottom:1px solid var(--border);color:var(--text-h);vertical-align:middle;padding:13px 16px}.data-table tbody tr{transition:background .1s}.data-table tbody tr:hover{background:#9f5df508}.data-table tbody tr:last-child td{border-bottom:none}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,#f0f0f5 25%,#e8e8f0 50%,#f0f0f5 75%) 0 0/800px 100%;border-radius:4px;animation:1.5s infinite shimmer}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-box{background:var(--surface);box-shadow:var(--shadow-lg);border-radius:16px;width:100%;max-width:560px;max-height:90vh;animation:.2s modal-in;overflow-y:auto}.modal-box-lg{max-width:800px}@keyframes modal-in{0%{opacity:0;transform:scale(.97)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-body{padding:24px}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:10px;padding:16px 24px;display:flex}.fade-enter-active,.fade-leave-active{transition:opacity .2s}.fade-enter-from,.fade-leave-to{opacity:0}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.divider{background:var(--border);height:1px;margin:20px 0}.alert-error{color:#dc2626;background:#ef44441a;border:1px solid #ef444440;border-radius:8px;padding:12px 16px;font-size:14px}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.65s linear infinite spin;display:inline-block}.spinner-dark{border-color:#9f5df533;border-top-color:var(--accent)}@keyframes spin{to{transform:rotate(360deg)}}.sidebar-logo[data-v-7cae95d9]{border-bottom:1px solid var(--sidebar-border);align-items:center;gap:12px;padding:24px 20px;display:flex}.logo-icon[data-v-7cae95d9]{background:var(--accent);color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;box-shadow:0 4px 14px #9f5df566}.logo-title[data-v-7cae95d9]{color:#fff;font-size:16px;font-weight:700;line-height:1.2}.logo-sub[data-v-7cae95d9]{color:var(--sidebar-text);margin-top:1px;font-size:11px;line-height:1}.sidebar-nav[data-v-7cae95d9]{flex-direction:column;flex:1;gap:2px;padding:20px 12px;display:flex}.nav-section-label[data-v-7cae95d9]{text-transform:uppercase;letter-spacing:.08em;color:#fff3;margin-bottom:8px;padding:0 8px;font-size:10px;font-weight:600}.nav-item[data-v-7cae95d9]{color:var(--sidebar-text);border-radius:8px;align-items:center;gap:10px;padding:9px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-item[data-v-7cae95d9]:hover{color:#fff;background:#ffffff0f}.nav-item.active[data-v-7cae95d9]{background:var(--accent-dim);color:var(--accent-light);border:1px solid var(--accent-border)}.nav-icon[data-v-7cae95d9]{flex-shrink:0;line-height:0}.nav-label[data-v-7cae95d9]{line-height:1}.sidebar-user[data-v-7cae95d9]{border-top:1px solid var(--sidebar-border);align-items:center;gap:10px;margin-top:auto;padding:16px;display:flex}.user-avatar[data-v-7cae95d9]{background:var(--accent);color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:12px;font-weight:700;display:flex}.user-info[data-v-7cae95d9]{flex:1;min-width:0}.user-name[data-v-7cae95d9]{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.user-role[data-v-7cae95d9]{color:var(--sidebar-text);text-transform:capitalize;font-size:11px}.logout-btn[data-v-7cae95d9]{color:var(--sidebar-text);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;padding:6px;transition:color .15s,background .15s;display:flex}.logout-btn[data-v-7cae95d9]:hover{color:#ff6b6b;background:#ff6b6b1a}.topbar-left[data-v-7cae95d9]{flex:1}.topbar-title[data-v-7cae95d9]{color:var(--text-h);font-size:20px;font-weight:700}.topbar-right[data-v-7cae95d9]{align-items:center;gap:12px;display:flex}.topbar-user[data-v-7cae95d9]{align-items:center;gap:8px;display:flex}.topbar-avatar[data-v-7cae95d9]{background:var(--accent-dim);width:32px;height:32px;color:var(--accent);border-radius:8px;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.topbar-name[data-v-7cae95d9]{color:var(--text-h);font-size:13px;font-weight:500}.login-page[data-v-5c7cbfa7]{background:#07080f;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:20px;display:flex;position:relative;overflow:hidden}.login-bg[data-v-5c7cbfa7]{pointer-events:none;position:absolute;inset:0}.bg-orb[data-v-5c7cbfa7]{filter:blur(80px);opacity:.25;border-radius:50%;animation:8s ease-in-out infinite alternate drift-5c7cbfa7;position:absolute}.orb-1[data-v-5c7cbfa7]{background:var(--accent);width:480px;height:480px;top:-120px;left:-120px}.orb-2[data-v-5c7cbfa7]{background:#3b82f6;width:360px;height:360px;animation-delay:-4s;bottom:-80px;right:-80px}@keyframes drift-5c7cbfa7{0%{transform:translate(0)scale(1)}to{transform:translate(30px,20px)scale(1.05)}}.login-card[data-v-5c7cbfa7]{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0a;border:1px solid #ffffff1a;border-radius:20px;width:100%;max-width:420px;padding:36px;position:relative;box-shadow:0 24px 64px #0006}.login-logo[data-v-5c7cbfa7]{align-items:center;gap:12px;margin-bottom:24px;display:flex}.login-logo-icon[data-v-5c7cbfa7]{background:var(--accent);color:#fff;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex;box-shadow:0 8px 24px #9f5df566}.login-brand[data-v-5c7cbfa7]{color:#fff;margin:0;font-size:18px;font-weight:700;line-height:1.2}.login-brand-sub[data-v-5c7cbfa7]{color:#fff6;margin-top:2px;font-size:12px}.login-divider[data-v-5c7cbfa7]{background:#ffffff14;height:1px;margin-bottom:24px}.login-heading[data-v-5c7cbfa7]{color:#fff;margin-bottom:6px;font-size:22px;font-weight:700}.login-sub[data-v-5c7cbfa7]{color:#ffffff73;margin-bottom:24px;font-size:14px}.login-card[data-v-5c7cbfa7] .form-control{color:#fff;background:#ffffff0f;border-color:#ffffff1a}.login-card[data-v-5c7cbfa7] .form-control::placeholder{color:#ffffff40}.login-card[data-v-5c7cbfa7] .form-control:focus{border-color:var(--accent);background:#ffffff14;box-shadow:0 0 0 3px #9f5df533}.login-card[data-v-5c7cbfa7] label{color:#ffffffa6}.login-btn[data-v-5c7cbfa7]{justify-content:center;height:44px;margin-top:4px;font-size:15px}
