body.ast-theme-transparent-header:has(.traceroute-map) #masthead{position:relative !important;}
body:has(.traceroute-map) .entry-header:has(.entry-title),
body:has(.traceroute-map) .ast-single-entry-banner{display:none !important;}
.traceroute-map{--tm-bg:#f8fafc;--tm-card:#ffffff;--tm-ink:#0f172a;--tm-text:#334155;--tm-muted:#64748b;--tm-line:#d8e1ea;--tm-soft:#eef6f5;--tm-teal:#0f766e;--tm-blue:#2563eb;--tm-amber:#b45309;--tm-red:#b42318;--tm-shadow:0 14px 32px rgba(15, 23, 42, .10);width:100%;max-width:1220px;margin:0 auto;color:var(--tm-text);font-family:-apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;font-size:15px;line-height:1.5;}
.traceroute-map, .traceroute-map *{box-sizing:border-box;}
.traceroute-map h2, .traceroute-map h3, .traceroute-map p{margin-top:0;}
.traceroute-map__tool, .traceroute-map__results, .traceroute-map__map-panel, .traceroute-map__route, .traceroute-map__raw{border:1px solid var(--tm-line);border-radius:8px;background:var(--tm-card);box-shadow:var(--tm-shadow);}
.traceroute-map__tool{overflow:hidden;}
.traceroute-map__head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:24px;border-bottom:1px solid var(--tm-line);background:linear-gradient(180deg, #fff 0%, #f8fbfc 100%);}
.traceroute-map__eyebrow{display:inline-flex;align-items:center;gap:8px;margin-bottom:8px;color:var(--tm-teal);font-size:12px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;}
.traceroute-map__eyebrow::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--tm-teal);}
.traceroute-map__head h2{margin-bottom:8px;color:var(--tm-ink);font-size:34px;font-weight:900;line-height:1.08;}
.traceroute-map__head p{max-width:760px;margin-bottom:0;color:var(--tm-muted);font-size:16px;}
.traceroute-map__status{display:inline-flex;align-items:center;justify-content:center;min-width:116px;min-height:38px;padding:8px 12px;border:1px solid #cbd5e1;border-radius:8px;background:#fff;color:var(--tm-ink);font-size:13px;font-weight:850;line-height:18px;white-space:nowrap;}
.traceroute-map.is-loading .traceroute-map__status{border-color:#facc15;background:#fffbeb;color:#854d0e;}
.traceroute-map__status.is-success{border-color:#5eead4;background:#ecfdf5;color:#047857;}
.traceroute-map__status.is-error{border-color:#fca5a5;background:#fff1f2;color:var(--tm-red);}
.traceroute-map__alert{margin:18px 24px 0;padding:14px 16px;border:1px solid #fecaca;border-left:5px solid #ef4444;border-radius:8px;background:#fff1f2;color:#7f1d1d;}
.traceroute-map__alert[hidden]{display:none;}
.traceroute-map__alert strong{color:var(--tm-red);font-size:16px;}
.traceroute-map__alert p{margin:4px 0 0;}
.traceroute-map__form{display:grid;grid-template-columns:minmax(0, 1fr) minmax(0, 1fr) 130px 130px;gap:14px;padding:20px 24px;background:#fff;}
.traceroute-map__field{display:block;margin:0;min-width:0;}
.traceroute-map__field--wide{min-width:220px;}
.traceroute-map__field span{display:block;margin-bottom:7px;color:var(--tm-ink);font-size:13px;font-weight:850;}
.traceroute-map__field small{display:block;margin-top:6px;color:var(--tm-muted);font-size:12px;}
.traceroute-map input, .traceroute-map select{width:100%;min-height:44px;margin:0;padding:9px 11px;border:1px solid #cbd5e1;border-radius:8px;background:#fff;color:var(--tm-ink);box-shadow:none;font:inherit;}
.traceroute-map input:focus, .traceroute-map select:focus{border-color:var(--tm-teal);outline:3px solid rgba(15, 118, 110, .16);}
.traceroute-map__actions{display:flex;align-items:center;flex-wrap:wrap;gap:10px;padding:0 24px 18px;}
.traceroute-map button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;margin:0;padding:10px 14px;border:1px solid transparent;border-radius:8px;box-shadow:none;font:inherit;font-size:14px;font-weight:850;line-height:1.2;cursor:pointer;transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease, color .16s ease;}
.traceroute-map button::before{content:"";display:inline-block;width:16px;height:16px;flex:0 0 16px;background:currentColor;-webkit-mask:var(--tm-button-icon) center / contain no-repeat;mask:var(--tm-button-icon) center / contain no-repeat;}
.traceroute-map button:hover{transform:translateY(-1px);}
.traceroute-map button:disabled{opacity:.62;cursor:wait;transform:none;}
.traceroute-map__primary{background:var(--tm-teal);color:#fff;box-shadow:0 10px 18px rgba(15, 118, 110, .22);}
.traceroute-map__primary:hover{color:#fff;box-shadow:0 12px 22px rgba(15, 118, 110, .30);}
.traceroute-map__secondary{border-color:#cbd5e1 !important;background:#fff;color:var(--tm-ink);}
.traceroute-map__secondary:hover{border-color:var(--tm-teal) !important;color:var(--tm-teal);box-shadow:0 8px 18px rgba(15, 23, 42, .08);}
.traceroute-map [data-run]{--tm-button-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M3 12h4l3 8 4-16 3 8h4'/%3E%3C/svg%3E");}
.traceroute-map [data-clear]{--tm-button-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M3 6h18M8 6V4h8v2M6 6l1 15h10l1-15M10 11v6M14 11v6'/%3E%3C/svg%3E");}
.traceroute-map [data-copy]{--tm-button-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M8 8h11v12H8zM5 16H4V4h12v1'/%3E%3C/svg%3E");}
.traceroute-map [data-export]{--tm-button-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M12 3v12m0 0 4-4m-4 4-4-4M5 21h14'/%3E%3C/svg%3E");}
.traceroute-map__note{margin:0;padding:12px 24px;border-top:1px solid var(--tm-line);background:#f8fafc;color:var(--tm-muted);font-size:12px;}
.traceroute-map__results{margin-top:18px;padding:18px;background:var(--tm-bg);}
.traceroute-map__results[hidden],
.traceroute-map [hidden]{display:none !important;}
.traceroute-map__summary{display:grid;grid-template-columns:repeat(4, minmax(120px, 1fr));gap:10px;margin-bottom:14px;}
.traceroute-map__summary div{min-width:0;padding:14px;border:1px solid var(--tm-line);border-radius:8px;background:#fff;}
.traceroute-map__summary span{display:block;margin-bottom:4px;color:var(--tm-muted);font-size:12px;font-weight:800;text-transform:uppercase;}
.traceroute-map__summary strong{display:block;color:var(--tm-ink);font-size:26px;font-weight:900;line-height:1;}
.traceroute-map__map-panel{overflow:hidden;margin-bottom:14px;}
.traceroute-map__map-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:14px 16px;border-bottom:1px solid var(--tm-line);background:#fff;}
.traceroute-map__map-head h3{margin:0;color:var(--tm-ink);font-size:20px;font-weight:900;}
.traceroute-map__map-head p{max-width:540px;margin:2px 0 0;color:var(--tm-muted);font-size:13px;text-align:right;}
.traceroute-map__map-canvas{position:relative;width:100%;height:520px;min-height:520px;overflow:hidden;background:#dbeafe;}
.traceroute-map__map-canvas.is-empty{display:flex;align-items:center;justify-content:center;padding:20px;color:var(--tm-muted);font-weight:800;text-align:center;}
.traceroute-map__map-canvas.is-fallback{background:linear-gradient(90deg, rgba(255, 255, 255, .35) 1px, transparent 1px), linear-gradient(rgba(255, 255, 255, .35) 1px, transparent 1px), linear-gradient(135deg, #dbeafe 0%, #e0f2fe 52%, #ecfeff 100%);background-size:8.333% 12.5%, 8.333% 12.5%, 100% 100%;}
.traceroute-map__fallback-pin{position:absolute;display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;margin:-13px 0 0 -13px;border:2px solid #fff;border-radius:50%;background:var(--route-color, var(--tm-teal));color:#fff;font-size:11px;font-weight:900;text-decoration:none;box-shadow:0 8px 16px rgba(15, 23, 42, .24);animation:traceroute-map-pin-in .28s ease both;animation-delay:var(--pin-delay, 0ms);}
@keyframes traceroute-map-pin-in {
from{opacity:0;transform:scale(.6);}
to{opacity:1;transform:scale(1);}
}
.traceroute-map__leaflet-marker{background:transparent;border:0;}
.traceroute-map__leaflet-marker span{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:2px solid #fff;border-radius:50%;color:#fff;font-size:12px;font-weight:900;box-shadow:0 8px 16px rgba(15, 23, 42, .24);}
.traceroute-map__map-list{display:grid;grid-template-columns:repeat(auto-fit, minmax(230px, 1fr));gap:8px;max-height:188px;padding:12px;overflow:auto;border-top:1px solid var(--tm-line);background:#fff;}
.traceroute-map__map-list:empty{display:none;}
.traceroute-map__map-list a{display:block;min-width:0;padding:10px 11px;border:1px solid #e2e8f0;border-left:4px solid var(--route-color, var(--tm-teal));border-radius:8px;color:var(--tm-text);text-decoration:none;}
.traceroute-map__map-list strong, .traceroute-map__map-list span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.traceroute-map__map-list strong{color:var(--tm-ink);font-size:13px;}
.traceroute-map__map-list span{color:var(--tm-muted);font-size:12px;}
.traceroute-map__warnings{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px;}
.traceroute-map__warnings[hidden]{display:none;}
.traceroute-map__warnings span{display:inline-flex;align-items:center;min-height:32px;padding:7px 10px;border:1px solid #fed7aa;border-radius:8px;background:#fff7ed;color:var(--tm-amber);font-size:12px;font-weight:800;}
.traceroute-map__routes{display:grid;gap:14px;}
.traceroute-map__route{overflow:hidden;border-left:5px solid var(--route-color, var(--tm-teal));box-shadow:none;}
.traceroute-map__route-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--tm-line);background:#fff;}
.traceroute-map__route-head h3{margin:0;color:var(--tm-ink);font-size:19px;font-weight:900;}
.traceroute-map__route-head p{margin:4px 0 0;color:var(--tm-muted);font-size:13px;overflow-wrap:anywhere;}
.traceroute-map__route-head strong{flex:0 0 auto;max-width:320px;padding:7px 9px;border:1px solid #dbeafe;border-radius:8px;background:#eff6ff;color:#1d4ed8;font-size:12px;font-weight:850;text-align:right;}
.traceroute-map__route-head strong.is-error{border-color:#fecaca;background:#fff1f2;color:var(--tm-red);}
.traceroute-map__route-error{margin:0;padding:16px;color:var(--tm-red);font-weight:800;}
.traceroute-map__table-wrap{overflow-x:auto;background:#fff;}
.traceroute-map table{width:100%;min-width:860px;border-collapse:collapse;margin:0;background:#fff;}
.traceroute-map th, .traceroute-map td{padding:11px 12px;border-bottom:1px solid #e2e8f0;color:var(--tm-text);font-size:13px;text-align:left;vertical-align:top;}
.traceroute-map th{background:#f8fafc;color:var(--tm-ink);font-size:12px;font-weight:900;text-transform:uppercase;}
.traceroute-map tr.is-mapped td:first-child{color:var(--route-color, var(--tm-teal));}
.traceroute-map td a{color:var(--tm-blue);font-weight:800;text-decoration:none;}
.traceroute-map__hop-num{width:70px;font-weight:900;}
.traceroute-map__raw{margin-top:14px;overflow:hidden;box-shadow:none;}
.traceroute-map__raw summary{padding:13px 16px;color:var(--tm-ink);font-weight:900;cursor:pointer;}
.traceroute-map__raw pre{max-height:340px;margin:0;padding:14px 16px;overflow:auto;border-top:1px solid var(--tm-line);background:#0f172a;color:#dbeafe;font-family:Consolas, Monaco, "Courier New", monospace;font-size:12px;line-height:1.55;white-space:pre-wrap;}
@media(max-width:980px){
.traceroute-map__head{display:block;}
.traceroute-map__status{margin-top:14px;}
.traceroute-map__form{grid-template-columns:1fr 1fr;}
.traceroute-map__field--wide{grid-column:1 / -1;}
.traceroute-map__summary{grid-template-columns:repeat(2, minmax(120px, 1fr));}
}
@media(max-width:680px){
.traceroute-map__head, .traceroute-map__form, .traceroute-map__actions {
padding-right: 16px;
padding-left: 16px;
}
.traceroute-map__head h2 {
font-size: 27px;
}
.traceroute-map__form, .traceroute-map__summary {
grid-template-columns: 1fr;
}
.traceroute-map__actions button {
width: 100%;
}
.traceroute-map__map-head, .traceroute-map__route-head {
display: block;
}
.traceroute-map__map-head p {
max-width: none;
margin-top: 6px;
text-align: left;
}
.traceroute-map__route-head strong {
display: inline-flex;
max-width: 100%;
margin-top: 10px;
text-align: left;
}
.traceroute-map__map-canvas {
height: 400px;
min-height: 400px;
}
.traceroute-map table, .traceroute-map thead, .traceroute-map tbody, .traceroute-map tr, .traceroute-map th, .traceroute-map td {
display: block;
min-width: 0;
}
.traceroute-map thead {
display: none;
}
.traceroute-map tr {
border-bottom: 1px solid #e2e8f0;
}
.traceroute-map td {
display: grid;
grid-template-columns: 98px minmax(0, 1fr);
gap: 10px;
border-bottom: 0;
overflow-wrap: anywhere;
}
.traceroute-map td::before {
content: attr(data-label);
color: var(--tm-muted);
font-weight: 900;
}
}