*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif;background-color:#f5f7fa;color:#333;line-height:1.5;margin:0;padding:0;font-weight:400}#app{min-height:100vh;display:flex;flex-direction:column;max-width:1600px;margin:0 auto}.header{background:#fff;padding:.75rem 1.5rem;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center}.site-title{font-size:1.5rem;font-weight:700;color:#2c3e50;letter-spacing:-.02em}.header-actions{display:flex;gap:1rem}.btn{padding:.5rem 1rem;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s}.btn-primary{background:#3498db;color:#fff}.btn-primary:hover{background:#2980b9;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.refresh-icon{display:inline-block;margin-right:.5rem;transition:transform .3s ease}.btn-primary:hover .refresh-icon{transform:rotate(180deg)}.overview-section{padding:1.5rem 0}.overview-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}.overview-card{position:relative;background:linear-gradient(135deg,#fff,#f8f9fa);padding:1.5rem 1.25rem;border-radius:16px;box-shadow:0 4px 20px #00000014;text-align:center;transition:all .3s ease;min-width:0;border:1px solid rgba(255,255,255,.2);overflow:hidden}.overview-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3498db,#2980b9);border-radius:16px 16px 0 0}.overview-card:nth-child(1):before{background:linear-gradient(90deg,#3498db,#2980b9)}.overview-card:nth-child(2):before{background:linear-gradient(90deg,#27ae60,#229954)}.overview-card:nth-child(3):before{background:linear-gradient(90deg,#e74c3c,#c0392b)}.overview-card:nth-child(4):before{background:linear-gradient(90deg,#f39c12,#e67e22)}.overview-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 30px #0000001f}.card-icon{font-size:2.5rem;margin-bottom:1rem;opacity:.8;transition:all .3s ease}.overview-card:hover .card-icon{opacity:1;transform:scale(1.1)}.overview-card h3{font-size:.95rem;color:#5a6c7d;margin-bottom:1.25rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;position:relative}.overview-card h3:after{content:"";position:absolute;bottom:-.5rem;left:50%;transform:translate(-50%);width:30px;height:2px;background:linear-gradient(90deg,#3498db,#2980b9);border-radius:1px}.overview-card:nth-child(2) h3:after{background:linear-gradient(90deg,#27ae60,#229954)}.overview-card:nth-child(3) h3:after{background:linear-gradient(90deg,#e74c3c,#c0392b)}.overview-card:nth-child(4) h3:after{background:linear-gradient(90deg,#f39c12,#e67e22)}.overview-value{font-size:2.25rem;font-weight:800;color:#2c3e50;margin-bottom:.75rem;letter-spacing:-.02em;text-shadow:0 2px 4px rgba(0,0,0,.1);position:relative;transition:all .3s ease}.overview-value.updating{transform:scale(1.05);color:#3498db}@keyframes pulse{0%{box-shadow:0 4px 20px #00000014}50%{box-shadow:0 4px 20px #3498db33}to{box-shadow:0 4px 20px #00000014}}.overview-card.updating{animation:pulse .6s ease-in-out}.overview-label{font-size:.85rem;color:#7f8c8d;font-weight:500;opacity:.8}.node-progress{margin-top:.75rem}.progress-info{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.85rem;font-weight:600}.online-info{color:#27ae60}.offline-info{color:#e74c3c}.progress-bar-container{width:100%;height:8px;background:#ecf0f1;border-radius:4px;overflow:hidden;position:relative;margin-bottom:.5rem}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#27ae60,#2ecc71);border-radius:4px;transition:width .3s ease;width:0%}.progress-percentage{font-size:.8rem;color:#7f8c8d;font-weight:500;text-align:center}.groups-section{padding:0 0 1rem}.groups-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.5rem 0}.groups-section h2{margin:0;color:#2c3e50;font-size:1.2rem;font-weight:700;position:relative;display:flex;align-items:center;gap:.75rem}.groups-section h2:before{content:"🏷️";font-size:1.1rem}.groups-section h2:after{content:"";flex:1;height:2px;background:linear-gradient(90deg,#3498db,transparent);border-radius:1px;max-width:100px}.groups-controls{display:flex;align-items:center;gap:.5rem}.toggle-btn{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:none;border-radius:8px;background:#3498db1a;color:#3498db;cursor:pointer;transition:all .2s ease}.toggle-btn:hover{background:#3498db33;transform:scale(1.05)}.toggle-btn:active{transform:scale(.95)}.toggle-icon{width:1rem;height:1rem;transition:transform .2s ease}.toggle-btn.groups-hidden .toggle-icon{opacity:.5}.toggle-btn.groups-hidden .toggle-icon path:first-child{stroke-dasharray:4 4}.groups-container{display:flex;flex-wrap:wrap;gap:1rem;transition:all .3s ease;overflow:hidden}.groups-container.hidden{max-height:0;opacity:0;margin-top:-1rem;pointer-events:none}.group-tag{background:transparent;color:#86868b;padding:.5rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;-webkit-user-select:none;user-select:none;position:relative}.group-tag:before{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background:#007aff;transition:all .2s ease;transform:translate(-50%);border-radius:1px}.group-tag:hover{color:#1d1d1f;background:#0000000d}.group-tag:hover:before{width:20px}.group-tag.active{color:#007aff;background:#007aff1a}.group-tag.active:before{width:100%}.nodes-section{padding:0 0 1.5rem;flex:1}.nodes-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.5rem 0}.nodes-section h2{margin:0;color:#2c3e50;font-size:1.2rem;font-weight:700;position:relative;display:flex;align-items:center;gap:.75rem}.nodes-section h2:before{content:"📋";font-size:1.1rem}.nodes-section h2:after{content:"";flex:1;height:2px;background:linear-gradient(90deg,#27ae60,transparent);border-radius:1px;max-width:100px}.sort-controls{display:flex;align-items:center;gap:.75rem;background:#ffffffe6;padding:.5rem 1rem;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);box-shadow:0 2px 8px #0000000d;transition:all .2s ease}.sort-controls:hover{background:#fffffff2;box-shadow:0 4px 12px #00000014;transform:translateY(-1px)}.sort-controls label{font-size:.9rem;color:#5a6c7d;font-weight:600;letter-spacing:.02em;text-shadow:0 1px 2px rgba(255,255,255,.8)}.custom-select{position:relative;min-width:160px}.select-trigger{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;border:2px solid #e9ecef;border-radius:8px;background:#fff;font-size:.9rem;font-weight:500;color:#2c3e50;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.select-trigger:hover{border-color:#3498db;background-color:#f8f9fa;transform:translateY(-1px);box-shadow:0 2px 8px #3498db26}.select-trigger.active{border-color:#3498db;background-color:#fff;box-shadow:0 0 0 3px #3498db1a,0 2px 8px #3498db26}.select-arrow{width:1rem;height:1rem;color:#6b7280;transition:all .2s ease;flex-shrink:0}.select-trigger.active .select-arrow{color:#3498db;transform:rotate(180deg)}.select-dropdown{position:absolute;top:calc(100% + .5rem);left:0;right:0;background:#fff;border:2px solid #e9ecef;border-radius:10px;box-shadow:0 8px 25px #00000026;z-index:1000;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow:hidden;max-height:280px}.custom-select.open .select-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.select-option{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;cursor:pointer;transition:all .15s ease;border-bottom:1px solid #f1f3f4}.select-option:last-child{border-bottom:none}.select-option:hover{background:linear-gradient(135deg,#f8f9fa,#e9ecef);transform:translate(4px)}.select-option.active{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.select-option.active:hover{background:linear-gradient(135deg,#2980b9,#1f5f8b)}.option-icon{font-size:1rem;flex-shrink:0;width:1.2rem;text-align:center}.option-text{font-size:.9rem;font-weight:600;flex:1}.select-dropdown:before{content:"";position:absolute;top:-6px;left:1rem;width:12px;height:12px;background:#fff;border:2px solid #e9ecef;border-bottom:none;border-right:none;transform:rotate(45deg);z-index:-1}.select-option{animation:slideIn .2s ease forwards;opacity:0;transform:translateY(-10px)}.custom-select.open .select-option:nth-child(1){animation-delay:.05s}.custom-select.open .select-option:nth-child(2){animation-delay:.1s}.custom-select.open .select-option:nth-child(3){animation-delay:.15s}.custom-select.open .select-option:nth-child(4){animation-delay:.2s}@keyframes slideIn{to{opacity:1;transform:translateY(0)}}@media (max-width: 480px){.sort-controls{background:#fff;padding:.4rem .8rem;border-radius:8px}.custom-select{min-width:140px}.select-trigger{font-size:.85rem;padding:.4rem .8rem}.select-dropdown{border-radius:8px;max-height:250px}.select-option{padding:.5rem .8rem;gap:.6rem}.option-icon{font-size:.9rem;width:1rem}.option-text{font-size:.85rem}}.nodes-table-container{background:#fff;border-radius:16px;padding:1.5rem 0;box-shadow:0 4px 20px #00000014;overflow-x:auto}.nodes-table{width:1536px;border-collapse:separate;border-spacing:0 .5rem;font-size:.9rem;margin:0 auto}.nodes-table thead tr{background:none}.nodes-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.82rem;color:#6c757d;text-transform:uppercase}.nodes-table tbody tr{background:#fff;box-shadow:0 2px 8px #0000000f;transition:all .3s ease}.nodes-table tbody tr.offline-row,.nodes-table tbody tr.offline-row .node-name{color:#e74c3c}.nodes-table tbody tr:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-3px)}.nodes-table tbody tr td:first-child{border-radius:8px 0 0 8px}.nodes-table tbody tr td:last-child{border-radius:0 8px 8px 0}.nodes-table td{padding:.75rem 1rem;color:#2c3e50;font-weight:500;background:#fff}.node-name{font-weight:700;font-size:1.05rem;color:#1a1a1a;cursor:pointer;position:relative;transition:all .2s ease;-webkit-user-select:none;user-select:none}.node-name:hover{color:#667eea}.node-name:active{transform:scale(.98)}.nodes-table tbody tr:hover .node-name{color:#667eea}.status-badge{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;position:relative}.status-badge svg{width:24px;height:24px;transition:all .3s ease}.status-badge.status-online svg{filter:drop-shadow(0 0 4px rgba(39,174,96,.4));animation:server-pulse 3s ease-in-out infinite}@keyframes server-pulse{0%,to{filter:drop-shadow(0 0 4px rgba(39,174,96,.4))}50%{filter:drop-shadow(0 0 8px rgba(39,174,96,.6))}}.status-badge.status-offline svg{filter:drop-shadow(0 0 2px rgba(231,76,60,.3));opacity:.8}.nodes-table tbody tr:hover .status-badge.status-online svg{transform:scale(1.15);filter:drop-shadow(0 0 8px rgba(39,174,96,.6))}.nodes-table tbody tr:hover .status-badge.status-offline svg{transform:scale(1.15);filter:drop-shadow(0 0 4px rgba(231,76,60,.5))}.circular-progress{display:inline-flex;align-items:center;min-height:38px}.circle-wrap{width:38px;height:38px;position:relative}.circle-bg{width:100%;height:100%;border-radius:50%;background:#f1f3f5}.circle{width:100%;height:100%;position:absolute;top:0;left:0}.circle svg{width:100%;height:100%;transform:rotate(-90deg);overflow:visible}.circle-progress{fill:none;stroke-width:3;stroke-linecap:round;transition:stroke-dashoffset .5s ease}.circle-progress.low{stroke:#27ae60}.circle-progress.medium{stroke:#f39c12}.circle-progress.high{stroke:#e74c3c}.circle-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.65rem;font-weight:700;color:#2c3e50}.report-time{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border-radius:12px;font-size:.78rem;font-weight:600;background:#3498db1a;color:#3498db;border:1px solid rgba(52,152,219,.25);transition:all .2s ease}.report-time.recent{background:#27ae601a;color:#27ae60;border-color:#27ae6040}.report-time.warning{background:#f39c121a;color:#f39c12;border-color:#f39c1240}.report-time.offline{background:#e74c3c1a;color:#e74c3c;border-color:#e74c3c40}.report-icon{font-size:.75rem}.uptime-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .85rem;border-radius:12px;font-size:.82rem;font-weight:650;background:#16a0851f;color:#16a085;border:1.5px solid rgba(22,160,133,.3);transition:all .2s ease}.uptime-badge.warning{background:#f39c121f;color:#e67e22;border-color:#f39c1259}.uptime-badge.danger{background:#d354001f;color:#d35400;border-color:#d3540059}.uptime-icon{font-size:.8rem}.nodes-table tbody tr:hover .report-time,.nodes-table tbody tr:hover .uptime-badge{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.nodes-table tbody tr:hover .uptime-badge{border-color:#16a08573;background:#16a08526}.nodes-table tbody tr:hover .uptime-badge.warning{border-color:#f39c1280;background:#f39c122e}.nodes-table tbody tr:hover .uptime-badge.danger{border-color:#d3540080;background:#d354002e}.data-dual-line{display:flex;flex-direction:column;gap:.15rem;font-family:SF Mono,Consolas,monospace;font-size:.8rem;justify-content:center;min-height:38px}.data-row{display:flex;align-items:center;gap:.4rem}.data-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:4px;font-size:.7rem;font-weight:700}.data-icon.download{background:linear-gradient(135deg,#3498db26,#2980b926);color:#3498db}.data-icon.upload{background:linear-gradient(135deg,#9b59b626,#8e44ad26);color:#9b59b6}.data-value{color:#2c3e50;font-weight:600}.country-cell{display:flex;align-items:center;gap:.5rem}.country-flag{width:24px;height:24px;border-radius:4px;object-fit:cover;box-shadow:0 1px 3px #0000001a}.country-code{font-size:.85rem;font-weight:600;color:#495057;letter-spacing:.5px}.os-display{display:inline-flex;align-items:center;gap:.5rem;font-size:.85rem;color:#495057;font-weight:500}.os-icon{width:20px;height:20px;object-fit:contain;opacity:.6;filter:grayscale(30%) brightness(1.1)}.progress-bar{width:50px;height:6px;background:#ecf0f1;border-radius:3px;overflow:hidden;display:inline-block;margin-right:.25rem}.progress-fill{height:100%;background:#3498db;transition:width .3s}.progress-fill.high{background:#e74c3c}.progress-fill.medium{background:#f39c12}.loading{position:fixed;top:0;left:0;right:0;bottom:0;background:#ffffffe6;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000}.loading.hidden{display:none}.spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.footer{background:#2c3e50;color:#ecf0f1;text-align:center;padding:1rem;margin-top:auto}@media (max-width: 1200px){.overview-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem}.overview-card{padding:1.25rem 1rem}.card-icon{font-size:2.25rem}.overview-value{font-size:2rem}.nodes-table{min-width:1000px}}@media (max-width: 768px){#app{max-width:100%}.header{padding:.75rem;flex-direction:column;gap:.75rem}.overview-section,.groups-section,.nodes-section{padding:.75rem}.groups-header{flex-direction:column;align-items:flex-start;gap:.75rem}.groups-controls{align-self:flex-end}.groups-section h2:after,.nodes-section h2:after{max-width:60px}.nodes-header{flex-direction:column;align-items:flex-start;gap:.75rem}.sort-controls{align-self:flex-end}.overview-grid{grid-template-columns:1fr;gap:1rem}.overview-card{padding:1rem .75rem;border-radius:12px}.card-icon{font-size:2rem;margin-bottom:.75rem}.overview-card h3{font-size:.85rem;margin-bottom:1rem}.overview-value{font-size:1.75rem;margin-bottom:.5rem}.overview-label{font-size:.8rem}.nodes-table{font-size:.75rem;min-width:800px}.nodes-table th,.nodes-table td{padding:.4rem .25rem;max-width:100px}.progress-bar{width:40px;height:5px}}.text-center{text-align:center}.text-right{text-align:right}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.hidden{display:none}.copy-toast{position:fixed;top:20px;right:20px;background:#27ae60f2;color:#fff;padding:.75rem 1.25rem;border-radius:8px;font-size:.9rem;font-weight:600;box-shadow:0 4px 12px #00000026;z-index:9999;animation:slideIn .3s ease,slideOut .3s ease 2.7s;pointer-events:none}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(400px);opacity:0}}
