@import url(https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap);*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#2563eb;--primary-dark:#1d4ed8;--primary-light:#93c5fd;--primary-muted:#eff6ff;--accent:#f97316;--success:#16a34a;--success-muted:#f0fdf4;--danger:#dc2626;--danger-muted:#fef2f2;--warning:#d97706;--warning-muted:#fffbeb;--info:#0284c7;--text-primary:#111827;--text-secondary:#6b7280;--text-muted:#9ca3af;--border:#e5e7eb;--border-light:#f3f4f6;--bg:#f4f6f9;--bg-white:#fff;--bg-elevated:#fff;--bg-elevated-2:#fafafa;--scrollbar-thumb:#d1d5db;--scrollbar-thumb-hover:#9ca3af;--sidebar-width:256px;--header-height:60px;--radius:10px;--radius-lg:14px;--shadow-sm:0 1px 2px #0000000d;--shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;--shadow-md:0 4px 6px #00000012,0 2px 4px #0000000f;--shadow-lg:0 10px 15px #0000001a,0 4px 6px #0000000d}:root[data-theme=dark]{--primary:#60a5fa;--primary-dark:#3b82f6;--primary-light:#93c5fd;--primary-muted:#60a5fa24;--accent:#fb923c;--success:#22c55e;--success-muted:#22c55e24;--danger:#ef4444;--danger-muted:#ef444424;--warning:#f59e0b;--warning-muted:#f59e0b24;--info:#38bdf8;--text-primary:#e5e7eb;--text-secondary:#cbd5e1;--text-muted:#94a3b8;--border:#94a3b82e;--border-light:#94a3b81f;--bg:#0b1220;--bg-white:#0f172a;--bg-elevated:#111c33;--bg-elevated-2:#0b162b;--shadow-sm:0 1px 2px #00000059;--shadow:0 1px 3px #00000073,0 1px 2px #00000059;--shadow-md:0 4px 10px #00000073;--shadow-lg:0 18px 40px #0000008c;--scrollbar-thumb:#94a3b859;--scrollbar-thumb-hover:#94a3b88c}:root[data-theme=dark] .logo-img,:root[data-theme=dark] img.brand-logo-img{background:linear-gradient(160deg,#f8fafc,#e2e8f0);border:1px solid #fff3;box-shadow:inset 0 1px 0 #ffffff0f,0 2px 10px #00000059;box-sizing:border-box}:root[data-theme=dark] .logo-img{padding:4px}:root[data-theme=dark] .sidebar.closed .logo-img{padding:3px}:root[data-theme=dark] img.brand-logo-img{border-radius:12px;padding:6px}body{-webkit-font-smoothing:antialiased;background-color:#f4f6f9;background-color:var(--bg);color:#111827;color:var(--text-primary);font-family:Plus Jakarta Sans,sans-serif;font-size:14px;line-height:1.5}::-webkit-scrollbar{height:5px;width:5px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#d1d5db;background:var(--scrollbar-thumb);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#9ca3af;background:var(--scrollbar-thumb-hover)}.table-container{background:#fff;background:var(--bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:14px;box-shadow:0 10px 30px #0f172a0f;overflow-x:auto;overflow:auto}.table-container table{background:#0000;border-collapse:collapse;width:100%}.table-container thead th{background:#fafafa;background:var(--bg-elevated-2);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border);color:#6b7280;color:var(--text-secondary);font-size:11px;font-weight:700;letter-spacing:.06em;padding:12px 14px;position:-webkit-sticky;position:sticky;text-align:left;text-transform:uppercase;top:0;white-space:nowrap;z-index:2}.table-container tbody td{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light);color:#111827;color:var(--text-primary);font-size:13px;padding:11px 14px;vertical-align:middle;white-space:nowrap}.table-container tbody tr:nth-child(2n){background:#94a3b80a}.table-container tbody tr:hover{background:#94a3b80f}.table-container tbody tr:last-child td{border-bottom:none}.data-table thead th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border)}.data-table td,.data-table th{line-height:1.35}.data-table th:hover [role=separator]>div{background:#2563eb;background:var(--primary);opacity:.9}.data-table [role=separator]>div{background:#e5e7eb;background:var(--border);opacity:.7;transition:background .15s ease,opacity .15s ease}.data-table.table-wrap tbody td,.data-table.table-wrap thead th{white-space:normal}.table-container table.data-table-auto-cols{min-width:100%;width:-webkit-max-content;width:max-content}.data-table-toolbar{align-items:center;display:flex;gap:12px;justify-content:space-between}.data-table-toolbar-left{align-items:center;display:flex;flex:1 1;flex-wrap:wrap;gap:10px;min-width:0}.data-table-toolbar-right{align-items:center;display:flex;flex-shrink:0;gap:8px}.data-table-search{max-width:360px;min-width:220px;position:relative;width:clamp(220px,28vw,360px)}.data-table-search-icon{color:#9ca3af;left:10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.data-table-search-input{font-size:13px}@media (max-width:640px){.data-table-toolbar{align-items:stretch}.data-table-toolbar-right{justify-content:flex-end}.data-table-search{max-width:none;width:100%}}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:11px;font-weight:600;letter-spacing:.02em;padding:2px 9px}.badge-service{background:#dbeafe;color:#1d4ed8}.badge-error{background:#fee2e2;color:#b91c1c}.badge-selesai{background:#dcfce7;color:#15803d}.badge-banding{background:#fef9c3;color:#a16207}.badge-tidak-banding{background:#fee2e2;color:#b91c1c}.badge-clear{background:#dcfce7;color:#15803d}.badge-no-going{background:#fef9c3;color:#a16207}.badge-surabaya{background:#ede9fe;color:#6d28d9}.badge-jakarta{background:#dbeafe;color:#1d4ed8}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .25s ease-out}.spinner{animation:spin .7s linear infinite;border:2px solid #e5e7eb;border-top-color:#2563eb;border:2px solid var(--border);border-radius:50%;border-top-color:var(--primary);display:inline-block;height:18px;width:18px}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#00000073;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.modal-content{animation:fadeIn .2s ease-out;background:#fff;background:var(--bg-elevated);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 20px 60px #0003;max-height:90vh;max-width:700px;overflow-y:auto;width:100%}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:500;margin-bottom:5px}.form-control,.form-label{color:#111827;color:var(--text-primary)}.form-control{background:#fff;background:var(--bg-elevated);border:1.5px solid #e5e7eb;border:1.5px solid var(--border);border-radius:10px;border-radius:var(--radius);font-family:inherit;font-size:13.5px;outline:none;padding:9px 13px;transition:border-color .15s,box-shadow .15s;width:100%}.form-control.data-table-search-input{padding-left:36px}.form-control:focus{border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.form-control:disabled{background:#f4f6f9;background:var(--bg);color:#9ca3af;color:var(--text-muted);cursor:not-allowed}.btn,select.form-control{cursor:pointer}.btn{align-items:center;border:none;border-radius:10px;border-radius:var(--radius);display:inline-flex;font-family:inherit;font-size:13px;font-weight:600;gap:6px;padding:8px 16px;text-decoration:none;transition:all .15s;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.55}.btn-primary{background:#2563eb;background:var(--primary);box-shadow:0 1px 2px #2563eb4d;color:#fff}.btn-primary:hover:not(:disabled){background:#1d4ed8;background:var(--primary-dark);box-shadow:0 4px 10px #2563eb4d;transform:translateY(-1px)}.btn-success{background:#16a34a;background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#15803d;transform:translateY(-1px)}.btn-danger{background:#dc2626;background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px)}.btn-warning{background:#d97706;background:var(--warning);color:#fff}.btn-warning:hover:not(:disabled){background:#b45309}.btn-secondary{background:#fff;background:var(--bg-elevated);border:1.5px solid #e5e7eb;border:1.5px solid var(--border);color:#6b7280;color:var(--text-secondary)}.btn-secondary:hover:not(:disabled){background:#f4f6f9;background:var(--bg);border-color:#e5e7eb;border-color:var(--border);color:#111827;color:var(--text-primary)}.btn-sm{font-size:12px;padding:5px 11px}.btn-icon{border-radius:8px;padding:7px}.card{background:#fff;background:var(--bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);overflow:hidden}.card-header{align-items:center;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light);display:flex;gap:12px;justify-content:space-between;padding:16px 20px}.card-body,.stat-card{padding:20px}.stat-card{background:#fff;background:var(--bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius-lg);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);overflow:hidden;position:relative;transition:transform .15s,box-shadow .15s}.stat-card:hover{box-shadow:0 4px 6px #00000012,0 2px 4px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.pagination{gap:3px}.page-btn,.pagination{align-items:center;display:flex}.page-btn{background:#fff;background:var(--bg-elevated);border:1.5px solid #e5e7eb;border:1.5px solid var(--border);border-radius:7px;color:#6b7280;color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:13px;height:32px;justify-content:center;transition:all .15s;width:32px}.page-btn:hover{background:#eff6ff;background:var(--primary-muted);color:#2563eb;color:var(--primary)}.page-btn.active,.page-btn:hover{border-color:#2563eb;border-color:var(--primary)}.page-btn.active{background:#2563eb;background:var(--primary);color:#fff;font-weight:600}.page-btn:disabled{cursor:not-allowed;opacity:.35}.login-page{align-items:center;background:#d8e0ef;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:24px;position:relative}.login-shell{grid-gap:18px;align-items:stretch;display:grid;gap:18px;grid-template-columns:1.05fr .95fr;max-width:980px;position:relative;width:100%;z-index:1}.login-brand-panel{backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:24px;box-shadow:inset 0 0 0 1px #ffffff0d,0 28px 70px #00000059;overflow:hidden}.login-brand-inner{display:flex;flex-direction:column;height:100%;padding:34px 34px 26px}.login-brand-mark{background:#fff;border-radius:16px;box-shadow:0 10px 30px #00000059;display:grid;height:56px;place-items:center;width:56px}.login-brand-logo{height:36px;object-fit:contain;width:36px}.login-brand-copy{margin-top:16px}.login-brand-title{color:#fff;font-size:22px;font-weight:800;letter-spacing:-.4px;line-height:1.1}.login-brand-tagline{color:#ffffff8c;font-size:13px;line-height:1.45;margin-top:6px}.login-brand-divider{background:linear-gradient(90deg,#0000,#ffffff24,#0000);height:1px;margin:18px 0 16px}.login-brand-bullets{color:#fff9;display:flex;flex-direction:column;font-size:13px;gap:10px}.login-bullet{align-items:flex-start;display:flex;gap:10px;line-height:1.45}.login-bullet-dot{background:#60a5fad9;border-radius:999px;box-shadow:0 0 0 3px #2563eb2e;flex-shrink:0;height:8px;margin-top:6px;width:8px}.login-brand-foot{color:#ffffff59;font-size:12px;margin-top:auto;padding-top:18px}.login-bg{inset:0;pointer-events:none;position:absolute;z-index:0}.login-bg-orb{animation:orbFloat linear infinite;border-radius:50%;filter:blur(100px);position:absolute;will-change:transform}.orb-1{animation-duration:20s;background:radial-gradient(circle,#2563eb59 0,#0000 70%);height:600px;left:-150px;top:-200px;width:600px}.orb-2{animation-direction:reverse;animation-duration:25s;background:radial-gradient(circle,#7c3aed4d 0,#0000 70%);bottom:-150px;height:500px;right:-100px;width:500px}.orb-3{animation-delay:-8s;animation-duration:18s;background:radial-gradient(circle,#06b6d433 0,#0000 70%);height:350px;left:55%;top:40%;width:350px}@keyframes orbFloat{0%{transform:translate(0) scale(1)}25%{transform:translate(40px,-30px) scale(1.05)}50%{transform:translate(20px,40px) scale(.97)}75%{transform:translate(-30px,20px) scale(1.03)}to{transform:translate(0) scale(1)}}.login-grid{background-image:linear-gradient(hsla(0,0%,100%,.025) 1px,#0000 0),linear-gradient(90deg,hsla(0,0%,100%,.025) 1px,#0000 0);background-size:60px 60px}.login-grid,.login-particles{inset:0;position:absolute}.particle{animation:particleDrift linear infinite;background:#fff6;border-radius:50%;height:2px;position:absolute;width:2px}@keyframes particleDrift{0%{opacity:0;transform:translateY(0) translateX(0)}10%{opacity:1}90%{opacity:.6}to{opacity:0;transform:translateY(-120vh) translateX(30px)}}.login-card{animation:cardEntrance .6s cubic-bezier(.16,1,.3,1) both;justify-self:end;max-width:440px;position:relative;width:100%}@keyframes cardEntrance{0%{opacity:0;transform:translateY(32px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.login-glass{backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);background:#ffffff0f;border:1px solid #ffffff1f;border-radius:24px;box-shadow:inset 0 0 0 1px #ffffff0d,0 32px 64px #0006,0 0 80px #2563eb14;padding:40px 40px 36px}.login-logo-wrap{align-items:center;display:flex;gap:12px;margin-bottom:32px}.login-logo-bg{align-items:center;background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000004d;display:flex;flex-shrink:0;height:46px;justify-content:center;width:46px}.login-logo{height:32px;object-fit:contain;width:32px}.login-brand-name{color:#fff;font-size:18px;font-weight:700;letter-spacing:-.3px}.login-brand-sub{color:#ffffff59;font-size:10.5px;letter-spacing:.8px;text-transform:uppercase}.login-heading{margin-bottom:28px}.login-title{color:#fff;font-size:24px;font-weight:700;letter-spacing:-.4px;line-height:1.2;margin-bottom:6px}.login-subtitle{color:#ffffff73;font-size:13.5px;line-height:1.5}.login-form{gap:16px}.login-field,.login-form{display:flex;flex-direction:column}.login-field{gap:6px}.login-label{color:#fff9;font-size:12.5px;font-weight:500;letter-spacing:.02em}.login-input-wrap{position:relative}.login-input-icon{align-items:center;color:#ffffff4d;display:flex;left:14px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);transition:color .2s}.login-input{background:#ffffff12;border:1.5px solid #ffffff1a;border-radius:11px;caret-color:#60a5fa;color:#fff;font-family:inherit;font-size:14px;outline:none;padding:11px 14px 11px 42px;transition:all .2s;width:100%}.login-input::placeholder{color:#fff3}.login-input:focus{background:#ffffff1a;border-color:#60a5fa99;box-shadow:0 0 0 3px #2563eb33}.login-input-wrap:focus-within .login-input-icon,.login-input:focus+.login-input-icon{color:#60a5fa}.login-input-toggle{align-items:center;background:none;border:none;color:#ffffff4d;cursor:pointer;display:flex;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:color .15s}.login-input-toggle:hover{color:#ffffffb3}.login-input-password{padding-right:42px}.login-footer-note{color:#ffffff54;font-size:11.5px;line-height:1.5;margin-top:14px;text-align:center}.login-submit{align-items:center;background:linear-gradient(135deg,#2563eb,#1d4ed8);border:none;border-radius:11px;box-shadow:0 4px 20px #2563eb66;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:600;gap:8px;justify-content:center;margin-top:4px;overflow:hidden;padding:12px;position:relative;transition:all .2s;width:100%}.login-submit:before{background:linear-gradient(135deg,#ffffff26,#0000 60%);content:"";inset:0;opacity:0;position:absolute;transition:opacity .2s}.login-submit:hover:not(:disabled):before{opacity:1}.login-submit:hover:not(:disabled){box-shadow:0 8px 28px #2563eb80;transform:translateY(-1px)}.login-submit:active:not(:disabled){box-shadow:0 4px 16px #2563eb66;transform:translateY(0)}.login-submit:disabled{cursor:not-allowed;opacity:.6}.login-divider{align-items:center;display:flex;gap:12px;margin:4px 0}.login-divider-line{background:#ffffff14;flex:1 1;height:1px}.login-divider-text{color:#ffffff40;font-size:11.5px}.login-hint{background:#ffffff0a;border:1px solid #ffffff14;border-radius:10px;color:#ffffff59;font-size:12px;line-height:1.6;margin-top:20px;padding:12px 16px;text-align:center}.login-hint strong{color:#fff9;font-weight:600}.spinner-sm{animation:spin .7s linear infinite;border:2px solid #ffffff40;border-radius:50%;border-top-color:#fff;flex-shrink:0;height:16px;width:16px}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:480px){.login-glass{border-radius:20px;padding:28px 24px}.login-title{font-size:21px}}@media (max-width:920px){.login-shell{grid-template-columns:1fr;max-width:520px}.login-brand-panel{display:none}.login-card{justify-self:center;max-width:520px}}.login-shell.login-shell-utech{grid-gap:0;background:#fff;border-radius:16px;box-shadow:0 32px 80px #0f172a38;display:grid;gap:0;grid-template-columns:400px 1fr;max-width:1100px;overflow:hidden;position:relative;width:100%;z-index:1}.login-shell-utech .login-left{background:#fff;display:flex;padding:40px 40px 32px}.login-shell-utech .login-left-inner{display:flex;flex-direction:column;width:100%}.login-shell-utech .login-left-logo{align-items:center;color:#1e293b;display:flex;font-size:15px;font-weight:800;gap:8px;letter-spacing:-.2px}.login-shell-utech .login-left-logo img{height:34px;object-fit:contain;width:34px}.login-shell-utech .login-left-heading{margin-top:52px}.login-shell-utech .login-left-heading h1{color:#1e293b;font-size:30px;font-weight:800;letter-spacing:-.5px;line-height:1.2;margin:0}.login-shell-utech .login-left-heading p{color:#64748b;font-size:14.5px;margin:8px 0 0}.login-shell-utech .login-form.login-form-utech{gap:14px;margin-top:28px}.login-shell-utech .login-right{align-items:center;background:linear-gradient(160deg,#5b4fcf,#2196f3 55%,#00c6ff);display:flex;justify-content:center;min-height:520px;overflow:hidden;padding:0}.login-shell-utech .login-illus{display:block;height:100%;width:100%}.login-shell-utech .login-input.login-input-light{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:8px;caret-color:#3b82f6;color:#1e293b;font-size:14px;padding-left:14px}.login-shell-utech .login-input.login-input-light::placeholder{color:#94a3b8}.login-shell-utech .login-input.login-input-light:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.login-shell-utech .login-input-toggle.login-input-toggle-light{color:#94a3b8}.login-shell-utech .login-input-toggle.login-input-toggle-light:hover{color:#475569}.login-shell-utech .login-submit.login-submit-light{background:#1d7edb;border-radius:8px;box-shadow:0 8px 20px #1d7edb4d;font-size:15px;font-weight:700;letter-spacing:.01em;margin-top:8px;padding:12px}.login-shell-utech .login-submit.login-submit-light:hover:not(:disabled){background:#1a6fc4;box-shadow:0 12px 28px #1d7edb61;transform:translateY(-1px)}.login-shell-utech .login-forgot{background:none;border:none;color:#3b82f6;cursor:pointer;display:inline-block;font-family:inherit;font-size:12.5px;margin-top:4px;padding:0;text-align:left;text-decoration:none;transition:color .15s}.login-shell-utech .login-forgot:hover{color:#1d4ed8;text-decoration:underline}.login-shell-utech .login-left-foot{color:#94a3b8;font-size:12px;margin-top:auto;padding-top:24px}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute!important;white-space:nowrap;width:1px}.spinner-sm.spinner-sm-dark{border-color:#fffffff2 #0f172a2e #0f172a2e}@media (max-width:920px){.login-shell.login-shell-utech{border-radius:16px;grid-template-columns:1fr;max-width:480px}.login-shell-utech .login-right{display:none}.login-shell-utech .login-left{padding:36px 32px 28px}}.fp-shell .login-input{background:#f8fafc;border-color:#e2e8f0;caret-color:#3b82f6;color:#1e293b}.fp-shell .login-input::placeholder{color:#94a3b8}.fp-shell .login-input:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.fp-shell{animation:fpEntrance .5s cubic-bezier(.16,1,.3,1) both;background:#fff;border-radius:20px;box-shadow:0 32px 80px #0f172a33;display:flex;flex-direction:column;gap:0;max-width:460px;padding:40px 44px 36px;position:relative;width:100%;z-index:1}@keyframes fpEntrance{0%{opacity:0;transform:translateY(24px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.fp-logo{align-items:center;color:#1e293b;display:flex;font-size:15px;font-weight:800;gap:8px;letter-spacing:-.2px;margin-bottom:28px}.fp-logo img{height:32px;object-fit:contain;width:32px}.fp-icon-wrap{margin-bottom:20px}.fp-icon-circle,.fp-icon-wrap{display:flex;justify-content:center}.fp-icon-circle{align-items:center;background:#eff6ff;border:2px solid #bfdbfe;border-radius:50%;height:64px;width:64px}.fp-heading{margin-bottom:28px;text-align:center}.fp-heading h1{color:#1e293b;font-size:24px;font-weight:800;letter-spacing:-.4px;margin:0 0 8px}.fp-heading p{color:#64748b;font-size:13.5px;line-height:1.6;margin:0}.fp-form{gap:16px;margin-bottom:20px}.fp-field,.fp-form{display:flex;flex-direction:column}.fp-field{gap:6px}.fp-label{color:#374151;font-size:13px;font-weight:600}.fp-input-icon{align-items:center;color:#94a3b8;display:flex;left:13px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.fp-input{padding-left:38px!important}.fp-input--error{border-color:#ef4444!important;box-shadow:0 0 0 3px #ef44441f!important}.fp-input--ok{border-color:#22c55e!important;box-shadow:0 0 0 3px #22c55e1f!important}.fp-field-error{color:#ef4444;font-size:12px;margin-top:2px}.fp-strength{align-items:center;display:flex;gap:10px;margin-top:4px}.fp-strength-bars{display:flex;flex:1 1;gap:4px}.fp-strength-bar{border-radius:2px;flex:1 1;height:4px;transition:background .25s}.fp-strength-label{font-size:11.5px;font-weight:600;min-width:36px;text-align:right;transition:color .25s}.fp-submit{align-items:center;display:flex;justify-content:center;margin-top:4px!important;text-decoration:none}.fp-submit-link{margin-top:16px!important;text-decoration:none}.fp-token-box{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;margin:16px 0;padding:14px 16px}.fp-token-label{color:#94a3b8;display:block;font-size:11px;font-weight:600;letter-spacing:.06em;margin-bottom:8px;text-transform:uppercase}.fp-token-value{align-items:center;display:flex;gap:10px}.fp-token-value code{color:#1e293b;flex:1 1;font-family:Courier New,monospace;font-size:11.5px;line-height:1.5;word-break:break-all}.fp-copy-btn{align-items:center;background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;color:#3b82f6;cursor:pointer;display:flex;flex-shrink:0;padding:6px 8px;transition:all .15s}.fp-copy-btn:hover{background:#dbeafe}.fp-success{flex-direction:column;padding:8px 0;text-align:center}.fp-success,.fp-success-icon{align-items:center;display:flex}.fp-success-icon{background:#dcfce7;border:2px solid #86efac;border-radius:50%;color:#16a34a;height:56px;justify-content:center;margin-bottom:16px;width:56px}.fp-success-icon--info{background:#eff6ff;border-color:#bfdbfe;color:#3b82f6}.fp-success-icon--error{background:#fef2f2;border-color:#fca5a5;color:#ef4444}.fp-success h2{color:#1e293b;font-size:20px;font-weight:800;margin:0 0 8px}.fp-success p{color:#64748b;font-size:13.5px;line-height:1.6;margin:0}.fp-validating{flex-direction:column;font-size:14px;gap:14px;padding:24px 0}.fp-back,.fp-validating{align-items:center;color:#64748b;display:flex}.fp-back{font-size:13px;gap:6px;justify-content:center;margin-top:20px;text-decoration:none;transition:color .15s}.fp-back:hover{color:#3b82f6}@media (max-width:520px){.fp-shell{border-radius:16px;padding:32px 28px 28px}}.layout{background:var(--bg)}.layout,.sidebar{display:flex;min-height:100vh}.sidebar{background:var(--bg-white);border-right:1px solid var(--border);bottom:0;flex-direction:column;left:0;overflow:hidden;position:fixed;top:0;transition:width .25s ease;width:var(--sidebar-width);z-index:100}.sidebar.closed{width:64px}.sidebar-header{border-bottom:1px solid var(--border-light);flex-shrink:0;padding:14px}.logo{align-items:center;display:flex;gap:10px;min-height:46px}.logo-img{border-radius:10px;flex-shrink:0;height:44px;object-fit:contain;width:44px}.sidebar.closed .logo-img{border-radius:8px;height:28px;width:28px}.logo-text{display:flex;flex-direction:column;overflow:hidden}.logo-name{color:var(--text-primary);font-size:15px;font-weight:700;letter-spacing:-.2px;white-space:nowrap}.logo-sub{color:var(--text-muted);font-size:10px;letter-spacing:.6px;text-transform:uppercase;white-space:nowrap}.sidebar-nav{flex:1 1;overflow-x:hidden;overflow-y:auto;padding:10px 8px}.sidebar-nav::-webkit-scrollbar{width:0}.nav-section-label{color:var(--text-muted);font-size:10px;font-weight:600;letter-spacing:.08em;padding:10px 10px 4px;text-transform:uppercase;white-space:nowrap}.nav-item-wrapper{margin-bottom:1px}.nav-item{align-items:center;background:none;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;font-family:inherit;font-size:13px;font-weight:500;gap:9px;padding:8px 10px;text-align:left;text-decoration:none;transition:all .15s;width:100%}.nav-item:hover{background:var(--bg);color:var(--text-primary)}.nav-item.active{background:var(--primary-muted);font-weight:600}.nav-item.active,.nav-item.active .nav-icon{color:var(--primary)}.nav-group-header{justify-content:flex-start}.nav-icon{color:var(--text-muted);flex-shrink:0;font-size:15px;text-align:center;transition:color .15s;width:18px}.nav-item:hover .nav-icon{color:var(--text-secondary)}.nav-label{flex:1 1;white-space:nowrap}.nav-arrow{color:var(--text-muted);font-size:16px;line-height:1;transition:transform .2s}.nav-arrow.expanded{transform:rotate(90deg)}.nav-children{margin-top:1px;padding-left:10px}.nav-child-item{align-items:center;border-radius:7px;color:var(--text-secondary);display:flex;font-size:12.5px;font-weight:500;gap:8px;margin-bottom:1px;padding:7px 10px;text-decoration:none;transition:all .15s}.nav-child-item:hover{background:var(--bg);color:var(--text-primary)}.nav-child-item.active{background:var(--primary-muted);color:var(--primary);font-weight:600}.nav-child-icon{color:var(--text-muted);font-size:12px;text-align:center;width:16px}.nav-child-item.active .nav-child-icon,.nav-child-item:hover .nav-child-icon{color:inherit}.sidebar-footer{border-top:1px solid var(--border-light);flex-shrink:0;padding:10px 8px}.user-info{border-radius:8px;gap:9px;margin-bottom:2px;padding:8px 10px}.user-avatar,.user-info{align-items:center;display:flex}.user-avatar{background:var(--primary-muted);border:1.5px solid #bfdbfe;border-radius:50%;color:var(--primary);flex-shrink:0;font-size:13px;font-weight:700;height:32px;justify-content:center;width:32px}.user-details{display:flex;flex-direction:column;overflow:hidden}.user-name{color:var(--text-primary);font-size:12.5px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{color:var(--text-muted);font-size:11px;text-transform:capitalize}.logout-btn{align-items:center;background:none;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;font-family:inherit;font-size:13px;font-weight:500;gap:9px;padding:8px 10px;transition:all .15s;width:100%}.logout-btn:hover{background:var(--danger-muted);color:var(--danger)}.main-wrapper{display:flex;flex:1 1;flex-direction:column;margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left .25s ease}.sidebar.closed~.main-wrapper{margin-left:64px}.sidebar-flyout{background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;box-shadow:0 20px 50px #0f172a2e;overflow:hidden;position:fixed;z-index:500}.sidebar-flyout-header{align-items:center;background:var(--bg-elevated-2);border-bottom:1px solid var(--border-light);color:var(--text-primary);display:flex;font-size:12.5px;font-weight:700;gap:10px;justify-content:space-between;padding:10px 12px}.sidebar-flyout-close{background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;height:28px;width:28px}.sidebar-flyout-close:hover{border-color:var(--primary);color:var(--primary)}.sidebar-flyout-body{padding:8px}.sidebar-flyout-item{width:100%}.header{background:var(--bg-white);border-bottom:1px solid var(--border);height:var(--header-height);justify-content:space-between;padding:0 20px;position:-webkit-sticky;position:sticky;top:0;z-index:50}.header,.toggle-btn{align-items:center;display:flex}.toggle-btn{background:var(--bg-elevated);border:1.5px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;font-size:15px;height:34px;justify-content:center;transition:all .15s;width:34px}.toggle-btn:hover{background:var(--primary-muted);border-color:var(--primary);color:var(--primary)}.header-right{align-items:center;display:flex;gap:12px}.notif-btn{align-items:center;background:var(--bg-elevated);border:1.5px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:inline-flex;height:34px;justify-content:center;position:relative;transition:all .15s;width:34px}.notif-btn:hover{background:var(--primary-muted);border-color:var(--primary);color:var(--primary)}.notif-badge{align-items:center;background:var(--danger);border:2px solid var(--bg-elevated);border-radius:999px;color:#fff;display:inline-flex;font-size:11px;font-weight:700;height:18px;justify-content:center;line-height:1;min-width:18px;padding:0 5px;position:absolute;right:-6px;top:-6px}.notif-popover{background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;box-shadow:0 20px 60px #00000026;max-width:calc(100vw - 30px);overflow:hidden;position:absolute;right:0;top:calc(100% + 10px);width:360px;z-index:1000}.notif-popover-header{align-items:center;border-bottom:1px solid var(--border-light);display:flex;gap:10px;justify-content:space-between;padding:12px}.notif-link{background:#0000;border:none;color:var(--primary);cursor:pointer;font-size:12px;font-weight:600}.notif-link:disabled{cursor:not-allowed;opacity:.5}.notif-list{max-height:420px;overflow:auto}.notif-item{background:#0000;border:none;border-bottom:1px solid var(--border-light);cursor:pointer;padding:12px;text-align:left;width:100%}.notif-item:hover{background:var(--bg-elevated-2)}.notif-item.unread{background:#94a3b80f}.notif-dot{background:var(--primary);border-radius:999px;flex-shrink:0;height:9px;margin-top:5px;width:9px}.header-user{gap:9px}.header-avatar,.header-user{align-items:center;display:flex}.header-avatar{background:var(--primary);border-radius:50%;color:#fff;font-size:13px;font-weight:700;height:32px;justify-content:center;width:32px}.header-name{color:var(--text-primary);font-size:13px;font-weight:600}.header-role{color:var(--text-muted);font-size:11px;text-transform:capitalize}.main-content{flex:1 1;padding:22px 24px}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.main-wrapper{margin-left:0!important}}
/*# sourceMappingURL=main.a51702e1.css.map*/