:root{--primary-color: #7abf00;--bg-color: #0a0a0a;--bg-secondary: #111111;--bg-tertiary: #1a1a1a;--border-color: #1a1a1a;--text-main: #e0e0e0;--text-secondary: #a0a0a0;--sidebar-width: 260px;--hover-color: rgba(122, 191, 0, .08)}[data-theme=light]{--primary-color: #349700;--bg-color: #fafafa;--bg-secondary: #ffffff;--bg-tertiary: #f0f0f0;--border-color: #e0e0e0;--text-main: #333333;--text-secondary: #666666;--hover-color: rgba(52, 151, 0, .1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif;background:var(--bg-color);color:var(--text-main);line-height:1.5}#app{width:100%;min-height:100vh}.btn{padding:10px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s;border:1px solid var(--border-color);display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--bg-tertiary);color:var(--text-main)}.btn:hover{background:var(--bg-secondary);border-color:var(--primary-color)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#42a5f5,#2196f3);color:#fff;box-shadow:0 4px 12px #42a5f54d}.btn-primary:hover{background:linear-gradient(135deg,#64b5f6,#42a5f5);transform:translateY(-2px);box-shadow:0 6px 20px #42a5f566}.btn-danger{background:linear-gradient(135deg,#ef5350,#f44336);color:#fff}.btn-danger:hover{background:linear-gradient(135deg,#e57373,#ef5350);transform:translateY(-2px);box-shadow:0 6px 20px #f4433666}.input,.form-input{width:100%;padding:12px 16px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;font-size:14px;color:var(--text-main);outline:none;transition:all .3s}.input:focus,.form-input:focus{border-color:var(--primary-color);background:var(--bg-tertiary)}.form-group{margin-bottom:20px}.form-label{display:block;font-size:14px;font-weight:500;color:var(--text-main);margin-bottom:8px}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-container{background:var(--bg-secondary);border-radius:12px;width:90%;max-width:500px;border:1px solid var(--border-color);box-shadow:0 20px 60px #00000080;animation:modalSlideIn .3s cubic-bezier(.16,1,.3,1)}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.modal-header h3{font-size:18px;font-weight:600;color:var(--text-main)}.modal-close{background:transparent;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;line-height:1}.modal-close:hover{color:var(--text-main)}.modal-body{padding:24px}.modal-footer{padding:20px 24px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:12px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.upload-area{border:2px dashed var(--border-color);border-radius:12px;padding:40px;text-align:center;cursor:pointer;transition:all .3s}.upload-area:hover{border-color:var(--primary-color);background:var(--hover-color)}.upload-placeholder{color:var(--text-secondary);display:flex;flex-direction:column;align-items:center;gap:12px}.upload-placeholder svg{width:48px;height:48px;color:var(--text-secondary)}.avatar-preview-large img{max-width:100%;max-height:300px;border-radius:8px}.table-container{width:100%;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;overflow-x:auto;overflow-y:hidden;position:relative}.table{width:100%;border-collapse:collapse;white-space:nowrap}.table th{text-align:left;padding:16px 24px;color:var(--text-secondary);font-weight:500;font-size:13px;border-bottom:1px solid var(--border-color)}.table td{padding:16px 24px;border-bottom:1px solid var(--border-color);font-size:14px;color:var(--text-main)}.table tbody tr{transition:background-color .2s}.table tbody tr:hover{background-color:var(--hover-color)}.action-buttons{display:flex;gap:12px;align-items:center}.btn-action{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.btn-action svg{width:18px;height:18px;stroke-width:2}.btn-action:hover{transform:translateY(-2px);border-color:var(--primary-color);color:var(--primary-color);background:var(--bg-secondary);box-shadow:0 4px 12px #42a5f526}.btn-action.btn-edit:hover{border-color:var(--primary-color);color:var(--primary-color);box-shadow:0 4px 12px #42a5f533}.btn-action.btn-delete{box-shadow:0 0 15px #ef535040;border-color:#ef535033}.btn-action.btn-delete:hover{border-color:#ef5350;color:#ef5350;box-shadow:0 0 22px #ef535080}.btn-action.btn-forbidden:hover{border-color:#ffa726;color:#ffa726;box-shadow:0 4px 12px #ffa72633}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-color)}::-webkit-scrollbar-thumb{background:#333;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#444}.badge{padding:4px 10px;border-radius:4px;font-size:12px;font-weight:500}.badge-success{background:#4caf5026;color:#66bb6a}.badge-warning{background:#ffa72626;color:#ffa726}.badge-danger{background:#ef535026;color:#ef5350}.badge-info{background:#42a5f526;color:#42a5f5}.toast-container[data-v-2114475a]{position:fixed;top:40px;left:50%;transform:translate(-50%);z-index:20000}.toast-content[data-v-2114475a]{display:flex;align-items:center;width:auto;min-width:320px;max-width:450px;min-height:80px;height:auto;border-radius:16px;border:1px solid #7abf00;background:#1c1c1c;box-shadow:0 12px 40px #0006,0 0 20px #7abf001a;padding:12px 20px;gap:16px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=light] .toast-content[data-v-2114475a]{background:#fff;box-shadow:0 12px 40px #0000001a}.toast-logo[data-v-2114475a]{flex-shrink:0}.logo-img[data-v-2114475a]{width:70px;height:50px;object-fit:contain}.toast-text[data-v-2114475a]{display:flex;flex-direction:column;gap:4px}.toast-title[data-v-2114475a]{color:#fab301;font-family:inherit;font-size:17px;font-weight:600}.toast-message[data-v-2114475a]{color:var(--text-main);font-family:inherit;font-size:14px;font-weight:400;line-height:1.4}.toast-enter-active[data-v-2114475a],.toast-leave-active[data-v-2114475a]{transition:all .4s cubic-bezier(.25,.1,.25,1)}.toast-enter-from[data-v-2114475a],.toast-leave-to[data-v-2114475a]{opacity:0;transform:translate(-50%) translateY(-30px) scale(.9)}.admin-layout[data-v-2414e152]{display:flex;min-height:100vh;background:var(--bg-color);color:var(--text-main);transition:background .3s,color .3s}.sidebar[data-v-2414e152]{width:260px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100;transition:all .4s cubic-bezier(.25,.1,.25,1);overflow:hidden}.sidebar-collapsed .sidebar[data-v-2414e152]{width:72px}.logo-wrapper[data-v-2414e152]{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.full-logo[data-v-2414e152],.fold-logo[data-v-2414e152]{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);object-fit:contain;transition:all .4s cubic-bezier(.25,.1,.25,1)}.full-logo[data-v-2414e152]{height:45px;width:auto;opacity:1}.fold-logo[data-v-2414e152]{height:39px;width:auto;opacity:0;transform:translate(-50%,-50%) scale(.6)}.sidebar-collapsed .full-logo[data-v-2414e152]{opacity:0;transform:translate(-50%,-50%) scale(.8);pointer-events:none}.sidebar-collapsed .fold-logo[data-v-2414e152]{opacity:1;transform:translate(-50%,-50%) scale(1)}.nav-item span[data-v-2414e152],.sidebar-footer p[data-v-2414e152]{white-space:nowrap;opacity:1;transition:opacity .3s ease,transform .3s ease;font-size:13px}.sidebar-collapsed .nav-item span[data-v-2414e152],.sidebar-collapsed .sidebar-footer p[data-v-2414e152]{display:none}.nav-item[data-v-2414e152]{display:flex;align-items:center;gap:12px;padding:24px;color:var(--text-secondary);text-decoration:none;font-size:15px;font-weight:500;transition:all .3s;position:relative;min-width:260px}.nav-item[data-v-2414e152]:hover,.nav-item.active[data-v-2414e152]{color:var(--primary-color);background:var(--hover-color)}.nav-item.active[data-v-2414e152]:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--primary-color)}.sidebar-collapsed .nav-item[data-v-2414e152]{padding:24px 0;justify-content:center;gap:0;min-width:72px;width:72px}.has-submenu[data-v-2414e152]{cursor:pointer}.arrow-icon[data-v-2414e152]{width:16px!important;height:16px!important;margin-left:auto;transition:transform .3s}.is-open .arrow-icon[data-v-2414e152]{transform:rotate(180deg)}.submenu[data-v-2414e152]{max-height:0;overflow:hidden;transition:max-height .3s ease-out;background:var(--bg-tertiary)}.is-open .submenu[data-v-2414e152]{max-height:560px;overflow:visible}.submenu-item[data-v-2414e152]{display:flex;align-items:center;padding:24px 24px 24px 58px;color:var(--text-secondary);text-decoration:none;font-size:14px;transition:all .3s}.submenu-item[data-v-2414e152]:hover,.submenu-item.active[data-v-2414e152]{color:var(--primary-color);background:var(--hover-color)}.sidebar-collapsed .submenu[data-v-2414e152],.sidebar-collapsed .arrow-icon[data-v-2414e152]{display:none}.nav-item svg[data-v-2414e152]{width:22px;height:22px;flex-shrink:0;transition:all .4s cubic-bezier(.25,.1,.25,1)}.sidebar-collapsed .nav-item svg[data-v-2414e152]{margin:0;transform:scale(1.15)}.sidebar-collapsed .main-content[data-v-2414e152]{margin-left:72px}.sidebar-header[data-v-2414e152]{height:100px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border-color);width:100%;transition:all .4s cubic-bezier(.25,.1,.25,1)}.sidebar-collapsed .sidebar-header[data-v-2414e152]{height:80px}.sidebar-nav[data-v-2414e152]{flex:1;padding:24px 0;overflow-y:auto;overflow-x:hidden;width:100%;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent}.sidebar-nav[data-v-2414e152]::-webkit-scrollbar{width:6px}.sidebar-nav[data-v-2414e152]::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:999px}.sidebar-collapsed .sidebar-nav[data-v-2414e152]{overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.sidebar-collapsed .sidebar-nav[data-v-2414e152]::-webkit-scrollbar{display:none}.sidebar-footer[data-v-2414e152]{padding:20px;text-align:center;color:var(--text-secondary);border-top:1px solid var(--border-color);width:100%}.main-content[data-v-2414e152]{flex:1;margin-left:260px;display:flex;flex-direction:column;transition:all .4s cubic-bezier(.25,.1,.25,1)}.top-bar[data-v-2414e152]{height:70px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 32px;position:sticky;top:0;z-index:50;transition:background .3s,border-color .3s}.left-section[data-v-2414e152]{display:flex;align-items:center}.collapse-btn[data-v-2414e152]{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:8px;border-radius:8px;transition:all .2s;margin-right:16px}.collapse-btn[data-v-2414e152]:hover{background:var(--hover-color);color:var(--primary-color)}.collapse-btn svg[data-v-2414e152]{width:24px;height:24px}.user-section[data-v-2414e152]{display:flex;align-items:center;gap:16px}.user-info[data-v-2414e152]{display:flex;align-items:center;gap:12px;padding:6px 12px;border-radius:8px}.avatar[data-v-2414e152]{width:32px;height:32px;border-radius:50%;overflow:hidden;background:#333;display:flex;align-items:center;justify-content:center}.avatar img[data-v-2414e152]{width:100%;height:100%;object-fit:cover}.user-name[data-v-2414e152]{font-size:14px;font-weight:500;color:var(--text-main)}.settings-dropdown[data-v-2414e152]{position:relative}.settings-btn[data-v-2414e152]{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .3s}.settings-btn[data-v-2414e152]:hover{border-color:var(--primary-color);color:var(--primary-color);background:var(--hover-color)}.settings-btn svg[data-v-2414e152]{width:20px;height:20px}.dropdown-item[data-v-2414e152]{padding:10px 16px;cursor:pointer;color:var(--text-main);font-size:14px;transition:background .2s}.dropdown-item[data-v-2414e152]:hover{background:var(--hover-color);color:var(--primary-color)}.dropdown-divider[data-v-2414e152]{height:1px;background:var(--border-color);margin:4px 0}.dropdown-item.logout[data-v-2414e152]{color:#ef5350}.content-wrapper[data-v-2414e152]{padding:32px}.fade-scale-enter-active[data-v-2414e152],.fade-scale-leave-active[data-v-2414e152]{transition:all .3s ease}.fade-scale-enter-from[data-v-2414e152]{opacity:0;transform:scale(.8)}.fade-scale-leave-to[data-v-2414e152]{opacity:0;transform:scale(1.2)}.dropdown-menu[data-v-2414e152]{position:absolute;top:120%;right:0;width:180px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 40px #0000004d;padding:8px 0;animation:slideIn .3s cubic-bezier(.16,1,.3,1);z-index:1000}.modal-overlay[data-v-2414e152]{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-container[data-v-2414e152]{background:var(--bg-secondary);border-radius:12px;width:90%;max-width:500px;border:1px solid var(--border-color);box-shadow:0 20px 60px #00000080;animation:modalSlideIn-2414e152 .3s cubic-bezier(.16,1,.3,1)}.modal-header[data-v-2414e152]{padding:20px 24px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.modal-header h3[data-v-2414e152]{font-size:18px;font-weight:600;color:var(--text-main)}.modal-close[data-v-2414e152]{background:transparent;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;line-height:1}.modal-close[data-v-2414e152]:hover{color:var(--text-main)}.modal-body[data-v-2414e152]{padding:24px}.modal-footer[data-v-2414e152]{padding:20px 24px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:12px}@keyframes modalSlideIn-2414e152{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.upload-area[data-v-2414e152]{border:2px dashed var(--border-color);border-radius:12px;padding:40px;text-align:center;cursor:pointer;transition:all .3s}.upload-area[data-v-2414e152]:hover{border-color:var(--primary-color);background:var(--hover-color)}.upload-placeholder[data-v-2414e152]{color:var(--text-secondary);display:flex;flex-direction:column;align-items:center;gap:12px}.avatar-preview[data-v-2414e152]{max-width:200px;max-height:200px;border-radius:50%;object-fit:cover}.input[data-v-2414e152]{width:100%;padding:12px 16px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;font-size:14px;color:var(--text-main);outline:none;transition:all .3s}.input[data-v-2414e152]:focus{border-color:var(--primary-color)}.btn[data-v-2414e152]{padding:10px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-main)}.btn[data-v-2414e152]:hover{background:var(--bg-secondary);border-color:var(--primary-color)}.btn-primary[data-v-2414e152]{background:linear-gradient(135deg,#42a5f5,#2196f3);color:#fff;border:none;box-shadow:0 4px 12px #42a5f54d}.btn-primary[data-v-2414e152]:hover{background:linear-gradient(135deg,#64b5f6,#42a5f5);transform:translateY(-2px);box-shadow:0 6px 20px #42a5f566}.btn-primary[data-v-2414e152]:disabled{opacity:.5;cursor:not-allowed;transform:none}
