:root{--color-primary: #4F46E5;--color-primary-dark: #4338CA;--color-primary-light: #6366F1;--color-accent: #4F46E5;--color-accent-dark: #4338CA;--color-accent-light: #6366F1;--color-accent-soft: rgba(79,70,229,.1);--color-success: #15A66B;--color-danger: #E23D4B;--color-warning: #D98A0B;--color-info: #0E8FBF;--color-bg: #F6F7FB;--color-surface: #FFFFFF;--color-surface-2: #F1F3F9;--color-border: #E6E8F0;--color-border-soft: #F1F3F9;--sidebar-bg: #08111F;--sidebar-bg-2: #0D1B2E;--sidebar-panel: #13233A;--sidebar-panel-soft: #102038;--sidebar-text: #D8E4F4;--sidebar-text-soft: #A8B8D0;--sidebar-text-muted: #7488A8;--sidebar-hover: rgba(79, 70, 229, .14);--sidebar-active: #4F46E5;--sidebar-active-2: #4338CA;--sidebar-accent: #818CF8;--sidebar-accent-soft: rgba(79, 70, 229, .16);--sidebar-warm: #A78BFA;--sidebar-border: rgba(174, 207, 236, .12);--color-text: #0B1220;--color-text-soft: #4B5268;--color-text-muted: #69718A;--sidebar-width: 260px;--header-height: 64px;--shadow-sm: 0 1px 2px rgba(16,24,40,.05);--shadow-md: 0 4px 16px -4px rgba(16,24,40,.1), 0 2px 6px -2px rgba(16,24,40,.06);--shadow-lg: 0 12px 32px -8px rgba(16,24,40,.18);--shadow-card: 0 1px 3px rgba(16,24,40,.06), 0 1px 2px rgba(16,24,40,.04);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--font-main: "Inter", system-ui, -apple-system, sans-serif}[data-theme=dark],.dark{--color-bg: #0A0E1A;--color-surface: #131A2B;--color-surface-2: #1B2438;--color-border: #283149;--color-border-soft: #1B2438;--color-text: #EEF2FB;--color-text-soft: #B0BCDA;--color-text-muted: #93A0BD;--color-accent: #6366F1;--color-accent-dark: #818CF8;--color-accent-soft: rgba(99,102,241,.16);--sidebar-bg: #050B14;--sidebar-bg-2: #0A1626;--sidebar-panel: #102139;--sidebar-panel-soft: #0C1B30;--sidebar-text: #D8E4F4;--sidebar-text-soft: #A7B6CE;--sidebar-text-muted: #7186A6;--sidebar-hover: rgba(99, 102, 241, .16);--sidebar-active: #4F46E5;--sidebar-active-2: #4338CA;--sidebar-accent: #A5B4FC;--sidebar-accent-soft: rgba(99, 102, 241, .18);--sidebar-warm: #A78BFA;--sidebar-border: rgba(174, 207, 236, .11);--shadow-card: 0 4px 12px rgba(0,0,0,.35)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;background-color:var(--color-bg)}body{font-family:var(--font-main);font-size:14px;line-height:1.5;color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"cv02","cv03","cv04","cv11";transition:background-color .3s ease,color .3s ease}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;border:1px solid transparent;white-space:nowrap}.btn-primary{background:var(--color-accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-accent-dark)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-bg)}.btn-outline{background:var(--color-surface);color:var(--color-accent);border:1px solid var(--color-accent)}.btn-outline:hover:not(:disabled){background:#eef2ff}.btn-danger{background:var(--color-danger);color:#fff}.btn-ghost{background:transparent;color:var(--color-text-soft)}.btn-ghost:hover{background:var(--color-border-soft);color:var(--color-text)}.btn:hover:not(:disabled){filter:brightness(1.06)}.btn:active:not(:disabled){transform:scale(.98)}.card{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-card);border:1px solid var(--color-border);overflow:hidden}.card-header{padding:16px 20px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.card-body{padding:20px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:600;font-size:12px;color:var(--color-text-soft)}.input,.select,.textarea,select{width:100%;padding:10px 12px;border-radius:var(--radius-sm);border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:14px;transition:all .2s ease;outline:none}.input:focus,.select:focus,select:focus,.textarea:focus,.input:focus-visible,.select:focus-visible,select:focus-visible,.textarea:focus-visible{border-color:var(--color-accent);outline:0;box-shadow:0 0 0 3px #4f46e533}.input:disabled,.select:disabled,select:disabled,.textarea:disabled{background:var(--color-surface-2);color:var(--color-text-muted);border-color:var(--color-border);cursor:not-allowed;opacity:.7}[data-theme=dark] .input:disabled,[data-theme=dark] .select:disabled,[data-theme=dark] select:disabled,[data-theme=dark] .textarea:disabled{background:var(--color-surface-2);color:var(--color-text-muted);border-color:var(--color-border)}.search-field{position:relative;display:flex;align-items:center}.search-field .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);pointer-events:none;z-index:1}.search-field input,.search-field select{width:100%;padding:8px 12px 8px 36px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);font-size:13px;transition:all .2s}.search-field select{cursor:pointer}.pill{display:inline-flex;padding:2px 10px;border-radius:999px;font-size:11px;font-weight:700;text-transform:uppercase}.pill-success{background:#15a66b1f;color:#0d7a50}.pill-danger{background:#e23d4b1f;color:#b91c2c}.pill-info{background:#4f46e51f;color:#4f46e5}.pill-muted{background:#69718a1a;color:var(--color-text-muted)}.pill-warning{background:#d98a0b1f;color:#92600a}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.app-busy-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:5000;display:grid;place-items:center;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.auth-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:#0009;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);padding:24px}.auth-modal-card{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--color-border);overflow-y:auto;width:max-content;min-width:500px;max-width:95vw;max-height:calc(100vh - 48px);display:flex;flex-direction:column}.auth-modal-header{padding:16px 24px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.auth-modal-header h3{margin:0;font-size:16px;font-weight:700;color:var(--color-text)}.auth-modal-body{padding:24px;overflow-y:auto;flex:1}.auth-modal-footer{padding:16px 24px;border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:flex-end;gap:12px;background:var(--color-bg)}.auth-confirm-card{max-width:440px;min-width:unset}.auth-confirm-body{padding:24px;text-align:center}.auth-confirm-actions{padding:16px 24px;display:flex;justify-content:center;gap:12px;border-top:1px solid var(--color-border);background:var(--color-bg)}.auth-modal-close{background:transparent;border:none;font-size:16px;line-height:1;color:var(--color-text-muted);cursor:pointer;width:24px;height:24px;display:grid;place-items:center;border-radius:var(--radius-sm);transition:all .2s}.auth-modal-close:hover{background:var(--color-danger);color:#fff}.inst-badge{display:inline-flex;align-items:center;padding:4px 10px;background:var(--color-accent-soft);color:var(--color-accent);border-radius:999px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.glass-panel{background:var(--color-card-bg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--color-border)}[data-theme=dark] .glass-panel{background:#1e293bb3}.management-container{display:flex;flex-direction:column;gap:20px;min-height:100%}.management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.management-title h1{font-size:24px;font-weight:700;color:var(--color-text);margin:0 0 4px}.management-title p{font-size:14px;color:var(--color-text-soft);margin:0}.management-toolbar{display:flex;justify-content:space-between;align-items:center;background:var(--color-surface);padding:12px 16px;border-radius:var(--radius-md);border:1px solid var(--color-border);gap:16px}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:12px}.table-container{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);overflow:hidden;box-shadow:var(--shadow-sm)}.table-scroll{overflow-x:auto;max-width:100%}.management-table{width:100%;border-collapse:collapse;text-align:left;font-size:13px}.management-table thead th{background:var(--color-bg);padding:12px 16px;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;font-size:11px;letter-spacing:.5px;border-bottom:1px solid var(--color-border);white-space:nowrap}.management-table tbody td{padding:12px 16px;border-bottom:1px solid var(--color-border-soft);color:var(--color-text);vertical-align:middle}.management-table tbody tr:hover{background:var(--color-border-soft)}.management-table tbody tr:last-child td{border-bottom:none}.action-cell{display:flex;gap:8px;align-items:center}.btn-delete:hover{background:var(--color-danger-soft)!important;color:var(--color-danger)!important;border-color:var(--color-danger)!important}.management-table .pill{padding:2px 8px;font-weight:700}.management-pagination{display:flex;justify-content:space-between;align-items:center;background:var(--color-surface);padding:12px 20px;border-radius:var(--radius-md);border:1px solid var(--color-border);margin-top:12px}.pagination-controls{display:flex;gap:4px}.btn-page{min-width:32px;height:32px;display:grid;place-items:center;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}.btn-page.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.btn-page:disabled{opacity:.5;cursor:not-allowed}.alert-lane-container{width:100%;display:flex;flex-direction:column;gap:8px;margin-bottom:20px;animation:alert-slide-down .3s ease-out}.alert-lane{width:100%;padding:14px 24px;display:flex;align-items:center;gap:16px;position:relative;overflow:hidden;border-radius:var(--radius-md);box-shadow:0 4px 12px #0000000d;border-left:6px solid transparent}.alert-lane--success{background:#ecfdf5;border-color:#10b981;color:#065f46}.alert-lane--error{background:#fef2f2;border-color:#ef4444;color:#991b1b}.alert-lane--warning{background:#fffbeb;border-color:#f59e0b;color:#92400e}.alert-lane--info{background:#eff6ff;border-color:#3b82f6;color:#1e40af}.alert-lane-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.alert-lane-content{flex:1;font-size:14px;font-weight:600;line-height:1.5}.alert-lane-close{flex-shrink:0;background:transparent;border:none;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;opacity:.6;transition:opacity .2s;color:inherit}.alert-lane-close:hover{opacity:1;background:#0000000d}@keyframes alert-slide-down{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.admin-layout{display:flex;height:100vh;overflow:hidden;background:var(--color-bg)}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);height:100vh;display:flex;flex-direction:column;background:linear-gradient(180deg,#4f46e514,#08111f00 34%),linear-gradient(180deg,var(--sidebar-bg-2) 0%,var(--sidebar-bg) 100%);overflow:hidden;flex-shrink:0;border-right:1px solid var(--sidebar-border)}.sidebar-header{display:flex;align-items:center;gap:10px;height:var(--header-height);padding:0 16px;border-bottom:1px solid var(--sidebar-border);flex-shrink:0}.sidebar-logo-icon{width:32px;height:32px;border-radius:8px;overflow:hidden;background:linear-gradient(135deg,#312e81,#4f46e5);box-shadow:inset 0 0 0 1px #ffffff14;flex-shrink:0}.sidebar-logo-img{display:block;width:100%;height:100%;object-fit:cover}.sidebar-title{font-size:14px;font-weight:700;color:#fff;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-search-wrap{padding:8px 10px 4px;flex-shrink:0}.sidebar-search-inner{position:relative}.sidebar-search-icon{position:absolute;left:9px;top:50%;transform:translateY(-50%);color:var(--sidebar-text-muted);pointer-events:none}.sidebar-search{width:100%;height:30px;padding:0 10px 0 30px;background:#ffffff0d;border:1px solid var(--sidebar-border);border-radius:8px;color:#fff;font-size:12px;outline:none;transition:border-color .2s,background .2s}.sidebar-search::placeholder{color:#d8e4f461}.sidebar-search:focus{background:#ffffff14;border-color:#4f46e5b8;box-shadow:0 0 0 2px #4f46e52e}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:4px 8px 16px;overscroll-behavior:contain}.sidebar-nav::-webkit-scrollbar{width:3px}.sidebar-nav::-webkit-scrollbar-thumb{background:#a8b8d038;border-radius:4px}.nav-group{margin-bottom:1px}.nav-group-toggle{width:100%;display:flex;align-items:center;gap:8px;padding:0 10px;height:36px;background:none;border:none;border-radius:6px;cursor:pointer;transition:background .1s;text-align:left}.nav-group-toggle:hover{background:var(--sidebar-hover)}.nav-section-open>.nav-group-toggle{background:var(--sidebar-panel)}.nav-group:first-child .nav-group-toggle.active{background:linear-gradient(90deg,var(--sidebar-active) 0%,var(--sidebar-active-2) 100%)}.nav-group:not(:first-child) .nav-group-toggle.active:not(.nav-link-direct){background:none}.nav-group-toggle.nav-link-direct.active{background:linear-gradient(90deg,var(--sidebar-active) 0%,var(--sidebar-active-2) 100%)}.nav-group-icon{color:var(--sidebar-text-muted);flex-shrink:0}.nav-group-toggle:hover .nav-group-icon,.nav-group-toggle.active .nav-group-icon{color:var(--sidebar-accent)}.nav-section-open>.nav-group-toggle .nav-group-icon{color:var(--sidebar-accent)}.nav-group-title{flex:1;font-size:13px;font-weight:500;color:var(--sidebar-text-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-group-toggle:hover .nav-group-title{color:var(--sidebar-text)}.nav-group-toggle.active .nav-group-title{color:var(--sidebar-text);font-weight:600}.nav-section-open>.nav-group-toggle .nav-group-title{color:var(--sidebar-text);font-weight:600}.nav-group-arrow{color:var(--sidebar-text-muted);transition:transform .18s;flex-shrink:0}.nav-group-arrow.expanded{transform:rotate(0)}.nav-group-toggle .nav-group-arrow:not(.expanded){transform:rotate(-90deg)}.nav-section-open>.nav-group-toggle .nav-group-arrow{color:var(--sidebar-accent)}.nav-section-open>div:not(.nav-group-toggle){margin:2px 0 4px 8px;padding-left:10px;border-left:1px solid rgba(129,140,248,.32)}.nav-group-label{padding:6px 8px 4px;margin:6px 0 2px;font-size:9.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#c7d2fe;background:#4f46e51f;border-left:2px solid var(--sidebar-warm);border-radius:0 4px 4px 0;-webkit-user-select:none;user-select:none;pointer-events:none}.nav-group-label--first{margin-top:2px}.nav-submenu{display:flex;flex-direction:column;gap:1px;padding:2px 0 4px}.nav-item{display:block;width:100%;padding:0 10px;height:32px;line-height:32px;border:none;border-radius:5px;background:none;color:var(--sidebar-text-soft);font-size:13px;font-weight:400;text-align:left;cursor:pointer;transition:background .1s,color .1s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-item:hover{background:var(--sidebar-hover);color:var(--sidebar-text)}.nav-item.active{background:linear-gradient(90deg,var(--sidebar-active) 0%,var(--sidebar-active-2) 100%);color:#fff;font-weight:600;box-shadow:inset 3px 0 0 var(--sidebar-warm)}.sidebar-user{display:flex;align-items:center;gap:9px;padding:10px 12px;border-top:1px solid var(--sidebar-border);background:#050b149e;flex-shrink:0}.sidebar-user-avatar{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--sidebar-active),var(--sidebar-active-2));color:#fff;font-size:12px;font-weight:700;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:12px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:10px;color:var(--sidebar-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-transform:uppercase;letter-spacing:.05em}.sidebar-logout-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;background:none;cursor:pointer;color:var(--sidebar-text-muted);transition:background .15s,color .15s;flex-shrink:0}.sidebar-logout-btn:hover{background:#e74c3c2e;color:#ff6b6b}.main-content{flex:1;display:flex;flex-direction:column;min-width:0;height:100vh;overflow:hidden}.main-header{display:flex;align-items:center;justify-content:space-between;gap:12px;height:var(--header-height);padding:0 24px;background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:0 1px 0 var(--color-border);flex-shrink:0}.header-institution{display:flex;align-items:center;gap:10px;min-width:0}.inst-badge{display:inline-flex;align-items:center;padding:3px 8px;background:#4f46e51a;color:#4f46e5;border-radius:6px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;flex-shrink:0}.header-inst-name{font-size:13px;font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:420px}.btn-switch{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#fff;color:var(--color-text-soft);font-size:12px;font-weight:600;cursor:pointer;transition:border-color .15s,color .15s,background .15s;white-space:nowrap;flex-shrink:0}.btn-switch:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-info-bg)}.page-content{flex:1;padding:24px;overflow-y:auto;overflow-x:auto;overscroll-behavior:contain;min-height:0}.management-container{display:flex;flex-direction:column;gap:20px}.management-header{display:flex;justify-content:space-between;align-items:flex-start}.management-title h1{font-size:20px;font-weight:700;color:var(--color-text);margin-bottom:4px}.management-title p{font-size:14px;color:var(--color-text-muted)}.management-toolbar{display:flex;justify-content:space-between;align-items:center;gap:20px;background:var(--color-surface);padding:16px 20px;border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);flex-wrap:wrap}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:16px}.page-size-selector{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--color-text-soft)}.page-size-selector select{padding:6px 10px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text)}.status-tabs{display:flex;background:var(--color-bg);padding:4px;border-radius:var(--radius-sm);border:1px solid var(--color-border)}.status-tab{padding:6px 16px;border:none;background:transparent;color:var(--color-text-muted);font-size:12px;font-weight:600;text-transform:capitalize;cursor:pointer;border-radius:var(--radius-sm);transition:all .2s}.status-tab.active{background:var(--color-surface);color:var(--color-accent);box-shadow:var(--shadow-sm)}.btn-add{display:flex;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;color:#fff;background:var(--color-primary);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.btn-add:hover:not(:disabled){background:var(--color-primary-dark)}[data-theme=dark] .btn-add{background:var(--color-accent)}[data-theme=dark] .btn-add:hover:not(:disabled){background:var(--color-accent-dark)}.btn-add:disabled{opacity:.5;cursor:not-allowed}.btn-refresh,.btn-search{display:flex;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.btn-refresh:hover:not(:disabled),.btn-search:hover:not(:disabled){background:var(--color-border-soft)}.btn-refresh:disabled,.btn-search:disabled{opacity:.5;cursor:not-allowed}.table-container{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-card);overflow:hidden}.table-scroll{overflow-x:auto}.management-table{width:100%;border-collapse:collapse;text-align:left}.management-table th{background:var(--color-border-soft);padding:14px 20px;font-size:11px;font-weight:700;color:var(--color-text-soft);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--color-border)}.management-table td{padding:14px 20px;font-size:13px;border-bottom:1px solid var(--color-border-soft);color:var(--color-text)}.management-table tr:last-child td{border-bottom:none}.management-table tr:hover td{background:var(--color-border-soft)}.action-cell{display:flex;gap:8px}.actions-cell{display:flex;flex-wrap:wrap;gap:4px}.btn-icon{padding:4px 8px;font-size:11px;font-weight:600;border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);cursor:pointer;transition:all .2s}.btn-icon:hover{background:var(--color-border-soft);color:var(--color-accent);border-color:var(--color-accent)}.btn-icon.btn-danger{color:var(--color-danger)}.btn-icon.btn-danger:hover{background:var(--color-danger);color:#fff}.btn-icon-text{padding:6px 12px;font-size:11px;text-transform:none;font-weight:600;border-radius:var(--radius-sm);display:flex;align-items:center;gap:6px;cursor:pointer;transition:all .2s;background:transparent}.btn-edit{color:var(--color-accent);border:1px solid var(--color-border);background:var(--color-surface)}.btn-edit:hover{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}[data-theme=dark] .btn-edit{background:#3498db1a;border:1px solid rgba(52,152,219,.3)}[data-theme=dark] .btn-edit:hover{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.btn-delete{color:var(--color-danger);border:1px solid var(--color-border);background:var(--color-surface)}.btn-delete:hover{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}[data-theme=dark] .btn-delete{background:#e74c3c1a;border:1px solid rgba(231,76,60,.3)}[data-theme=dark] .btn-delete:hover{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.management-pagination{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.pagination-info{font-size:13px;color:var(--color-text-muted)}.pagination-controls{display:flex;gap:6px}.btn-page{width:36px;height:36px;display:grid;place-items:center;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-soft);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.btn-page:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent)}.btn-page.active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.btn-page:disabled{opacity:.3;cursor:not-allowed}.no-options{display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--color-text-muted);font-weight:500}.pill-muted{background:#95a5a626;color:#7f8c8d}.pill-success{background:#2ecc7126;color:#27ae60}.pill-danger{background:#e74c3c26;color:#c0392b}.pill-info{background:#3498db26;color:#2980b9}.mgmt-select-wrap{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--color-text-soft);font-weight:600}.mgmt-select-wrap select{padding:6px 10px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);min-width:180px}.login-split{display:flex;min-height:100vh;height:100vh;overflow:hidden}.login-brand{width:50%;flex-shrink:0;background:#4f46e5;display:flex;flex-direction:column;padding:36px 48px;position:relative;overflow:hidden}.login-blob{position:absolute;border-radius:50%;background:#ffffff1f;pointer-events:none}.login-blob--tl{width:280px;height:280px;top:-80px;right:30px}.login-blob--br{width:320px;height:320px;bottom:-100px;left:-60px}.login-brand__logo{display:flex;align-items:center;gap:12px;position:relative;z-index:1;flex-shrink:0}.login-brand__logo-icon{width:44px;height:44px;border-radius:10px;background:none;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.login-brand__logo-img{width:44px;height:44px;object-fit:contain}.login-brand__logo-name{display:flex;flex-direction:column;gap:1px}.login-brand__logo-fullname{font-size:11px;font-weight:600;color:#ffffffa6;letter-spacing:.04em;text-transform:uppercase;line-height:1.2}.login-brand__logo-abbr{font-size:20px;font-weight:800;color:#fff;letter-spacing:.02em;line-height:1}.login-brand__copy{flex:1;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:1;padding:40px 0 32px}.login-brand__title{font-size:28px;font-weight:800;color:#fff;margin-bottom:12px;line-height:1.3;letter-spacing:-.01em}.login-brand__subtitle{font-size:14px;color:#ffffffbf;line-height:1.65;max-width:100%}.login-brand__features{list-style:none;margin:24px 0 0;padding:0;display:flex;flex-direction:column;gap:16px}.login-brand__features li{display:flex;align-items:center;gap:12px;font-size:17px;color:#ffffffeb;font-weight:500;line-height:1.4}.login-brand__feat-dot{color:#ffffff8c;font-size:12px;flex-shrink:0}.login-brand__footer-link{color:#ffffffb3;text-decoration:underline;text-underline-offset:2px;transition:color .15s}.login-brand__footer-link:hover{color:#fff}.login-brand__footer{font-size:12px;color:#fff6;position:relative;z-index:1;flex-shrink:0}.login-form-panel{flex:1;background:#f8faff;display:flex;align-items:center;justify-content:center;padding:48px 60px;overflow-y:auto}.login-form-wrap{width:100%;max-width:420px}.login-logo-wrap{margin-bottom:24px;display:flex;justify-content:center}.login-logo-icon{width:130px;height:130px;border-radius:24px;background:none;display:flex;align-items:center;justify-content:center;overflow:hidden}.login-logo-img{width:130px;height:130px;object-fit:contain;display:block}.login-heading{font-size:30px;font-weight:800;color:#0f172a;margin-bottom:8px;letter-spacing:-.025em;text-align:center}.login-sub{font-size:15px;color:#64748b;margin-bottom:32px;text-align:center;line-height:1.5}.login-error{display:flex;align-items:center;gap:8px;padding:12px 14px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:13px;font-weight:500;margin-bottom:20px}.login-form{display:flex;flex-direction:column;gap:20px}.login-field{display:flex;flex-direction:column;gap:7px}.login-label-row{display:flex;align-items:center;justify-content:space-between}.login-label{font-size:13.5px;font-weight:600;color:#1e293b}.login-forgot{font-size:13px;font-weight:500;color:#4f46e5;background:none;border:none;cursor:pointer;padding:0}.login-forgot:hover{text-decoration:underline}.login-input-wrap{position:relative;display:flex;align-items:center}.login-input-icon{position:absolute;left:13px;color:#9ca3af;pointer-events:none}.login-input{width:100%;height:48px;padding:0 48px 0 42px;border:1.5px solid #e2e8f0;border-radius:10px;background:#fff;color:#0f172a;font-size:14.5px;font-family:inherit;transition:border-color .15s,box-shadow .15s;outline:none;box-shadow:0 1px 2px #0000000a}.login-input::placeholder{color:#a0aec0;font-size:13.5px}.login-input:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51f}.login-eye{position:absolute;right:12px;background:none;border:none;cursor:pointer;color:#9ca3af;display:flex;padding:4px}.login-eye:hover{color:#6b7280}.login-btn{width:100%;height:50px;background:#4f46e5;color:#fff;font-size:15.5px;font-weight:700;border:none;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .15s,transform .1s;font-family:inherit;letter-spacing:.01em;margin-top:4px}.login-btn:hover:not(:disabled){background:#4338ca}.login-btn:active:not(:disabled){transform:scale(.99)}.login-btn:disabled{opacity:.65;cursor:not-allowed}.login-copyright{text-align:center;font-size:12px;color:#94a3b8;margin-top:28px}.login-copyright__link{color:#64748b;text-decoration:none;font-weight:500}.login-copyright__link:hover{color:#4f46e5;text-decoration:underline}.login-demo{text-align:center;font-size:12px;color:#9ca3af;margin-top:20px}.login-demo code{background:#f3f4f6;padding:1px 5px;border-radius:4px;font-family:monospace;color:#374151}@media (max-width: 768px){.login-split{flex-direction:column}.login-brand{width:100%;min-height:220px;flex:none}.login-brand__copy{justify-content:flex-end;padding-bottom:8px}.login-brand__title{font-size:20px}.login-form-panel{padding:32px 24px}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg);padding:20px}[data-theme=dark] .auth-page,.dark .auth-page{background:#07090f}.auth-card{width:100%;max-width:480px;padding:40px;background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-lg)}.theme-btn{background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-soft);width:36px;height:36px;border-radius:50%;display:grid;place-items:center;cursor:pointer;transition:all .2s}.theme-btn:hover{color:var(--color-accent);transform:rotate(15deg)}.auth-theme-toggle{display:flex;justify-content:flex-end;margin-bottom:16px}.auth-header{text-align:center;margin-bottom:28px}.auth-header h1{font-size:22px;font-weight:700;color:var(--color-text);margin-bottom:6px}.auth-header p{font-size:14px;color:var(--color-text-muted)}.auth-logo{width:64px;height:64px;background:#4f46e5;border-radius:14px;overflow:hidden;margin:0 auto 16px;display:flex;align-items:center;justify-content:center}.auth-logo img{display:block;width:52px;height:52px;object-fit:contain}.auth-alert{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:13px;margin-bottom:16px}.auth-form .form-group{margin-bottom:16px}.auth-form label{display:block;font-size:13px;font-weight:600;color:var(--color-text-soft);margin-bottom:6px}.auth-footer{text-align:center;font-size:12px;color:var(--color-text-muted);margin-top:20px}.auth-input-wrapper{position:relative}.auth-input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);pointer-events:none}.auth-input{width:100%;height:48px;padding:0 16px 0 44px;border:2px solid #edf2f7;border-radius:var(--radius-sm);background:#f8fafc;color:var(--color-text);font-size:15px;transition:all .2s}[data-theme=dark] .auth-input{background:var(--color-bg);border-color:var(--color-border)}.auth-input:focus{outline:none;border-color:var(--color-accent);background:#fff;box-shadow:0 0 0 4px #4f46e51f}.btn-auth{width:100%;height:50px;margin-top:12px;font-size:15px;font-weight:700}.custom-select{position:relative;width:100%}.select-trigger{width:100%;height:48px;padding:0 16px;display:flex;align-items:center;justify-content:space-between;background:#f8fafc;border:2px solid #edf2f7;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text)}.select-trigger--locked{cursor:default;background:#eef2f7;color:var(--color-text-soft)}[data-theme=dark] .select-trigger{background:var(--color-bg);border-color:var(--color-border)}[data-theme=dark] .select-trigger--locked{background:var(--color-border-soft)}.select-options{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border-radius:var(--radius-sm);box-shadow:0 10px 15px -3px #0000001a;border:1px solid #edf2f7;z-index:100;max-height:250px;overflow-y:auto}[data-theme=dark] .select-options{background:var(--color-surface);border-color:var(--color-border)}.option-search{padding:12px;position:sticky;top:0;background:#fff;border-bottom:1px solid #edf2f7}[data-theme=dark] .option-search{background:var(--color-surface);border-color:var(--color-border)}.option-search input{width:100%;height:36px;padding:0 12px;border:1px solid #edf2f7;border-radius:4px;font-size:13px}.select-option{padding:12px 16px;cursor:pointer;font-size:14px;transition:all .2s}.select-option:hover{background:#f7fafc;color:var(--color-accent)}[data-theme=dark] .select-option:hover{background:var(--color-border-soft)}.select-option.selected{background:#ebf8ff;color:var(--color-accent);font-weight:700}[data-theme=dark] .select-option.selected{background:#3498db1a}.inst-option-content{display:flex;align-items:center;gap:12px}.inst-code-tag{background:var(--color-accent);color:#fff;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;flex-shrink:0;box-shadow:0 2px 4px #3498db33}.select-option.selected .inst-code-tag{background:var(--color-primary)}.inst-name-text{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.content-area{padding:24px}.header-title{font-size:15px;font-weight:700;color:var(--color-text)}.header-subtitle{font-size:12px;color:var(--color-text-muted)}.environment-pill{display:inline-flex;align-items:center;height:26px;padding:0 10px;border-radius:999px;border:1px solid var(--color-border);background:var(--color-border-soft);color:var(--color-text-soft);font-size:11px;font-weight:700}.dashboard-page{display:flex;flex-direction:column;gap:20px}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.metric-card{display:grid;gap:8px;padding:18px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-card)}.metric-card svg{color:var(--color-accent)}.metric-card span{color:var(--color-text-muted);font-size:12px;font-weight:600}.metric-card strong{color:var(--color-text);font-size:26px;line-height:1}.dashboard-table code,.management-title code{color:var(--color-primary-dark);background:var(--color-border-soft);padding:2px 6px;border-radius:4px}.resource-search{min-width:320px}.error-banner{display:flex;align-items:center;gap:8px;padding:12px 14px;border:1px solid rgba(231,76,60,.25);border-radius:var(--radius-md);background:#e74c3c14;color:var(--color-danger);font-weight:600}.pagination-row{display:flex;align-items:center;justify-content:space-between;color:var(--color-text-soft);font-size:13px}.pagination-actions{display:flex;align-items:center;gap:12px}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;justify-content:flex-end;background:#0f172a59}.crud-drawer{width:min(560px,100vw);height:100%;display:flex;flex-direction:column;background:var(--color-surface);box-shadow:var(--shadow-lg)}.drawer-header,.drawer-footer{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 20px;border-bottom:1px solid var(--color-border)}.drawer-footer{border-top:1px solid var(--color-border);border-bottom:none}.drawer-header h2{font-size:18px;color:var(--color-text)}.drawer-header p{margin-top:3px;color:var(--color-text-muted);font-size:12px}.drawer-body{flex:1;overflow:auto;padding:20px}.actions-cell .btn-icon{display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:30px}@media (max-width: 900px){.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.management-toolbar,.toolbar-left,.toolbar-right{align-items:stretch;width:100%}.resource-search{min-width:100%}}@media (max-width: 640px){.metric-grid{grid-template-columns:1fr}.content-area{padding:16px}}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-soft);cursor:pointer;transition:all .2s ease}.theme-toggle:hover{color:var(--color-accent);background:var(--color-border-soft);border-color:var(--color-accent)}[data-theme=dark] .theme-toggle{color:#fbbf24}
