@import"https://fonts.googleapis.com/css2?family=Syne:wght@500;600;700;800&family=Figtree:wght@300;400;500;600&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--c-sidebar: #0f1923;--c-sidebar-hover: rgba(255,255,255,.05);--c-accent: #1fd99a;--c-accent-dark: #17b882;--c-accent-dim: rgba(31,217,154,.1);--c-bg: #131e2b;--c-surface: #1a2a3a;--c-text: #cdd8e3;--c-text-muted: #7a95a8;--c-text-light: #4a6880;--c-border: rgba(255,255,255,.1);--c-border-light: rgba(255,255,255,.05);--c-danger: #e04646;--c-danger-dim: rgba(224,70,70,.08);--c-warning: #e8a020;--c-warning-dim: rgba(232,160,32,.1);--font-display: "Syne", sans-serif;--font-body: "Figtree", sans-serif;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--r-sm: 6px;--r-md: 10px;--r-lg: 16px;--r-xl: 20px;--r-full: 9999px;--shadow-xs: 0 1px 2px rgba(0,0,0,.25);--shadow-sm: 0 2px 8px rgba(0,0,0,.35);--shadow-md: 0 4px 20px rgba(0,0,0,.45);--shadow-lg: 0 12px 40px rgba(0,0,0,.6);--t-fast: .12s ease;--t-base: .2s ease}html,body{height:100%}body{font-family:var(--font-body);font-size:15px;color:var(--c-text);background:var(--c-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{height:100%}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:var(--font-body)}button{cursor:pointer;border:none;background:none}.app-layout{display:grid;grid-template-columns:228px 1fr;height:100vh;overflow:hidden}.layout-full{grid-template-columns:1fr}.sidebar{background:var(--c-sidebar);display:flex;flex-direction:column;height:100vh;overflow:hidden;position:relative}.sidebar:after{content:"";position:absolute;top:0;right:0;width:1px;height:100%;background:linear-gradient(to bottom,transparent,rgba(255,255,255,.06) 30%,rgba(255,255,255,.06) 70%,transparent)}.sidebar-logo{padding:26px 20px 22px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.05)}.logo-icon{width:34px;height:34px;background:var(--c-accent);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.logo-wordmark{display:flex;flex-direction:column}.logo-name{font-family:var(--font-display);font-size:17px;font-weight:800;color:#fff;letter-spacing:-.4px;line-height:1}.logo-tagline{font-size:10px;color:#ffffff40;text-transform:uppercase;letter-spacing:1.2px;margin-top:3px}.sidebar-nav{flex:1;overflow-y:auto;padding:10px 0;scrollbar-width:none}.sidebar-nav::-webkit-scrollbar{display:none}.nav-section{padding:12px 20px 4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.4px;color:#ffffff2e}.nav-item{display:flex;align-items:center;gap:9px;padding:9px 20px;color:#ffffff7a;font-size:15px;font-weight:500;transition:color var(--t-fast),background var(--t-fast);position:relative;cursor:pointer}.nav-item:hover{color:#ffffffd1;background:var(--c-sidebar-hover)}.nav-item.router-link-active{color:var(--c-accent);background:var(--c-accent-dim)}.nav-item.router-link-active:before{content:"";position:absolute;left:0;top:5px;bottom:5px;width:3px;background:var(--c-accent);border-radius:0 3px 3px 0}.nav-icon{width:16px;height:16px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}.sidebar-footer{padding:12px 16px;border-top:1px solid rgba(255,255,255,.05)}.user-card{display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--r-md)}.user-avatar{width:32px;height:32px;border-radius:var(--r-sm);background:var(--c-accent-dim);border:1px solid rgba(31,217,154,.2);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:13px;font-weight:700;color:var(--c-accent);flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-size:12.5px;font-weight:600;color:#fffc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-label{font-size:10.5px;color:#ffffff40;margin-top:1px}.logout-btn{display:flex;align-items:center;justify-content:center;padding:5px;border-radius:var(--r-sm);color:#fff3;transition:color var(--t-fast),background var(--t-fast)}.logout-btn:hover{color:var(--c-danger);background:var(--c-danger-dim)}.main-content{overflow-y:auto;background:var(--c-bg)}.page{padding:var(--sp-8)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--sp-6);gap:var(--sp-4)}.page-title{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--c-text);letter-spacing:-.3px}.page-subtitle{font-size:14px;color:var(--c-text-muted);margin-top:3px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--r-sm);font-size:13px;font-weight:600;line-height:1;white-space:nowrap;transition:background var(--t-fast),color var(--t-fast),box-shadow var(--t-fast);cursor:pointer;border:none}.btn-primary{background:var(--c-accent);color:#0d1f18}.btn-primary:hover{background:var(--c-accent-dark)}.btn-danger{background:var(--c-danger-dim);color:var(--c-danger)}.btn-danger:hover{background:var(--c-danger);color:#fff}.btn-ghost{background:transparent;color:var(--c-text-muted);border:1px solid var(--c-border)}.btn-ghost:hover{background:var(--c-border-light);color:var(--c-text)}.btn-sm{padding:5px 10px;font-size:12px}.btn:disabled{opacity:.55;cursor:not-allowed}.card{background:var(--c-surface);border-radius:var(--r-lg);border:1px solid var(--c-border);box-shadow:var(--shadow-xs);overflow:hidden}.table-wrapper{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table thead th{padding:10px 16px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--c-text-muted);background:var(--c-border-light);border-bottom:1px solid var(--c-border);white-space:nowrap}.table tbody td{padding:11px 16px;font-size:14.5px;color:var(--c-text);border-bottom:1px solid var(--c-border-light);vertical-align:middle}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover td{background:var(--c-border-light)}.table-actions{display:flex;gap:6px;justify-content:flex-end}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}.form-group:last-of-type{margin-bottom:0}.form-label{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--c-text-muted)}.input,.select{width:100%;padding:9px 11px;border:1.5px solid var(--c-border);border-radius:var(--r-sm);font-size:13.5px;color:var(--c-text);background:var(--c-surface);outline:none;transition:border-color var(--t-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none}.input:focus,.select:focus{border-color:var(--c-accent)}.input::placeholder{color:var(--c-text-light)}.badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:var(--r-full);font-size:11px;font-weight:600;letter-spacing:.2px}.badge-active{background:#1fd99a1f;color:#1fd99a}.badge-inactive{background:#8c9eb01f;color:#8fa8bc}.badge-pending{background:#e8a02024;color:#e8a020}.badge-final{background:#8c9eb01f;color:#7a95a8}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a121c8c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.modal{background:var(--c-surface);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);width:100%;max-width:500px;max-height:92vh;overflow-y:auto;animation:modal-in .16s ease}@keyframes modal-in{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{padding:20px 22px 16px;border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--c-text)}.modal-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);color:var(--c-text-muted);font-size:20px;line-height:1;transition:background var(--t-fast),color var(--t-fast)}.modal-close:hover{background:var(--c-border-light);color:var(--c-text)}.modal-body{padding:20px 22px}.modal-footer{padding:14px 22px;border-top:1px solid var(--c-border);display:flex;justify-content:flex-end;gap:8px}.loading-state{display:flex;align-items:center;justify-content:center;gap:10px;padding:56px 24px;color:var(--c-text-muted);font-size:13px}.spinner{width:18px;height:18px;border:2px solid var(--c-border);border-top-color:var(--c-accent);border-radius:50%;animation:spin .65s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{padding:56px 24px;text-align:center;color:var(--c-text-muted)}.empty-state-title{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--c-text);margin-bottom:4px}.alert{padding:11px 14px;border-radius:var(--r-sm);font-size:13px;margin-bottom:16px;display:flex;align-items:flex-start;gap:8px}.alert-error{background:var(--c-danger-dim);color:var(--c-danger);border:1px solid rgba(224,70,70,.18)}.login-page{height:100vh;background:var(--c-sidebar);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(31,217,154,.07) 0%,transparent 65%);top:-180px;left:-120px;pointer-events:none}.login-page:after{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(31,217,154,.05) 0%,transparent 65%);bottom:-100px;right:-80px;pointer-events:none}.login-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:var(--r-xl);padding:40px 38px;width:100%;max-width:380px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:relative;z-index:1}.login-logo{display:flex;align-items:center;gap:11px;margin-bottom:32px}.login-logo-icon{width:40px;height:40px;background:var(--c-accent);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center}.login-logo-name{font-family:var(--font-display);font-size:22px;font-weight:800;color:#fff;letter-spacing:-.4px}.login-logo-tagline{font-size:10px;color:#ffffff40;text-transform:uppercase;letter-spacing:1.2px;margin-top:2px}.login-title{font-family:var(--font-display);font-size:19px;font-weight:700;color:#fff;margin-bottom:6px}.login-subtitle{font-size:13px;color:#ffffff59;margin-bottom:28px}.login-label{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#ffffff59;margin-bottom:5px;display:block}.login-input{width:100%;padding:10px 13px;background:#ffffff0f;border:1.5px solid rgba(255,255,255,.1);border-radius:var(--r-sm);color:#fff;font-size:14px;outline:none;transition:border-color var(--t-fast)}.login-input:focus{border-color:var(--c-accent)}.login-input::placeholder{color:#fff3}.login-form-group{margin-bottom:16px}.login-btn{width:100%;padding:11px;background:var(--c-accent);color:#0d1f18;border:none;border-radius:var(--r-sm);font-size:14px;font-weight:700;margin-top:24px;cursor:pointer;transition:background var(--t-fast);font-family:var(--font-display);letter-spacing:.3px}.login-btn:hover{background:var(--c-accent-dark)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{background:#e046461f;border:1px solid rgba(224,70,70,.2);color:#ff8080;padding:10px 13px;border-radius:var(--r-sm);font-size:13px;margin-top:14px}
