:root{--bg: #0a0e14;--bg2: #111820;--bg3: #1a2332;--border: #263040;--text: #c8d6e5;--text2: #6b7d95;--gold: #f0a030;--gold2: #e5921b;--green: #2ecc71;--blue: #5dade2;--red: #e74c3c}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5}.navbar{position:sticky;top:0;z-index:100;background:#0a0e14eb;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);height:64px;display:flex;align-items:center}.nav-inner{max-width:1200px;width:100%;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between}.nav-brand{cursor:pointer;display:flex;align-items:center;gap:12px}.nav-logo{width:36px;height:36px;border-radius:8px;object-fit:cover;flex-shrink:0}.nav-brand-text{display:flex;flex-direction:column}.brand-text{font-size:18px;font-weight:700;background:linear-gradient(135deg,var(--gold),#ffd580);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.brand-sub{font-size:12px;color:var(--text2)}.nav-links{display:flex;gap:8px}.nav-link{color:var(--text2);text-decoration:none;font-size:14px;padding:6px 16px;border-radius:8px;transition:all .2s}.nav-link:hover{color:var(--text);background:#f0a0300f}.nav-link.router-link-active{color:var(--gold);background:#f0a0301a}.nav-admin{border:1px solid var(--border)}.main{max-width:1200px;margin:0 auto;padding:32px 24px;min-height:calc(100vh - 120px)}.main-admin{max-width:100%;padding:0;min-height:100vh}.footer{border-top:1px solid var(--border);padding:20px 24px;text-align:center;color:var(--text2);font-size:13px}.dot{margin:0 8px;opacity:.4}.card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:20px 24px;transition:border-color .3s,box-shadow .3s}.card:hover{border-color:#f0a03040;box-shadow:0 0 24px #f0a0300d}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:10px 20px;color:var(--text);font-size:14px;cursor:pointer;transition:all .2s;text-decoration:none}.btn:hover{border-color:var(--gold);color:var(--gold)}.btn.primary{background:var(--gold2);border-color:var(--gold2);color:#111820;font-weight:600}.btn.primary:hover{background:var(--gold)}.btn.danger{background:#e74c3c14;border-color:#e74c3c33;color:var(--red)}.btn.danger:hover{background:#e74c3c26}.btn:disabled{opacity:.4;cursor:not-allowed}.input,textarea,select{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:10px 14px;color:var(--text);font-size:14px;outline:none;transition:border-color .3s;width:100%}.input:focus,textarea:focus,select:focus{border-color:var(--gold)}.input::placeholder,textarea::placeholder{color:var(--text2)}select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:600}.badge.gold{background:#f0a0301f;color:var(--gold)}.badge.green{background:#2ecc711f;color:var(--green)}.badge.red{background:#e74c3c1f;color:var(--red)}.badge.blue{background:#5dade21f;color:var(--blue)}.section-title{font-size:16px;font-weight:700;color:var(--gold);margin-bottom:20px;display:flex;align-items:center;gap:10px}.section-title:after{content:"";flex:1;height:1px;background:var(--border)}.empty{text-align:center;padding:60px 20px;color:var(--text2)}.loading{text-align:center;padding:40px;color:var(--text2)}.grid2{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.grid3{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}.grid4{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.nav-user{font-size:14px;color:var(--gold);font-weight:600}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000000a6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center}.auth-card{position:relative;width:420px;max-width:90vw;max-height:90vh;overflow-y:auto;background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:36px 32px 28px;box-shadow:0 24px 80px #00000080,0 0 0 1px #f0a03014 inset}.auth-close{position:absolute;top:14px;right:18px;background:none;border:none;color:var(--text2);font-size:24px;cursor:pointer;line-height:1;transition:color .2s}.auth-close:hover{color:var(--text)}.auth-header{text-align:center;margin-bottom:28px}.auth-logo{width:60px;height:60px;border-radius:12px;object-fit:cover;margin-bottom:8px;border:2px solid rgba(240,160,48,.3)}.auth-brand{font-size:22px;font-weight:700;background:linear-gradient(135deg,var(--gold),#ffd580);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-sub{font-size:12px;color:var(--text2);margin-top:6px}.auth-tabs{display:flex;gap:0;margin-bottom:24px;background:var(--bg3);border-radius:10px;padding:4px}.auth-tab{flex:1;padding:10px 0;border:none;border-radius:8px;background:transparent;color:var(--text2);font-size:14px;cursor:pointer;transition:all .25s;font-weight:500}.auth-tab.on{background:var(--bg2);color:var(--gold);font-weight:600;box-shadow:0 2px 8px #0000004d}.auth-field{position:relative;margin-bottom:14px}.auth-field-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:15px;color:var(--text2);pointer-events:none;z-index:1}.auth-field .input{padding-left:42px;height:46px;font-size:14px}.auth-err{color:var(--red);font-size:13px;margin-bottom:8px;padding:8px 12px;background:#e74c3c14;border-radius:8px;border:1px solid rgba(231,76,60,.15)}.auth-submit{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px;margin-top:6px;background:linear-gradient(135deg,var(--gold2),var(--gold));border:none;border-radius:10px;color:#111820;font-size:16px;font-weight:700;cursor:pointer;transition:all .25s;letter-spacing:4px}.auth-submit:hover{filter:brightness(1.08);box-shadow:0 4px 20px #f0a03040}.auth-submit:active{transform:scale(.98)}.auth-submit:disabled{opacity:.5;cursor:not-allowed;transform:none;filter:none;box-shadow:none}.spinner{width:18px;height:18px;border:2px solid rgba(17,24,32,.3);border-top-color:#111820;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-foot{text-align:center;margin-top:20px;font-size:13px;color:var(--text2)}.auth-switch{background:none;border:none;color:var(--gold);font-size:13px;cursor:pointer;font-weight:600;padding:0}.auth-switch:hover{text-decoration:underline}.fade-enter-active,.fade-leave-active{transition:opacity .25s}.fade-enter-from,.fade-leave-to{opacity:0}@media (max-width: 1024px){.grid2{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.grid3{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.grid4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.navbar{height:52px}.nav-inner{padding:0 14px}.nav-brand{gap:8px}.nav-logo{width:30px;height:30px;border-radius:6px}.brand-text{font-size:15px}.brand-sub{display:none}.nav-link{padding:5px 10px;font-size:12px}.main{padding:16px 12px;min-height:calc(100vh - 90px)}.footer{padding:14px 12px;font-size:11px}.grid2{grid-template-columns:1fr}.grid3{grid-template-columns:repeat(2,1fr);gap:10px}.grid4{grid-template-columns:repeat(2,1fr);gap:8px}.btn{padding:8px 14px;font-size:13px}.input,textarea,select{padding:8px 12px;font-size:13px}.section-title{font-size:14px;margin-bottom:14px}.card{padding:14px 16px;border-radius:10px}.auth-card{padding:24px 20px 20px;border-radius:12px}.auth-header{margin-bottom:20px}.auth-icon{font-size:32px}.auth-brand{font-size:18px}.auth-tab{font-size:13px;padding:8px 0}.auth-field .input{height:42px;font-size:13px;padding-left:38px}.auth-submit{padding:11px;font-size:15px;letter-spacing:2px}.auth-foot{margin-top:16px;font-size:12px}}@media (max-width: 480px){.grid3,.grid4{grid-template-columns:1fr}.btn{padding:6px 10px;font-size:12px}.card{padding:12px}}
