*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #09090b;--bg-secondary: #121216;--bg-tertiary: #1b1b21;--bg-hover: #212129;--border: #27272f;--border-hover: #383842;--text-primary: #f4f1f1;--text-secondary: #b6a7aa;--text-muted: #7f7074;--accent: #d7263d;--accent-hover: #b71f33;--accent-glow: rgba(215, 38, 61, .24);--success: #44ff88;--warning: #ffaa44;--danger: #ff4444;--danger-hover: #dd3333;--sidebar-bg: #0c0c10;--card-bg: #121216;--radius: 16px;--radius-sm: 8px}html,body,#root{height:100%;width:100%;overflow:hidden;overscroll-behavior:none}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif;background:var(--app-background, var(--bg-primary));color:var(--text-primary);overflow:hidden;-webkit-font-smoothing:antialiased;background-size:cover;background-position:center;background-attachment:fixed}*,*:before,*:after{transition:background-color .35s ease,border-color .35s ease,color .2s ease,box-shadow .35s ease}.app-layout{height:100vh;display:flex;flex-direction:column;padding:16px;gap:16px;overflow:hidden}.top-bar{display:flex;align-items:center;gap:20px;flex-shrink:0}.brand-box{background:var(--card-bg);border-radius:16px;padding:10px 18px;display:flex;align-items:center;gap:14px;flex-shrink:0}.brand-box .logo{width:28px;height:28px;object-fit:contain;display:block;flex-shrink:0}.brand-box .brand-text h1{color:var(--text-primary);font-size:13px;font-weight:600;margin:0}.brand-box .brand-text p{color:var(--text-muted);font-size:11px;margin-top:2px}.tabs-wrapper{display:flex;align-items:center;justify-content:center;background:var(--card-bg);padding:5px;border-radius:30px;gap:3px}.tab{padding:7px 14px;color:var(--text-muted);font-size:12px;font-weight:500;border-radius:20px;cursor:pointer;display:flex;align-items:center;gap:7px;transition:color .2s,background-color .2s;user-select:none;white-space:nowrap}.tab:hover{color:var(--text-secondary)}.tab.active{background:var(--bg-hover);color:var(--text-primary)}.tab svg{width:14px;height:14px;flex-shrink:0}.conn-badge{margin-left:auto;display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:20px;font-size:12px;font-weight:500;flex-shrink:0;white-space:nowrap}.conn-badge.off{background:#ff444414;color:var(--danger)}.conn-badge.on{background:#44ff8814;color:var(--success)}.conn-badge-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.conn-badge.off .conn-badge-dot{background:var(--danger)}.conn-badge.on .conn-badge-dot{background:var(--success);box-shadow:0 0 5px var(--success)}.conn-badge-text{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.workspace{display:flex;flex:1;gap:20px;overflow:hidden}.sidebar{width:70px;background:var(--card-bg);border-radius:16px;display:flex;flex-direction:column;align-items:center;padding:12px 0;gap:4px;flex-shrink:0;user-select:none}.nav-item{width:100%;height:48px;display:flex;justify-content:center;align-items:center;color:var(--text-muted);cursor:pointer;position:relative;transition:color .2s,background-color .2s;background:none;border:none;flex-shrink:0}.nav-item:hover{color:#aaa}.nav-item.active{color:var(--text-primary);background:#ffffff05}.nav-item.active:after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--accent);border-radius:3px 0 0 3px}.nav-item-badge{position:absolute;top:8px;right:8px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--danger);color:#fff;font-size:10px;font-weight:700;line-height:18px;text-align:center;box-shadow:0 0 0 2px var(--card-bg)}.nav-separator{width:32px;height:1px;background:#ffffff0f;margin:4px 0;border-radius:1px}.main-content{flex:1;overflow-y:auto;padding:0;min-height:0;border-radius:16px}.main-content::-webkit-scrollbar{width:4px}.main-content::-webkit-scrollbar-track{background:transparent}.main-content::-webkit-scrollbar-thumb{background:#2a2a2f;border-radius:4px}.home-page{display:grid;grid-template-columns:280px 1fr;gap:20px;height:100%;overflow:hidden}.home-left{display:flex;flex-direction:column;gap:10px;overflow-y:auto;min-height:0}.home-left::-webkit-scrollbar{width:3px}.home-left::-webkit-scrollbar-track{background:transparent}.home-left::-webkit-scrollbar-thumb{background:#2a2a2f;border-radius:3px}.home-right{display:flex;flex-direction:column;overflow:hidden;min-height:0}.status-panel{display:flex;align-items:center;gap:16px;padding:16px;background:var(--card-bg);border-radius:var(--radius);flex-shrink:0}.connect-btn{width:56px;height:56px;border-radius:50%;border:2px solid var(--border);background:var(--bg-tertiary);cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.connect-btn:hover{border-color:var(--accent);box-shadow:0 0 20px var(--accent-glow)}.connect-btn.connected{border-color:var(--success);box-shadow:0 0 20px #4f83}.connect-btn.connected:hover{border-color:var(--danger);box-shadow:0 0 20px #f443}.connect-btn.loading{opacity:.7;cursor:wait}.connect-btn-inner{display:flex;align-items:center;justify-content:center}.connect-btn-icon{font-size:24px;color:var(--text-primary)}.status-info{display:flex;flex-direction:column;gap:4px}.status-label{font-size:18px;font-weight:600}.status-server{font-size:14px;color:var(--text-secondary);display:inline-flex;align-items:center;gap:6px}.status-server.selected{color:var(--accent)}.status-time{font-size:13px;color:var(--text-muted);font-family:Consolas,Fira Code,monospace}.status-core{font-size:11px;color:var(--text-muted);font-family:Consolas,Fira Code,monospace}.connection-info-bar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:2px}.info-chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:2px 8px;border-radius:4px;background:var(--bg-tertiary);color:var(--text-secondary);font-family:Consolas,Fira Code,monospace}.info-chip-label{color:var(--text-muted);font-size:10px;text-transform:uppercase;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif}.info-chip.proto{color:var(--accent);border:1px solid var(--accent);background:transparent;font-weight:600;letter-spacing:.3px}.traffic-panel{display:flex;align-items:center;padding:12px 16px;background:var(--card-bg);border-radius:var(--radius);gap:0;flex-shrink:0}.traffic-item{flex:1;display:flex;align-items:center;gap:12px}.traffic-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center}.upload-icon{background:#7c5cff26;color:var(--accent)}.download-icon{background:#44ff8826;color:var(--success)}.traffic-speed{font-size:16px;font-weight:600;font-family:Consolas,Fira Code,monospace}.traffic-total{font-size:12px;color:var(--text-muted)}.traffic-divider{width:1px;height:36px;background:var(--border);margin:0 14px}.home-left .traffic-panel{flex-direction:column;gap:8px;padding:12px 14px}.home-left .traffic-sparkline{display:none}.home-left .traffic-item{flex:unset;width:100%}.home-left .traffic-divider{display:none}.quick-connect{display:flex;flex-direction:column;gap:6px;flex-shrink:0;padding:0;overflow:hidden}.quick-section{display:flex;flex-direction:column;gap:5px;min-width:0;overflow:hidden}.quick-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;font-weight:600}.quick-items{display:flex;flex-direction:column;gap:4px;min-width:0;overflow:hidden}.quick-item{display:flex;align-items:center;gap:6px;padding:6px 10px;background:var(--bg-tertiary);border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:12px;color:var(--text-primary);white-space:nowrap;transition:all .15s;width:100%}.quick-item:hover{border-color:var(--border-hover);background:var(--bg-hover)}.quick-item.active{border-color:var(--accent);background:var(--bg-tertiary)}.quick-item-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quick-item-ping{font-size:10px;color:var(--text-muted);font-family:Consolas,Fira Code,monospace}.quick-recommended{display:flex;align-items:center;gap:6px;padding:6px 10px;background:transparent;border:1px solid var(--accent);border-radius:var(--radius-sm);color:var(--accent);cursor:pointer;font-size:11px;font-weight:600;transition:all .15s;width:100%;overflow:hidden}.quick-recommended span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quick-recommended:hover{background:var(--accent);color:#fff}.server-list-panel{display:flex;flex-direction:column;gap:12px;flex:1;min-height:0;overflow:hidden}.server-list-header{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.search-input{flex:1;min-width:140px;padding:7px 12px;background:var(--bg-tertiary);border:none;border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;outline:none;transition:box-shadow .15s}.search-input:focus{box-shadow:0 0 0 1px var(--accent)}.server-list-actions{display:flex;gap:6px}.import-box{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px;display:flex;flex-direction:column;gap:8px}.import-textarea{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:Consolas,Fira Code,monospace;font-size:12px;padding:8px;resize:vertical;outline:none}.import-textarea:focus{border-color:var(--accent)}.import-actions{display:flex;gap:8px}.server-tabs{display:flex;gap:4px;overflow-x:auto;padding-bottom:4px}.tab-btn{padding:6px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:12px;cursor:pointer;white-space:nowrap;transition:all .15s}.tab-btn:hover{background:var(--bg-hover)}.tab-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.server-list-items{display:flex;flex-direction:column;gap:4px;flex:1;min-height:0;overflow-y:auto}.server-card{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--card-bg);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.server-card:hover{background:var(--bg-hover)}.server-card.active{background:color-mix(in srgb,var(--accent) 10%,var(--card-bg));box-shadow:inset 0 0 0 2px var(--accent)}.server-proto{font-size:10px;padding:2px 6px;border-radius:4px;background:var(--bg-tertiary);color:var(--text-muted);text-transform:uppercase;font-weight:600;flex-shrink:0}.proto-badge{font-size:10px;padding:2px 7px;border-radius:4px;border:1px solid;background:transparent;text-transform:uppercase;font-weight:600;flex-shrink:0;letter-spacing:.3px}.stack-badge{font-size:10px;padding:2px 6px;border-radius:4px;background:var(--bg-tertiary);color:var(--text-muted);font-weight:500;flex-shrink:0;letter-spacing:.2px;white-space:nowrap}@media (max-width: 600px){.server-card{flex-wrap:wrap;row-gap:4px;column-gap:8px;padding:10px 12px}.server-card .server-name{flex-basis:100%;order:-1;font-size:14px;font-weight:500}.server-card .ping-section .ping-bar-container{display:none}.server-card .ping-section{min-width:auto}.server-card .proto-badge,.server-card .stack-badge{font-size:9px;padding:1px 5px}}.ping-section{display:flex;align-items:center;gap:6px;min-width:90px;justify-content:flex-end}.ping-bar-container{width:40px;height:4px;background:var(--bg-tertiary);border-radius:2px;overflow:hidden;flex-shrink:0}.ping-bar{height:100%;border-radius:2px;transition:width .3s ease}.ping-bar.good{background:var(--success)}.ping-bar.medium{background:var(--warning)}.ping-bar.bad{background:var(--danger)}.grid-card .ping-bar-container{width:100%;margin-top:4px}.server-name{flex:1;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.server-ping{font-size:12px;color:var(--text-muted);min-width:55px;text-align:right;font-family:Consolas,Fira Code,monospace}.server-ping.good{color:var(--success)}.server-ping.medium{color:var(--warning)}.server-ping.bad{color:var(--danger)}.server-delete{font-size:16px;color:var(--text-muted);cursor:pointer;padding:0 4px;opacity:0;transition:all .15s}.server-card:hover .server-delete{opacity:1}.server-delete:hover{color:var(--danger)}.empty-list{color:var(--text-muted);font-size:13px;text-align:center;padding:32px}.sub-page{max-width:800px}.sub-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:8px;flex-wrap:wrap}.sub-header-actions{display:flex;gap:8px;flex-wrap:wrap}.sub-header h2{font-size:20px}.sub-list{display:flex;flex-direction:column;gap:8px}.sub-card{display:flex;flex-direction:column;padding:16px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius)}.sub-info{display:flex;flex-direction:column;gap:4px;overflow:hidden;flex:1;min-width:0}.sub-name{font-size:15px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.sub-url{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:400px}.sub-meta{font-size:12px;color:var(--text-secondary)}.sub-actions{display:flex;gap:8px;flex-shrink:0}.sub-featured{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 6%,var(--card-bg));transition:border-color .15s ease,background .15s ease}.sub-featured:hover{border-color:var(--accent-hover);background:color-mix(in srgb,var(--accent) 10%,var(--card-bg))}.sub-featured-badge{display:inline-block;padding:1px 7px;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-right:8px;background:var(--accent);color:#fff}.sub-top{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%}.sub-info.clickable{cursor:pointer;border-radius:6px;padding:4px 6px;margin:-4px -6px;transition:background .15s ease}.sub-info.clickable:hover{background:color-mix(in srgb,var(--text-primary) 5%,transparent)}.sub-info.clickable:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.sub-name-row{display:flex;align-items:center;gap:6px}.sub-chevron{color:var(--text-muted);transition:transform .2s ease;flex-shrink:0}.sub-chevron.open{transform:rotate(180deg)}.sub-compact-meta{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-muted);margin-top:2px;flex-wrap:wrap}.sub-sep{opacity:.4}.sub-auto-tag{display:inline-flex;align-items:center;gap:3px;color:var(--accent)}.sub-expanded{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:6px;width:100%}.sub-row{display:flex;align-items:center;gap:8px;font-size:13px}.sub-row-icon{flex-shrink:0;color:var(--text-muted)}.sub-row-icon.text-danger{color:var(--danger)}.sub-row-icon.text-warning{color:var(--warning)}.sub-row-label{font-size:12px;color:var(--text-muted);min-width:70px}.sub-row-value{font-weight:500;color:var(--text-primary);display:flex;align-items:center;gap:6px}.sub-row-value.text-danger{color:var(--danger)}.sub-row-value.text-warning{color:var(--warning)}.sub-row-dim{color:var(--text-muted);font-weight:400}.sub-row-links{display:flex;gap:12px}.sub-row-link{font-size:12px;font-weight:500;color:var(--accent);cursor:pointer;background:none;border:none;padding:0;font-family:inherit}.sub-row-link:hover,.sub-row-link:focus-visible{text-decoration:underline;color:var(--accent-hover)}.sub-row-link:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}.sub-badge{display:inline-block;padding:1px 6px;border-radius:3px;font-size:10px;font-weight:600;background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent)}.sub-badge.warning{background:color-mix(in srgb,var(--warning) 15%,transparent);color:var(--warning)}.sub-progress{height:4px;background:var(--border);border-radius:2px;overflow:hidden;margin-left:22px;margin-top:-2px}.sub-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.sub-progress-fill.warning{background:var(--warning)}.sub-progress-fill.danger{background:var(--danger)}.sub-announce{display:flex;gap:6px;align-items:flex-start;padding:8px 10px;border-radius:6px;background:color-mix(in srgb,var(--accent) 6%,transparent);border:1px solid color-mix(in srgb,var(--accent) 15%,transparent);font-size:12px;line-height:1.4;color:var(--text-secondary);white-space:pre-line}.announce-banner{display:flex;gap:10px;padding:10px 14px;margin-bottom:12px;background:color-mix(in srgb,var(--accent) 8%,var(--card-bg));border:1px solid color-mix(in srgb,var(--accent) 25%,var(--border));border-radius:var(--radius);font-size:13px;line-height:1.5;color:var(--text-primary);white-space:pre-line}.announce-banner-icon{flex-shrink:0;color:var(--accent);margin-top:1px}.announce-banner-content{flex:1;min-width:0;overflow-wrap:break-word}.announce-banner-source{font-size:11px;color:var(--text-muted);margin-top:4px}.settings-page{max-width:700px;display:flex;flex-direction:column;gap:16px}.settings-page h2{font-size:14px;font-weight:500;color:var(--text-muted);margin-bottom:0}.settings-section{background:var(--card-bg);border-radius:var(--radius);padding:16px}.settings-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-weight:500}.theme-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.background-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(132px,1fr));gap:10px}.background-card{border:1px solid var(--border);background:var(--bg-secondary);border-radius:var(--radius-sm);padding:10px;cursor:pointer;display:flex;flex-direction:column;gap:10px;color:var(--text-secondary);text-align:left}.background-card:hover{border-color:var(--border-hover);transform:translateY(-2px)}.background-card.active{border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow);color:var(--text-primary)}.background-preview{display:block;width:100%;height:64px;border-radius:10px;border:1px solid rgba(255,255,255,.08);background-size:cover;background-position:center}.background-preview-theme{background:radial-gradient(circle at top,rgba(255,0,60,.18),transparent 38%),linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 55%,var(--bg-tertiary) 100%)}.background-card-label{font-size:12px;font-weight:600}.background-upload-row{margin-top:12px;display:flex;gap:10px;flex-wrap:wrap}.background-upload-btn,.background-reset-btn{border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;font-weight:600;cursor:pointer}.background-upload-btn:hover,.background-reset-btn:hover{border-color:var(--border-hover)}.background-upload-btn input{display:none}.settings-hint{margin-top:10px;font-size:12px;color:var(--text-muted);line-height:1.5}.admin-only-notice{max-width:540px}.admin-only-message{color:var(--text-secondary);font-size:14px;line-height:1.6}.admin-page{display:flex;flex-direction:column;gap:16px}.desktop-login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(circle at top left,rgba(124,92,255,.12),transparent 32%),radial-gradient(circle at bottom right,rgba(68,255,136,.1),transparent 28%),var(--app-background, var(--bg-primary))}.desktop-login-card{width:min(100%,420px);display:flex;flex-direction:column;gap:16px;padding:28px;border-radius:24px;background:#0a0a10d1;border:1px solid rgba(255,255,255,.06);box-shadow:0 24px 80px #00000047;backdrop-filter:blur(18px)}.desktop-login-card h1{font-size:30px;line-height:1.1}.desktop-login-actions{display:flex;gap:10px;flex-wrap:wrap}.desktop-login-meta{margin:0;color:var(--text-muted);font-size:12px;line-height:1.5}.auth-shell{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr;gap:24px;padding:24px;background:radial-gradient(circle at top left,rgba(124,92,255,.18),transparent 30%),radial-gradient(circle at bottom right,rgba(68,255,136,.12),transparent 26%),var(--app-background, var(--bg-primary))}.auth-panel{background:#0a0a10c7;border:1px solid rgba(255,255,255,.06);border-radius:24px;padding:28px;backdrop-filter:blur(18px)}.auth-panel-brand{display:flex;flex-direction:column;justify-content:space-between;gap:24px}.auth-panel-brand h1,.auth-panel-form h2{font-size:32px;line-height:1.1;margin-bottom:10px}.auth-panel-brand p,.auth-panel-form p{color:var(--text-secondary);line-height:1.6}.auth-brand-badge{width:fit-content;padding:8px 12px;border-radius:999px;background:#7c5cff24;color:#d7cbff;font-size:12px;letter-spacing:.08em;text-transform:uppercase}.auth-meta-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.auth-meta-card{display:flex;flex-direction:column;gap:8px;padding:16px;border-radius:18px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06)}.auth-meta-card span{color:var(--text-muted);font-size:12px}.auth-meta-card strong{font-size:16px;color:var(--text-primary);overflow-wrap:anywhere}.auth-panel-form{display:flex;flex-direction:column;justify-content:center;gap:18px}.auth-upload-box,.auth-footer-actions{display:flex;gap:10px;flex-wrap:wrap}.user-session-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;margin-bottom:16px;border-radius:14px;background:#ffffff0a;border:1px solid var(--border)}.admin-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.admin-hero h2,.admin-auth-card h2{font-size:24px;margin-bottom:8px}.admin-page-copy{color:var(--text-secondary);max-width:720px;line-height:1.6}.admin-hero-actions{display:flex;gap:10px;flex-wrap:wrap}.admin-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.admin-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.admin-auth-card{max-width:520px}.admin-auth-form,.admin-form{display:flex;flex-direction:column;gap:10px}.admin-input{width:100%;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);border-radius:var(--radius-sm);padding:12px 14px;font-size:14px}.admin-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent)}.admin-inline-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.admin-list{display:flex;flex-direction:column;gap:10px;margin-top:12px}.admin-list-item{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;background:var(--bg-secondary);border:1px solid var(--border)}.admin-log-item{align-items:flex-start;flex-direction:column}.admin-user-item{align-items:flex-start}.admin-user-controls{display:flex;flex-direction:column;align-items:flex-end;gap:10px;min-width:220px}.admin-user-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.admin-announcement-textarea{min-height:120px;resize:vertical}.admin-list-title{color:var(--text-primary);font-size:14px;font-weight:600}.admin-list-subtitle,.admin-submetric,.admin-empty{color:var(--text-muted);font-size:12px;line-height:1.5}.admin-metric{color:var(--text-primary);font-size:24px;font-weight:700;margin-bottom:8px}.admin-badge{padding:6px 10px;border-radius:999px;font-size:11px;text-transform:uppercase;letter-spacing:.4px;background:var(--bg-tertiary)}.admin-badge.active{color:var(--success)}.admin-badge.disabled,.admin-badge.banned,.admin-badge.expired{color:var(--danger)}.announcements-page{display:flex;flex-direction:column;gap:16px}.announcements-hero h2{color:var(--text-primary);font-size:28px;margin-top:4px}.announcements-list{display:flex;flex-direction:column;gap:12px}.announcement-card{padding:16px 18px;border-radius:14px;background:var(--bg-secondary);border:1px solid var(--border);display:flex;flex-direction:column;gap:12px}.announcement-card-header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.announcement-card-title-wrap{display:flex;align-items:flex-start;gap:10px}.announcement-card-title{color:var(--text-primary);font-size:15px;font-weight:700}.announcement-card-meta{color:var(--text-muted);font-size:12px;line-height:1.5}.announcement-card-body{color:var(--text-secondary);font-size:14px;line-height:1.6;white-space:pre-wrap}@media (max-width: 1100px){.auth-shell,.admin-grid,.admin-grid-3,.auth-meta-grid{grid-template-columns:1fr}.admin-hero{flex-direction:column}}.theme-card{padding:16px 12px;border-radius:var(--radius);border:2px solid;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px;transition:all .2s}.theme-card:hover{transform:translateY(-2px)}.theme-card.active{box-shadow:0 0 12px var(--accent-glow)}.theme-preview-accent{width:24px;height:24px;border-radius:50%}.theme-preview-text{font-size:12px;font-weight:600}.core-radio-group{display:flex;gap:8px}.core-radio{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;font-size:14px;color:var(--text-secondary)}.core-radio:hover{border-color:var(--border-hover)}.core-radio.active{border-color:var(--accent);color:var(--text-primary)}.core-radio input{display:none}.vpn-mode-group{display:flex;flex-direction:column;gap:8px}.vpn-mode-card{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:10px;border:1px solid var(--border);background:var(--bg-secondary);cursor:pointer;transition:all .2s}.vpn-mode-card:hover{border-color:var(--border-hover);background:var(--bg-tertiary)}.vpn-mode-card.active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--bg-secondary))}.vpn-mode-card input{display:none}.vpn-mode-info{display:flex;flex-direction:column;gap:3px}.vpn-mode-title{font-size:13px;font-weight:600;color:var(--text-primary)}.vpn-mode-desc{font-size:11px;color:var(--text-muted);line-height:1.4}.btn-elevate{margin-top:6px;align-self:flex-start;font-size:11px;padding:4px 10px;border-radius:6px;background:var(--accent);color:#fff;border:none;cursor:pointer;transition:opacity .15s}.btn-elevate:hover{opacity:.85}.port-inputs{display:flex;gap:16px}.form-group{margin-bottom:12px}.form-group.inline{display:flex;align-items:center;gap:8px;margin-bottom:0}.form-label{font-size:13px;color:var(--text-secondary);margin-bottom:4px;display:block}.form-input{width:100%;padding:8px 12px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;outline:none;transition:border-color .15s}.form-input:focus{border-color:var(--accent)}.form-input.small{width:100px}.form-actions{display:flex;gap:8px;margin-top:16px}.toggle{position:relative;display:inline-block;width:36px;height:20px;cursor:pointer;flex-shrink:0}.toggle input{display:none}.toggle-slider{position:absolute;inset:0;background:var(--bg-tertiary);border-radius:20px;transition:background .3s}.toggle-slider:after{content:"";position:absolute;width:14px;height:14px;border-radius:50%;background:var(--text-muted);top:3px;left:3px;transition:transform .3s,background .3s}.toggle input:checked+.toggle-slider{background:var(--accent-glow)}.toggle input:checked+.toggle-slider:after{transform:translate(16px);background:var(--accent)}.settings-save-bar{margin-bottom:24px}.import-export-actions{display:flex;gap:8px}.hwid-desc{font-size:12px;color:var(--text-muted);margin:6px 0 10px;line-height:1.4}.hwid-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;display:flex;flex-direction:column;gap:8px}.hwid-row{display:flex;align-items:center;gap:10px;font-size:13px}.hwid-label{color:var(--text-muted);min-width:80px;flex-shrink:0;font-size:12px}.hwid-value{font-family:Consolas,Fira Code,monospace;color:var(--text-primary);font-size:13px}.hwid-copy-btn{margin-left:auto;padding:3px 10px;font-size:11px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;transition:all .15s}.hwid-copy-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-hover)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.btn-md{padding:8px 16px}.btn-sm{padding:6px 12px;font-size:12px}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:var(--danger-hover)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:active:not(:disabled){transform:scale(.97)}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;backdrop-filter:blur(4px)}.modal-content{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);min-width:400px;max-width:500px;box-shadow:0 20px 60px #00000080}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-header h3{font-size:16px}.modal-close{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;padding:0 4px}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:20px}.toast-stack{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column-reverse;gap:8px;z-index:2000;max-width:360px}.toast{padding:12px 16px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:13px;box-shadow:0 4px 20px #0000004d;animation:slideIn .2s ease}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-info{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary)}.toast-success{background:#44ff881a;border:1px solid rgba(68,255,136,.3);color:var(--success)}.toast-error{background:#ff44441a;border:1px solid rgba(255,68,68,.3);color:var(--danger)}.toast-close{background:none;border:none;color:inherit;opacity:.5;cursor:pointer;font-size:16px;padding:0}.toast-close:hover{opacity:1}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.flag-icon{border-radius:50%;object-fit:cover;flex-shrink:0}.flag-fallback{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:var(--bg-tertiary);color:var(--text-muted);font-weight:700;flex-shrink:0;line-height:1;letter-spacing:-.02em}.sort-select{background:var(--bg-tertiary);color:var(--text-primary);border:none;border-radius:6px;padding:6px 30px 6px 12px;font-size:12px;font-weight:500;cursor:pointer;outline:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2373737b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 8px center;background-size:14px}.sort-select:focus{outline:1px solid var(--accent)}.vpn-mode-badge{display:inline-block;padding:1px 6px;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-left:8px;background:var(--bg-tertiary);color:var(--text-muted);border:1px solid var(--border)}.vpn-mode-badge.tun{background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent);border-color:color-mix(in srgb,var(--accent) 30%,transparent)}.traffic-sparkline{display:flex;align-items:center;padding:0 8px}.sparkline{display:block}.logs-page{display:flex;flex-direction:column;height:100%;gap:12px}.logs-page h2{margin:0}.logs-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.logs-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.logs-tabs{display:flex;gap:2px;background:var(--bg-tertiary);border-radius:var(--radius-sm);padding:2px}.logs-tab{padding:4px 12px;border:none;background:none;color:var(--text-muted);font-size:12px;font-weight:500;font-family:inherit;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:4px}.logs-tab.active{background:var(--card-bg);color:var(--text-primary)}.logs-tab-badge{font-size:10px;padding:0 5px;border-radius:8px;background:var(--accent);color:#fff;font-weight:600}.logs-filter{width:160px;font-size:12px}.logs-autoscroll{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-muted);cursor:pointer;white-space:nowrap}.logs-autoscroll input{accent-color:var(--accent)}.logs-container{flex:1;min-height:0;overflow-y:auto;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-family:Cascadia Code,Fira Code,Consolas,monospace;font-size:11.5px;line-height:1.55}.logs-empty{color:var(--text-muted);text-align:center;padding:40px 0;font-size:13px}.log-line{white-space:pre-wrap;word-break:break-all;color:var(--text-secondary)}.log-line.log-error{color:#ef4444}.log-line.log-warn{color:#f59e0b}.log-line.log-info{color:var(--text-primary)}.stats-page{display:flex;flex-direction:column;gap:20px}.stats-page h2{margin:0}.stats-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.stats-section{display:flex;flex-direction:column;gap:8px}.stats-label{font-size:13px;font-weight:600;color:var(--text-secondary)}.stats-sparkline-container{position:relative;background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;padding:12px 16px;min-height:60px;display:flex;align-items:center;justify-content:center}.stats-sparkline-hint{position:absolute;color:var(--text-muted);font-size:12px}.stats-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.stat-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;padding:14px;text-align:center}.stat-value{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.history-table{border:1px solid var(--border);border-radius:8px;overflow:hidden}.history-header,.history-row{display:grid;grid-template-columns:2fr 1fr 1.5fr 1.5fr;padding:8px 12px;gap:8px;font-size:12px;align-items:center}.history-header{background:var(--bg-tertiary);font-weight:600;color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.04em}.history-row{border-top:1px solid var(--border);color:var(--text-secondary)}.history-row:hover{background:var(--bg-secondary)}.history-server{display:flex;align-items:center;gap:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-proto{font-size:10px;padding:1px 5px;border-radius:4px;background:var(--bg-tertiary);color:var(--text-muted);text-transform:uppercase;flex-shrink:0}.history-date{color:var(--text-muted);font-size:11px}.routing-page{max-width:600px;display:flex;flex-direction:column;gap:20px}.routing-page>.settings-section{background:var(--card-bg, rgba(255,255,255,.03));border:1px solid var(--border, rgba(255,255,255,.06));border-radius:12px;padding:16px}.routing-page h2{font-size:20px;margin-bottom:4px}.routing-add-form{display:flex;gap:8px;align-items:center}.routing-domain-input{flex:1}.routing-action-select{min-width:100px;padding:8px 10px;font-size:13px}.routing-presets{display:flex;gap:8px;flex-wrap:wrap}.routing-rules-list{display:flex;flex-direction:column;gap:8px;max-height:calc(100vh - 520px);overflow-y:auto}.routing-rule-card{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-sm);transition:background .15s}.routing-rule-card:hover{background:#ffffff0a}.routing-divider{height:1px;background:var(--border, rgba(255,255,255,.08));margin:16px 0}.routing-rule-card.disabled{opacity:.5}.routing-action-badge{font-size:10px;font-weight:700;text-transform:uppercase;padding:2px 8px;border-radius:4px;border:1px solid;min-width:54px;text-align:center;flex-shrink:0}.routing-rule-domain{flex:1;font-size:13px;font-family:Consolas,Fira Code,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.routing-rule-toggle{flex-shrink:0}.routing-rule-delete{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;padding:0 4px;opacity:0;transition:all .15s}.routing-rule-card:hover .routing-rule-delete{opacity:1}.routing-rule-delete:hover{color:var(--danger)}.style-minimal .sidebar{background:var(--bg-primary);border-right:1px solid var(--border)}.style-minimal .card,.style-minimal .server-card,.style-minimal .sub-card{border-radius:6px;border:1px solid var(--border);background:var(--bg-primary);box-shadow:none}.style-minimal .card:hover,.style-minimal .server-card:hover,.style-minimal .sub-card:hover{box-shadow:none;border-color:var(--border-hover)}.style-minimal .btn{border-radius:6px;text-transform:uppercase;letter-spacing:.05em;font-weight:600;box-shadow:none}.style-minimal .connect-btn{box-shadow:none;border:2px solid var(--accent)}.style-minimal .connect-btn:hover{box-shadow:none}.style-minimal .modal-content{border-radius:8px;border:1px solid var(--border);box-shadow:0 4px 20px #0000004d}.style-minimal .form-input{border-radius:4px;border:1px solid var(--border)}.style-minimal .toggle-slider{border-radius:4px}.style-minimal .toggle-slider:before{border-radius:3px}.style-minimal .nav-item.active{border-radius:6px}.style-minimal .toast{border-radius:6px;box-shadow:none;border:1px solid var(--border)}.style-minimal .search-input,.style-minimal .tab-btn{border-radius:4px}.style-minimal .theme-card{border-radius:6px}.style-minimal .core-radio{border-radius:4px}.style-minimal .server-card.active{background:color-mix(in srgb,var(--accent) 14%,var(--bg-primary));border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}.style-glass .sidebar{background:#ffffff08;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-right:1px solid rgba(255,255,255,.08)}.style-glass .card,.style-glass .server-card,.style-glass .sub-card{background:#ffffff0a;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);box-shadow:0 4px 24px #00000026}.style-glass .card:hover,.style-glass .server-card:hover,.style-glass .sub-card:hover{background:#ffffff12;border-color:#ffffff24;box-shadow:0 8px 32px #0003}.style-glass .btn{background:#ffffff0f;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.style-glass .btn:hover{background:#ffffff1a;border-color:#ffffff2e}.style-glass .btn.primary{background:#7c5cff66;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(124,92,255,.3)}.style-glass .btn.primary:hover{background:#7c5cff8c}.style-glass .connect-btn{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12)}.style-glass .modal-content{background:#141423bf;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);box-shadow:0 16px 48px #0006}.style-glass .modal-overlay{background:#0000004d;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.style-glass .form-input{background:#ffffff0a;border:1px solid rgba(255,255,255,.1)}.style-glass .form-input:focus{background:#ffffff0f;border-color:#fff3}.style-glass .toast{background:#141423b3;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1)}.style-glass .search-input{background:#ffffff0a;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.08)}.style-glass .tab-btn.active{background:#ffffff14;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.style-glass .theme-card{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.08)}.style-glass .core-radio{background:#ffffff08;border:1px solid rgba(255,255,255,.08)}.style-glass .core-radio.active{background:#7c5cff33;border-color:#7c5cff4d}.style-glass .nav-item{background:transparent}.style-glass .nav-item.active{background:#ffffff0f}.style-glass .server-card.active{background:color-mix(in srgb,var(--accent) 20%,rgba(255,255,255,.06));border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 8px 32px #7c5cff40,inset 0 0 0 1px #ffffff14}.style-neon .sidebar{border-right:1px solid var(--accent);box-shadow:1px 0 15px #7c5cff26}.style-neon .card,.style-neon .server-card,.style-neon .sub-card{border:1px solid rgba(124,92,255,.2);box-shadow:0 0 12px #7c5cff14,inset 0 0 12px #7c5cff08}.style-neon .card:hover,.style-neon .server-card:hover,.style-neon .sub-card:hover{border-color:var(--accent);box-shadow:0 0 20px #7c5cff33,0 0 40px #7c5cff14,inset 0 0 15px #7c5cff0d}.style-neon .btn{border:1px solid rgba(124,92,255,.3);box-shadow:0 0 8px #7c5cff1a}.style-neon .btn:hover{box-shadow:0 0 16px #7c5cff40;border-color:var(--accent)}.style-neon .btn.primary{box-shadow:0 0 16px #7c5cff59,0 0 32px #7c5cff26}.style-neon .btn.primary:hover{box-shadow:0 0 24px #7c5cff80,0 0 48px #7c5cff33}.style-neon .connect-btn{box-shadow:0 0 20px #7c5cff40,0 0 40px #7c5cff1a}.style-neon .connect-btn:hover{box-shadow:0 0 30px #7c5cff66,0 0 60px #7c5cff26}.style-neon .connect-btn.connected{box-shadow:0 0 20px #10b9814d,0 0 40px #10b9811f}.style-neon .modal-content{border:1px solid rgba(124,92,255,.25);box-shadow:0 0 30px #7c5cff26,0 16px 48px #00000080}.style-neon .form-input{border:1px solid rgba(124,92,255,.2)}.style-neon .form-input:focus{border-color:var(--accent);box-shadow:0 0 12px #7c5cff33}.style-neon .toast{border:1px solid rgba(124,92,255,.25);box-shadow:0 0 16px #7c5cff1f}.style-neon .search-input{border:1px solid rgba(124,92,255,.15)}.style-neon .search-input:focus{border-color:var(--accent);box-shadow:0 0 10px #7c5cff33}.style-neon .nav-item.active{box-shadow:0 0 10px #7c5cff26;border:1px solid rgba(124,92,255,.3)}.style-neon .tab-btn.active{box-shadow:0 0 8px #7c5cff26}.style-neon .theme-card{border:1px solid rgba(124,92,255,.15)}.style-neon .theme-card.active{box-shadow:0 0 16px #7c5cff4d}.style-neon .core-radio{border:1px solid rgba(124,92,255,.15)}.style-neon .core-radio.active{border-color:var(--accent);box-shadow:0 0 12px #7c5cff33}.style-neon .toggle input:checked+.toggle-slider{box-shadow:0 0 12px #7c5cff4d}.style-neon h2{text-shadow:0 0 20px rgba(124,92,255,.3)}.style-neon .status-label{text-shadow:0 0 10px rgba(124,92,255,.2)}.style-neon .traffic-value{text-shadow:0 0 8px rgba(124,92,255,.2)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulseGlow{0%,to{box-shadow:0 0 20px #4f83}50%{box-shadow:0 0 30px #44ff8859}}@keyframes gentlePulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.9)}60%{opacity:1;transform:scale(1.03)}to{transform:scale(1)}}@keyframes bounceSlideIn{0%{transform:translate(110%);opacity:0}60%{transform:translate(-4%);opacity:1}to{transform:translate(0);opacity:1}}@keyframes popIn{0%{opacity:0;transform:scale(.85)}60%{opacity:1;transform:scale(1.05)}to{transform:scale(1)}}@keyframes pulseGlowFast{0%,to{box-shadow:0 0 20px #4f83}50%{box-shadow:0 0 35px #44ff8873}}.anim-none *,.anim-none *:before,.anim-none *:after{animation-duration:0s!important;animation-delay:0s!important;transition-duration:0s!important;transition-delay:0s!important}.anim-smooth .main-content>*:not(.onboarding-overlay){animation:fadeIn .25s ease both}.anim-smooth .modal-overlay{animation:fadeIn .2s ease both}.anim-smooth .modal-content{animation:scaleIn .25s ease both}.anim-smooth .toast{animation:slideIn .25s ease both}.anim-smooth .server-card{animation:fadeIn .2s ease both}.anim-smooth .server-card:nth-child(1){animation-delay:0s}.anim-smooth .server-card:nth-child(2){animation-delay:.03s}.anim-smooth .server-card:nth-child(3){animation-delay:.06s}.anim-smooth .server-card:nth-child(4){animation-delay:.09s}.anim-smooth .server-card:nth-child(5){animation-delay:.12s}.anim-smooth .server-card:nth-child(n+6){animation-delay:.15s}.anim-smooth .stat-card{animation:fadeIn .25s ease both}.anim-smooth .sub-card{animation:fadeIn .2s ease both}.anim-smooth .connect-btn.connected{animation:pulseGlow 2.5s ease-in-out infinite}.anim-smooth .status-indicator.on{animation:gentlePulse 2.5s ease-in-out infinite}.anim-smooth .server-card:hover,.anim-smooth .sub-card:hover,.anim-smooth .stat-card:hover{transform:translateY(-1px);box-shadow:0 4px 16px #00000026}.anim-smooth .settings-section{animation:fadeIn .2s ease both}.anim-smooth .settings-section:nth-child(1){animation-delay:0s}.anim-smooth .settings-section:nth-child(2){animation-delay:.04s}.anim-smooth .settings-section:nth-child(3){animation-delay:.08s}.anim-smooth .settings-section:nth-child(4){animation-delay:.12s}.anim-smooth .settings-section:nth-child(5){animation-delay:.16s}.anim-smooth .settings-section:nth-child(n+6){animation-delay:.2s}.anim-energetic .main-content>*:not(.onboarding-overlay){animation:slideUp .3s cubic-bezier(.34,1.56,.64,1) both}.anim-energetic .modal-overlay{animation:fadeIn .2s ease both}.anim-energetic .modal-content{animation:bounceIn .35s cubic-bezier(.34,1.56,.64,1) both}.anim-energetic .toast{animation:bounceSlideIn .35s cubic-bezier(.34,1.56,.64,1) both}.anim-energetic .server-card{animation:slideUp .25s cubic-bezier(.34,1.56,.64,1) both}.anim-energetic .server-card:nth-child(1){animation-delay:0s}.anim-energetic .server-card:nth-child(2){animation-delay:.04s}.anim-energetic .server-card:nth-child(3){animation-delay:.08s}.anim-energetic .server-card:nth-child(4){animation-delay:.12s}.anim-energetic .server-card:nth-child(5){animation-delay:.16s}.anim-energetic .server-card:nth-child(n+6){animation-delay:.2s}.anim-energetic .stat-card{animation:popIn .3s cubic-bezier(.34,1.56,.64,1) both}.anim-energetic .stat-card:nth-child(1){animation-delay:0s}.anim-energetic .stat-card:nth-child(2){animation-delay:.06s}.anim-energetic .stat-card:nth-child(3){animation-delay:.12s}.anim-energetic .stat-card:nth-child(4){animation-delay:.18s}.anim-energetic .sub-card{animation:slideUp .25s cubic-bezier(.34,1.56,.64,1) both}.anim-energetic .sub-card:nth-child(1){animation-delay:0s}.anim-energetic .sub-card:nth-child(2){animation-delay:.05s}.anim-energetic .sub-card:nth-child(3){animation-delay:.1s}.anim-energetic .sub-card:nth-child(n+4){animation-delay:.15s}.anim-energetic .connect-btn.connected{animation:pulseGlowFast 1.8s ease-in-out infinite}.anim-energetic .status-indicator.on{animation:gentlePulse 1.8s ease-in-out infinite}.anim-energetic .server-card:hover,.anim-energetic .sub-card:hover,.anim-energetic .stat-card:hover{transform:translateY(-2px);box-shadow:0 6px 24px #0003}.anim-energetic .settings-section{animation:slideUp .25s cubic-bezier(.34,1.56,.64,1) both}.anim-energetic .settings-section:nth-child(1){animation-delay:0s}.anim-energetic .settings-section:nth-child(2){animation-delay:.05s}.anim-energetic .settings-section:nth-child(3){animation-delay:.1s}.anim-energetic .settings-section:nth-child(4){animation-delay:.15s}.anim-energetic .settings-section:nth-child(5){animation-delay:.2s}.anim-energetic .settings-section:nth-child(n+6){animation-delay:.25s}.onboarding-overlay{position:fixed;inset:0;z-index:3000;pointer-events:auto}.onboarding-backdrop{position:absolute;inset:0;background:#000000b3;transition:clip-path .35s ease}.onboarding-step-content{position:absolute;inset:0;z-index:3002}.onboarding-step-content.entering{animation:onboardingEnter .35s cubic-bezier(.16,1,.3,1) both}.onboarding-step-content.leaving{animation:onboardingLeave .2s ease both;pointer-events:none}@keyframes onboardingEnter{0%{opacity:0;transform:translateY(10px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes onboardingLeave{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-8px) scale(.97)}}.onboarding-tooltip{position:absolute;background:var(--bg-secondary);border:1px solid var(--accent);border-radius:var(--radius);padding:16px 20px;max-width:320px;box-shadow:0 8px 32px #00000080,0 0 20px var(--accent-glow);transition:top .3s ease,bottom .3s ease,left .3s ease}.onboarding-tooltip-text{font-size:14px;color:var(--text-primary);line-height:1.5;margin-bottom:16px}.onboarding-tooltip-actions{display:flex;align-items:center;justify-content:space-between;gap:8px}.onboarding-dots{display:flex;gap:6px}.onboarding-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:all .2s}.onboarding-dot.active{background:var(--accent);box-shadow:0 0 6px var(--accent-glow)}.onboarding-tooltip-btns{display:flex;gap:8px}.onboarding-card-wrapper{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.onboarding-card{background:var(--bg-secondary);border:1px solid var(--accent);border-radius:16px;padding:40px 48px;text-align:center;max-width:420px;box-shadow:0 16px 48px #0009,0 0 30px var(--accent-glow)}.onboarding-card-title{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:24px}.onboarding-card-actions{display:flex;flex-direction:column;gap:10px}.onboarding-card-actions .btn{padding:10px 24px;font-size:14px}.onboarding-card-icon{width:56px;height:56px;background:var(--accent);color:#fff;font-weight:700;font-size:28px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}.onboarding-card-subtitle{font-size:14px;color:var(--text-muted);font-weight:600;letter-spacing:.05em;margin-bottom:28px}.onboarding-lang-title{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:20px}.onboarding-lang-buttons{display:flex;gap:12px;justify-content:center}.onboarding-lang-btn{display:flex;align-items:center;gap:10px;padding:14px 28px;background:var(--bg-tertiary);border:2px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:15px;font-weight:500;cursor:pointer;transition:all .2s;min-width:150px;justify-content:center}.onboarding-lang-btn:hover{border-color:var(--accent);background:var(--bg-hover);box-shadow:0 0 16px var(--accent-glow);transform:translateY(-2px)}.onboarding-lang-flag{font-size:12px;font-weight:700;padding:3px 8px;border-radius:4px;background:var(--accent);color:#fff;letter-spacing:.05em}.onboarding-lang-label{font-size:15px}@media (max-width: 640px){html,body,#root{overflow-x:hidden!important;max-width:100vw!important;width:100%!important}*:not(.modal-overlay):not(.onboarding-overlay):not(.toast-stack):not(.onboarding-backdrop){max-width:100vw}.app-layout{padding:0;gap:0;width:100%;max-width:100vw;height:100vh;height:100dvh;flex-direction:column;overflow:hidden}.top-bar{gap:6px;padding:6px 10px;padding-top:calc(6px + env(safe-area-inset-top,0px));flex-shrink:0;overflow:visible;max-width:100%;flex-wrap:nowrap}.brand-box{padding:6px 8px;gap:6px;border-radius:10px;flex-shrink:0}.brand-box .brand-text{display:none}.brand-box .logo{width:22px;height:22px}.tabs-wrapper{flex:1;min-width:0;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;border-radius:20px;padding:3px;gap:2px}.tabs-wrapper::-webkit-scrollbar{display:none}.tab{padding:5px 9px;font-size:11px;border-radius:16px;flex-shrink:0}.conn-badge{display:none}.workspace{flex:1;flex-direction:column;gap:0;min-height:0;overflow:hidden;max-width:100%;width:100%}.sidebar{width:100%!important;height:auto!important;flex-direction:row!important;align-items:center!important;justify-content:space-around!important;border-radius:0!important;padding:0!important;padding-bottom:env(safe-area-inset-bottom,0px)!important;gap:0!important;order:2;flex-shrink:0;border-top:1px solid var(--border);background:var(--bg-secondary)}.nav-separator{display:none!important}.nav-item{flex:1 1 0%!important;width:auto!important;min-width:0!important;height:52px!important;min-height:52px!important}.nav-item svg{width:22px;height:22px}.nav-item.active:after{right:50%;transform:translate(50%);top:0;width:24px;height:3px;border-radius:0 0 3px 3px}.nav-item.active{background:#ffffff08;color:var(--accent)}.main-content{flex:1;order:1;padding:10px;min-height:0;border-radius:0;overflow-x:hidden;overflow-y:auto;max-width:100%}.home-page{display:flex;flex-direction:column;gap:10px;height:auto;overflow:visible;max-width:100%}.home-left{overflow:visible;gap:8px;max-width:100%}.home-right{flex:1;min-height:0;overflow:hidden;max-width:100%}.status-panel{flex-direction:column;align-items:center;text-align:center;padding:16px;gap:12px}.status-info{align-items:center;order:-1}.status-label{font-size:18px;font-weight:700}.status-core{display:none}.connection-info-bar{justify-content:center;max-width:100%}.info-chip{font-size:10px;padding:2px 6px}.hwid-card{max-width:100%;overflow:hidden}.hwid-row{flex-wrap:wrap}.hwid-value{font-size:11px;word-break:break-all;min-width:0}.connect-btn{width:80px;height:80px;border-width:3px}.connect-btn-icon{font-size:32px}.connect-btn:active:not(:disabled){transform:scale(.95);box-shadow:0 0 30px var(--accent-glow)}.home-left .traffic-panel{flex-direction:row;gap:0;padding:10px 14px}.home-left .traffic-divider{display:block;width:1px;height:32px;margin:0 10px}.home-left .traffic-item{width:auto;flex:1}.traffic-speed{font-size:13px}.traffic-icon{width:30px;height:30px;font-size:16px}.quick-connect{gap:4px}.quick-items{flex-direction:row;overflow-x:auto;gap:6px;padding-bottom:2px;scrollbar-width:none}.quick-items::-webkit-scrollbar{display:none}.quick-item{min-width:120px;flex-shrink:0}.server-list-panel{gap:8px;max-width:100%;overflow:hidden}.server-list-header{gap:6px;flex-wrap:wrap;max-width:100%}.server-list-actions{flex-wrap:wrap;gap:4px;max-width:100%}.server-list-actions .btn{font-size:11px;padding:5px 8px}.search-input{min-width:0;width:100%;font-size:14px;padding:8px 12px}.sort-select{font-size:11px;padding:5px 24px 5px 8px}.server-list-items{flex:1;min-height:0}.server-card{padding:10px 12px;min-height:44px;max-width:100%;overflow:hidden}.server-delete{opacity:.6}.server-name{font-size:12px;min-width:0}.ping-section{min-width:60px}.server-ping{min-width:40px;font-size:11px}.server-list-items.grid-view{grid-template-columns:repeat(2,1fr)!important;gap:6px}.import-box{max-width:100%}.import-textarea{max-width:100%;min-width:0}.import-actions{flex-wrap:wrap;gap:6px}.sub-page{max-width:100%;overflow:hidden}.sub-header{flex-direction:column;align-items:stretch;gap:10px}.sub-header-actions{flex-wrap:wrap;gap:8px}.sub-header-actions .btn{flex:0 0 auto;font-size:13px;white-space:nowrap}.sub-card{flex-direction:column;align-items:flex-start;gap:10px;padding:12px;max-width:100%;overflow:hidden}.sub-url{max-width:100%}.sub-actions{width:100%;flex-wrap:wrap}.sub-actions .btn{flex:1;min-width:0}.sub-top{flex-direction:column;align-items:stretch;gap:8px}.sub-actions{width:100%}.sub-compact-meta{font-size:11px}.sub-row{font-size:12px}.sub-row-label{min-width:55px;font-size:11px}.sub-row-link{font-size:13px;padding:10px 0;min-height:44px;display:inline-flex;align-items:center}.sub-announce{font-size:11px;padding:6px 8px}.announce-banner{font-size:12px;padding:8px 10px;margin-bottom:8px}.settings-page{max-width:100%;overflow:hidden}.settings-section{padding:12px}.theme-grid{grid-template-columns:repeat(2,1fr);gap:6px}.theme-card{padding:10px 8px}.core-radio-group{flex-direction:column}.port-inputs{flex-direction:column;gap:8px}.form-input.small{width:100%}.vpn-mode-card{padding:10px 12px}.stats-page{max-width:100%;overflow:hidden}.stats-summary{grid-template-columns:repeat(2,1fr);gap:8px}.stat-card{padding:10px}.stat-value{font-size:14px;word-break:break-all}.dashboard-grid{grid-template-columns:1fr;gap:10px}.dashboard-card{padding:12px;max-width:100%;overflow:hidden}.protocol-chart{flex-direction:column;align-items:center;gap:10px}.donut-chart{width:80px;height:80px}.protocol-legend{width:100%}.protocol-legend-item{font-size:12px}.protocol-name{min-width:0}.traffic-chart{max-width:100%;overflow-x:auto}.top-server-row{flex-wrap:wrap;gap:4px;font-size:11px}.top-server-bar-bg{width:60px}.top-server-traffic{min-width:45px;font-size:10px}.top-server-name{min-width:0;max-width:120px}.history-table{max-width:100%;overflow-x:auto}.history-header,.history-row{grid-template-columns:2fr 1fr 1.5fr;font-size:11px;padding:6px 8px;min-width:0}.history-header>*:nth-child(4),.history-row>*:nth-child(4){display:none}.logs-page{gap:8px;max-width:100%;overflow:hidden}.logs-container{overflow-x:hidden;word-break:break-all;font-size:10px;padding:6px 8px}.logs-header{flex-direction:column;align-items:stretch;gap:6px}.logs-actions{flex-wrap:wrap}.logs-filter{width:100%}.routing-page{max-width:100%;overflow:hidden}.routing-page h2{font-size:16px;margin-bottom:12px}.routing-add-form{flex-wrap:wrap}.routing-domain-input{min-width:0;width:100%}.routing-presets{gap:6px}.routing-rules-list{max-height:none}.routing-rule-delete{opacity:.6}.modal-content{min-width:unset;max-width:calc(100vw - 32px);margin:16px}.toast-stack{left:12px;right:12px;bottom:64px;bottom:calc(60px + env(safe-area-inset-bottom,0px));max-width:unset}.onboarding-card{margin:16px;padding:24px 18px;max-width:calc(100vw - 32px)}.onboarding-card-title{font-size:20px}.onboarding-tooltip{max-width:calc(100vw - 32px);left:16px!important;right:16px!important}.onboarding-lang-buttons{flex-direction:column;gap:10px}.onboarding-lang-btn{min-width:unset;width:100%;padding:12px 16px}.onboarding-lang-title{font-size:16px}}.connect-btn{position:relative}.connect-btn.connected:before,.connect-btn.connected:after{content:"";position:absolute;inset:-6px;border-radius:50%;border:2px solid var(--success);opacity:0}.anim-smooth .connect-btn.connected:before,.anim-energetic .connect-btn.connected:before{animation:pulse-ring 2.5s ease-out infinite}.anim-smooth .connect-btn.connected:after,.anim-energetic .connect-btn.connected:after{animation:pulse-ring 2.5s ease-out 1.25s infinite}.anim-energetic .connect-btn.connected:before{animation-duration:1.8s}.anim-energetic .connect-btn.connected:after{animation-duration:1.8s;animation-delay:.9s}@keyframes pulse-ring{0%{transform:scale(1);opacity:.6}to{transform:scale(1.5);opacity:0}}.home-page{position:relative}.home-page:before{content:"";position:absolute;top:-50px;left:50%;transform:translate(-50%);width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,var(--accent-glow),transparent 70%);opacity:0;pointer-events:none;z-index:-1;transition:opacity 1s ease}.home-page.vpn-active:before{opacity:1}.anim-energetic .home-page.vpn-active:before{animation:glow-breathe 3s ease-in-out infinite}@keyframes glow-breathe{0%,to{opacity:.6;transform:translate(-50%) scale(1)}50%{opacity:1;transform:translate(-50%) scale(1.1)}}.connect-btn.loading{animation:connecting-pulse 1.2s ease-in-out infinite}@keyframes connecting-pulse{0%,to{border-color:var(--warning);box-shadow:0 0 15px #fa43}50%{border-color:var(--accent);box-shadow:0 0 25px var(--accent-glow)}}.status-panel{position:relative;overflow:hidden}.status-panel.connected-particles:after{content:"";position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(2px 2px at 20% 30%,var(--success) 50%,transparent 50%),radial-gradient(2px 2px at 40% 70%,var(--accent) 50%,transparent 50%),radial-gradient(1.5px 1.5px at 60% 20%,var(--success) 50%,transparent 50%),radial-gradient(2px 2px at 80% 50%,var(--accent) 50%,transparent 50%),radial-gradient(1.5px 1.5px at 10% 80%,var(--success) 50%,transparent 50%),radial-gradient(2px 2px at 90% 10%,var(--accent) 50%,transparent 50%);background-size:100% 100%;opacity:0;transition:opacity .5s ease}.anim-smooth .status-panel.connected-particles:after,.anim-energetic .status-panel.connected-particles:after{opacity:.4;animation:float-particles 8s linear infinite}.anim-energetic .status-panel.connected-particles:after{opacity:.6;animation-duration:5s}@keyframes float-particles{0%{transform:translateY(0)}to{transform:translateY(-20px)}}.glass-card{background:#ffffff08;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius)}.home-page.vpn-active{background:linear-gradient(135deg,transparent 0%,color-mix(in srgb,var(--accent) 3%,transparent) 50%,transparent 100%);border-radius:var(--radius)}.anim-energetic .home-page.vpn-active{animation:gradient-shift 6s ease-in-out infinite;background-size:200% 200%;background-image:linear-gradient(135deg,transparent 0%,color-mix(in srgb,var(--accent) 4%,transparent) 25%,transparent 50%,color-mix(in srgb,var(--success) 3%,transparent) 75%,transparent 100%)}@keyframes gradient-shift{0%{background-position:0% 0%}50%{background-position:100% 100%}to{background-position:0% 0%}}.world-map-container{width:100%;height:clamp(100px,22vh,180px);padding:0;border-bottom:1px solid var(--border);overflow:hidden;position:relative;background:var(--bg-primary);flex-shrink:0}.world-map-viewport{width:100%;height:100%;overflow:hidden;cursor:grab}.world-map-viewport.dragging{cursor:grabbing}.world-map-svg{width:100%;height:auto;display:block;transition:transform .15s ease}.world-map-viewport.dragging .world-map-svg{transition:none}.map-controls{position:absolute;top:6px;right:6px;display:flex;flex-direction:column;gap:2px;z-index:2}.map-ctrl-btn{width:24px;height:24px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);border-radius:4px;cursor:pointer;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center;line-height:1;opacity:.7;transition:opacity .15s,background .15s}.map-ctrl-btn:hover{opacity:1;background:var(--bg-hover)}.map-zoom-badge{position:absolute;bottom:6px;right:6px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:4px;padding:1px 5px;font-size:9px;color:var(--text-muted);z-index:2}.connection-line{animation:dash-flow 1.5s linear infinite}@keyframes dash-flow{to{stroke-dashoffset:-18}}.server-dot-glow{animation:dot-pulse 2s ease-in-out infinite}@keyframes dot-pulse{0%,to{r:10;opacity:.15}50%{r:16;opacity:.3}}.user-dot-pulse{animation:dot-pulse 2s ease-in-out infinite}.privacy-page{padding:20px;overflow-y:auto;height:100%}.privacy-header h2{display:flex;align-items:center;gap:8px;margin-bottom:20px}.privacy-score-section{display:flex;flex-direction:column;align-items:center;gap:16px;margin-bottom:24px}.privacy-gauge{position:relative}.privacy-hint{text-align:center;color:var(--text-muted);padding:24px;font-size:13px}.privacy-checks{display:flex;flex-direction:column;gap:10px}.privacy-check-card{display:flex;align-items:flex-start;gap:12px;padding:14px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .3s ease}.privacy-check-card.pass{border-left:3px solid var(--success)}.privacy-check-card.warn{border-left:3px solid var(--warning)}.privacy-check-card.fail{border-left:3px solid var(--danger)}.privacy-check-icon{flex-shrink:0;margin-top:2px}.privacy-check-label{font-weight:600;font-size:13px;margin-bottom:2px}.privacy-check-desc{font-size:11px;color:var(--text-muted);margin-bottom:4px}.privacy-check-detail{font-size:12px;color:var(--text-secondary)}.speedtest-page{padding:20px;overflow-y:auto;height:100%}.speedtest-header h2{display:flex;align-items:center;gap:8px;margin-bottom:20px}.speedtest-gauges{display:flex;justify-content:center;align-items:flex-end;gap:24px;margin-bottom:20px}.speed-gauge{display:flex;flex-direction:column;align-items:center}.speed-gauge-label{margin-top:4px;font-size:12px;color:var(--text-secondary);font-weight:500}.speed-ping-card{display:flex;flex-direction:column;align-items:center;padding:16px 24px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);min-width:80px}.speed-ping-value{font-size:28px;font-weight:700;color:var(--text-primary)}.speed-ping-unit{font-size:11px;color:var(--text-muted)}.speed-ping-label{font-size:12px;color:var(--text-secondary);font-weight:500;margin-top:4px}.speedtest-actions{display:flex;justify-content:center;margin-bottom:16px}.speedtest-btn{min-width:180px}.speedtest-spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--text-muted);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite;margin-right:6px;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.speedtest-hint{text-align:center;color:var(--text-muted);font-size:13px;padding:12px}.speedtest-history{margin-top:16px}.server-fav{cursor:pointer;flex-shrink:0;display:flex;align-items:center;padding:2px;opacity:.6;transition:opacity .15s ease,transform .15s ease}.server-fav:hover{opacity:1;transform:scale(1.2)}.view-toggle{display:flex;background:var(--bg-tertiary);border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border)}.view-toggle-btn{background:none;border:none;padding:4px 8px;cursor:pointer;color:var(--text-muted);display:flex;align-items:center}.view-toggle-btn.active{background:var(--accent);color:#fff}.country-group{margin-bottom:4px}.country-group-header{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg-tertiary);border-radius:var(--radius-sm);cursor:pointer;user-select:none;font-size:13px;font-weight:500}.country-group-header:hover{background:var(--bg-hover)}.country-flag{font-size:16px}.country-name{flex:1;color:var(--text-primary)}.country-count{color:var(--text-muted);font-size:11px;background:var(--bg-secondary);padding:1px 6px;border-radius:10px}.country-chevron{font-size:10px;color:var(--text-muted);transition:transform .2s ease}.country-chevron.collapsed{transform:rotate(-90deg)}.country-group-servers{padding-left:4px}.server-list-items.grid-view{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;align-content:start}.server-card.grid-card{flex-direction:column;align-items:flex-start;padding:10px;gap:6px}.grid-card-top{display:flex;justify-content:space-between;width:100%;align-items:center}.grid-card-name{font-size:12px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.grid-card-meta{display:flex;justify-content:space-between;width:100%;font-size:11px}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.dashboard-card{padding:16px;border-radius:var(--radius)}.traffic-chart{display:flex;align-items:flex-end;gap:4px;height:100px;padding-top:8px}.traffic-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.traffic-bar-wrapper{width:100%;position:relative;display:flex;flex-direction:column;justify-content:flex-end;align-items:center}.traffic-bar{width:70%;border-radius:3px 3px 0 0;min-height:2px;transition:height .5s ease}.traffic-bar.download{background:var(--accent);opacity:.7}.traffic-bar.upload{background:var(--success);opacity:.5;position:absolute;bottom:0}.traffic-bar-label{font-size:9px;color:var(--text-muted)}.protocol-chart{display:flex;align-items:center;gap:16px}.donut-chart{width:100px;height:100px;flex-shrink:0}.protocol-legend{display:flex;flex-direction:column;gap:4px}.protocol-legend-item{display:flex;align-items:center;gap:6px;font-size:11px}.protocol-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.protocol-name{color:var(--text-primary);min-width:50px}.protocol-pct{color:var(--text-muted)}.top-servers{display:flex;flex-direction:column;gap:6px}.top-server-row{display:flex;align-items:center;gap:8px;font-size:12px}.top-server-rank{font-weight:700;color:var(--accent);width:24px}.top-server-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary)}.top-server-proto{color:var(--text-muted);font-size:10px;text-transform:uppercase}.top-server-bar-bg{width:80px;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden}.top-server-bar-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .5s ease}.top-server-traffic{color:var(--text-secondary);font-size:11px;min-width:60px;text-align:right}.update-checker{display:flex;flex-direction:column;gap:10px}.update-checker-header{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px}.update-status{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--radius-sm);font-size:13px}.update-status.up-to-date{background:color-mix(in srgb,var(--success) 10%,var(--bg-tertiary));border:1px solid color-mix(in srgb,var(--success) 20%,transparent)}.update-status.has-update{background:color-mix(in srgb,var(--accent) 10%,var(--bg-tertiary));border:1px solid color-mix(in srgb,var(--accent) 20%,transparent);flex-direction:column;align-items:flex-start}.update-status.update-error{background:color-mix(in srgb,var(--danger) 10%,var(--bg-tertiary));border:1px solid color-mix(in srgb,var(--danger) 20%,transparent);color:var(--danger)}.update-version{color:var(--text-muted);font-size:11px}.update-versions{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500}.update-current{color:var(--text-muted)}.update-arrow{color:var(--accent)}.update-latest{color:var(--success);font-weight:700}.update-changelog{font-size:12px;color:var(--text-secondary);max-height:60px;overflow-y:auto;white-space:pre-line;margin:4px 0}.update-check-btn{align-self:flex-start}.dev-badge{display:inline-flex;align-items:center;gap:5px;padding:2px 10px;border-radius:20px;background:linear-gradient(135deg,#ff9f4326,#ff6b6b26);border:1px solid rgba(255,159,67,.4);color:#ff9f43;font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase}.dev-badge-dot{width:6px;height:6px;border-radius:50%;background:#ff9f43;animation:dev-pulse 2s ease-in-out infinite}@keyframes dev-pulse{0%,to{opacity:1;box-shadow:0 0 #ff9f4366}50%{opacity:.6;box-shadow:0 0 6px 2px #ff9f434d}}.update-status.dev-version{background:linear-gradient(135deg,#ff9f4314,#ff6b6b14);border:1px solid rgba(255,159,67,.2);flex-direction:column;align-items:flex-start;gap:4px}.dev-version-label{font-size:14px;font-weight:700;color:#ff9f43;font-family:Consolas,Fira Code,monospace}.dev-version-hint{font-size:12px;color:var(--text-secondary)}.home-page .status-panel,.home-page .traffic-panel{background:#ffffff05;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.04);border-radius:var(--radius)}@media (min-width: 1200px){.home-page{max-width:1000px}.dashboard-grid{grid-template-columns:1fr 1fr}.server-list-items.grid-view{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}@media (max-width: 900px){.app-layout{padding:10px;gap:10px}.sidebar{width:56px}.home-page{grid-template-columns:1fr}.home-left{flex-direction:row;flex-wrap:wrap;gap:10px}.home-left>*{flex:1;min-width:200px}.home-left .traffic-panel{flex-direction:row;gap:0}.home-left .traffic-divider{display:block;width:1px;height:32px;margin:0 12px}.home-left .traffic-item{width:auto}.server-list-header{flex-direction:column;gap:8px}.server-list-actions{flex-wrap:wrap}.stats-summary{grid-template-columns:repeat(2,1fr)}.top-bar{gap:10px}.tabs-wrapper{overflow-x:auto;scrollbar-width:none}.tabs-wrapper::-webkit-scrollbar{display:none}}@media (min-height: 800px){.world-map-container{max-height:220px;height:25vh}}@media (max-height: 550px){.world-map-container{height:80px;min-height:60px}}.per-app-vpn{display:flex;flex-direction:column;gap:12px}.per-app-search{display:flex;align-items:center;gap:10px}.per-app-search .form-input{flex:1}.per-app-count{font-size:12px;opacity:.6;white-space:nowrap}.per-app-list{display:flex;flex-direction:column;gap:2px;max-height:400px;overflow-y:auto;border-radius:8px;background:var(--card-bg, rgba(255,255,255,.04))}.per-app-item{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;border-radius:6px;transition:background .15s}.per-app-item:hover{background:#ffffff0f}.per-app-item.selected{background:#6366f11f}.per-app-icon{width:36px;height:36px;border-radius:8px;flex-shrink:0;object-fit:contain}.per-app-icon-placeholder{background:#ffffff1a}.per-app-info{flex:1;min-width:0}.per-app-label{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.per-app-package{font-size:11px;opacity:.45;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.per-app-check{width:24px;height:24px;border-radius:6px;border:2px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;transition:all .15s}.per-app-check.checked{background:var(--accent, #6366f1);border-color:var(--accent, #6366f1);color:#fff}.per-app-empty{padding:24px;text-align:center;opacity:.5;font-size:13px}.per-app-loading{padding:24px;text-align:center;opacity:.5}.xposed-card{background:#6366f10f;border:1px solid rgba(99,102,241,.15);border-radius:10px;padding:14px;margin-top:8px}.xposed-status{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;margin-bottom:8px}.xposed-dot{width:8px;height:8px;border-radius:50%;background:#6366f1;flex-shrink:0}.xposed-dot.active{background:#22c55e;box-shadow:0 0 6px #22c55e80}.xposed-dot.pending{background:#f59e0b;box-shadow:0 0 6px #f59e0b80}.xposed-card.xposed-active{border-color:#22c55e40;background:#22c55e0f}.xposed-card.xposed-pending{border-color:#f59e0b33;background:#f59e0b0f}.xposed-hooked{font-size:12px;opacity:.7;margin-top:4px}.xposed-steps{display:flex;flex-direction:column;gap:4px;margin-top:10px;padding:10px 12px;background:#00000026;border-radius:8px;font-size:12px;opacity:.8}.xposed-step{line-height:1.5}.per-app-warning{padding:10px 14px;background:#fbbf241a;border:1px solid rgba(251,191,36,.25);border-radius:8px;color:#fbbf24;font-size:13px}
