:root{--bg-base:#f0fdf9;--bg-card:#e6faf5;--bg-elevated:#d4f5ec;--bg-hover:#c0efe3;--border:#b0e8d8;--border-strong:#8edcc8;--text-primary:#0a1f1a;--text-secondary:#3d6b5e;--text-muted:#6b9a8d;--accent:#14b8a6;--accent-dim:rgba(20, 184, 166, 0.1);--success:#10b981;--success-dim:rgba(16, 185, 129, 0.1);--warning:#f59e0b;--warning-dim:rgba(245, 158, 11, 0.1);--danger:#ef4444;--danger-dim:rgba(239, 68, 68, 0.1);--purple:#8b5cf6;--purple-dim:rgba(139, 92, 246, 0.1);--orange:#f97316;--orange-dim:rgba(249, 115, 22, 0.1);--font:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;--font-mono:'JetBrains Mono', 'SF Mono', monospace;--radius-sm:6px;--radius:8px;--radius-lg:12px;--radius-xl:16px;--shadow:0 1px 3px rgba(20, 184, 166, 0.08);--shadow-md:0 4px 12px rgba(20, 184, 166, 0.12);--shadow-lg:0 8px 24px rgba(20, 184, 166, 0.16)}[data-theme="dark"]{--bg-base:#071511;--bg-card:#0d201a;--bg-elevated:#132a22;--bg-hover:#1a352c;--border:#1f4035;--border-strong:#2a5042;--text-primary:#e0f5ee;--text-secondary:#8ecfba;--text-muted:#5a9a85;--accent:#2dd4bf;--accent-dim:rgba(45, 212, 191, 0.15);--success:#34d399;--success-dim:rgba(52, 211, 153, 0.15);--warning:#fbbf24;--warning-dim:rgba(251, 191, 36, 0.15);--danger:#f87171;--danger-dim:rgba(248, 113, 113, 0.15);--purple:#a78bfa;--purple-dim:rgba(167, 139, 250, 0.15);--orange:#fb923c;--orange-dim:rgba(251, 146, 60, 0.15);--shadow:0 1px 3px rgba(0, 0, 0, 0.3);--shadow-md:0 4px 12px rgba(0, 0, 0, 0.4);--shadow-lg:0 8px 24px rgba(0, 0, 0, 0.5)}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg-base);color:var(--text-primary);line-height:1.6;min-height:100vh;transition:background-color 0.2s ease,color 0.2s ease}.header{position:sticky;top:0;z-index:100;background:var(--bg-card);border-bottom:1px solid var(--border);backdrop-filter:blur(12px)}.header-content{max-width:1200px;margin:0 auto;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:inherit}.logo svg{color:var(--accent)}.logo h1{font-size:1.25rem;font-weight:700;letter-spacing:-.02em}.logo-text{font-size:1.25rem;font-weight:700;letter-spacing:-.02em}.header-actions{display:flex;gap:.5rem;align-items:center}.share-divider{width:1px;height:20px;background:var(--border);margin:0 .25rem}.share-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;border:none;cursor:pointer;transition:transform 0.2s,box-shadow 0.2s;color:#fff;text-decoration:none}.share-btn:hover{transform:scale(1.15);box-shadow:0 2px 8px rgb(0 0 0 / .2)}.share-facebook{background:#1877f2}.share-twitter{background:#000}.share-pinterest{background:#e60023}.share-linkedin{background:#0a66c2}.share-telegram{background:#08c}.share-email{background:#777}.share-whatsapp{background:#25d366}.share-copy{background:#6c757d;cursor:pointer}.share-sms{background:#17a2b8}.main{max-width:1200px;margin:0 auto;padding:1.5rem}.section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.section-header h2{font-size:1rem;font-weight:600}.section-actions{display:flex;gap:.5rem;flex-wrap:wrap}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media (max-width:900px){.grid-2{grid-template-columns:1fr}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;border:none;border-radius:var(--radius);cursor:pointer;transition:all 0.15s ease;font-family:var(--font)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#2563eb;box-shadow:0 4px 12px rgb(59 130 246 / .3)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-outline{background:#fff0;color:var(--text-secondary);border:1px solid var(--border);padding:.5rem .75rem;font-size:.75rem}.btn-outline:hover{background:var(--bg-elevated);border-color:var(--border-strong)}.btn-text{background:none;border:none;color:#070807;font-size:.8125rem;font-weight:500;cursor:pointer;padding:.25rem .5rem}.btn-text:hover{text-decoration:underline}.btn-danger-text{color:var(--danger)}.icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;transition:all 0.15s ease}.icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.input,.select{width:100%;padding:.625rem .875rem;font-size:.875rem;font-family:var(--font);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);transition:all 0.15s ease}.input:focus,.select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235a6178' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.5rem;cursor:pointer}.location-card{max-width:600px;margin:0 auto 1.5rem;padding:1rem 1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);font-size:.875rem}.location-info{display:flex;flex-direction:column;gap:.25rem}.location-row{display:flex;align-items:center;gap:.5rem}.location-row svg{color:var(--accent);flex-shrink:0}.location-row span:first-child{font-weight:600;color:var(--text-primary)}.ip-text{font-family:var(--font-mono);font-weight:600;font-size:.9375rem;color:var(--text-primary);letter-spacing:.02em}.copy-ip-btn{display:none;align-items:center;justify-content:center;width:24px;height:24px;border-radius:4px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-muted);cursor:pointer;transition:all 0.15s ease;flex-shrink:0}.copy-ip-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.copy-hint{font-size:.6875rem;color:var(--text-muted);cursor:pointer;user-select:none}.copy-hint:hover{color:var(--accent)}.location-details{font-size:.75rem;color:var(--text-muted);margin-top:.125rem}.hidden{display:none!important}.stats-bar{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.stat-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;text-align:center}.stat-label{display:block;font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.stat-value{display:block;font-size:1.5rem;font-weight:700;color:var(--text-primary);font-family:var(--font-mono)}.test-hero{background:linear-gradient(135deg,var(--accent-dim) 0%,rgb(139 92 246 / .06) 100%);border:1px solid var(--border);border-radius:var(--radius-xl);padding:2.5rem 2rem;margin-bottom:1.5rem;position:relative;overflow:hidden}.test-hero::before{content:'';position:absolute;top:-40%;right:-20%;width:300px;height:300px;background:radial-gradient(circle,var(--accent-dim) 0%,transparent 70%);opacity:.5;pointer-events:none}.test-hero::after{content:'';position:absolute;bottom:-30%;left:-10%;width:250px;height:250px;background:radial-gradient(circle,var(--purple-dim) 0%,transparent 70%);opacity:.4;pointer-events:none}.test-hero-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:1.25rem}.test-hero-title{display:flex;align-items:center;gap:.75rem}.test-hero-icon{color:var(--accent)}.test-hero-title h2{font-size:1.75rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.test-hero-desc{font-size:1rem;color:var(--text-secondary);text-align:center;max-width:420px}.test-hero-controls{display:flex;align-items:center;gap:1rem;margin-top:.5rem}.test-mode-group{display:flex;flex-direction:column;gap:.375rem}.test-mode-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.test-mode-select{padding:.875rem 2.5rem .875rem 1rem;font-size:.9375rem;font-weight:500;font-family:var(--font);background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-lg);color:var(--text-primary);cursor:pointer;transition:all 0.2s ease;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236b9a8d' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .875rem center}.test-mode-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-dim)}.test-hero-btn{display:inline-flex;align-items:center;gap:.625rem;padding:1rem 2.5rem;font-size:1.0625rem;font-weight:700;font-family:var(--font);background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);color:#fff;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all 0.2s ease;box-shadow:0 4px 14px rgb(239 68 68 / .35);position:relative;overflow:hidden}.test-hero-btn::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgb(255 255 255 / .15),transparent);transition:left 0.5s ease}.test-hero-btn:hover::before{left:100%}.test-hero-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgb(239 68 68 / .45)}.test-hero-btn:active{transform:translateY(0);box-shadow:0 2px 8px rgb(239 68 68 / .3)}.test-hero-btn.btn-danger{background:linear-gradient(135deg,var(--accent) 0%,#0d9488 100%);box-shadow:0 4px 14px rgb(20 184 166 / .35)}.test-hero-btn.btn-danger:hover{box-shadow:0 6px 20px rgb(20 184 166 / .45)}.btn-icon{flex-shrink:0}.test-hero-hint{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--text-muted)}.test-hero-hint svg{flex-shrink:0;opacity:.6}.progress-container{width:100%;max-width:480px;margin:1rem auto 0;position:relative;z-index:1}.progress-header{display:flex;justify-content:space-between;font-size:.8125rem;font-weight:500;color:var(--text-secondary);margin-bottom:.5rem}.progress-bar{height:8px;background:var(--bg-elevated);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#ef4444,#dc2626);border-radius:4px;transition:width 0.3s ease;width:0%;position:relative}.progress-fill::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgb(255 255 255 / .3) 50%,transparent 100%);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}.completion-message{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.25rem;background:var(--success-dim);color:var(--success);border-radius:var(--radius);font-size:.875rem;font-weight:600;margin-top:1rem;position:relative;z-index:1}.best-server{margin-bottom:1.5rem}#bestServer{margin-bottom:2rem}.best-server-card{background:linear-gradient(135deg,var(--accent-dim),var(--purple-dim));border:1px solid var(--accent);border-radius:var(--radius-lg);padding:2rem 1.5rem;text-align:center}.best-server-badge{display:inline-block;padding:.25rem .75rem;background:var(--accent);color:#fff;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.best-server-name{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.best-server-score{font-size:2rem;font-weight:700;color:var(--accent);font-family:var(--font-mono)}.score-ring-container{position:relative;width:120px;height:120px;margin:1rem auto}.score-ring{width:100%;height:100%;transform:rotate(-90deg)}.score-ring-bg{fill:none;stroke:var(--border);stroke-width:8}.score-ring-fill{fill:none;stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset 1s ease-out}.score-ring-value{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.score-ring-number{display:block;font-size:2rem;font-weight:800;font-family:var(--font-mono);color:var(--text-primary);line-height:1}.score-ring-label{font-size:.875rem;color:var(--text-muted);font-weight:500}.best-server-ips{font-size:.75rem;color:var(--text-muted);font-family:var(--font-mono);margin-top:.5rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.copy-ips-btn{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:4px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-muted);cursor:pointer;transition:all 0.15s ease;padding:0}.copy-ips-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.best-server-time{font-size:.875rem;color:var(--text-secondary)}.server-list{max-height:400px;overflow-y:auto;margin-top:.75rem}.server-checkbox{display:flex;align-items:center;gap:.75rem;padding:.625rem .75rem;border-radius:var(--radius);cursor:pointer;transition:background-color 0.15s ease}.server-checkbox:hover{background:var(--bg-elevated)}.server-checkbox input[type="checkbox"]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.checkbox-label{flex:1;display:flex;flex-direction:column}.checkbox-label .server-name{font-size:.875rem;font-weight:500;color:var(--text-primary)}.checkbox-label .server-meta{font-size:.75rem;color:var(--text-muted)}.privacy-badge{font-size:.625rem;font-weight:600;padding:.125rem .5rem;border-radius:9999px;text-transform:uppercase;letter-spacing:.03em}.privacy-very-high,.privacy-high{background:var(--success-dim);color:var(--success)}.privacy-medium{background:var(--warning-dim);color:var(--warning)}.privacy-low,.privacy-unknown{background:var(--bg-elevated);color:var(--text-muted)}.chart-container{position:relative;height:auto;min-height:300px;padding:.5rem 0}#chartSection{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border)}#chartSection .section-header{padding:1.25rem 1.5rem .5rem;margin-bottom:0}#chartSection h2{font-size:.9375rem;font-weight:700;color:var(--text-primary);margin:0}.table-container{overflow-x:auto}.results-table{width:100%;border-collapse:collapse;font-size:.875rem}.results-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);white-space:nowrap}.results-table th:last-child{text-align:center}.results-table th.sortable{cursor:pointer;user-select:none}.results-table th.sortable:hover{color:var(--text-primary)}.results-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border);vertical-align:middle}.cell-status{text-align:center;white-space:nowrap}.results-table tr:last-child td{border-bottom:none}.results-table tr:hover{background:var(--bg-elevated)}.server-info{display:flex;align-items:center;gap:.75rem}.server-rank{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);font-weight:700;font-size:.75rem;font-family:var(--font-mono);color:var(--text-muted)}.server-name{font-weight:600;color:var(--text-primary)}.server-meta{font-size:.75rem;color:var(--text-muted)}.time-fast{color:var(--success)}.time-medium{color:var(--warning)}.time-slow{color:var(--orange)}.time-unavailable{color:var(--text-muted)}.score-badge{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:26px;padding:0 .5rem;border-radius:13px;font-size:.75rem;font-weight:700;font-family:var(--font-mono)}.score-excellent{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46;box-shadow:0 1px 3px rgb(16 185 129 / .3)}.score-good{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;box-shadow:0 1px 3px rgb(245 158 11 / .3)}.score-fair{background:linear-gradient(135deg,#ffedd5,#fed7aa);color:#9a3412;box-shadow:0 1px 3px rgb(249 115 22 / .3)}.score-poor{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b;box-shadow:0 1px 3px rgb(239 68 68 / .3)}[data-theme="dark"] .score-excellent{background:linear-gradient(135deg,rgb(16 185 129 / .2),rgb(16 185 129 / .1));color:#34d399}[data-theme="dark"] .score-good{background:linear-gradient(135deg,rgb(245 158 11 / .2),rgb(245 158 11 / .1));color:#fbbf24}[data-theme="dark"] .score-fair{background:linear-gradient(135deg,rgb(249 115 22 / .2),rgb(249 115 22 / .1));color:#fb923c}[data-theme="dark"] .score-poor{background:linear-gradient(135deg,rgb(239 68 68 / .2),rgb(239 68 68 / .1));color:#f87171}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.3rem .75rem;border-radius:9999px;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.status-pending{background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border)}.status-testing{background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent);animation:pulse 1.5s infinite}.status-done{background:var(--success-dim);color:var(--success);border:1px solid var(--success)}.status-partial{background:var(--warning-dim);color:var(--warning);border:1px solid var(--warning)}.status-error{background:var(--danger-dim);color:var(--danger);border:1px solid var(--danger)}.status-stable{background:var(--success-dim);color:var(--success);border:1px solid var(--success)}.status-unstable{background:var(--warning-dim);color:var(--warning);border:1px solid var(--warning)}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.6}}.result-row.expandable{user-select:none}.result-row.expandable:hover{background:var(--bg-elevated)}.expand-arrow{color:var(--text-muted);flex-shrink:0;transition:transform 0.2s ease}.result-row.expanded .expand-arrow{transform:rotate(90deg);color:var(--accent)}.detail-row td{padding:0!important;border-bottom:1px solid var(--border)!important;background:var(--bg-base)}.detail-row:hover{background:var(--bg-base)!important}.detail-content{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.detail-ips,.detail-doh{display:flex;flex-direction:column;gap:.375rem}.detail-ips-label,.detail-doh-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.detail-ips-value,.detail-doh-value{display:flex;align-items:center;gap:.5rem}.detail-ips-text{font-family:var(--font-mono);font-size:.8125rem;font-weight:600;color:var(--accent);background:var(--accent-dim);padding:.375rem .75rem;border-radius:var(--radius-sm);border:1px solid rgb(20 184 166 / .2);user-select:all}.detail-doh-value code{font-family:var(--font-mono);font-size:.75rem;color:var(--text-secondary);background:var(--bg-elevated);padding:.375rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--border);user-select:all}.detail-copy-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-muted);cursor:pointer;transition:all 0.15s ease;flex-shrink:0}.detail-copy-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.detail-status{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:500;padding:.5rem .75rem;border-radius:var(--radius)}.detail-status svg{flex-shrink:0}.detail-status-ok{background:var(--success-dim);color:var(--success)}.detail-status-error{background:var(--danger-dim);color:var(--danger)}.detail-breakdown{border-top:1px solid var(--border);padding-top:1rem}.detail-breakdown-title{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.75rem}.detail-breakdown-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.375rem}.hostname-row{display:flex;align-items:center;justify-content:space-between;padding:.375rem .625rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.8125rem}.hostname-name{font-family:var(--font-mono);font-weight:500;color:var(--text-primary)}.hostname-time{font-family:var(--font-mono);font-weight:600;font-size:.75rem}.hostname-fail{color:var(--danger)}.empty-state{text-align:center;padding:3rem;color:var(--text-muted)}.empty-state svg{margin-bottom:1rem;opacity:.3}.empty-state p{font-size:.875rem}#historyList{max-height:300px;overflow-y:auto}.history-item{padding:.75rem;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.5rem}.history-header{display:flex;justify-content:space-between;margin-bottom:.25rem}.history-date{font-weight:600;font-size:.875rem}.history-time{font-size:.8125rem;color:var(--text-muted)}.history-stats{display:flex;gap:1rem;font-size:.75rem;color:var(--text-secondary)}.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}@media (max-width:900px){.how-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:500px){.how-grid{grid-template-columns:1fr}}.how-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;text-align:center}.how-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);margin:0 auto .75rem}.how-icon.green{background:var(--success-dim);color:var(--success)}.how-icon.blue{background:var(--accent-dim);color:var(--accent)}.how-icon.yellow{background:var(--warning-dim);color:var(--warning)}.how-icon.purple{background:var(--purple-dim);color:var(--purple)}.how-card h3{font-size:.875rem;font-weight:600;margin-bottom:.375rem}.how-card p{font-size:.8125rem;color:var(--text-secondary);line-height:1.5}.footer{margin-top:3rem;padding:2rem 1.5rem;border-top:1px solid var(--border);text-align:center}.footer-content{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1rem}.footer-ogimage{width:100%;max-width:600px;height:auto;aspect-ratio:1200 / 630;border-radius:var(--radius-lg);object-fit:cover;box-shadow:var(--shadow-md)}.footer-nav{display:flex;gap:1.5rem}.footer-nav a{color:var(--text-secondary);text-decoration:none;font-size:.875rem;font-weight:500;transition:color 0.15s ease}.footer-nav a:hover{color:var(--accent)}.footer-copyright{font-size:.8125rem;color:var(--text-muted)}.heart{color:var(--danger)}.toast{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--bg-card);border:1px solid var(--border-strong);color:var(--text-primary);padding:.75rem 1.25rem;border-radius:var(--radius);display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;box-shadow:var(--shadow-lg);transform:translateY(120%);opacity:0;transition:all 0.3s ease;z-index:1000}.toast.show{transform:translateY(0);opacity:1}.toast svg{flex-shrink:0}.toast-success svg{color:var(--success)}.toast-error svg{color:var(--danger)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#fff0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}@media (max-width:768px){.header-content{padding:.75rem 1rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.header-content::-webkit-scrollbar{display:none}.logo{flex-shrink:0}.logo svg{width:20px;height:20px}.logo h1{font-size:1rem}.logo-text{font-size:1rem}.header-actions{gap:.375rem;flex-shrink:0}.share-divider{display:none}.share-btn{width:28px;height:28px}.share-btn svg{width:13px;height:13px}.icon-btn{width:32px;height:32px}.icon-btn svg{width:16px;height:16px}.main{padding:.75rem}.section{padding:1rem;margin-bottom:1rem;border-radius:var(--radius)}.stats-bar{grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:1rem}.stat-item{padding:.625rem .375rem}.stat-label{font-size:.625rem}.stat-value{font-size:1.125rem}.test-hero{padding:2rem 1.25rem;border-radius:var(--radius-lg)}.test-hero-title h2{font-size:1.375rem}.test-hero-desc{font-size:.875rem}.test-hero-controls{flex-direction:column;width:100%;gap:.75rem}.test-mode-group{width:100%}.test-mode-select{width:100%}.test-hero-btn{width:100%;justify-content:center;padding:1rem 1.5rem;font-size:1rem}.progress-container{width:100%}.grid-2{grid-template-columns:1fr;gap:1rem}.server-list{max-height:300px}.server-checkbox{padding:.5rem}.checkbox-label .server-name{font-size:.8125rem}.checkbox-label .server-meta{font-size:.6875rem}.privacy-badge{font-size:.5625rem;padding:.0625rem .375rem}.table-container{margin:0 -.5rem;padding:0 .5rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.results-table{min-width:600px;font-size:.75rem}.results-table th,.results-table td{padding:.5rem .375rem;white-space:nowrap}.results-table th{font-size:.6875rem}.server-rank{width:24px;height:24px;font-size:.6875rem}.server-name{font-size:.8125rem}.server-meta{font-size:.6875rem}.score-badge{width:32px;height:22px;font-size:.6875rem}.detail-content{padding:1rem;gap:.75rem}.detail-ips-text{font-size:.75rem;word-break:break-all}.detail-doh-value code{font-size:.6875rem;word-break:break-all}.detail-breakdown-grid{grid-template-columns:1fr}.hostname-row{font-size:.75rem}.chart-container{min-height:250px;padding:.25rem 0}#chartSection .section-header{padding:1rem 1rem .25rem}.best-server-card{padding:1.25rem}.best-server-name{font-size:1.25rem}.best-server-ips{font-size:.6875rem;word-break:break-all;justify-content:center}.score-ring-container{width:100px;height:100px}.score-ring-number{font-size:1.5rem}.score-ring-label{font-size:.75rem}.section-header{flex-direction:column;align-items:flex-start;gap:.5rem}.section-header h2{font-size:.9375rem}.section-actions{width:100%;display:flex;flex-wrap:wrap;gap:.375rem}.btn-outline{font-size:.6875rem;padding:.375rem .5rem}.btn-outline svg{display:none}.btn-text{font-size:.75rem}.history-item{padding:.625rem}.history-header{flex-direction:column;gap:.125rem}.history-stats{flex-wrap:wrap;gap:.5rem}.how-grid{grid-template-columns:1fr 1fr;gap:.75rem}.how-card{padding:1rem}.how-icon{width:36px;height:36px}.how-icon svg{width:18px;height:18px}.how-card h3{font-size:.8125rem}.how-card p{font-size:.75rem}.footer{padding:1.5rem 1rem;margin-top:2rem}.footer-ogimage{width:100%;max-width:300px;height:auto}.footer-nav{gap:.75rem;flex-wrap:wrap;justify-content:center}.footer-nav a{font-size:.8125rem}.footer-copyright{font-size:.75rem}.toast{left:1rem;right:1rem;bottom:1rem;font-size:.8125rem}.location-card{font-size:.8125rem;padding:.75rem 1rem}.ip-text{font-size:.8125rem;word-break:break-all}.location-details{font-size:.6875rem}.guide-cta{padding:2rem 1.25rem}.guide-cta h2{font-size:1.25rem}}@media (max-width:400px){.logo h1{font-size:.875rem}.logo-text{font-size:.875rem}.share-btn{display:none}.share-copy{display:flex}.stats-bar{grid-template-columns:repeat(3,1fr);gap:.375rem}.stat-item{padding:.5rem .25rem}.stat-label{font-size:.5625rem}.stat-value{font-size:1rem}.how-grid{grid-template-columns:1fr}.section-actions{flex-direction:column}.btn-outline{width:100%;justify-content:center}.test-hero{padding:1.5rem 1rem}.test-hero-title h2{font-size:1.125rem}.test-hero-title svg{width:22px;height:22px}}@media (min-width:769px) and (max-width:1024px){.main{padding:1.25rem}.grid-2{grid-template-columns:1fr 1fr}.how-grid{grid-template-columns:repeat(2,1fr)}}@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important}}.guide-hero{background:linear-gradient(135deg,var(--accent-dim),var(--purple-dim));border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;margin-bottom:1.5rem;text-align:center}.guide-hero h2{font-size:1.75rem;font-weight:700;margin:.75rem 0 .5rem}.guide-hero p{font-size:1rem;color:var(--text-secondary);max-width:600px;margin:0 auto}.badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:var(--accent-dim);color:var(--accent);border-radius:9999px;font-size:.75rem;font-weight:600}.toc{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem}.toc-title{font-size:.8125rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.75rem}.toc-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:.375rem 2rem;counter-reset:toc-counter}.toc-list li{counter-increment:toc-counter;font-size:.875rem;line-height:1.5}.toc-list li::before{content:counter(toc-counter) ". ";color:var(--text-muted);font-weight:500}.toc-list a{color:var(--accent);text-decoration:none;transition:color 0.15s ease}.toc-list a:hover{color:var(--text-primary);text-decoration:underline}@media (max-width:768px){.toc-list{grid-template-columns:1fr}}.page-header{margin-bottom:1.5rem}.page-header h1{font-size:1.75rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:.375rem}.page-header p{font-size:1rem;color:var(--text-secondary)}.page-content{display:flex;flex-direction:column;gap:1.5rem}.page-content h2{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.page-content p{font-size:.9375rem;color:var(--text-secondary);line-height:1.7}.mission-card{background:linear-gradient(135deg,var(--accent-dim),var(--purple-dim));border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem}.mission-card h3{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin-bottom:.75rem}.mission-card p{font-size:.9375rem;color:var(--text-secondary);line-height:1.7;margin:0}.feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}@media (max-width:600px){.feature-grid{grid-template-columns:1fr}}.feature-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;transition:border-color 0.15s ease,box-shadow 0.15s ease}.feature-item:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}.feature-icon{font-size:1.5rem;margin-bottom:.5rem;line-height:1}.feature-item h4{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:.375rem}.feature-item p{font-size:.8125rem;color:var(--text-secondary);line-height:1.5;margin:0}.tech-list{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem}.tech-list h4{font-size:.8125rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.tech-tags{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{display:inline-flex;align-items:center;padding:.375rem .75rem;background:var(--accent-dim);color:var(--accent);border-radius:9999px;font-size:.75rem;font-weight:600}@media (max-width:768px){.page-header h1{font-size:1.375rem}.mission-card{padding:1.5rem}.feature-item{padding:1rem}}.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}@media (max-width:768px){.contact-grid{grid-template-columns:1fr}}.contact-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;text-align:center;transition:border-color 0.15s ease,box-shadow 0.15s ease}.contact-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}.contact-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--accent-dim);color:var(--accent);border-radius:var(--radius);margin:0 auto .75rem}.contact-icon svg{width:20px;height:20px}.contact-card h3{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:.375rem}.contact-card p{font-size:.8125rem;color:var(--text-muted);margin-bottom:.75rem}.contact-card a{font-size:.8125rem;color:var(--accent);text-decoration:none;font-weight:500;word-break:break-all}.contact-card a:hover{text-decoration:underline}.form-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem}.form-section h2{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin-bottom:1.25rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width:600px){.form-row{grid-template-columns:1fr}}.form-group{display:flex;flex-direction:column;gap:.375rem;margin-bottom:1rem}.form-group label{font-size:.8125rem;font-weight:600;color:var(--text-primary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.625rem .875rem;font-size:.875rem;font-family:var(--font);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);transition:all 0.15s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-group textarea{min-height:120px;resize:vertical}.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235a6178' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.5rem;cursor:pointer}.submit-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 2rem;font-size:.9375rem;font-weight:600;font-family:var(--font);background:var(--accent);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;transition:all 0.15s ease}.submit-btn:hover{background:#0d9488;box-shadow:0 4px 12px rgb(20 184 166 / .3)}@media (max-width:768px){.contact-card{padding:1.25rem}.form-section{padding:1.25rem}}.seo-content{display:flex;flex-direction:column;gap:1.5rem}.seo-article{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow)}.seo-article h2{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:1rem;line-height:1.4}.seo-article h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:1.25rem 0 .5rem}.seo-article p{font-size:.9375rem;color:var(--text-secondary);line-height:1.7;margin-bottom:.75rem}.seo-article p:last-child{margin-bottom:0}.seo-article code{background:var(--bg-elevated);padding:.125rem .375rem;border-radius:4px;font-size:.8125rem;font-family:var(--font-mono)}.faq-item{border-bottom:1px solid var(--border)}.faq-item:last-child{border-bottom:none}.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0;background:none;border:none;cursor:pointer;text-align:left;font-family:var(--font);color:var(--text-primary);transition:color 0.15s ease}.faq-question:hover{color:var(--accent)}.faq-question h3{font-size:.9375rem;font-weight:600;color:inherit;margin:0;flex:1}.faq-question svg{width:18px;height:18px;flex-shrink:0;color:var(--text-muted);transition:transform 0.25s ease}.faq-item.open .faq-question svg{transform:rotate(180deg);color:var(--accent)}.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.3s ease,padding 0.3s ease}.faq-item.open .faq-answer{max-height:500px;padding-bottom:1rem}.faq-answer p{font-size:.875rem;color:var(--text-secondary);line-height:1.7;margin:0}.guide-cta{text-align:center;padding:3rem 2rem;margin-bottom:1.5rem;background:linear-gradient(135deg,var(--accent-dim),rgb(139 92 246 / .08));border:1px solid var(--border);border-radius:var(--radius-xl);position:relative;overflow:hidden}.guide-cta::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at center,var(--accent-dim) 0%,transparent 60%);opacity:.4;pointer-events:none}.guide-cta h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.75rem;position:relative}.guide-cta p{color:var(--text-secondary);margin-bottom:1.5rem;max-width:560px;margin-left:auto;margin-right:auto;line-height:1.7;position:relative}.guide-cta .btn{font-size:1rem;padding:.875rem 2.5rem;position:relative;box-shadow:0 4px 14px rgb(20 184 166 / .25)}.guide-cta .btn:hover{box-shadow:0 6px 20px rgb(20 184 166 / .35);transform:translateY(-1px)}@media (max-width:768px){.guide-hero{padding:1.5rem}.guide-hero h2{font-size:1.375rem}.seo-article{padding:1.25rem}.seo-article h2{font-size:1.125rem}.seo-article p{font-size:.875rem}.faq-question{padding:.75rem 0}.faq-question h3{font-size:.875rem}.faq-question svg{width:16px;height:16px}.faq-answer p{font-size:.8125rem}}