.elementor-14920 .elementor-element.elementor-element-f6964ad{--display:flex;}/* Start custom CSS for html, class: .elementor-element-b38e77c *//* ========== RESET &amp; BASE ========== */
html { scroll-behavior: smooth; font-size: 16px; }
body {
  background:
	radial-gradient(ellipse at 20% 50%, rgba(0,240,255,.04) 0%, transparent 60%),
	radial-gradient(ellipse at 80% 50%, rgba(0,255,65,.03) 0%, transparent 60%),
	linear-gradient(180deg,#0a0e17 0%,#0d1525 50%,#0a0e17 100%);
  color: #c9d1d9;
  line-height: 1.75;
  overflow-x: hidden;
}
a { color: #f97316; text-decoration: none; transition: border-color 0.3s, color 0.3s; }
a:hover { border-color: #fdba74; color: #fdba74; }
h1,h2,h3,h4 { color: #e6edf3; font-weight: 700; letter-spacing: -0.02em; }
h2 { font-size: 2rem; margin-bottom: 1rem; position: relative; display: inline-block; }
h2::after { content: ''; position: absolute; bottom: -6px; left: 0; width: 60px; height: 3px; background: linear-gradient(90deg, #f97316, #fdba74); border-radius: 2px; }
h3 { font-size: 1.35rem; margin-bottom: 0.75rem; color: #fdba74; }
p { margin-bottom: 1rem; max-width: 78ch; }
.container { max-width: 1120px; margin: 0 auto; padding: 0 1.5rem; }
.section { padding: 2rem 1.5rem; position: relative; }
.badge {
  display: inline-block; padding: 0.25rem 0.75rem; border-radius: 999px;
  font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em;
  margin-bottom: 1rem;
}
.badge-orange { background: rgba(249,115,22,0.15); color: #f97316; border: 1px solid rgba(249,115,22,0.3); }
.badge-amber { background: rgba(253,186,116,0.1); color: #fdba74; border: 1px solid rgba(253,186,116,0.25); }
.badge-red { background: rgba(239,68,68,0.12); color: #f87171; border: 1px solid rgba(239,68,68,0.3); }
.badge-green { background: rgba(74,222,128,0.1); color: #4ade80; border: 1px solid rgba(74,222,128,0.25); }

/* ========== 25+ @KEYFRAMES ANIMATIONS ========== */
@keyframes fadeIn {
  0% { opacity: 0; }
  100% { opacity: 1; }
}
@keyframes slideUp {
  0% { opacity: 0; transform: translateY(40px); }
  100% { opacity: 1; transform: translateY(0); }
}
@keyframes slideDown {
  0% { opacity: 0; transform: translateY(-30px); }
  100% { opacity: 1; transform: translateY(0); }
}
@keyframes slideLeft {
  0% { opacity: 0; transform: translateX(60px); }
  100% { opacity: 1; transform: translateX(0); }
}
@keyframes slideRight {
  0% { opacity: 0; transform: translateX(-60px); }
  100% { opacity: 1; transform: translateX(0); }
}
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}
@keyframes glow {
  0%, 100% { box-shadow: 0 0 5px rgba(249,115,22,0.3), 0 0 15px rgba(249,115,22,0.1); }
  50% { box-shadow: 0 0 20px rgba(249,115,22,0.6), 0 0 40px rgba(249,115,22,0.2), 0 0 60px rgba(253,186,116,0.1); }
}
@keyframes dnsQueryTravel {
  0% { left: 5%; opacity: 0; }
  8% { opacity: 1; }
  88% { opacity: 1; }
  100% { left: 88%; opacity: 0; }
}
@keyframes dnsResponseTravel {
  0% { right: 5%; opacity: 0; }
  8% { opacity: 1; }
  88% { opacity: 1; }
  100% { right: 88%; opacity: 0; }
}
@keyframes recordTypeFloat {
  0%, 100% { transform: translateY(0px) rotate(0deg); }
  25% { transform: translateY(-8px) rotate(2deg); }
  50% { transform: translateY(-14px) rotate(0deg); }
  75% { transform: translateY(-8px) rotate(-2deg); }
}
@keyframes subdomainCascade {
  0% { opacity: 0; transform: translateX(-20px) scale(0.9); max-height: 0; }
  40% { opacity: 1; transform: translateX(0) scale(1); max-height: 30px; }
  100% { opacity: 1; transform: translateX(0) scale(1); max-height: 30px; }
}
@keyframes timelineEntry {
  0% { opacity: 0; transform: translateX(-30px); }
  30% { opacity: 1; transform: translateX(0); }
  100% { opacity: 1; transform: translateX(0); }
}
@keyframes ipMappingPulse {
  0%, 100% { background: rgba(249,115,22,0.08); border-color: rgba(249,115,22,0.2); }
  50% { background: rgba(249,115,22,0.18); border-color: rgba(249,115,22,0.5); }
}
@keyframes networkPathTrace {
  0% { width: 0%; opacity: 0; }
  10% { opacity: 1; }
  100% { width: 100%; opacity: 1; }
}
@keyframes reverseDnsReveal {
  0% { clip-path: inset(0 100% 0 0); }
  60% { clip-path: inset(0 0% 0 0); }
  100% { clip-path: inset(0 0% 0 0); }
}
@keyframes typewriterCursor {
  0%, 50% { border-right-color: #f97316; }
  51%, 100% { border-right-color: transparent; }
}
@keyframes domainLetterReveal {
  0%, 100% { opacity: 0.3; }
  50% { opacity: 1; }
}
@keyframes float {
  0%, 100% { transform: translateY(0px); }
  50% { transform: translateY(-12px); }
}
@keyframes rotate {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}
@keyframes scaleIn {
  0% { opacity: 0; transform: scale(0); }
  80% { transform: scale(1.08); }
  100% { opacity: 1; transform: scale(1); }
}
@keyframes shake {
  0%, 100% { transform: translateX(0); }
  10%, 30%, 50%, 70%, 90% { transform: translateX(-4px); }
  20%, 40%, 60%, 80% { transform: translateX(4px); }
}
@keyframes colorShift {
  0% { color: #f97316; }
  33% { color: #fdba74; }
  66% { color: #fb923c; }
  100% { color: #f97316; }
}
@keyframes scanLine {
  0% { top: -2px; opacity: 1; }
  100% { top: 100%; opacity: 0; }
}
@keyframes dataStream {
  0% { background-position: 0% 0%; }
  100% { background-position: 0% 200%; }
}
@keyframes packetBounce {
  0% { transform: translateX(0) translateY(0); }
  25% { transform: translateX(80px) translateY(-15px); }
  50% { transform: translateX(160px) translateY(5px); }
  75% { transform: translateX(240px) translateY(-10px); }
  100% { transform: translateX(320px) translateY(0); }
}
@keyframes ripple {
  0% { transform: scale(0.8); opacity: 1; box-shadow: 0 0 0 0 rgba(249,115,22,0.4); }
  100% { transform: scale(2.5); opacity: 0; box-shadow: 0 0 0 30px rgba(249,115,22,0); }
}
@keyframes borderGlow {
  0%, 100% { border-color: rgba(249,115,22,0.3); }
  50% { border-color: rgba(253,186,116,0.8); }
}
@keyframes queryBarFill {
  0% { width: 0%; }
  100% { width: 100%; }
}
@keyframes recordBadgeAppear {
  0% { opacity: 0; transform: scale(0.5) rotate(-10deg); }
  60% { transform: scale(1.15) rotate(3deg); }
  100% { opacity: 1; transform: scale(1) rotate(0deg); }
}
@keyframes passiveDnsScroll {
  0% { transform: translateY(100%); opacity: 0; }
  10% { opacity: 0.8; }
  90% { opacity: 0.8; }
  100% { transform: translateY(-100%); opacity: 0; }
}
@keyframes nsGlowPulse {
  0%, 100% { text-shadow: 0 0 5px rgba(249,115,22,0.4); }
  50% { text-shadow: 0 0 20px rgba(249,115,22,0.8), 0 0 40px rgba(253,186,116,0.3); }
}

/* ========== HERO ========== */
.hero {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  padding-top: 5rem; position: relative; overflow: hidden;
  background: radial-gradient(ellipse at 20% 50%, rgba(249,115,22,0.07) 0%, transparent 50%),
              radial-gradient(ellipse at 80% 20%, rgba(253,186,116,0.05) 0%, transparent 50%),
              radial-gradient(ellipse at 50% 80%, rgba(249,115,22,0.04) 0%, transparent 50%),
              #0a0a0f;
}
.hero-content { text-align: center; z-index: 2; animation: fadeIn 1.2s ease-out both; }
.hero-content .technique-id {
  font-size: 0.85rem; font-weight: 700; letter-spacing: 0.15em;
  color: #f97316; text-transform: uppercase; margin-bottom: 0.5rem;
  animation: colorShift 6s ease-in-out infinite;
}
.hero-content h1 {
  font-size: clamp(2.5rem, 6vw, 4.2rem); font-weight: 900;
  background: linear-gradient(135deg, #e6edf3 0%, #f97316 40%, #fdba74 70%, #fb923c 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; margin-bottom: 0.75rem; line-height: 1.15;
}
.hero-content .subtitle {
  font-size: 1.15rem; color: #8b949e; max-width: 660px; margin: 0 auto 2rem;
}
.hero-meta { display: flex; gap: 1.5rem; justify-content: center; flex-wrap: wrap; margin-top: 1.5rem; }
.hero-meta .tag {
  padding: 0.35rem 1rem; border-radius: 6px; font-size: 0.8rem; font-weight: 600;
  background: rgba(249,115,22,0.1); color: #f97316; border: 1px solid rgba(249,115,22,0.2);
}
.hero-meta .tag:nth-child(2) { background: rgba(253,186,116,0.08); color: #fdba74; border-color: rgba(253,186,116,0.2); }
.hero-meta .tag:nth-child(3) { background: rgba(74,222,128,0.08); color: #4ade80; border-color: rgba(74,222,128,0.2); }
.hero-meta .tag:nth-child(4) { background: rgba(239,68,68,0.08); color: #f87171; border-color: rgba(239,68,68,0.2); }

/* Hero Background: Floating DNS labels */
.hero-bg {
  position: absolute; inset: 0; overflow: hidden; z-index: 0; pointer-events: none;
}
.dns-float {
  position: absolute; font-family: 'Courier New', monospace; font-size: 0.7rem;
  color: rgba(249,115,22,0.12); white-space: nowrap;
}
.dns-float:nth-child(1) { top: 8%; left: 5%; animation: float 7s ease-in-out infinite 0s; }
.dns-float:nth-child(2) { top: 18%; left: 82%; animation: float 9s ease-in-out infinite 1s; color: rgba(253,186,116,0.1); }
.dns-float:nth-child(3) { top: 35%; left: 12%; animation: float 8s ease-in-out infinite 2s; }
.dns-float:nth-child(4) { top: 55%; left: 88%; animation: float 6s ease-in-out infinite 0.5s; color: rgba(249,115,22,0.1); }
.dns-float:nth-child(5) { top: 72%; left: 8%; animation: float 10s ease-in-out infinite 3s; color: rgba(253,186,116,0.08); }
.dns-float:nth-child(6) { top: 88%; left: 75%; animation: float 7.5s ease-in-out infinite 1.5s; }
.dns-float:nth-child(7) { top: 25%; left: 48%; animation: float 11s ease-in-out infinite 2.5s; color: rgba(249,115,22,0.08); }
.dns-float:nth-child(8) { top: 65%; left: 38%; animation: float 8.5s ease-in-out infinite 0.8s; color: rgba(253,186,116,0.1); }
.dns-float:nth-child(9) { top: 45%; left: 65%; animation: float 9.5s ease-in-out infinite 1.8s; }
.dns-float:nth-child(10) { top: 12%; left: 30%; animation: float 7.8s ease-in-out infinite 2.2s; }

/* ========== SECTION DIVIDER ========== */
.section-divider {
  height: 1px; max-width: 900px; margin: 0 auto;
  background: linear-gradient(90deg, transparent, rgba(249,115,22,0.3), rgba(253,186,116,0.3), transparent);
}

/* ========== SECTION 1: SIMULATION ========== */
.sim-section { padding: 5rem 1.5rem; }
.sim-section h2 { animation: slideUp 0.8s ease-out both; }

/* Query Bar */
.query-bar-container {
  background: rgba(10,10,15,0.7); border: 1px solid rgba(249,115,22,0.18);
  border-radius: 14px; padding: 1.5rem 2rem; margin: 2rem 0;
  position: relative; overflow: hidden;
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
}
.query-bar-container::before {
  content: ''; position: absolute; top: -2px; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, #f97316, #fdba74, #fb923c);
  animation: dataStream 3s linear infinite;
  background-size: 100% 200%;
}
.query-bar-label {
  font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em;
  color: #f97316; margin-bottom: 0.75rem; display: flex; align-items: center; gap: 0.5rem;
}
.query-bar-label .blink-dot {
  width: 8px; height: 8px; border-radius: 50%; background: #f97316;
  animation: pulse 1.5s ease-in-out infinite;
}
.query-bar {
  font-family: 'Courier New', monospace; font-size: 0.95rem;
  background: rgba(0,0,0,0.4); border: 1px solid rgba(249,115,22,0.15);
  border-radius: 8px; padding: 0.75rem 1rem; color: #fdba74;
  overflow: hidden; white-space: nowrap; position: relative;
}
.query-bar .cursor {
  display: inline-block; width: 2px; height: 1.1em; background: #f97316;
  animation: typewriterCursor 1s step-end infinite; vertical-align: text-bottom; margin-left: 2px;
}
.query-bar .letter {
  animation: domainLetterReveal 0.1s ease-out both;
}
.query-bar .letter:nth-child(1) { animation-delay: 0.2s; }
.query-bar .letter:nth-child(2) { animation-delay: 0.35s; }
.query-bar .letter:nth-child(3) { animation-delay: 0.5s; }
.query-bar .letter:nth-child(4) { animation-delay: 0.65s; }
.query-bar .letter:nth-child(5) { animation-delay: 0.8s; }
.query-bar .letter:nth-child(6) { animation-delay: 0.95s; }
.query-bar .letter:nth-child(7) { animation-delay: 1.1s; }
.query-bar .letter:nth-child(8) { animation-delay: 1.25s; }
.query-bar .letter:nth-child(9) { animation-delay: 1.4s; }
.query-bar .letter:nth-child(10) { animation-delay: 1.55s; }
.query-bar .letter:nth-child(11) { animation-delay: 1.7s; }
.query-bar .letter:nth-child(12) { animation-delay: 1.85s; }
.query-bar .letter:nth-child(13) { animation-delay: 2.0s; }
.query-bar .letter:nth-child(14) { animation-delay: 2.15s; }
.query-bar .letter:nth-child(15) { animation-delay: 2.3s; }
.query-bar .letter:nth-child(16) { animation-delay: 2.45s; }
.query-bar .letter:nth-child(17) { animation-delay: 2.6s; }
.query-bar .letter:nth-child(18) { animation-delay: 2.75s; }
.query-bar .letter:nth-child(19) { animation-delay: 2.9s; }
.query-bar .letter:nth-child(20) { animation-delay: 3.05s; }

/* DNS Query/Response Flow */
.dns-flow-container {
  background: rgba(10,10,15,0.6); border: 1px solid rgba(249,115,22,0.15);
  border-radius: 16px; padding: 2.5rem 2rem; margin: 2rem 0;
  position: relative; overflow: hidden;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.dns-flow {
  display: flex; align-items: center; justify-content: space-between;
  gap: 0.5rem; flex-wrap: wrap; padding: 1rem 0;
}
.dns-node {
  background: rgba(249,115,22,0.06); border: 1px solid rgba(249,115,22,0.2);
  border-radius: 10px; padding: 1rem 0.8rem; text-align: center;
  min-width: 120px; position: relative; flex: 1;
  animation: scaleIn 0.6s ease-out both;
  transition: border-color 0.3s, box-shadow 0.3s;
}
.dns-node:hover { border-color: rgba(253,186,116,0.5); box-shadow: 0 0 20px rgba(249,115,22,0.15); }
.dns-node:nth-child(1) { animation-delay: 0.2s; }
.dns-node:nth-child(3) { animation-delay: 0.5s; border-color: rgba(253,186,116,0.2); }
.dns-node:nth-child(5) { animation-delay: 0.8s; border-color: rgba(249,115,22,0.2); }
.dns-node:nth-child(7) { animation-delay: 1.1s; border-color: rgba(253,186,116,0.2); }
.dns-node .node-icon { font-size: 1.5rem; margin-bottom: 0.4rem; display: block; }
.dns-node .node-label { font-size: 0.72rem; font-weight: 700; color: #e6edf3; text-transform: uppercase; letter-spacing: 0.04em; }
.dns-node .node-sub { font-size: 0.62rem; color: #8b949e; margin-top: 0.2rem; }
.dns-arrow {
  flex: 0 0 30px; text-align: center; color: #f97316;
  font-size: 1.2rem; animation: pulse 2s ease-in-out infinite;
}

/* Packet Track */
.packet-track {
  position: relative; height: 20px; margin: 1.5rem 0;
  background: rgba(249,115,22,0.06); border-radius: 10px; overflow: visible;
  border: 1px dashed rgba(249,115,22,0.12);
}
.packet-track-label {
  position: absolute; top: -18px; font-size: 0.6rem; text-transform: uppercase;
  letter-spacing: 0.08em; font-weight: 600;
}
.packet-track-label.left { left: 0; color: #f97316; }
.packet-track-label.right { right: 0; color: #fdba74; }
.packet-dot {
  position: absolute; top: 3px; width: 14px; height: 14px; border-radius: 50%;
  background: #f97316; box-shadow: 0 0 12px rgba(249,115,22,0.6);
  animation: dnsQueryTravel 3.5s linear infinite;
}
.packet-dot.response {
  background: #fdba74; box-shadow: 0 0 12px rgba(253,186,116,0.6);
  animation: dnsResponseTravel 3.5s linear infinite 1.75s;
}
.packet-dot.third { background: #fb923c; animation-delay: 0.8s; }
.packet-dot.fourth { background: #fdba74; animation-delay: 2.4s; }

/* Record Type Badges */
.record-badges-row {
  display: flex; gap: 0.75rem; flex-wrap: wrap; margin: 2rem 0;
  justify-content: center;
}
.record-badge {
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.5rem 1rem; border-radius: 8px;
  background: rgba(10,10,15,0.7); border: 1px solid rgba(249,115,22,0.2);
  font-family: 'Courier New', monospace; font-size: 0.82rem;
  animation: recordBadgeAppear 0.6s ease-out both;
  transition: all 0.3s;
}
.record-badge:hover { border-color: rgba(253,186,116,0.6); transform: translateY(-3px); box-shadow: 0 0 15px rgba(249,115,22,0.15); }
.record-badge:nth-child(1) { animation-delay: 0.3s; }
.record-badge:nth-child(2) { animation-delay: 0.5s; }
.record-badge:nth-child(3) { animation-delay: 0.7s; }
.record-badge:nth-child(4) { animation-delay: 0.9s; }
.record-badge:nth-child(5) { animation-delay: 1.1s; }
.record-badge:nth-child(6) { animation-delay: 1.3s; }
.record-badge .rb-type { color: #f97316; font-weight: 800; font-size: 0.95rem; }
.record-badge .rb-value { color: #fdba74; font-size: 0.72rem; }
.record-badge:nth-child(1) .rb-type { color: #f97316; }
.record-badge:nth-child(2) .rb-type { color: #fb923c; }
.record-badge:nth-child(3) .rb-type { color: #fdba74; }
.record-badge:nth-child(4) .rb-type { color: #f97316; }
.record-badge:nth-child(5) .rb-type { color: #fb923c; }
.record-badge:nth-child(6) .rb-type { color: #fdba74; }

/* Subdomain Discovery Cascade */
.subdomain-panel {
  background: rgba(10,10,15,0.6); border: 1px solid rgba(249,115,22,0.12);
  border-radius: 12px; padding: 1.5rem; margin: 2rem 0;
  font-family: 'Courier New', monospace; font-size: 0.78rem;
  position: relative; overflow: hidden;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.subdomain-panel::after {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: #f97316; animation: scanLine 4s linear infinite;
  opacity: 0.6;
}
.subdomain-line {
  padding: 0.3rem 0; overflow: hidden; white-space: nowrap;
  animation: subdomainCascade 0.6s ease-out both;
}
.subdomain-line:nth-child(1) { animation-delay: 0.3s; }
.subdomain-line:nth-child(2) { animation-delay: 0.7s; }
.subdomain-line:nth-child(3) { animation-delay: 1.1s; }
.subdomain-line:nth-child(4) { animation-delay: 1.5s; }
.subdomain-line:nth-child(5) { animation-delay: 1.9s; }
.subdomain-line:nth-child(6) { animation-delay: 2.3s; }
.subdomain-line:nth-child(7) { animation-delay: 2.7s; }
.subdomain-line:nth-child(8) { animation-delay: 3.1s; }
.subdomain-line .prefix { color: #fdba74; }
.subdomain-line .domain { color: #f97316; }
.subdomain-line .ip { color: #8b949e; }
.subdomain-line .status-found { color: #4ade80; font-weight: 700; }
.subdomain-line .status-new { color: #fbbf24; font-weight: 700; }
.subdomain-line .status-hidden { color: #f87171; font-weight: 700; }

/* Passive DNS Timeline */
.passive-dns-timeline {
  position: relative; margin: 2rem 0;
  padding: 1.5rem; border-radius: 12px;
  background: rgba(10,10,15,0.6); border: 1px solid rgba(253,186,116,0.15);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  overflow: hidden;
}
.passive-dns-timeline::before {
  content: ''; position: absolute; left: 16px; top: 10px; bottom: 10px; width: 2px;
  background: linear-gradient(180deg, #f97316, #fdba74, #fb923c, #f97316);
  animation: dataStream 4s linear infinite;
  background-size: 100% 200%;
}
.timeline-entry {
  padding-left: 2.5rem; position: relative; margin-bottom: 1rem;
  animation: timelineEntry 0.7s ease-out both;
}
.timeline-entry::before {
  content: ''; position: absolute; left: 10px; top: 6px;
  width: 14px; height: 14px; border-radius: 50%;
  background: #f97316; border: 2px solid #0a0a0f;
  box-shadow: 0 0 8px rgba(249,115,22,0.4);
}
.timeline-entry:nth-child(1) { animation-delay: 0.4s; }
.timeline-entry:nth-child(2) { animation-delay: 0.9s; }
.timeline-entry:nth-child(3) { animation-delay: 1.4s; }
.timeline-entry:nth-child(4) { animation-delay: 1.9s; }
.timeline-entry:nth-child(5) { animation-delay: 2.4s; }
.timeline-entry:nth-child(6) { animation-delay: 2.9s; }
.timeline-entry .tl-date { font-size: 0.68rem; color: #f97316; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; }
.timeline-entry .tl-record { font-family: 'Courier New', monospace; font-size: 0.78rem; color: #e6edf3; margin-top: 0.15rem; }
.timeline-entry .tl-value { font-size: 0.68rem; color: #fdba74; margin-top: 0.1rem; }
.timeline-entry .tl-source { font-size: 0.62rem; color: #6e7681; margin-top: 0.1rem; }

/* IP Address Mapping */
.ip-mapping-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin: 2rem 0;
}
@media (max-width: 640px) { .ip-mapping-grid { grid-template-columns: 1fr; } }
.ip-map-item {
  background: rgba(10,10,15,0.6); border: 1px solid rgba(249,115,22,0.12);
  border-radius: 10px; padding: 1rem 1.25rem;
  animation: ipMappingPulse 3s ease-in-out infinite, slideUp 0.5s ease-out both;
  display: flex; align-items: center; gap: 1rem;
  transition: border-color 0.3s;
}
.ip-map-item:hover { border-color: rgba(249,115,22,0.5); }
.ip-map-item:nth-child(1) { animation-delay: 0.1s, 0s; }
.ip-map-item:nth-child(2) { animation-delay: 0.3s, 0.15s; }
.ip-map-item:nth-child(3) { animation-delay: 0.5s, 0.3s; }
.ip-map-item:nth-child(4) { animation-delay: 0.7s, 0.45s; }
.ip-map-icon {
  width: 36px; height: 36px; border-radius: 8px;
  background: rgba(249,115,22,0.1); border: 1px solid rgba(249,115,22,0.2);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Courier New', monospace; font-weight: 800; font-size: 0.7rem;
  color: #f97316; flex-shrink: 0;
}
.ip-map-info { flex: 1; }
.ip-map-domain { font-size: 0.82rem; font-weight: 700; color: #e6edf3; }
.ip-map-ip { font-family: 'Courier New', monospace; font-size: 0.72rem; color: #fdba74; margin-top: 0.15rem; }

/* Reverse DNS Panel */
.reverse-dns-panel {
  background: rgba(10,10,15,0.6); border: 1px solid rgba(253,186,116,0.15);
  border-radius: 12px; padding: 1.5rem; margin: 2rem 0;
  font-family: 'Courier New', monospace; font-size: 0.78rem;
  position: relative; overflow: hidden;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.reverse-dns-panel .panel-header {
  font-size: 0.82rem; font-weight: 700; color: #fdba74; margin-bottom: 1rem;
  display: flex; align-items: center; gap: 0.5rem; text-transform: uppercase;
  letter-spacing: 0.06em;
}
.reverse-line {
  padding: 0.3rem 0; animation: reverseDnsReveal 1s ease-out both;
  color: #c9d1d9;
}
.reverse-line:nth-child(2) { animation-delay: 0.3s; }
.reverse-line:nth-child(3) { animation-delay: 0.6s; }
.reverse-line:nth-child(4) { animation-delay: 0.9s; }
.reverse-line:nth-child(5) { animation-delay: 1.2s; }
.reverse-line:nth-child(6) { animation-delay: 1.5s; }
.reverse-line .ip-addr { color: #8b949e; }
.reverse-line .arrow-char { color: #f97316; margin: 0 0.5rem; }
.reverse-line .resolved { color: #4ade80; }
.reverse-line .multiple { color: #fbbf24; }

/* Network Path */
.network-path-container {
  background: rgba(10,10,15,0.6); border: 1px solid rgba(249,115,22,0.12);
  border-radius: 12px; padding: 2rem 1.5rem; margin: 2rem 0;
  position: relative; overflow: hidden;
}
.network-path {
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap;
  gap: 0.5rem;
}
.net-hop {
  display: flex; flex-direction: column; align-items: center; gap: 0.4rem;
  animation: scaleIn 0.5s ease-out both;
}
.net-hop:nth-child(1) { animation-delay: 0.2s; }
.net-hop:nth-child(3) { animation-delay: 0.5s; }
.net-hop:nth-child(5) { animation-delay: 0.8s; }
.net-hop:nth-child(7) { animation-delay: 1.1s; }
.net-hop:nth-child(9) { animation-delay: 1.4s; }
.net-hop-icon {
  width: 40px; height: 40px; border-radius: 10px;
  background: rgba(249,115,22,0.08); border: 1px solid rgba(249,115,22,0.2);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem;
  animation: borderGlow 3s ease-in-out infinite;
}
.net-hop:nth-child(3) .net-hop-icon { border-color: rgba(253,186,116,0.2); }
.net-hop:nth-child(5) .net-hop-icon { border-color: rgba(249,115,22,0.25); }
.net-hop:nth-child(7) .net-hop-icon { border-color: rgba(253,186,116,0.25); }
.net-hop-label { font-size: 0.62rem; color: #8b949e; text-align: center; max-width: 80px; }
.net-hop-ip { font-family: 'Courier New', monospace; font-size: 0.58rem; color: #fdba74; }
.net-path-line {
  flex: 0 0 40px; height: 2px; position: relative; overflow: hidden;
  background: rgba(249,115,22,0.1); border-radius: 1px;
}
.net-path-line::after {
  content: ''; position: absolute; top: 0; left: 0; height: 100%; width: 100%;
  background: linear-gradient(90deg, transparent, #f97316, transparent);
  animation: networkPathTrace 2s ease-in-out infinite;
}
.net-path-line:nth-child(4) { animation-delay: 0.5s; }
.net-path-line:nth-child(6) { animation-delay: 1s; }
.net-path-line:nth-child(8) { animation-delay: 1.5s; }

/* Floating Record Type Icons */
.floating-icons {
  position: relative; height: 120px; margin: 2rem 0;
  overflow: hidden;
}
.float-icon {
  position: absolute; font-family: 'Courier New', monospace;
  font-weight: 900; font-size: 0.9rem;
  color: rgba(249,115,22,0.15);
  animation: recordTypeFloat 4s ease-in-out infinite;
}
.float-icon:nth-child(1) { left: 5%; top: 20%; animation-delay: 0s; color: rgba(249,115,22,0.2); }
.float-icon:nth-child(2) { left: 20%; top: 60%; animation-delay: 0.5s; color: rgba(253,186,116,0.18); }
.float-icon:nth-child(3) { left: 38%; top: 10%; animation-delay: 1s; color: rgba(249,115,22,0.15); }
.float-icon:nth-child(4) { left: 55%; top: 50%; animation-delay: 1.5s; color: rgba(253,186,116,0.2); }
.float-icon:nth-child(5) { left: 70%; top: 25%; animation-delay: 2s; color: rgba(249,115,22,0.18); }
.float-icon:nth-child(6) { left: 85%; top: 65%; animation-delay: 2.5s; color: rgba(253,186,116,0.15); }
.float-icon:nth-child(7) { left: 48%; top: 75%; animation-delay: 3s; color: rgba(249,115,22,0.12); }
.float-icon:nth-child(8) { left: 12%; top: 45%; animation-delay: 3.5s; color: rgba(253,186,116,0.22); }

/* ========== SECTION 2: WHY IT MATTERS ========== */
.why-section {
  background: linear-gradient(180deg, #0a0a0f 0%, rgba(249,115,22,0.03) 50%, #0a0a0f 100%);
}
.stats-row {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.25rem; margin: 2rem 0;
}
.stat-card {
  background: rgba(10,10,15,0.7); border: 1px solid rgba(249,115,22,0.12);
  border-radius: 12px; padding: 1.5rem; position: relative; overflow: hidden;
  animation: slideUp 0.6s ease-out both;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  transition: border-color 0.3s;
}
.stat-card:hover { border-color: rgba(249,115,22,0.4); }
.stat-card:nth-child(1) { animation-delay: 0.1s; }
.stat-card:nth-child(2) { animation-delay: 0.25s; }
.stat-card:nth-child(3) { animation-delay: 0.4s; }
.stat-card:nth-child(4) { animation-delay: 0.55s; }
.stat-card:nth-child(5) { animation-delay: 0.7s; }
.stat-card:nth-child(6) { animation-delay: 0.85s; }
.stat-number {
  font-size: 2rem; font-weight: 900; line-height: 1;
  background: linear-gradient(135deg, #f97316, #fdba74);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.stat-label { font-size: 0.82rem; color: #8b949e; margin-top: 0.35rem; line-height: 1.4; }
.stat-source { font-size: 0.65rem; color: #6e7681; margin-top: 0.4rem; font-style: italic; }
.why-text { margin-top: 2rem; animation: fadeIn 1s ease-out both 0.5s; }
.why-text p { max-width: 85ch; }
.link-list { list-style: none; padding: 0; margin: 1.5rem 0; }
.link-list li {
  padding: 0.5rem 0; border-bottom: 1px solid rgba(249,115,22,0.06);
  animation: slideRight 0.4s ease-out both;
}
.link-list li:nth-child(1) { animation-delay: 0.1s; }
.link-list li:nth-child(2) { animation-delay: 0.2s; }
.link-list li:nth-child(3) { animation-delay: 0.3s; }
.link-list li:nth-child(4) { animation-delay: 0.4s; }
.link-list li .link-icon { color: #f97316; margin-right: 0.5rem; }

/* ========== SECTION 3: KEY TERMS ========== */
.terms-section {
  background: linear-gradient(180deg, #0a0a0f 0%, rgba(253,186,116,0.02) 50%, #0a0a0f 100%);
}
.terms-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 2rem;
  margin-top: 2rem;
}
@media (max-width: 768px) { .terms-grid { grid-template-columns: 1fr; } }
.term-card {
  background: rgba(10,10,15,0.6); border: 1px solid rgba(249,115,22,0.12);
  border-radius: 14px; padding: 2rem; position: relative; overflow: hidden;
  animation: slideUp 0.6s ease-out both;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.term-card:nth-child(1) { animation-delay: 0.2s; }
.term-card:nth-child(2) { animation-delay: 0.4s; }
.term-card:nth-child(3) { animation-delay: 0.6s; }
.term-card:nth-child(4) { animation-delay: 0.8s; }
.term-card::before {
  content: ''; position: absolute; top: 0; left: 0; width: 4px; height: 100%;
  border-radius: 4px 0 0 4px;
}
.term-card:nth-child(1)::before { background: linear-gradient(180deg, #f97316, #fdba74); }
.term-card:nth-child(2)::before { background: linear-gradient(180deg, #fdba74, #fb923c); }
.term-card:nth-child(3)::before { background: linear-gradient(180deg, #f97316, #fb923c); }
.term-card:nth-child(4)::before { background: linear-gradient(180deg, #fdba74, #f97316); }
.term-card h3 { margin-bottom: 0.75rem; }
.term-card p { font-size: 0.92rem; }
.term-card .analogy {
  margin-top: 0.75rem; padding: 0.6rem 0.8rem; border-radius: 8px;
  background: rgba(253,186,116,0.06); border: 1px solid rgba(253,186,116,0.1);
  font-size: 0.82rem; color: #fdba74; font-style: italic;
}

/* ========== SECTION 4: REAL-WORLD SCENARIO ========== */
.scenario-section {
  background: linear-gradient(180deg, #0a0a0f 0%, rgba(249,115,22,0.03) 50%, #0a0a0f 100%);
}
.scenario-header {
  display: flex; align-items: center; gap: 1.5rem; margin: 1.5rem 0;
  flex-wrap: wrap;
}
.scenario-avatar {
  width: 64px; height: 64px; border-radius: 50%;
  background: linear-gradient(135deg, #f97316, #fdba74);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem; font-weight: 900; color: #0a0a0f;
  animation: glow 3s ease-in-out infinite;
  flex-shrink: 0;
}
.scenario-info h3 { margin-bottom: 0.15rem; color: #e6edf3; font-size: 1.2rem; }
.scenario-info .role { color: #f97316; font-size: 0.85rem; font-weight: 600; }
.scenario-info .company { color: #8b949e; font-size: 0.82rem; }

.before-after-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; margin-top: 2rem;
}
@media (max-width: 768px) { .before-after-grid { grid-template-columns: 1fr; } }
.ba-card {
  border-radius: 14px; padding: 2rem; position: relative; overflow: hidden;
  animation: slideUp 0.7s ease-out both;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.ba-card.before {
  background: rgba(239,68,68,0.04); border: 1px solid rgba(239,68,68,0.15);
}
.ba-card.before::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, #f87171, #ef4444);
}
.ba-card.after {
  background: rgba(74,222,128,0.04); border: 1px solid rgba(74,222,128,0.15);
}
.ba-card.after::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, #4ade80, #14b8a6);
}
.ba-card h3 { font-size: 1.1rem; }
.ba-card.before h3 { color: #f87171; }
.ba-card.after h3 { color: #4ade80; }
.ba-card p { font-size: 0.88rem; }
.ba-card ul { list-style: none; padding: 0; margin: 1rem 0; }
.ba-card ul li {
  padding: 0.35rem 0; padding-left: 1.25rem; position: relative; font-size: 0.85rem;
}
.ba-card.before ul li::before { content: '\2715'; position: absolute; left: 0; color: #f87171; font-weight: 700; }
.ba-card.after ul li::before { content: '\2713'; position: absolute; left: 0; color: #4ade80; font-weight: 700; }

/* ========== SECTION 5: STEP-BY-STEP GUIDE ========== */
.chain-section {
  background: linear-gradient(180deg, #0a0a0f 0%, rgba(249,115,22,0.03) 50%, #0a0a0f 100%);
}
.chain-timeline {
  position: relative; padding-left: 3rem; margin-top: 2rem;
}
.chain-timeline::before {
  content: ''; position: absolute; left: 14px; top: 0; bottom: 0; width: 2px;
  background: linear-gradient(180deg, #f97316, #fdba74, #fb923c, #f97316);
}
.chain-step {
  position: relative; margin-bottom: 2.5rem; padding-bottom: 0.5rem;
  animation: slideRight 0.5s ease-out both;
}
.chain-step:nth-child(1) { animation-delay: 0.1s; }
.chain-step:nth-child(2) { animation-delay: 0.25s; }
.chain-step:nth-child(3) { animation-delay: 0.4s; }
.chain-step:nth-child(4) { animation-delay: 0.55s; }
.chain-step:nth-child(5) { animation-delay: 0.7s; }
.chain-step:nth-child(6) { animation-delay: 0.85s; }
.chain-step:nth-child(7) { animation-delay: 1s; }
.chain-dot {
  position: absolute; left: -3rem; top: 0.35rem;
  width: 12px; height: 12px; border-radius: 50%;
  background: #f97316; border: 2px solid #0a0a0f;
  box-shadow: 0 0 8px rgba(249,115,22,0.5);
}
.chain-step:nth-child(2) .chain-dot { background: #fdba74; box-shadow: 0 0 8px rgba(253,186,116,0.5); }
.chain-step:nth-child(3) .chain-dot { background: #fb923c; box-shadow: 0 0 8px rgba(251,146,60,0.5); }
.chain-step:nth-child(4) .chain-dot { background: #f97316; box-shadow: 0 0 8px rgba(249,115,22,0.5); }
.chain-step:nth-child(5) .chain-dot { background: #fdba74; box-shadow: 0 0 8px rgba(253,186,116,0.5); }
.chain-step:nth-child(6) .chain-dot { background: #fb923c; box-shadow: 0 0 8px rgba(251,146,60,0.5); }
.chain-step:nth-child(7) .chain-dot { background: #f97316; box-shadow: 0 0 8px rgba(249,115,22,0.5); }
.chain-step h3 { font-size: 1rem; margin-bottom: 0.35rem; }
.chain-step .step-num {
  font-size: 0.7rem; color: #6e7681; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.1em; margin-bottom: 0.15rem;
}
.chain-step p { font-size: 0.88rem; }
.chain-step ul { list-style: none; padding: 0; margin: 0.5rem 0; }
.chain-step ul li {
  padding: 0.2rem 0 0.2rem 1.2rem; position: relative; font-size: 0.82rem; color: #8b949e;
}
.chain-step ul li::before { content: '\25B8'; position: absolute; left: 0; color: #f97316; }
.protection-tag {
  display: inline-block; padding: 0.15rem 0.55rem; border-radius: 4px;
  font-size: 0.68rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.05em; margin: 0.25rem 0.25rem 0.25rem 0;
  background: rgba(74,222,128,0.08); color: #4ade80; border: 1px solid rgba(74,222,128,0.15);
}

/* ========== SECTION 6: COMMON MISTAKES ========== */
.mistakes-section {
  background: linear-gradient(180deg, #0a0a0f 0%, rgba(239,68,68,0.02) 50%, #0a0a0f 100%);
}
.mistakes-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 1.5rem; margin-top: 2rem;
}
.mistake-card {
  background: rgba(10,10,15,0.6); border: 1px solid rgba(239,68,68,0.12);
  border-radius: 12px; padding: 1.5rem; position: relative; overflow: hidden;
  animation: slideUp 0.5s ease-out both;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.mistake-card:nth-child(1) { animation-delay: 0.1s; }
.mistake-card:nth-child(2) { animation-delay: 0.25s; }
.mistake-card:nth-child(3) { animation-delay: 0.4s; }
.mistake-card:nth-child(4) { animation-delay: 0.55s; }
.mistake-card:nth-child(5) { animation-delay: 0.7s; }
.mistake-card .mc-icon {
  font-size: 1.2rem; margin-bottom: 0.5rem; display: block;
  animation: shake 3s ease-in-out infinite;
}
.mistake-card h3 { color: #f87171; font-size: 0.95rem; margin-bottom: 0.4rem; }
.mistake-card p { font-size: 0.82rem; color: #8b949e; }
.mistake-card .fix {
  margin-top: 0.75rem; padding: 0.6rem 0.8rem; border-radius: 8px;
  background: rgba(74,222,128,0.06); border: 1px solid rgba(74,222,128,0.12);
  font-size: 0.78rem; color: #4ade80;
}
.mistake-card .fix strong { color: #4ade80; }

/* Best Practices */
.practices-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 1.5rem; margin-top: 2rem;
}
.practice-card {
  background: rgba(10,10,15,0.6); border: 1px solid rgba(249,115,22,0.12);
  border-radius: 12px; padding: 1.5rem; position: relative; overflow: hidden;
  animation: slideUp 0.5s ease-out both;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.practice-card:nth-child(1) { animation-delay: 0.15s; }
.practice-card:nth-child(2) { animation-delay: 0.3s; }
.practice-card:nth-child(3) { animation-delay: 0.45s; }
.practice-card:nth-child(4) { animation-delay: 0.6s; }
.practice-card:nth-child(5) { animation-delay: 0.75s; }
.practice-card .pc-icon { font-size: 1.2rem; margin-bottom: 0.5rem; display: block; color: #4ade80; }
.practice-card h3 { color: #4ade80; font-size: 0.95rem; margin-bottom: 0.4rem; }
.practice-card p { font-size: 0.82rem; color: #8b949e; }

/* ========== SECTION 7: RED TEAM vs BLUE TEAM ========== */
.team-section {
  background: linear-gradient(180deg, #0a0a0f 0%, rgba(249,115,22,0.02) 50%, #0a0a0f 100%);
}
.team-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; margin-top: 2rem;
}
@media (max-width: 768px) { .team-grid { grid-template-columns: 1fr; } }
.team-card {
  border-radius: 14px; padding: 2rem; position: relative;
  animation: slideUp 0.6s ease-out both;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.team-card.red {
  background: rgba(239,68,68,0.04); border: 1px solid rgba(239,68,68,0.15);
}
.team-card.red::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, #ef4444, #f97316);
}
.team-card.blue {
  background: rgba(59,130,246,0.04); border: 1px solid rgba(59,130,246,0.15);
}
.team-card.blue::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, #3b82f6, #60a5fa);
}
.team-card h3 { font-size: 1.1rem; }
.team-card.red h3 { color: #f87171; }
.team-card.blue h3 { color: #60a5fa; }
.team-card ol, .team-card ul { padding-left: 1.25rem; margin: 1rem 0; }
.team-card li { font-size: 0.85rem; padding: 0.3rem 0; line-height: 1.5; }
.team-card .tool-tag {
  display: inline-block; padding: 0.15rem 0.5rem; border-radius: 4px;
  font-size: 0.7rem; font-weight: 600; font-family: 'Courier New', monospace;
  margin: 0.1rem 0.15rem;
}
.team-card.red .tool-tag { background: rgba(239,68,68,0.1); color: #f87171; border: 1px solid rgba(239,68,68,0.2); }
.team-card.blue .tool-tag { background: rgba(59,130,246,0.1); color: #60a5fa; border: 1px solid rgba(59,130,246,0.2); }

/* ========== SECTION 8: THREAT HUNTER ========== */
.hunter-section {
  background: linear-gradient(180deg, #0a0a0f 0%, rgba(253,186,116,0.03) 50%, #0a0a0f 100%);
}
.hunter-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; margin-top: 2rem;
}
@media (max-width: 768px) { .hunter-grid { grid-template-columns: 1fr; } }
.hunter-card {
  background: rgba(10,10,15,0.6); border: 1px solid rgba(253,186,116,0.12);
  border-radius: 12px; padding: 1.5rem;
  animation: slideUp 0.5s ease-out both;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.hunter-card:nth-child(1) { animation-delay: 0.1s; }
.hunter-card:nth-child(2) { animation-delay: 0.25s; }
.hunter-card:nth-child(3) { animation-delay: 0.4s; grid-column: 1 / -1; }
.hunter-card h3 { color: #fdba74; font-size: 1rem; margin-bottom: 0.75rem; }
.hunter-card p { font-size: 0.85rem; }
.hunter-card code {
  display: block; background: rgba(0,0,0,0.3); border: 1px solid rgba(253,186,116,0.1);
  border-radius: 6px; padding: 0.75rem 1rem; margin: 0.75rem 0;
  font-family: 'Courier New', monospace; font-size: 0.75rem;
  color: #f97316; overflow-x: auto; white-space: pre;
}
.indicator-list { list-style: none; padding: 0; margin: 0.75rem 0; }
.indicator-list li {
  padding: 0.4rem 0; padding-left: 1.5rem; position: relative; font-size: 0.82rem;
}
.indicator-list li::before { content: '\25B8'; position: absolute; left: 0; color: #f97316; font-weight: 700; }

/* ========== SECTION 9: CTA ========== */
.cta-section {
  text-align: center; padding: 6rem 1.5rem;
  background: radial-gradient(ellipse at 50% 50%, rgba(249,115,22,0.08) 0%, transparent 60%), #0a0a0f;
  position: relative; overflow: hidden;
}
.cta-section::before {
  content: ''; position: absolute; inset: 0;
  background: repeating-linear-gradient(
    0deg, transparent, transparent 40px, rgba(249,115,22,0.02) 40px, rgba(249,115,22,0.02) 41px
  );
}
.cta-content { position: relative; z-index: 2; animation: fadeIn 1s ease-out both; }
.cta-content h2 {
  font-size: 2.2rem; margin-bottom: 1rem; display: block;
  animation: colorShift 8s ease-in-out infinite;
  -webkit-background-clip: unset; -webkit-text-fill-color: unset; background-clip: unset;
}
.cta-content p { max-width: 600px; margin: 0 auto 2rem; font-size: 1rem; color: #8b949e; }
.cta-links { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.cta-link {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.85rem 2rem; border-radius: 10px; font-weight: 700;
  font-size: 0.9rem; transition: all 0.3s; border: none; text-decoration: none;
}
.cta-link.primary {
  background: linear-gradient(135deg, #f97316, #fdba74); color: #0a0a0f;
  box-shadow: 0 0 30px rgba(249,115,22,0.3);
  animation: glow 3s ease-in-out infinite;
}
.cta-link.primary:hover { box-shadow: 0 0 50px rgba(249,115,22,0.5); transform: translateY(-2px); }
.cta-link.secondary {
  background: rgba(249,115,22,0.08); color: #f97316;
  border: 1px solid rgba(249,115,22,0.25);
}
.cta-link.secondary:hover { background: rgba(249,115,22,0.15); }

/* ========== SIBLING NAVIGATION ========== */
.sibling-nav {
  background: rgba(10,10,15,0.6); border: 1px solid rgba(249,115,22,0.12);
  border-radius: 14px; padding: 2rem; margin: 3rem 0;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.sibling-nav h3 { font-size: 1rem; margin-bottom: 1rem; text-align: center; }
.sibling-nav-grid {
  display: flex; flex-wrap: wrap; gap: 0.75rem; justify-content: center;
}
.sibling-link {
  display: inline-flex; align-items: center; gap: 0.35rem;
  padding: 0.5rem 1rem; border-radius: 8px;
  background: rgba(249,115,22,0.06); border: 1px solid rgba(249,115,22,0.15);
  color: #f97316; font-size: 0.78rem; font-weight: 600;
  border-bottom: none; transition: all 0.3s;
}
.sibling-link:hover { border-color: rgba(253,186,116,0.5); background: rgba(249,115,22,0.12); color: #fdba74; }
.cross-link-grid {
  display: flex; flex-wrap: wrap; gap: 0.75rem; justify-content: center; margin-top: 1rem;
}
.cross-link {
  display: inline-flex; align-items: center; gap: 0.35rem;
  padding: 0.5rem 1rem; border-radius: 8px;
  background: rgba(253,186,116,0.04); border: 1px solid rgba(253,186,116,0.12);
  color: #fdba74; font-size: 0.75rem; font-weight: 600;
  border-bottom: none; transition: all 0.3s;
}
.cross-link:hover { border-color: rgba(249,115,22,0.5); background: rgba(253,186,116,0.1); color: #f97316; }
.cross-link .family-label { font-size: 0.62rem; color: #6e7681; font-weight: 400; }

/* ========== RESPONSIVE ========== */
@media (max-width: 968px) {
  .record-badges-row { gap: 0.5rem; }
  .record-badge { padding: 0.4rem 0.75rem; font-size: 0.75rem; }
  .network-path { flex-direction: column; align-items: center; }
  .net-path-line { width: 2px; height: 30px; flex: 0 0 30px; }
  .net-path-line::after { width: 100%; height: auto; background: linear-gradient(180deg, transparent, #f97316, transparent); }
}
@media (max-width: 768px) {
  .dns-flow { flex-direction: column; align-items: center; }
  .dns-arrow { transform: rotate(90deg); }
  .dns-node { min-width: 200px; }
  .stats-row { grid-template-columns: 1fr 1fr; }
  .hero-content h1 { font-size: 2.2rem; }
  nav .nav-links { display: none; }
  .ip-mapping-grid { grid-template-columns: 1fr; }
  .terms-grid { grid-template-columns: 1fr; }
  .team-grid { grid-template-columns: 1fr; }
  .hunter-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .stats-row { grid-template-columns: 1fr; }
  .hero-content h1 { font-size: 1.8rem; }
  .hero-meta { flex-direction: column; align-items: center; }
  .query-bar { font-size: 0.78rem; padding: 0.5rem 0.75rem; }
  .sibling-nav-grid { flex-direction: column; align-items: center; }
  .cross-link-grid { flex-direction: column; align-items: center; }
}

/* ========== REDUCED MOTION ========== */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; }
}/* End custom CSS */