2026-04-14 15:54:53 +02:00

2 lines
27 KiB
CSS

:root{--surface-base: rgba(10, 10, 14, .97);--surface-1: rgba(255, 255, 255, .025);--surface-2: rgba(255, 255, 255, .04);--surface-3: rgba(255, 255, 255, .06);--surface-card: rgba(255, 255, 255, .03);--accent: #3b82f6;--accent-light: #60a5fa;--accent-dim: rgba(59, 130, 246, .12);--accent-subtle: rgba(59, 130, 246, .05);--accent-glow: rgba(59, 130, 246, .25);--success: #4ade80;--success-dim: rgba(74, 222, 128, .12);--danger: #ef4444;--danger-dim: rgba(239, 68, 68, .12);--text-primary: #fafafa;--text-secondary: #d4d4d8;--text-muted: #71717a;--text-dim: #52525b;--text-ghost: #3f3f46;--border-subtle: rgba(255, 255, 255, .035);--border-default: rgba(255, 255, 255, .06);--border-accent: rgba(59, 130, 246, .15);--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 20px;--space-2xl: 24px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 10px;--radius-xl: 14px;--font-family: "Inter", "Segoe UI", -apple-system, BlinkMacSystemFont, sans-serif;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-default: .25s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{background:transparent!important;font-family:var(--font-family);color:var(--text-secondary);overflow:hidden;-webkit-font-smoothing:antialiased}#app{width:100vw;height:100vh;display:flex;justify-content:center;align-items:center;background:transparent}@property --neon-angle{syntax: "<angle>"; initial-value: 0deg; inherits: false;}@keyframes neon-rotate{to{--neon-angle: 360deg}}@keyframes pulse-glow{0%,to{box-shadow:0 0 8px var(--accent-glow)}50%{box-shadow:0 0 22px var(--accent-glow),0 0 44px #3b82f614}}@keyframes card-appear{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer-line{0%{transform:translate(-100%)}to{transform:translate(200%)}}@keyframes status-pulse{0%,to{box-shadow:0 0 4px var(--success)}50%{box-shadow:0 0 12px var(--success),0 0 20px #4ade8040}}@keyframes banner-zoom{0%{transform:scale(1)}to{transform:scale(1.08)}}@keyframes alert-pulse{0%,to{border-color:#ef444426}50%{border-color:#ef444466}}.frak-overlay{position:relative;width:75vw;max-width:1100px;height:75vh;max-height:800px;background:var(--surface-base);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);display:flex;flex-direction:row;overflow:hidden}.frak-overlay:before,.frak-overlay:after{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:var(--radius-xl);pointer-events:none;z-index:2}.frak-overlay:before{background:conic-gradient(from var(--neon-angle, 0deg),transparent 0%,transparent 15%,var(--accent) 25%,var(--accent-light) 30%,transparent 40%,transparent 100%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;padding:1.5px;animation:neon-rotate 4s linear infinite}.frak-overlay:after{background:conic-gradient(from var(--neon-angle, 0deg),transparent 0%,transparent 18%,var(--accent-dim) 25%,transparent 42%,transparent 100%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;padding:4px;filter:blur(6px);animation:neon-rotate 4s linear infinite}.overlay-enter-active{transition:all .3s cubic-bezier(.16,1,.3,1)}.overlay-leave-active{transition:all .2s cubic-bezier(.4,0,1,1)}.overlay-enter-from{opacity:0;transform:scale(.95) translateY(10px)}.overlay-leave-to{opacity:0;transform:scale(.97) translateY(5px)}.garage-overlay{width:50vw;max-width:700px}.frak-sidebar{width:220px;min-width:220px;background:linear-gradient(180deg,var(--accent-subtle) 0%,transparent 40%);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;position:relative;z-index:1}.sidebar-banner{position:relative;height:140px;overflow:hidden;flex-shrink:0}.sidebar-banner-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;animation:banner-zoom 20s ease-in-out infinite alternate}.sidebar-banner-gradient{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#0a0a0ef2,#0a0a0e80,#00000026)}.sidebar-banner-fallback{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-subtle),var(--surface-1))}.sidebar-banner-fallback svg{opacity:.1;color:var(--accent)}.sidebar-banner-content{position:absolute;bottom:0;left:0;right:0;padding:var(--space-lg);display:flex;align-items:center;gap:var(--space-md)}.sidebar-avatar{width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-dim),var(--accent-subtle));border:2px solid var(--accent);border-radius:var(--radius-lg);color:var(--accent);flex-shrink:0;box-shadow:0 0 14px var(--accent-glow)}.sidebar-banner-info{flex:1;min-width:0}.sidebar-banner-name{font-size:15px;font-weight:800;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:0 2px 8px rgba(0,0,0,.6)}.sidebar-banner-rank{font-size:11px;font-weight:600;color:var(--accent);text-shadow:0 1px 4px rgba(0,0,0,.5);margin-top:1px}.sidebar-nav{flex:1;padding:var(--space-md);display:flex;flex-direction:column;gap:3px;overflow-y:auto}.sidebar-nav-btn{display:flex;align-items:center;gap:var(--space-md);padding:11px 14px;background:transparent;border:1px solid transparent;border-radius:var(--radius-lg);color:var(--text-muted);font-size:13px;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);text-align:left;white-space:nowrap}.sidebar-nav-icon{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--radius-md);background:var(--surface-1);border:1px solid var(--border-subtle);color:var(--text-dim);flex-shrink:0;transition:all var(--transition-fast)}.sidebar-nav-btn:hover{color:var(--text-secondary)}.sidebar-nav-btn:hover .sidebar-nav-icon{background:var(--surface-2);border-color:var(--border-default);color:var(--text-muted)}.sidebar-nav-btn.active{color:var(--accent);background:var(--accent-dim);border-color:var(--border-accent)}.sidebar-nav-btn.active .sidebar-nav-icon{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 12px var(--accent-glow)}.sidebar-footer{padding:var(--space-md);border-top:1px solid var(--border-subtle)}.close-sidebar-btn{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:9px 14px;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-dim);font-size:11px;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast)}.close-sidebar-btn:hover{background:var(--danger-dim);border-color:#ef444426;color:var(--danger)}.frak-main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.frak-main-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg) var(--space-2xl);border-bottom:1px solid var(--border-subtle);flex-shrink:0;position:relative}.frak-main-header:after{content:"";position:absolute;bottom:-1px;left:5%;right:5%;height:1px;background:linear-gradient(90deg,transparent,var(--border-accent),transparent)}.frak-main-header h2{font-size:18px;font-weight:800;color:var(--text-primary);letter-spacing:-.3px}.header-left{display:flex;align-items:center;gap:14px}.header-icon{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-dim),var(--accent-subtle));border:1px solid var(--border-accent);border-radius:var(--radius-md);color:var(--accent);flex-shrink:0}.close-btn{background:var(--surface-1);border:1px solid var(--border-subtle);color:var(--text-dim);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast)}.close-btn:hover{background:var(--danger-dim);border-color:#ef444426;color:var(--danger);transform:scale(1.05)}.frak-content{flex:1;overflow-y:auto;padding:var(--space-xl) var(--space-2xl)}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md);margin-bottom:var(--space-xl)}.stat-card{background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-sm);position:relative;overflow:hidden;transition:all var(--transition-fast)}.stat-card:hover{background:var(--surface-2);border-color:var(--border-accent);transform:translateY(-2px);box-shadow:0 4px 16px #0003}.stat-card:after{content:"";position:absolute;top:0;left:0;width:40%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.02),transparent);animation:shimmer-line 4s ease-in-out infinite;pointer-events:none}.stat-icon{width:44px;height:44px;border-radius:var(--radius-lg);background:var(--accent-dim);border:1px solid var(--border-accent);display:flex;align-items:center;justify-content:center;color:var(--accent)}.stat-icon svg{width:20px;height:20px}.stat-value{font-size:22px;font-weight:800;color:var(--accent);font-variant-numeric:tabular-nums;text-shadow:0 0 16px var(--accent-glow);letter-spacing:-.5px}.stat-label{font-size:10px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.8px;font-weight:600}.dash-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md);margin-bottom:var(--space-md)}.player-card{background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-xl);display:flex;flex-direction:column;gap:var(--space-lg)}.player-card-header{display:flex;align-items:center;gap:var(--space-lg)}.player-card-avatar{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-dim),var(--accent-subtle));border:2px solid var(--accent);border-radius:var(--radius-xl);color:var(--accent);flex-shrink:0;box-shadow:0 0 16px var(--accent-glow)}.player-card-info{flex:1}.player-card-name{font-size:16px;font-weight:700;color:var(--text-primary)}.player-card-rank-badge{display:inline-block;margin-top:4px;padding:3px 10px;border-radius:20px;background:var(--accent-dim);border:1px solid var(--border-accent);color:var(--accent);font-size:11px;font-weight:700}.progress-label{display:flex;justify-content:space-between;font-size:10px;color:var(--text-dim);font-weight:600;margin-bottom:6px}.progress-track{height:6px;background:var(--surface-3);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-light));border-radius:3px;transition:width .5s ease;box-shadow:0 0 8px var(--accent-glow)}.player-card-meta{display:flex;gap:var(--space-xl)}.meta-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);font-weight:500}.meta-item svg{color:var(--text-dim)}.rank-list-card{background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-xl);display:flex;flex-direction:column}.rank-list{flex:1;overflow-y:auto;max-height:200px;display:flex;flex-direction:column;gap:3px}.rank-list-item{display:flex;align-items:center;gap:var(--space-md);padding:8px 12px;border-radius:var(--radius-md);transition:all var(--transition-fast)}.rank-list-item:hover{background:var(--surface-2)}.rank-list-number{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-size:11px;font-weight:700;color:var(--text-dim);font-variant-numeric:tabular-nums;flex-shrink:0}.rank-list-label{flex:1;font-size:13px;font-weight:500;color:var(--text-secondary)}.rank-list-badge{padding:2px 8px;border-radius:10px;background:var(--accent-dim);color:var(--accent);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.rank-list-item.current{background:var(--accent-dim);border:1px solid var(--border-accent);box-shadow:0 0 8px var(--accent-glow)}.rank-list-item.current .rank-list-number{background:var(--accent);border-color:var(--accent);color:#fff}.rank-list-item.current .rank-list-label{color:var(--text-primary);font-weight:600}.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.quick-action{display:flex;align-items:center;gap:var(--space-md);padding:14px var(--space-lg);background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-family);text-align:left}.quick-action:hover{background:var(--surface-2);border-color:var(--border-accent);transform:translate(3px);box-shadow:0 2px 12px #00000026}.quick-action-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--accent-dim);border:1px solid var(--border-accent);border-radius:var(--radius-lg);color:var(--accent);flex-shrink:0;transition:all var(--transition-fast)}.quick-action-icon.treasury{background:var(--success-dim);color:var(--success);border-color:#4ade8026}.quick-action-icon.perms{background:#a855f71f;color:#a855f7;border-color:#a855f726}.quick-action:hover .quick-action-icon{box-shadow:0 0 10px var(--accent-glow)}.quick-action:hover .quick-action-icon.treasury{box-shadow:0 0 10px #4ade8033}.quick-action:hover .quick-action-icon.perms{box-shadow:0 0 10px #a855f733}.quick-action-info{flex:1}.quick-action-title{font-size:13px;font-weight:600;color:var(--text-primary)}.quick-action-desc{font-size:10px;color:var(--text-dim);margin-top:2px}.quick-action-arrow{color:var(--text-ghost);flex-shrink:0;transition:all var(--transition-fast)}.quick-action:hover .quick-action-arrow{color:var(--accent);transform:translate(2px)}.section-title{font-size:13px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:var(--space-md);display:flex;align-items:center;gap:8px}.section-title:before{content:"";width:3px;height:16px;background:var(--accent);border-radius:2px;flex-shrink:0}.listing-card{display:flex;align-items:center;gap:var(--space-lg);background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:14px var(--space-lg);transition:all var(--transition-fast);animation:card-appear .3s ease-out both}.listing-card:hover{background:var(--surface-2);border-color:var(--border-accent);box-shadow:0 4px 16px #00000026;transform:translate(4px)}.listing-card-info{flex:1;min-width:0}.listing-card .listing-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.listing-card .listing-meta{font-size:11px;color:var(--text-dim);margin-top:3px}.listing-card-actions{display:flex;gap:6px;flex-shrink:0}.scrollable-list .listing-card:nth-child(1){animation-delay:0s}.scrollable-list .listing-card:nth-child(2){animation-delay:.03s}.scrollable-list .listing-card:nth-child(3){animation-delay:.06s}.scrollable-list .listing-card:nth-child(4){animation-delay:.09s}.scrollable-list .listing-card:nth-child(5){animation-delay:.12s}.scrollable-list .listing-card:nth-child(6){animation-delay:.15s}.scrollable-list .listing-card:nth-child(7){animation-delay:.18s}.scrollable-list .listing-card:nth-child(8){animation-delay:.21s}.listing-action-btn{padding:7px 12px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--surface-1);color:var(--text-dim);font-size:11px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-family)}.listing-action-btn:hover{background:var(--accent-subtle);border-color:var(--border-accent);color:var(--accent);transform:translateY(-1px);box-shadow:0 2px 8px var(--accent-glow)}.listing-action-btn.danger:hover{background:var(--danger-dim);border-color:#ef444426;color:var(--danger);box-shadow:0 2px 8px #ef444426}.listing-action-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.online-badge{width:10px;height:10px;border-radius:50%;flex-shrink:0}.online-badge.online{background:var(--success);box-shadow:0 0 6px var(--success);animation:status-pulse 2s ease-in-out infinite}.online-badge.offline{background:var(--text-ghost)}.member-avatar{width:46px;height:46px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--accent-dim),var(--accent-subtle));border:1px solid var(--border-accent);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0;font-size:17px;font-weight:700}.frak-btn{width:100%;padding:14px;border:none;border-radius:var(--radius-lg);font-size:14px;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-default);background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#fff;letter-spacing:.3px;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);position:relative;overflow:hidden}.frak-btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.12) 50%,transparent 60%);transform:translate(-100%);transition:transform .5s}.frak-btn:hover:not(:disabled){transform:translateY(-1px)}.frak-btn:hover:not(:disabled):after{transform:translate(100%)}.frak-btn:active:not(:disabled){transform:translateY(0) scale(.98)}.frak-btn:disabled{background:var(--surface-1);color:var(--text-ghost);cursor:not-allowed;border:1px solid var(--border-subtle);opacity:.6}.frak-btn:disabled:after{display:none}.frak-btn:not(:disabled):not(.ghost):not(.small){animation:pulse-glow 2.5s ease-in-out infinite}.frak-btn.small{width:auto;padding:8px 16px;font-size:12px;border-radius:var(--radius-md);animation:none}.frak-btn.green{background:linear-gradient(135deg,var(--success),#22c55e)}.frak-btn.green:hover:not(:disabled){background:linear-gradient(135deg,#86efac,var(--success))}.frak-btn.green:not(:disabled):not(.ghost):not(.small){--accent-glow: rgba(74, 222, 128, .25)}.frak-btn.red{background:linear-gradient(135deg,var(--danger),#dc2626)}.frak-btn.red:hover:not(:disabled){background:linear-gradient(135deg,#f87171,var(--danger))}.frak-btn.red:not(:disabled):not(.ghost):not(.small){--accent-glow: rgba(239, 68, 68, .25)}.frak-btn.ghost{background:var(--surface-1);border:1px solid rgba(255,255,255,.05);color:var(--text-secondary);animation:none}.frak-btn.ghost:after{display:none}.frak-btn.ghost:hover:not(:disabled){background:var(--surface-2);border-color:var(--border-default);color:var(--text-primary);transform:none}.frak-input{width:100%;padding:11px 14px;background:var(--surface-1);border:1px solid rgba(255,255,255,.05);border-radius:var(--radius-md);color:var(--text-primary);font-size:13px;font-weight:500;font-family:var(--font-family);outline:none;transition:all var(--transition-fast)}.frak-input:focus{border-color:var(--accent);background:var(--accent-subtle);box-shadow:0 0 0 3px var(--accent-glow)}.frak-input::placeholder{color:var(--text-ghost)}.search-bar{display:flex;align-items:center;gap:10px;padding:11px 14px;background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);margin-bottom:var(--space-md);transition:all var(--transition-fast)}.search-bar:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.search-bar svg{color:var(--text-ghost);flex-shrink:0;transition:color var(--transition-fast)}.search-bar:focus-within svg{color:var(--accent)}.search-bar input{flex:1;border:none;background:transparent;color:var(--text-primary);font-size:13px;font-family:var(--font-family);outline:none}.search-bar input::placeholder{color:var(--text-ghost)}.perm-select{padding:7px 28px 7px 10px;background-color:#14141af2;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%2371717a' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-secondary);font-size:11px;font-weight:600;font-family:var(--font-family);cursor:pointer;outline:none;transition:all var(--transition-fast)}.perm-select:hover{border-color:var(--border-accent);background-color:#1e1e26f2}.perm-select:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}.perm-select option{background:#14141a;color:var(--text-secondary);padding:6px 10px}.scrollable-list{max-height:400px;overflow-y:auto;display:flex;flex-direction:column;gap:5px;padding-right:2px}.treasury-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.treasury-section{background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-xl)}.treasury-section-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.treasury-section-icon{width:40px;height:40px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.treasury-section-icon svg{width:20px;height:20px}.treasury-section-icon.deposit{background:var(--success-dim);color:var(--success);box-shadow:0 0 10px #4ade8026}.treasury-section-icon.withdraw{background:var(--danger-dim);color:var(--danger);box-shadow:0 0 10px #ef444426}.treasury-section-title{font-size:14px;font-weight:700;color:var(--text-primary)}.tx-row{display:flex;align-items:center;gap:12px;padding:12px 14px;font-size:12px;background:var(--surface-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-fast);animation:card-appear .3s ease-out both}.tx-row:hover{background:var(--surface-2);transform:translate(3px)}.tx-row-info{flex:1}.tx-row .tx-name{font-weight:600;color:var(--text-primary);font-size:13px}.tx-row .tx-meta{font-size:11px;color:var(--text-ghost);margin-top:2px}.tx-row .tx-amount{font-weight:700;flex-shrink:0;font-variant-numeric:tabular-nums;font-size:14px}.tx-row .tx-amount.deposit{color:var(--success);text-shadow:0 0 10px rgba(74,222,128,.2)}.tx-row .tx-amount.withdraw{color:var(--danger);text-shadow:0 0 10px rgba(239,68,68,.2)}.tx-icon{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px;font-weight:700}.tx-icon.deposit{background:var(--success-dim);color:var(--success)}.tx-icon.withdraw{background:var(--danger-dim);color:var(--danger)}.vehicle-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md)}.vehicle-card{background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-fast);animation:card-appear .3s ease-out both}.vehicle-card:hover{border-color:var(--border-accent);box-shadow:0 6px 24px #0003;transform:translateY(-3px)}.vehicle-card-image{width:100%;aspect-ratio:16 / 10;background:linear-gradient(135deg,var(--surface-2),var(--surface-3));display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.vehicle-card-image img{width:100%;height:100%;object-fit:cover;filter:drop-shadow(0 4px 12px rgba(0,0,0,.5));transition:transform var(--transition-default)}.vehicle-card:hover .vehicle-card-image img{transform:scale(1.08)}.vehicle-card-image .vehicle-fallback-icon{color:var(--text-ghost);opacity:.3;filter:drop-shadow(0 0 10px currentColor);transition:all var(--transition-default)}.vehicle-card:hover .vehicle-fallback-icon{opacity:.5;transform:scale(1.1)}.vehicle-card-body{padding:var(--space-md);display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.vehicle-card-info{flex:1}.vehicle-card-name{font-size:14px;font-weight:600;color:var(--text-primary)}.vehicle-card-meta{font-size:10px;color:var(--text-dim);margin-top:2px}.vehicle-alert{border-color:#ef444433;background:var(--danger-dim);animation:alert-pulse 2s ease-in-out infinite}.perm-row{display:flex;align-items:center;gap:var(--space-lg);background:var(--surface-1);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:14px var(--space-lg);transition:all var(--transition-fast)}.perm-row+.perm-row{margin-top:5px}.perm-row:hover{background:var(--surface-2);border-color:var(--border-default)}.perm-info{flex:1;min-width:0}.perm-label{font-size:13px;font-weight:600;color:var(--text-secondary)}.perm-current{font-size:11px;color:var(--text-dim);margin-top:2px}.perm-controls{display:flex;gap:4px;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}.perm-grade-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-subtle);border-radius:var(--radius-md);background:var(--surface-2);color:var(--text-dim);font-size:12px;font-weight:700;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);font-variant-numeric:tabular-nums}.perm-grade-btn:hover:not(.active){background:var(--surface-3);border-color:var(--accent);color:var(--text-secondary);transform:scale(1.08)}.perm-grade-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 14px var(--accent-glow);transform:scale(1.08)}.confirm-overlay,.invite-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200}.confirm-box{background:#0a0a0efa;border:2px solid var(--border-accent);border-radius:var(--radius-xl);padding:var(--space-2xl) 32px;max-width:400px;width:90%;box-shadow:0 0 50px #00000080,0 0 20px var(--accent-glow);text-align:center}.confirm-icon{width:56px;height:56px;border-radius:50%;background:var(--accent-dim);border:2px solid var(--border-accent);display:flex;align-items:center;justify-content:center;color:var(--accent);margin:0 auto var(--space-lg);box-shadow:0 0 20px var(--accent-glow)}.confirm-box h3{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-sm)}.confirm-box p{font-size:13px;color:var(--text-muted);line-height:1.6;margin-bottom:var(--space-xl)}.confirm-actions{display:flex;gap:var(--space-sm)}.empty-state{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px;background:var(--surface-card);border:1px dashed var(--border-subtle);border-radius:var(--radius-lg);text-align:center}.empty-state svg{width:44px;height:44px;color:var(--text-ghost);opacity:.35}.empty-state span{font-size:13px;font-weight:500;color:var(--text-dim)}.fade-enter-active{transition:all .25s cubic-bezier(.16,1,.3,1)}.fade-leave-active{transition:all .15s ease-in}.fade-enter-from{opacity:0;transform:translateY(6px)}.fade-leave-to{opacity:0;transform:translateY(-4px)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:#ffffff03;margin:4px 0}::-webkit-scrollbar-thumb{background:var(--accent-dim);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-accent)}.row{display:flex;gap:var(--space-sm)}.row>*{flex:1}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}