:root{--bg-0:#05060a;--bg-1:#0a0b13;--bg-2:#11121c;--bg-3:#181a28;--bg-4:#1e2030;--ink-0:#f5f6ff;--ink-1:#c9cce0;--ink-2:#8a8fa8;--ink-3:#4d5169;--accent:#5cf2c4;--accent-2:#7c5cff;--accent-3:#ff5ca8;--warn:#ffd166;--error:#ff5c5c;--success:#5cf2c4;--info:#5cb4ff;--line:#ffffff12;--line-strong:#ffffff24;--glass-bg:#ffffff05;--glass-border:#ffffff1a;--glass-hover:#ffffff0d;--glass-active:#5cf2c414;--font-sans:"Space Grotesk", "PingFang SC", "Microsoft YaHei", "Noto Sans CJK SC", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Consolas", monospace;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:24px;--sp-6:32px;--sp-7:48px;--sp-8:64px;--r-xs:4px;--r-sm:8px;--r-md:14px;--r-lg:22px;--r-xl:28px;--r-full:999px;--shadow-card:0 8px 32px #0000004d;--shadow-glow-mint:0 6px 30px #5cf2c459;--shadow-glow-violet:0 6px 30px #7c5cff59;--shadow-glow-magenta:0 6px 30px #ff5ca859;--ease-elastic:cubic-bezier(.34, 1.56, .64, 1);--ease-smooth:cubic-bezier(.16, 1, .3, 1);--ease-glide:cubic-bezier(.7, 0, .2, 1);--ease-bounce:cubic-bezier(.68, -.6, .32, 1.6);--sidebar-w:240px;--sidebar-w-collapsed:64px;--navbar-h:56px;--content-max:1400px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);color:var(--ink-0);background:var(--bg-0);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;line-height:1.5;overflow-x:hidden}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;color:inherit;background:0 0;border:none}input,textarea,select{font:inherit;color:inherit}img,svg{max-width:100%;display:block}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2}code,pre,kbd{font-family:var(--font-mono)}::selection{background:var(--accent);color:#000}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--ink-3);border-radius:var(--r-full)}::-webkit-scrollbar-thumb:hover{background:var(--ink-2)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.text-accent{color:var(--accent)}.text-accent-2{color:var(--accent-2)}.text-accent-3{color:var(--accent-3)}.text-warn{color:var(--warn)}.text-error{color:var(--error)}.text-success{color:var(--success)}.text-info{color:var(--info)}.text-muted{color:var(--ink-2)}.text-dim{color:var(--ink-3)}.text-mono{font-family:var(--font-mono)}.text-center{text-align:center}.text-right{text-align:right}.text-sm{font-size:.8125rem}.text-xs{font-size:.6875rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:2rem}.text-bold{font-weight:600}.text-medium{font-weight:500}.text-light{font-weight:300}.text-truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.text-uppercase{text-transform:uppercase;letter-spacing:.1em}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:var(--sp-1)}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}.gap-4{gap:var(--sp-4)}.gap-5{gap:var(--sp-5)}.gap-6{gap:var(--sp-6)}.mt-1{margin-top:var(--sp-1)}.mt-2{margin-top:var(--sp-2)}.mt-3{margin-top:var(--sp-3)}.mt-4{margin-top:var(--sp-4)}.mt-5{margin-top:var(--sp-5)}.mt-6{margin-top:var(--sp-6)}.mb-2{margin-bottom:var(--sp-2)}.mb-3{margin-bottom:var(--sp-3)}.mb-4{margin-bottom:var(--sp-4)}.mb-5{margin-bottom:var(--sp-5)}.ml-auto{margin-left:auto}.p-2{padding:var(--sp-2)}.p-3{padding:var(--sp-3)}.p-4{padding:var(--sp-4)}.p-5{padding:var(--sp-5)}.p-6{padding:var(--sp-6)}.hidden{display:none!important}.block{display:block}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100dvh}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-y-auto{overflow-y:auto}.border{border:1px solid var(--line)}.border-strong{border:1px solid var(--line-strong)}.rounded-sm{border-radius:var(--r-sm)}.rounded-md{border-radius:var(--r-md)}.rounded-lg{border-radius:var(--r-lg)}.rounded-xl{border-radius:var(--r-xl)}.rounded-full{border-radius:var(--r-full)}.bg-surface{background:var(--bg-1)}.bg-elevated{background:var(--bg-2)}.bg-glass{background:var(--glass-bg)}.transition{transition:all .3s var(--ease-smooth)}.transition-colors{transition:color .2s,background-color .2s,border-color .2s}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.btn{justify-content:center;align-items:center;gap:var(--sp-2);border-radius:var(--r-full);letter-spacing:.02em;white-space:nowrap;cursor:pointer;transition:all .3s var(--ease-elastic);-webkit-user-select:none;user-select:none;border:1px solid #0000;padding:10px 20px;font-size:.875rem;font-weight:500;display:inline-flex;position:relative}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn svg{flex-shrink:0;width:16px;height:16px}.btn-primary{color:#000;background:linear-gradient(120deg, var(--accent), #b6ffd9);box-shadow:var(--shadow-glow-mint);border-color:#0000}.btn-primary:hover{transform:translateY(-1px)scale(1.02)}.btn-primary:active{transform:scale(.98)}.btn-ghost{color:var(--ink-1);border-color:var(--line-strong);background:0 0}.btn-ghost:hover{color:var(--ink-0);border-color:var(--ink-2)}.btn-danger{color:var(--error);background:#ff5c5c14;border-color:#ff5c5c4d}.btn-danger:hover{background:#ff5c5c26}.btn-outline-accent{color:var(--accent);background:0 0;border-color:#5cf2c44d}.btn-outline-accent:hover{background:#5cf2c414}.btn-sm{padding:6px 14px;font-size:.8125rem}.btn-lg{padding:14px 28px;font-size:1rem}.btn-xl{padding:16px 32px;font-size:1rem}.btn-icon{border-radius:var(--r-sm);padding:8px}.btn-block{width:100%}.glass-panel{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--r-lg);-webkit-backdrop-filter:blur(14px)saturate(120%)}.card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:var(--sp-5);transition:all .3s var(--ease-smooth)}.card-hover:hover{background:var(--glass-hover);border-color:var(--line-strong);transform:translateY(-2px)}.card-flat{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--sp-5)}.stat-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:var(--sp-5)}.stat-card .stat-label{font-family:var(--font-mono);color:var(--ink-2);letter-spacing:.14em;text-transform:uppercase;margin-bottom:var(--sp-2);font-size:.6875rem}.stat-card .stat-value{letter-spacing:-.02em;font-size:1.75rem;font-weight:500;line-height:1.1}.stat-card .stat-sub{color:var(--ink-2);margin-top:var(--sp-1);font-size:.75rem}.input-group{gap:var(--sp-2);flex-direction:column;display:flex}.input-label{color:var(--ink-1);font-size:.8125rem;font-weight:500}.input-label .required{color:var(--error);margin-left:2px}.input{background:var(--bg-1);border:1px solid var(--line-strong);border-radius:var(--r-sm);width:100%;color:var(--ink-0);outline:none;padding:10px 14px;font-size:.875rem;transition:border-color .2s,box-shadow .2s}.input::placeholder{color:var(--ink-3)}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #5cf2c41f}.input:disabled{opacity:.5;cursor:not-allowed}.input-error{border-color:var(--error)!important}.input-hint{color:var(--ink-2);font-size:.75rem}.input-error-msg{color:var(--error);font-size:.75rem}.textarea{background:var(--bg-1);border:1px solid var(--line-strong);border-radius:var(--r-sm);width:100%;color:var(--ink-0);resize:vertical;outline:none;min-height:80px;padding:10px 14px;font-size:.875rem;transition:border-color .2s,box-shadow .2s}.textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #5cf2c41f}.select{background:var(--bg-1);border:1px solid var(--line-strong);border-radius:var(--r-sm);width:100%;color:var(--ink-0);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 width=%2712%27 height=%2712%27 fill=%27%238a8fa8%27 viewBox=%270 0 24 24%27%3E%3Cpath d=%27M7 10l5 5 5-5z%27/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;outline:none;padding:10px 36px 10px 14px;font-size:.875rem;transition:border-color .2s}.select:focus{border-color:var(--accent)}.switch{flex-shrink:0;width:40px;height:22px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.switch-track{background:var(--bg-3);border:1px solid var(--line-strong);border-radius:var(--r-full);cursor:pointer;transition:background .25s;position:absolute;inset:0}.switch-track:after{content:"";background:var(--ink-2);width:16px;height:16px;transition:transform .25s var(--ease-elastic), background .25s;border-radius:50%;position:absolute;top:2px;left:2px}.switch input:checked+.switch-track{border-color:var(--accent);background:#5cf2c433}.switch input:checked+.switch-track:after{background:var(--accent);transform:translate(18px)}.checkbox{align-items:center;gap:var(--sp-2);cursor:pointer;font-size:.875rem;display:inline-flex}.checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}.tag{border-radius:var(--r-full);font-size:.6875rem;font-family:var(--font-mono);letter-spacing:.08em;border:1px solid var(--line-strong);color:var(--ink-2);align-items:center;padding:3px 10px;font-weight:500;display:inline-flex}.tag-mint{color:var(--accent);background:#5cf2c40f;border-color:#5cf2c44d}.tag-violet{color:var(--accent-2);background:#7c5cff0f;border-color:#7c5cff4d}.tag-magenta{color:var(--accent-3);background:#ff5ca80f;border-color:#ff5ca84d}.tag-warn{color:var(--warn);background:#ffd1660f;border-color:#ffd1664d}.tag-error{color:var(--error);background:#ff5c5c0f;border-color:#ff5c5c4d}.tag-success{color:var(--success);background:#5cf2c40f;border-color:#5cf2c44d}.badge{border-radius:var(--r-full);background:var(--accent-3);color:#fff;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:.625rem;font-weight:600;display:inline-flex}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.status-dot-online{background:var(--success);box-shadow:0 0 8px var(--success)}.status-dot-offline{background:var(--ink-3)}.status-dot-warning{background:var(--warn);box-shadow:0 0 8px var(--warn)}.status-dot-error{background:var(--error);box-shadow:0 0 8px var(--error)}.status-dot-pending{background:var(--info);animation:1.8s infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.data-table{border-collapse:collapse;width:100%;font-size:.875rem}.data-table thead{z-index:2;position:sticky;top:0}.data-table th{text-align:left;color:var(--ink-2);text-transform:uppercase;letter-spacing:.08em;background:var(--bg-1);border-bottom:1px solid var(--line);white-space:nowrap;padding:12px 16px;font-size:.75rem;font-weight:500}.data-table td{border-bottom:1px solid var(--line);color:var(--ink-1);vertical-align:middle;padding:12px 16px}.data-table tbody tr{transition:background .15s}.data-table tbody tr:hover{background:var(--glass-hover)}.data-table .col-actions{text-align:right;white-space:nowrap}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:var(--sp-5);opacity:0;pointer-events:none;background:#000000a6;justify-content:center;align-items:center;transition:opacity .25s;display:flex;position:fixed;inset:0}.modal-overlay.open{opacity:1;pointer-events:auto}.modal{background:var(--bg-1);border:1px solid var(--glass-border);border-radius:var(--r-xl);padding:var(--sp-6);width:100%;max-width:520px;max-height:90dvh;transition:transform .35s var(--ease-elastic);box-shadow:var(--shadow-card);overflow-y:auto;transform:scale(.95)translateY(10px)}.modal-overlay.open .modal{transform:scale(1)translateY(0)}.modal-header{margin-bottom:var(--sp-5);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:1.25rem;font-weight:600}.modal-close{border-radius:var(--r-sm);width:32px;height:32px;color:var(--ink-2);justify-content:center;align-items:center;transition:color .2s,background .2s;display:flex}.modal-close:hover{color:var(--ink-0);background:var(--glass-hover)}.modal-footer{justify-content:flex-end;gap:var(--sp-3);margin-top:var(--sp-6);padding-top:var(--sp-5);border-top:1px solid var(--line);display:flex}.toast-container{top:var(--sp-5);right:var(--sp-5);z-index:2000;gap:var(--sp-3);pointer-events:none;flex-direction:column;max-width:380px;display:flex;position:fixed}.toast{align-items:flex-start;gap:var(--sp-3);border-radius:var(--r-md);background:var(--bg-2);border:1px solid var(--glass-border);box-shadow:var(--shadow-card);pointer-events:auto;animation:toast-in .4s var(--ease-elastic);padding:14px 18px;font-size:.875rem;display:flex}.toast-icon{flex-shrink:0;width:18px;height:18px;margin-top:1px}.toast-msg{color:var(--ink-1);flex:1}.toast-close{color:var(--ink-3);cursor:pointer;flex-shrink:0;transition:color .2s}.toast-close:hover{color:var(--ink-0)}.toast-success .toast-icon{color:var(--success)}.toast-error .toast-icon{color:var(--error)}.toast-warn .toast-icon{color:var(--warn)}.toast-info .toast-icon{color:var(--info)}@keyframes toast-in{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast-exit{animation:toast-out .3s var(--ease-glide) forwards}@keyframes toast-out{to{opacity:0;transform:translate(100%)}}.tabs{gap:var(--sp-1);border-bottom:1px solid var(--line);display:flex;overflow-x:auto}.tab{color:var(--ink-2);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:10px 18px;font-size:.875rem;transition:color .2s;position:relative}.tab:hover,.tab.active{color:var(--ink-0)}.tab.active:after{content:"";background:var(--accent);border-radius:2px 2px 0 0;height:2px;position:absolute;bottom:-1px;left:0;right:0}.avatar{background:linear-gradient(135deg, var(--accent-2), var(--accent));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:.875rem;font-weight:600;display:flex;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%}.avatar-sm{width:32px;height:32px;font-size:.75rem}.avatar-lg{width:56px;height:56px;font-size:1.125rem}.avatar-xl{width:80px;height:80px;font-size:1.5rem}.code-block{background:var(--bg-0);border:1px solid var(--line);border-radius:var(--r-md);padding:var(--sp-4);font-family:var(--font-mono);color:var(--ink-1);font-size:.8125rem;line-height:1.6;position:relative;overflow-x:auto}.dropdown{display:inline-block;position:relative}.dropdown-menu{background:var(--bg-2);border:1px solid var(--glass-border);border-radius:var(--r-md);min-width:180px;padding:var(--sp-2) 0;box-shadow:var(--shadow-card);z-index:100;opacity:0;pointer-events:none;transition:opacity .2s, transform .25s var(--ease-smooth);position:absolute;top:calc(100% + 6px);right:0;transform:translateY(-4px)}.dropdown.open .dropdown-menu{opacity:1;pointer-events:auto;transform:translateY(0)}.dropdown-item{align-items:center;gap:var(--sp-2);color:var(--ink-1);cursor:pointer;text-align:left;width:100%;padding:8px 16px;font-size:.875rem;transition:background .15s;display:flex}.dropdown-item:hover{background:var(--glass-hover);color:var(--ink-0)}.dropdown-divider{background:var(--line);height:1px;margin:var(--sp-2) 0}.progress{background:var(--bg-3);border-radius:var(--r-full);width:100%;height:6px;overflow:hidden}.progress-bar{border-radius:var(--r-full);background:linear-gradient(90deg, var(--accent), var(--accent-2));height:100%;transition:width .6s var(--ease-smooth)}.progress-bar-warn{background:linear-gradient(90deg, var(--warn), var(--accent-3))}.progress-bar-danger{background:linear-gradient(90deg, var(--accent-3), var(--error))}.pagination{align-items:center;gap:var(--sp-1);display:flex}.page-btn{border-radius:var(--r-sm);width:32px;height:32px;color:var(--ink-2);cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;font-size:.8125rem;transition:all .2s;display:flex}.page-btn:hover{color:var(--ink-0);background:var(--glass-hover)}.page-btn.active{color:var(--ink-0);background:#5cf2c41a;border-color:#5cf2c44d}.page-btn:disabled{opacity:.3;pointer-events:none}.page-info{color:var(--ink-2);margin:0 var(--sp-2);font-size:.75rem}.skeleton{background:linear-gradient(90deg, var(--bg-2) 25%, var(--bg-3) 50%, var(--bg-2) 75%);border-radius:var(--r-sm);background-size:200% 100%;animation:1.5s infinite skeleton-pulse}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{padding:var(--sp-8) var(--sp-5);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{width:64px;height:64px;margin-bottom:var(--sp-5);color:var(--ink-3);opacity:.6}.empty-state-title{color:var(--ink-1);margin-bottom:var(--sp-2);font-size:1.125rem;font-weight:500}.empty-state-desc{color:var(--ink-2);max-width:32ch;margin-bottom:var(--sp-5);font-size:.875rem}.lang-switch{border-radius:var(--r-full);font-family:var(--font-mono);letter-spacing:.12em;color:var(--ink-2);border:1px solid var(--line-strong);cursor:pointer;background:0 0;padding:5px 12px;font-size:.6875rem;transition:color .3s,border-color .3s}.lang-switch:hover{color:var(--ink-0);border-color:var(--ink-2)}.divider{background:var(--line);height:1px;margin:var(--sp-5) 0}.oauth-btn{justify-content:center;align-items:center;gap:var(--sp-3);border-radius:var(--r-sm);border:1px solid var(--line-strong);background:var(--bg-1);width:100%;color:var(--ink-1);cursor:pointer;padding:10px 16px;font-size:.875rem;transition:all .2s;display:flex}.oauth-btn:hover{border-color:var(--ink-2);background:var(--glass-hover)}.oauth-btn svg{width:18px;height:18px}.oauth-grid{gap:var(--sp-3);grid-template-columns:repeat(3,1fr);display:grid}@media (max-width:480px){.oauth-grid{grid-template-columns:repeat(2,1fr)}}.key-display{align-items:center;gap:var(--sp-3);background:var(--bg-0);border:1px solid var(--line);border-radius:var(--r-sm);font-family:var(--font-mono);color:var(--ink-1);padding:10px 14px;font-size:.8125rem;display:flex;overflow:hidden}.key-display .key-value{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.chart-container{width:100%;min-height:200px;position:relative}.chart-container canvas{width:100%!important}.bg-grain{z-index:0;pointer-events:none;opacity:.25;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 width=%27180%27 height=%27180%27%3E%3Cfilter id=%27n%27%3E%3CfeTurbulence type=%27fractalNoise%27 baseFrequency=%270.9%27 numOctaves=%272%27 stitchTiles=%27stitch%27/%3E%3C/filter%3E%3Crect width=%27100%25%27 height=%27100%25%27 filter=%27url%28%23n%29%27 opacity=%270.55%27/%3E%3C/svg%3E");position:fixed;inset:0}.bg-vignette{z-index:0;pointer-events:none;background:radial-gradient(60% 50% at 70% 80%,#0000 0%,#05060a73 60%,#05060ad9 100%),radial-gradient(80% 60% at 20% 0,#05060abf 0%,#0000 60%);position:fixed;inset:0}.auth-shell{min-height:100dvh;padding:var(--sp-5);z-index:1;flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative}.auth-brand{align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-7);letter-spacing:.08em;font-size:1.125rem;font-weight:700;display:flex}.auth-brand-mark{background:conic-gradient(from 220deg, var(--accent), var(--accent-2), var(--accent-3), var(--accent));border-radius:10px;width:36px;height:36px;position:relative;overflow:hidden;box-shadow:0 0 30px #7c5cff80}.auth-brand-mark:after{content:"";background:var(--bg-0);border-radius:6px;position:absolute;inset:6px}.auth-brand-mark:before{content:"";background:conic-gradient(from 40deg, var(--accent), var(--accent-2), var(--accent));z-index:1;border-radius:4px;position:absolute;inset:11px}.auth-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--r-xl);width:100%;max-width:440px;padding:var(--sp-7);-webkit-backdrop-filter:blur(18px)saturate(120%);box-shadow:var(--shadow-card)}.auth-card h1{margin-bottom:var(--sp-2);letter-spacing:-.02em;font-size:1.5rem;font-weight:600}.auth-card .auth-subtitle{color:var(--ink-2);margin-bottom:var(--sp-6);font-size:.875rem}.auth-footer{margin-top:var(--sp-6);color:var(--ink-3);text-align:center;font-size:.8125rem}.auth-footer a{color:var(--ink-2);transition:color .2s}.auth-footer a:hover{color:var(--accent)}.auth-form{gap:var(--sp-5);flex-direction:column;display:flex}.auth-actions{gap:var(--sp-3);margin-top:var(--sp-2);flex-direction:column;display:flex}.auth-links{margin-top:var(--sp-2);justify-content:space-between;font-size:.8125rem;display:flex}.auth-links a{color:var(--ink-2);transition:color .2s}.auth-links a:hover{color:var(--accent)}.app-shell{z-index:1;min-height:100dvh;display:flex;position:relative}.sidebar{width:var(--sidebar-w);background:var(--bg-1);border-right:1px solid var(--line);z-index:40;transition:width .35s var(--ease-smooth), transform .35s var(--ease-smooth);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden auto}.sidebar-brand{align-items:center;gap:var(--sp-3);padding:var(--sp-5) var(--sp-5) var(--sp-4);letter-spacing:.06em;flex-shrink:0;font-size:.9375rem;font-weight:700;display:flex}.sidebar-brand-mark{background:conic-gradient(from 220deg, var(--accent), var(--accent-2), var(--accent-3), var(--accent));border-radius:8px;flex-shrink:0;width:28px;height:28px;position:relative;overflow:hidden}.sidebar-brand-mark:after{content:"";background:var(--bg-1);border-radius:5px;position:absolute;inset:5px}.sidebar-brand-mark:before{content:"";background:conic-gradient(from 40deg, var(--accent), var(--accent-2), var(--accent));z-index:1;border-radius:3px;position:absolute;inset:9px}.sidebar-brand-text{white-space:nowrap;overflow:hidden}.sidebar-brand-text span{color:var(--ink-2);margin-left:4px;font-size:.8125rem;font-weight:400}.sidebar-nav{padding:var(--sp-2) var(--sp-3);flex:1}.sidebar-section{margin-bottom:var(--sp-4)}.sidebar-section-label{font-family:var(--font-mono);color:var(--ink-3);letter-spacing:.18em;text-transform:uppercase;padding:var(--sp-2) var(--sp-3);margin-bottom:var(--sp-1);font-size:.625rem}.sidebar-link{align-items:center;gap:var(--sp-3);padding:9px var(--sp-3);border-radius:var(--r-sm);color:var(--ink-2);cursor:pointer;white-space:nowrap;font-size:.875rem;text-decoration:none;transition:all .2s;display:flex;position:relative;overflow:hidden}.sidebar-link:hover{color:var(--ink-0);background:var(--glass-hover)}.sidebar-link.active{color:var(--ink-0);background:var(--glass-active)}.sidebar-link.active:before{content:"";background:var(--accent);border-radius:2px;width:2px;position:absolute;top:6px;bottom:6px;left:0}.sidebar-link svg{opacity:.7;flex-shrink:0;width:18px;height:18px}.sidebar-link.active svg{opacity:1;color:var(--accent)}.sidebar-link .link-text{text-overflow:ellipsis;overflow:hidden}.sidebar-link .link-badge{flex-shrink:0;margin-left:auto}.sidebar-footer{padding:var(--sp-4) var(--sp-3);border-top:1px solid var(--line);flex-shrink:0}.sidebar-user{align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);border-radius:var(--r-sm);cursor:pointer;transition:background .2s;display:flex}.sidebar-user:hover{background:var(--glass-hover)}.sidebar-user-info{flex:1;overflow:hidden}.sidebar-user-name{white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:500;overflow:hidden}.sidebar-user-email{color:var(--ink-3);white-space:nowrap;text-overflow:ellipsis;font-size:.6875rem;overflow:hidden}.main-area{margin-left:var(--sidebar-w);min-height:100dvh;transition:margin-left .35s var(--ease-smooth);flex-direction:column;flex:1;display:flex}.navbar-app{z-index:30;height:var(--navbar-h);padding:0 var(--sp-6);-webkit-backdrop-filter:blur(14px)saturate(120%);border-bottom:1px solid var(--line);background:#05060abf;flex-shrink:0;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.navbar-left{align-items:center;gap:var(--sp-4);display:flex}.navbar-burger{border-radius:var(--r-sm);width:36px;height:36px;color:var(--ink-2);cursor:pointer;justify-content:center;align-items:center;transition:color .2s;display:none}.navbar-burger:hover{color:var(--ink-0)}.navbar-burger svg{width:20px;height:20px}.navbar-breadcrumb{align-items:center;gap:var(--sp-2);color:var(--ink-2);font-size:.875rem;display:flex}.navbar-breadcrumb a{color:var(--ink-2);transition:color .2s}.navbar-breadcrumb a:hover{color:var(--ink-0)}.navbar-breadcrumb .sep{color:var(--ink-3)}.navbar-breadcrumb .current{color:var(--ink-0);font-weight:500}.navbar-right{align-items:center;gap:var(--sp-3);display:flex}.navbar-search{align-items:center;gap:var(--sp-2);border-radius:var(--r-full);border:1px solid var(--line-strong);background:var(--bg-1);color:var(--ink-3);cursor:pointer;max-width:200px;padding:6px 14px;font-size:.8125rem;transition:border-color .2s;display:flex}.navbar-search:hover{border-color:var(--ink-3)}.navbar-search svg{width:14px;height:14px}.navbar-search kbd{font-family:var(--font-mono);border-radius:var(--r-xs);border:1px solid var(--line-strong);color:var(--ink-3);margin-left:auto;padding:1px 5px;font-size:.625rem}.navbar-notify{border-radius:var(--r-sm);width:36px;height:36px;color:var(--ink-2);cursor:pointer;justify-content:center;align-items:center;transition:color .2s;display:flex;position:relative}.navbar-notify:hover{color:var(--ink-0)}.navbar-notify svg{width:18px;height:18px}.navbar-notify .notify-dot{background:var(--accent-3);border:2px solid var(--bg-0);border-radius:50%;width:7px;height:7px;position:absolute;top:6px;right:6px}.main-content{padding:var(--sp-6);flex:1;width:100%}.page-header{margin-bottom:var(--sp-6);justify-content:space-between;align-items:flex-start;gap:var(--sp-4);flex-wrap:wrap;display:flex}.page-title{letter-spacing:-.02em;font-size:1.5rem;font-weight:600}.page-subtitle{color:var(--ink-2);margin-top:var(--sp-1);font-size:.875rem}.page-actions{align-items:center;gap:var(--sp-3);flex-wrap:wrap;display:flex}.page-body{gap:var(--sp-6);flex-direction:column;display:flex}.grid-2{gap:var(--sp-5);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--sp-5);grid-template-columns:repeat(3,1fr);display:grid}.grid-4{gap:var(--sp-5);grid-template-columns:repeat(4,1fr);display:grid}.grid-auto{gap:var(--sp-5);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}@media (max-width:1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}@media (max-width:1199px) and (min-width:768px){.sidebar{width:var(--sidebar-w-collapsed)}.sidebar-brand-text,.sidebar-section-label,.sidebar-link .link-text,.sidebar-link .link-badge,.sidebar-user-info{opacity:0;width:0;overflow:hidden}.sidebar-brand{padding:var(--sp-4);justify-content:center}.sidebar-link{justify-content:center;padding:10px}.sidebar-user{justify-content:center}.main-area{margin-left:var(--sidebar-w-collapsed)}}@media (max-width:767px){.sidebar{width:var(--sidebar-w);z-index:100;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay{z-index:99;opacity:0;pointer-events:none;background:#0009;transition:opacity .3s;position:fixed;inset:0}.sidebar-overlay.open{opacity:1;pointer-events:auto}.main-area{margin-left:0}.navbar-burger{display:flex}.navbar-search{display:none}.main-content{padding:var(--sp-4)}.page-header{flex-direction:column}}.fade-in{animation:fadeIn .6s var(--ease-smooth) both}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.slide-up{animation:slideUp .6s var(--ease-smooth) both}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.slide-down{animation:slideDown .5s var(--ease-smooth) both}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.scale-in{animation:scaleIn .4s var(--ease-elastic) both}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.stagger>*{animation:slideUp .5s var(--ease-smooth) both}.stagger>:first-child{animation-delay:0s}.stagger>:nth-child(2){animation-delay:60ms}.stagger>:nth-child(3){animation-delay:.12s}.stagger>:nth-child(4){animation-delay:.18s}.stagger>:nth-child(5){animation-delay:.24s}.stagger>:nth-child(6){animation-delay:.3s}.stagger>:nth-child(7){animation-delay:.36s}.stagger>:nth-child(8){animation-delay:.42s}.spin{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.count-up{font-variant-numeric:tabular-nums}.delay-1{transition-delay:80ms}.delay-2{transition-delay:.16s}.delay-3{transition-delay:.24s}.delay-4{transition-delay:.32s}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}