:root {
  --bg: #050307;
  --panel: rgba(13, 8, 18, .78);
  --panel-strong: rgba(20, 10, 26, .94);
  --ink: #f8eaff;
  --muted: #b499bd;
  --line: rgba(255, 90, 178, .2);
  --red: #ff244d;
  --pink: #ff4fbf;
  --violet: #a855f7;
  --purple: #5d2cff;
  --cyan: #65fff0;
  --mono: "Cascadia Mono", "JetBrains Mono", Consolas, monospace;
  --sans: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100vh;
  color: var(--ink);
  background:
    radial-gradient(circle at 72% 18%, rgba(168, 85, 247, .18), transparent 26rem),
    radial-gradient(circle at 22% 36%, rgba(255, 36, 77, .14), transparent 24rem),
    linear-gradient(135deg, #050307 0%, #0c0612 45%, #120719 100%);
  font-family: var(--sans);
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
button, input { font: inherit; }
body.intro-locked { overflow: hidden; }

#matrix {
  position: fixed;
  inset: 0;
  z-index: -3;
  opacity: .5;
}

.noise {
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.018) 1px, transparent 1px);
  background-size: 32px 32px;
  mask-image: linear-gradient(to bottom, black, transparent 92%);
}

.intro-gate {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 70% 20%, rgba(255, 79, 191, .2), transparent 32rem),
    radial-gradient(circle at 20% 80%, rgba(255, 36, 77, .18), transparent 28rem),
    #020104;
  overflow: hidden;
  opacity: 1;
  visibility: visible;
  transition: opacity .55s ease, visibility .55s ease;
}

.intro-gate.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.intro-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: contrast(1.2) saturate(1.22) hue-rotate(-8deg) brightness(.82);
  transform: scale(1.18);
}

.intro-vignette,
.intro-scan {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.intro-vignette {
  background:
    linear-gradient(90deg, rgba(5,3,7,.84), transparent 28%, transparent 72%, rgba(5,3,7,.86)),
    radial-gradient(circle at 50% 48%, transparent 0 34%, rgba(0,0,0,.62) 78%),
    linear-gradient(180deg, rgba(0,0,0,.36), rgba(255,36,77,.1), rgba(0,0,0,.72));
}

.intro-scan {
  background:
    linear-gradient(rgba(57,255,136,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,79,191,.05) 1px, transparent 1px);
  background-size: 100% 14px, 44px 100%;
  mix-blend-mode: screen;
  opacity: .52;
  animation: introScan 1.2s linear infinite;
}

.intro-copy {
  position: absolute;
  left: clamp(20px, 6vw, 72px);
  bottom: clamp(48px, 9vw, 110px);
  display: grid;
  gap: 8px;
  color: white;
  text-shadow: 0 0 28px rgba(255, 79, 191, .36);
}

.intro-copy span {
  color: var(--cyan);
  font: 900 12px/1 var(--mono);
  letter-spacing: .18em;
}

.intro-copy strong {
  max-width: 720px;
  font: 950 clamp(34px, 7vw, 86px)/.9 var(--mono);
  letter-spacing: 0;
  text-transform: uppercase;
}

.intro-controls {
  position: absolute;
  right: clamp(18px, 4vw, 54px);
  top: clamp(18px, 4vw, 42px);
  display: flex;
  align-items: center;
  gap: 9px;
}

.intro-skip,
.intro-sound {
  min-height: 38px;
  padding: 0 13px;
  border: 1px solid rgba(101, 255, 240, .28);
  border-radius: 6px;
  background: rgba(0, 8, 3, .68);
  color: var(--cyan);
  font: 900 11px/1 var(--mono);
  letter-spacing: .12em;
  text-transform: uppercase;
}

.intro-sound {
  border-color: rgba(57, 255, 136, .36);
  color: #39ff88;
  box-shadow: 0 0 18px rgba(57, 255, 136, .08);
}

.intro-sound.is-active {
  border-color: rgba(255, 79, 191, .5);
  color: var(--pink);
}

.intro-skip:hover,
.intro-sound:hover {
  border-color: rgba(255, 79, 191, .5);
  color: var(--pink);
}

.construction-banner {
  position: relative;
  z-index: 12;
  width: min(1180px, calc(100% - 36px));
  margin: 18px auto 0;
  display: grid;
  grid-template-columns: auto auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 16px;
  padding: 16px 18px;
  border: 1px solid rgba(255, 79, 191, .26);
  border-radius: 8px;
  background:
    linear-gradient(90deg, rgba(255,36,77,.14), rgba(168,85,247,.1), rgba(7,9,14,.72)),
    rgba(9, 4, 13, .78);
  box-shadow: 0 18px 48px rgba(0,0,0,.22), 0 0 28px rgba(255,79,191,.08);
  backdrop-filter: blur(14px);
  overflow: hidden;
}

.construction-banner::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(rgba(101,255,240,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,79,191,.04) 1px, transparent 1px);
  background-size: 100% 18px, 42px 100%;
  opacity: .55;
}

.construction-banner strong,
.construction-banner span {
  display: block;
}

.construction-banner strong {
  color: white;
  font: 900 clamp(18px, 2.1vw, 30px)/1.05 var(--mono);
  letter-spacing: 0;
}

.construction-banner span {
  margin-top: 5px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.tool-window-dots {
  position: relative;
  z-index: 1;
  align-self: start;
  display: grid;
  gap: 5px;
  padding-top: 3px;
}

.tool-window-dots span {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--pink);
  box-shadow: 0 0 12px rgba(255,79,191,.5);
}

.tool-window-dots span:nth-child(2) {
  background: var(--violet);
}

.tool-window-dots span:nth-child(3) {
  background: var(--cyan);
}

.tool-label {
  margin-bottom: 7px;
  color: var(--cyan);
  font: 900 10px/1 var(--mono);
  letter-spacing: .16em;
}

.construction-copy,
.construction-tooling,
.construction-logo {
  position: relative;
  z-index: 1;
}

.construction-logo {
  position: relative;
  width: 58px;
  height: 54px;
  filter: drop-shadow(0 0 18px rgba(255, 79, 191, .36));
}

.construction-logo span {
  position: absolute;
  display: block;
}

.logo-ear {
  top: 2px;
  width: 13px;
  height: 35px;
  border: 1px solid rgba(255, 79, 191, .62);
  border-radius: 999px 999px 8px 8px;
  background: #030105;
}

.logo-ear.left {
  left: 16px;
  transform: rotate(-18deg);
}

.logo-ear.right {
  right: 16px;
  transform: rotate(18deg);
}

.logo-face {
  left: 10px;
  bottom: 2px;
  width: 38px;
  height: 32px;
  border: 1px solid rgba(255, 79, 191, .62);
  border-radius: 44% 44% 40% 40%;
  background:
    radial-gradient(circle at 64% 44%, #ff244d 0 3px, transparent 4px),
    #050108;
}

.logo-spark {
  right: -1px;
  top: 12px;
  width: 13px;
  height: 13px;
  background: var(--cyan);
  clip-path: polygon(50% 0, 62% 38%, 100% 50%, 62% 62%, 50% 100%, 38% 62%, 0 50%, 38% 38%);
  animation: logoSpark 1.5s ease-in-out infinite;
}

.construction-tooling {
  display: grid;
  grid-template-columns: repeat(2, auto);
  gap: 8px;
  min-width: 230px;
}

.tool-chip {
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 10px;
  border: 1px solid rgba(101, 255, 240, .2);
  border-radius: 999px;
  background: rgba(101, 255, 240, .06);
  color: var(--cyan);
  font: 900 10px/1 var(--mono);
  white-space: nowrap;
}

.tool-progress {
  grid-column: 1 / -1;
  height: 8px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 999px;
  background: rgba(0,0,0,.28);
  overflow: hidden;
}

.tool-progress span {
  display: block;
  width: 74%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--red), var(--pink), var(--cyan));
  box-shadow: 0 0 18px rgba(255,79,191,.42);
  animation: toolProgress 2.4s ease-in-out infinite;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 14px clamp(18px, 4vw, 56px);
  border-bottom: 1px solid var(--line);
  background: rgba(5, 3, 7, .72);
  backdrop-filter: blur(18px);
}

.lang-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 36px;
  border: 1px solid rgba(101, 255, 240, .28);
  border-radius: 6px;
  background: rgba(101, 255, 240, .07);
  color: var(--cyan);
  font: 900 12px/1 var(--mono);
  letter-spacing: .08em;
}

.lang-toggle:hover {
  border-color: rgba(255, 79, 191, .44);
  color: var(--pink);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: max-content;
}

.brand-mark {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(255, 79, 191, .58);
  background: linear-gradient(135deg, rgba(255,36,77,.2), rgba(93,44,255,.18));
  color: white;
  font: 800 12px/1 var(--mono);
  border-radius: 6px;
  box-shadow: 0 0 24px rgba(255, 79, 191, .22);
}

.brand strong, .brand small { display: block; }
.brand strong { font-size: 14px; }
.brand small { color: var(--muted); font: 11px/1.4 var(--mono); }

nav {
  display: flex;
  gap: clamp(12px, 3vw, 32px);
  color: var(--muted);
  font: 700 12px/1 var(--mono);
  text-transform: uppercase;
}

nav a:hover { color: var(--pink); }

.section-band {
  width: min(1180px, calc(100% - 36px));
  margin-inline: auto;
  padding-block: clamp(64px, 9vw, 118px);
}

.hero {
  min-height: calc(100vh - 72px);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, .82fr);
  align-items: center;
  gap: clamp(36px, 7vw, 88px);
}

.eyebrow {
  margin: 0 0 16px;
  color: var(--cyan);
  font: 800 12px/1.4 var(--mono);
  letter-spacing: .13em;
  text-transform: uppercase;
}

h1, h2, h3, p { margin-top: 0; }
h1 {
  max-width: 850px;
  margin-bottom: 22px;
  font-size: clamp(54px, 9vw, 124px);
  line-height: .88;
  letter-spacing: 0;
  text-shadow: 0 0 40px rgba(255, 79, 191, .2);
}

h2 {
  font-size: clamp(34px, 5vw, 68px);
  line-height: .98;
  letter-spacing: 0;
}

h3 { font-size: 22px; }

.hero-lede {
  max-width: 700px;
  color: #dccbe4;
  font-size: clamp(18px, 2.2vw, 24px);
  line-height: 1.5;
}

.hero-actions, .contact-links {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 18px;
  border: 1px solid var(--line);
  border-radius: 6px;
  font: 800 12px/1 var(--mono);
  text-transform: uppercase;
  letter-spacing: .08em;
}

.btn.primary {
  border-color: transparent;
  background: linear-gradient(135deg, var(--red), var(--pink) 55%, var(--violet));
  color: white;
  box-shadow: 0 14px 34px rgba(255, 36, 77, .22);
}

.btn.ghost { background: rgba(255,255,255,.03); color: var(--ink); }
.btn:hover, .contact-links a:hover { transform: translateY(-2px); }

.signal-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  max-width: 820px;
  margin: 36px 0 0;
  border: 1px solid var(--line);
  background: var(--line);
}

.signal-strip div {
  padding: 16px;
  background: rgba(10, 5, 14, .74);
}

dt {
  color: var(--pink);
  font: 800 11px/1.5 var(--mono);
  text-transform: uppercase;
}

dd {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 14px;
}

.hero-visual {
  position: relative;
  min-height: 560px;
  display: grid;
  place-items: center;
  overflow: hidden;
}

.orbit {
  position: absolute;
  border: 1px solid rgba(255, 79, 191, .2);
  border-radius: 50%;
  animation: spin 12s linear infinite;
}

.orbit-one { width: 420px; height: 420px; }
.orbit-two {
  width: 310px;
  height: 310px;
  border-color: rgba(101, 255, 240, .2);
  animation-duration: 8s;
  animation-direction: reverse;
}

.orbit::before, .orbit::after {
  content: "";
  position: absolute;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--pink);
  box-shadow: 0 0 22px var(--pink);
}

.orbit::before { top: 28px; left: 80px; }
.orbit::after { right: 38px; bottom: 88px; background: var(--cyan); box-shadow: 0 0 22px var(--cyan); }

.rabbit-core {
  position: relative;
  width: 230px;
  height: 230px;
  filter: drop-shadow(0 0 44px rgba(255, 79, 191, .38));
  animation: pulse 3.2s ease-in-out infinite;
}

.rabbit-core span { position: absolute; display: block; }
.ear {
  width: 54px;
  height: 156px;
  top: 0;
  background: #030105;
  border: 1px solid rgba(255, 79, 191, .45);
  border-radius: 70% 70% 42% 42%;
}
.ear-left { left: 50px; transform: rotate(-18deg); }
.ear-right { right: 50px; transform: rotate(18deg); }
.head {
  left: 30px;
  bottom: 10px;
  width: 170px;
  height: 150px;
  border-radius: 48% 48% 42% 42%;
  background: radial-gradient(circle at 60% 40%, rgba(255,79,191,.16), transparent 25%), #040107;
  border: 1px solid rgba(255, 79, 191, .5);
}
.eye {
  right: 74px;
  bottom: 84px;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background: var(--red);
  box-shadow: 0 0 20px var(--red);
}

.scanner-card, .packet {
  position: absolute;
  border: 1px solid var(--line);
  background: rgba(11, 6, 16, .82);
  backdrop-filter: blur(12px);
  border-radius: 6px;
  box-shadow: 0 18px 50px rgba(0,0,0,.28);
}

.scanner-card {
  right: 0;
  bottom: 86px;
  width: min(260px, 58vw);
  padding: 18px;
  overflow: hidden;
}

.scanner-card p {
  margin-bottom: 8px;
  color: var(--cyan);
  font: 800 11px/1 var(--mono);
  letter-spacing: .16em;
}

.scanner-card strong { font-size: 20px; }
.scan-line {
  inset: 0;
  height: 2px;
  background: var(--pink);
  box-shadow: 0 0 24px var(--pink);
  animation: scan 2.4s ease-in-out infinite;
}

.packet {
  padding: 9px 11px;
  color: var(--cyan);
  font: 800 12px/1 var(--mono);
}
.packet-a { left: 16px; top: 122px; }
.packet-b { right: 72px; top: 34px; color: var(--pink); }
.packet-c { left: 80px; bottom: 120px; color: var(--red); }

.ops-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.section-heading {
  grid-column: 1 / -1;
  max-width: 780px;
}

.ops-panel, .timeline-list article, .project, .ids-console, .contact {
  border: 1px solid var(--line);
  background: var(--panel);
  backdrop-filter: blur(18px);
  border-radius: 8px;
  box-shadow: 0 24px 90px rgba(0,0,0,.22);
}

.ops-panel {
  min-height: 220px;
  padding: 24px;
}

.ops-panel.wide { grid-column: 1 / -1; }

.panel-top {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  margin: -24px -24px 0;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line);
  color: var(--muted);
  font: 800 12px/1 var(--mono);
}

.status-dot { color: var(--cyan); }
.panel-kicker {
  color: var(--pink);
  font: 800 11px/1 var(--mono);
  letter-spacing: .12em;
  text-transform: uppercase;
}

.terminal-output {
  min-height: 260px;
  padding: 22px 0;
  color: #e9dcf0;
  font: 14px/1.7 var(--mono);
}

.terminal-line { min-height: 24px; white-space: pre-wrap; }
.terminal-line.dim { color: var(--muted); }
.terminal-line.ok { color: var(--cyan); }
.terminal-line.hot { color: var(--pink); }
.terminal-line.err { color: var(--red); }

.terminal-form {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 10px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
  color: var(--pink);
  font-family: var(--mono);
}

.terminal-form input {
  min-width: 0;
  color: var(--ink);
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 6px;
  padding: 12px;
  outline: none;
}

.terminal-form input:focus { border-color: rgba(255, 79, 191, .55); }
.terminal-form button {
  min-width: 70px;
  border: 0;
  border-radius: 6px;
  padding: 12px;
  color: white;
  background: var(--pink);
  font-weight: 800;
}

.timeline-list {
  display: grid;
  gap: 12px;
}

.timeline-list article {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 20px;
  padding: 22px;
}

.timeline-list span {
  color: var(--cyan);
  font: 800 12px/1.4 var(--mono);
}

.timeline-list p, .ops-panel p, .project p, .contact p {
  color: var(--muted);
  line-height: 1.7;
}

.project {
  display: grid;
  grid-template-columns: minmax(0, .85fr) minmax(320px, 1fr);
  align-items: center;
  gap: 34px;
  padding: clamp(24px, 5vw, 54px);
}

.feature-list {
  display: grid;
  gap: 10px;
  margin: 24px 0 0;
  padding: 0;
  list-style: none;
}

.feature-list li {
  padding-left: 22px;
  position: relative;
  color: #e7d7ee;
}

.feature-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .58em;
  width: 8px;
  height: 8px;
  background: var(--red);
  box-shadow: 0 0 16px var(--red);
}

.ids-map {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  position: relative;
}

.ids-map::before {
  content: "";
  position: absolute;
  inset: 18px;
  border: 1px dashed rgba(255, 79, 191, .22);
  border-radius: 50%;
  animation: spin 18s linear infinite;
}

.ids-map span {
  min-height: 84px;
  display: grid;
  place-items: center;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel-strong);
  color: var(--ink);
  font: 800 13px/1.3 var(--mono);
  text-align: center;
  z-index: 1;
}

.ids-demo .section-heading p:not(.eyebrow) {
  max-width: 760px;
  color: var(--muted);
  line-height: 1.7;
}

.ids-console {
  padding: clamp(18px, 3vw, 28px);
  overflow: hidden;
}

.ids-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin: calc(clamp(18px, 3vw, 28px) * -1) calc(clamp(18px, 3vw, 28px) * -1) 0;
  padding: 18px clamp(18px, 3vw, 28px);
  border-bottom: 1px solid var(--line);
  background: linear-gradient(90deg, rgba(255, 36, 77, .12), rgba(168, 85, 247, .08));
}

.ids-topbar strong {
  display: block;
  margin-top: 6px;
  font-size: clamp(22px, 3vw, 34px);
}

.demo-badge {
  padding: 10px 12px;
  border: 1px solid rgba(101, 255, 240, .34);
  border-radius: 999px;
  color: var(--cyan);
  background: rgba(101, 255, 240, .08);
  font: 800 11px/1 var(--mono);
  text-transform: uppercase;
  letter-spacing: .12em;
  white-space: nowrap;
}

.ids-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  margin: 18px 0;
  border: 1px solid var(--line);
  background: var(--line);
}

.ids-metrics div {
  min-width: 0;
  padding: 16px;
  background: rgba(7, 3, 10, .72);
}

.ids-metrics span, .ids-metrics small {
  display: block;
}

.ids-metrics span {
  color: var(--ink);
  font: 900 clamp(22px, 4vw, 42px)/1 var(--mono);
}

.ids-metrics small {
  margin-top: 8px;
  color: var(--muted);
  font: 800 11px/1 var(--mono);
  text-transform: uppercase;
  letter-spacing: .12em;
}

.ids-dashboard-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, .85fr);
  gap: 14px;
}

.alert-feed, .evidence-panel, .attack-map, .case-panel {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(8, 4, 12, .78);
  overflow: hidden;
}

.feed-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--line);
  color: var(--muted);
  font: 800 11px/1 var(--mono);
  text-transform: uppercase;
  letter-spacing: .1em;
}

.feed-rows {
  display: grid;
  gap: 8px;
  padding: 12px;
}

.alert-row {
  display: grid;
  grid-template-columns: 78px minmax(0, 1fr) 84px;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 6px;
  background: rgba(255,255,255,.03);
}

.alert-row.active {
  border-color: rgba(255, 36, 77, .72);
  background: linear-gradient(90deg, rgba(255,36,77,.16), rgba(255,79,191,.06));
  box-shadow: 0 0 34px rgba(255, 36, 77, .16);
}

.alert-row strong, .alert-row span, .alert-row small {
  min-width: 0;
}

.alert-row strong {
  color: var(--ink);
  font: 850 14px/1.3 var(--mono);
}

.alert-row p {
  margin: 4px 0 0;
  color: var(--muted);
  font: 12px/1.45 var(--mono);
  overflow-wrap: anywhere;
}

.severity {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  border-radius: 999px;
  font: 900 10px/1 var(--mono);
  text-transform: uppercase;
}

.severity.high { color: white; background: rgba(255, 36, 77, .86); }
.severity.medium { color: #150812; background: var(--pink); }
.severity.critical { color: white; background: linear-gradient(135deg, var(--red), var(--violet)); }

.alert-time {
  color: var(--cyan);
  font: 800 11px/1 var(--mono);
  text-align: right;
}

.evidence-panel pre {
  min-height: 232px;
  margin: 0;
  padding: 18px;
  color: #f4d9ff;
  background:
    linear-gradient(rgba(101,255,240,.04) 1px, transparent 1px),
    rgba(0,0,0,.22);
  background-size: 100% 28px;
  font: 12px/1.65 var(--mono);
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

.evidence-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 12px;
  border-top: 1px solid var(--line);
}

.evidence-tags span {
  padding: 8px 9px;
  border: 1px solid rgba(101, 255, 240, .18);
  border-radius: 999px;
  color: var(--cyan);
  background: rgba(101, 255, 240, .06);
  font: 800 10px/1 var(--mono);
  text-transform: uppercase;
}

.attack-map {
  position: relative;
  min-height: 250px;
  background:
    radial-gradient(circle at 50% 50%, rgba(255,79,191,.15), transparent 36%),
    rgba(8, 4, 12, .78);
}

.node {
  position: absolute;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 92px;
  height: 42px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--panel-strong);
  color: var(--ink);
  font: 850 11px/1 var(--mono);
  text-transform: uppercase;
}

.node.attacker { left: 24px; top: 32px; border-color: rgba(255,36,77,.7); }
.node.waf { left: 36%; top: 102px; }
.node.snort { right: 32px; top: 38px; }
.node.soc { right: 18%; bottom: 30px; border-color: rgba(101,255,240,.42); }
.node.active { box-shadow: 0 0 28px rgba(255,36,77,.3); }

.trace {
  position: absolute;
  height: 2px;
  transform-origin: left center;
  background: linear-gradient(90deg, transparent, var(--red), var(--pink), transparent);
  opacity: .78;
  animation: tracePulse 2.6s ease-in-out infinite;
}

.trace-one { left: 110px; top: 64px; width: 190px; transform: rotate(20deg); }
.trace-two { left: 46%; top: 124px; width: 170px; transform: rotate(-24deg); animation-delay: .35s; }
.trace-three { right: 96px; top: 92px; width: 145px; transform: rotate(88deg); animation-delay: .72s; }

.case-panel {
  padding: 18px;
}

.case-panel h3 {
  margin: 10px 0;
}

.case-progress {
  display: grid;
  gap: 8px;
  margin-top: 20px;
}

.case-progress span {
  position: relative;
  min-height: 34px;
  display: flex;
  align-items: center;
  padding: 0 12px;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 6px;
  background: rgba(255,255,255,.035);
  color: var(--muted);
  font: 800 11px/1 var(--mono);
  text-transform: uppercase;
  overflow: hidden;
}

.case-progress span::before {
  content: "";
  position: absolute;
  inset: 0;
  width: calc(var(--step) * 25%);
  background: linear-gradient(90deg, rgba(255,36,77,.26), rgba(255,79,191,.12));
  z-index: -1;
}

.ids-product-shell {
  display: grid;
  grid-template-columns: 230px minmax(0, 1fr);
  min-height: 780px;
  border: 1px solid rgba(59, 130, 246, .22);
  border-radius: 10px;
  overflow: hidden;
  background: #020202;
  box-shadow: 0 32px 120px rgba(0,0,0,.36), 0 0 48px rgba(59, 130, 246, .1);
}

.ids-sidebar {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 24px 16px;
  border-right: 1px solid rgba(255,255,255,.06);
  background: #080808;
}

.ids-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  margin-bottom: 28px;
  padding: 10px;
}

.ids-brand img {
  width: 52px;
  height: 52px;
  object-fit: contain;
  filter: drop-shadow(0 0 12px rgba(185, 226, 255, .52));
}

.ids-brand strong,
.ids-brand span {
  display: block;
  min-width: 0;
}

.ids-brand strong {
  color: #f7fbff;
  font-size: 18px;
  font-weight: 900;
  font-style: italic;
  line-height: 1;
  text-shadow: 0 0 14px rgba(173, 220, 255, .38);
}

.ids-brand span {
  margin-top: 4px;
  color: #8fb6d9;
  font: 800 8px/1.25 var(--mono);
  letter-spacing: .12em;
  text-transform: uppercase;
}

.ids-nav {
  display: flex;
  align-items: center;
  width: 100%;
  min-height: 44px;
  padding: 0 14px;
  border: 0;
  border-radius: 14px;
  background: transparent;
  color: #737373;
  font: 850 12px/1 var(--sans);
  text-align: left;
  cursor: pointer;
}

.ids-nav.active {
  color: white;
  background: #2563eb;
  box-shadow: 0 18px 34px rgba(37, 99, 235, .22);
}

.ids-nav.danger {
  color: #fca5a5;
  background: rgba(239, 68, 68, .08);
}

.ids-nav.danger.active {
  color: white;
  background: #dc2626;
  box-shadow: 0 18px 34px rgba(220, 38, 38, .22);
}

.ids-nav:hover {
  color: white;
  background: rgba(255,255,255,.05);
}

.ids-product-main {
  min-width: 0;
  background:
    radial-gradient(circle at 74% 0%, rgba(37, 99, 235, .13), transparent 34rem),
    #050505;
}

.ids-window-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  min-height: 72px;
  padding: 16px 24px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  background: rgba(0, 0, 0, .42);
}

.ids-window-top strong {
  display: block;
  margin-top: 4px;
  color: white;
  font-size: 14px;
  text-transform: uppercase;
}

.ids-screen-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 16px;
  padding: 24px;
}

.ids-screen {
  display: none;
  min-width: 0;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 12px;
  background: #0a0a0a;
  padding: 18px;
  box-shadow: 0 18px 60px rgba(0,0,0,.24);
}

.ids-screen.is-active {
  display: block;
  animation: idsScreenIn .22s ease both;
}

.featured-screen {
  grid-row: span 2;
}

.screen-title {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 16px;
}

.screen-title span,
.screen-title small {
  color: #737373;
  font: 800 10px/1 var(--mono);
  text-transform: uppercase;
  letter-spacing: .12em;
}

.screen-title strong {
  display: block;
  margin-top: 6px;
  color: white;
  font-size: 22px;
  line-height: 1.1;
}

.screen-title small {
  color: #60a5fa;
  white-space: nowrap;
}

.ids-kpis,
.intel-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.overview-screen .ids-kpis {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.ids-kpis div,
.intel-grid div,
.profile-card {
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px;
  background: rgba(0,0,0,.32);
  padding: 14px;
}

.ids-kpis span,
.intel-grid span,
.profile-card strong {
  display: block;
  color: white;
  font: 900 28px/1 var(--mono);
}

.ids-kpis small,
.intel-grid small,
.profile-card span,
.profile-card small {
  display: block;
  margin-top: 8px;
  color: #737373;
  font: 800 10px/1.25 var(--mono);
  text-transform: uppercase;
}

.ids-kpis .hot span {
  color: #ef4444;
  text-shadow: 0 0 18px rgba(239, 68, 68, .32);
}

.threat-banner {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  margin-bottom: 14px;
  padding: 16px;
  border: 1px solid rgba(239, 68, 68, .34);
  border-radius: 12px;
  background:
    linear-gradient(90deg, rgba(239, 68, 68, .16), rgba(249, 115, 22, .08), rgba(37, 99, 235, .04)),
    rgba(0,0,0,.24);
  box-shadow: 0 0 34px rgba(239, 68, 68, .12);
}

.threat-icon {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border-radius: 14px;
  background: #dc2626;
  color: white;
  font: 950 26px/1 var(--mono);
  box-shadow: 0 0 28px rgba(239, 68, 68, .42);
  animation: threatPulse 1.35s ease-in-out infinite;
}

.threat-banner strong,
.threat-banner p,
.threat-banner span {
  display: block;
}

.threat-banner strong {
  color: white;
  font-size: 20px;
}

.threat-banner p {
  margin: 5px 0 0;
  color: #fecaca;
  font-size: 13px;
  line-height: 1.45;
}

.threat-banner span {
  padding: 8px 10px;
  border: 1px solid rgba(239, 68, 68, .34);
  border-radius: 999px;
  color: #fecaca;
  background: rgba(239, 68, 68, .12);
  font: 900 10px/1 var(--mono);
  text-transform: uppercase;
}

.overview-dashboard-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(260px, .65fr);
  gap: 12px;
  margin-top: 12px;
}

.chart-card {
  margin-top: 12px;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px;
  background: rgba(0,0,0,.28);
  padding: 14px;
}

.overview-dashboard-grid .chart-card {
  margin-top: 0;
}

.main-chart {
  grid-row: span 2;
}

.chart-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 12px;
}

.chart-head strong,
.chart-head span,
.chart-head b {
  display: block;
}

.chart-head strong {
  color: white;
  font-size: 14px;
}

.chart-head span {
  margin-top: 4px;
  color: #737373;
  font: 800 10px/1.3 var(--mono);
  text-transform: uppercase;
}

.chart-head b {
  padding: 7px 8px;
  border: 1px solid rgba(239,68,68,.24);
  border-radius: 999px;
  color: #fca5a5;
  background: rgba(239,68,68,.09);
  font: 900 10px/1 var(--mono);
  text-transform: uppercase;
  white-space: nowrap;
}

.chart-card p {
  margin: 12px 0 0;
  color: #737373;
  font: 800 10px/1 var(--mono);
  text-transform: uppercase;
}

.fake-area-chart {
  display: flex;
  align-items: end;
  gap: 8px;
  height: 122px;
  padding-top: 20px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.threat-chart {
  height: 292px;
  position: relative;
  background:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 100% 25%, 12.5% 100%;
  padding: 30px 10px 0;
}

.threat-chart::after {
  content: "";
  position: absolute;
  left: 49%;
  top: 18px;
  bottom: 0;
  border-left: 1px dashed rgba(239,68,68,.46);
  box-shadow: 0 0 20px rgba(239,68,68,.4);
}

.fake-area-chart span {
  flex: 1;
  height: var(--h);
  border-radius: 8px 8px 0 0;
  background: linear-gradient(180deg, #ef4444, #f97316 42%, rgba(37,99,235,.1));
  box-shadow: 0 -10px 24px rgba(239, 68, 68, .18);
}

.severity-card {
  display: grid;
  justify-items: center;
}

.severity-card .chart-head {
  width: 100%;
}

.severity-donut {
  width: 136px;
  height: 136px;
  border-radius: 50%;
  background: conic-gradient(#ef4444 0 24%, #f97316 24% 62%, #3b82f6 62% 91%, #22c55e 91% 100%);
  position: relative;
  box-shadow: 0 0 28px rgba(239,68,68,.16);
}

.severity-donut::after {
  content: "91";
  position: absolute;
  inset: 28px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: #0a0a0a;
  color: white;
  font: 950 32px/1 var(--mono);
}

.legend-list {
  width: 100%;
  display: grid;
  gap: 8px;
  margin-top: 16px;
}

.legend-list span {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #a3a3a3;
  font: 800 11px/1 var(--mono);
  text-transform: uppercase;
}

.legend-list b {
  width: 9px;
  height: 9px;
  border-radius: 50%;
}

.red-dot { background: #ef4444; }
.orange-dot { background: #f97316; }
.blue-dot { background: #3b82f6; }

.attack-bars {
  display: grid;
  gap: 12px;
}

.attack-bars div {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr) 40px;
  align-items: center;
  gap: 10px;
}

.attack-bars span,
.attack-bars em {
  color: #a3a3a3;
  font: 800 11px/1 var(--mono);
  font-style: normal;
}

.attack-bars b {
  height: 10px;
  width: var(--w);
  border-radius: 999px;
  background: linear-gradient(90deg, #ef4444, #f97316, #3b82f6);
  box-shadow: 0 0 18px rgba(239,68,68,.16);
}

.mini-stream {
  display: grid;
  gap: 10px;
}

.mini-stream div {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 10px;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 8px;
  background: rgba(0,0,0,.22);
}

.mini-stream b {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #ef4444;
  box-shadow: 0 0 16px rgba(239,68,68,.54);
}

.mini-stream span,
.mini-stream em {
  min-width: 0;
  color: #d4d4d4;
  font: 800 11px/1.35 var(--mono);
}

.mini-stream em {
  color: #737373;
  font-style: normal;
  overflow-wrap: anywhere;
}

.intrusions-screen.is-active {
  min-height: 590px;
}

.filter-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 10px;
  margin-bottom: 12px;
}

.filter-row span,
.filter-row b {
  min-height: 38px;
  display: flex;
  align-items: center;
  padding: 0 12px;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 8px;
  background: #111;
  color: #737373;
  font: 750 11px/1.3 var(--mono);
}

.filter-row b {
  color: #e5e5e5;
  text-transform: uppercase;
}

.ids-table {
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px;
  overflow: hidden;
}

.ids-tr {
  display: grid;
  grid-template-columns: 88px minmax(0, 1fr) 82px 86px;
  gap: 12px;
  align-items: center;
  padding: 13px 14px;
  border-top: 1px solid rgba(255,255,255,.06);
  color: #d4d4d4;
  font: 12px/1.35 var(--mono);
  width: 100%;
  background: transparent;
  text-align: left;
}

.ids-tr:first-child {
  border-top: 0;
}

.ids-head {
  color: #737373;
  background: rgba(17,17,17,.55);
  font-size: 10px;
  text-transform: uppercase;
}

.ids-tr span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.event-row {
  cursor: pointer;
}

.event-row:hover,
.event-row.active {
  background: rgba(37, 99, 235, .08);
}

.event-row.active {
  box-shadow: inset 3px 0 0 #60a5fa;
}

.ids-tr b,
.ids-tr em {
  justify-self: start;
  padding: 5px 7px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 6px;
  font: 900 10px/1 var(--mono);
  text-transform: uppercase;
  font-style: normal;
}

.ids-tr b.critical { color: #fca5a5; background: rgba(239,68,68,.12); border-color: rgba(239,68,68,.24); }
.ids-tr b.high { color: #fdba74; background: rgba(249,115,22,.12); border-color: rgba(249,115,22,.24); }
.ids-tr b.medium { color: #93c5fd; background: rgba(59,130,246,.12); border-color: rgba(59,130,246,.24); }
.ids-tr em { color: #bfdbfe; background: rgba(59,130,246,.08); }

.detail-drawer {
  margin-top: 12px;
  padding: 14px;
  border: 1px solid rgba(59,130,246,.22);
  border-radius: 10px;
  background: rgba(37, 99, 235, .08);
}

.detail-drawer strong,
.detail-drawer code {
  display: block;
}

.detail-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  margin-bottom: 12px;
}

.detail-drawer strong {
  color: white;
}

.detail-head span {
  padding: 6px 8px;
  border: 1px solid rgba(59,130,246,.24);
  border-radius: 999px;
  color: #bfdbfe;
  background: rgba(59,130,246,.08);
  font: 900 10px/1 var(--mono);
  text-transform: uppercase;
}

.event-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin: 0 0 12px;
}

.event-meta div {
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 8px;
  background: rgba(0,0,0,.22);
  padding: 10px;
}

.event-meta dt {
  color: #737373;
  font-size: 9px;
}

.event-meta dd {
  margin: 5px 0 0;
  color: #dbeafe;
  font: 800 11px/1.25 var(--mono);
  overflow-wrap: anywhere;
}

.detail-drawer code {
  color: #93c5fd;
  font: 11px/1.55 var(--mono);
  overflow-wrap: anywhere;
  padding: 12px;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 8px;
  background: rgba(0,0,0,.28);
}

.detail-drawer p {
  margin: 12px 0 0;
  color: #a3a3a3;
  font-size: 13px;
  line-height: 1.6;
}

.rules-screen pre {
  margin: 14px 0 0;
  min-height: 170px;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px;
  background: #111;
  color: #d4d4d4;
  font: 11px/1.5 var(--mono);
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

.profile-card strong {
  margin-top: 8px;
  color: #60a5fa;
  font-size: 24px;
}

.intel-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.intel-grid span {
  font-size: 24px;
}

.donut-row {
  display: grid;
  grid-template-columns: 90px minmax(0, 1fr);
  align-items: center;
  gap: 16px;
  margin-top: 18px;
}

.donut {
  width: 86px;
  height: 86px;
  border-radius: 50%;
  background: conic-gradient(#3b82f6 0 42%, #ef4444 42% 62%, #22c55e 62% 78%, #a855f7 78% 100%);
  position: relative;
}

.donut::after {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 50%;
  background: #0a0a0a;
}

.donut-row p {
  margin: 0;
  color: #737373;
  font-size: 13px;
  line-height: 1.6;
}

.defense-stack,
.origin-list {
  display: grid;
  gap: 10px;
}

.defense-stack div,
.origin-list div {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px;
  background: rgba(0,0,0,.32);
  padding: 14px;
}

.defense-stack strong,
.origin-list span {
  color: white;
  font-weight: 850;
}

.defense-stack span,
.origin-list b {
  color: #60a5fa;
  font: 900 10px/1 var(--mono);
  text-transform: uppercase;
}

.screen-copy {
  margin: 16px 0 0;
  color: #a3a3a3;
  line-height: 1.7;
}

.skill-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.skill-cloud span {
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: rgba(255,255,255,.04);
  color: #eadcf1;
  font: 750 13px/1 var(--mono);
}

.contact {
  display: grid;
  grid-template-columns: minmax(0, .8fr) minmax(280px, 1fr);
  gap: 28px;
  align-items: center;
  margin-bottom: 48px;
  padding: clamp(24px, 5vw, 48px);
}

.contact-links a {
  display: block;
  width: 100%;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: rgba(255,255,255,.035);
  color: var(--ink);
  font: 800 13px/1.3 var(--mono);
  transition: transform .18s ease, border-color .18s ease;
}

@keyframes spin { to { transform: rotate(360deg); } }
@keyframes logoSpark {
  0%, 100% { transform: scale(.86) rotate(0deg); opacity: .55; }
  50% { transform: scale(1.12) rotate(20deg); opacity: 1; }
}
@keyframes toolProgress {
  0%, 100% { transform: translateX(0); filter: saturate(1); }
  50% { transform: translateX(9%); filter: saturate(1.25); }
}
@keyframes pulse {
  0%, 100% { transform: translateY(0) scale(1); }
  50% { transform: translateY(-8px) scale(1.03); }
}
@keyframes scan {
  0% { transform: translateY(-4px); opacity: 0; }
  15%, 85% { opacity: 1; }
  100% { transform: translateY(116px); opacity: 0; }
}
@keyframes tracePulse {
  0%, 100% { opacity: .16; filter: blur(1px); }
  45%, 60% { opacity: .95; filter: blur(0); }
}
@keyframes idsScreenIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes threatPulse {
  0%, 100% { transform: scale(1); box-shadow: 0 0 24px rgba(239, 68, 68, .34); }
  50% { transform: scale(1.05); box-shadow: 0 0 38px rgba(239, 68, 68, .58); }
}
@keyframes introScan {
  from { transform: translateY(-14px); }
  to { transform: translateY(0); }
}
@media (max-width: 900px) {
  .construction-banner {
    width: min(100% - 24px, 1180px);
    grid-template-columns: auto auto minmax(0, 1fr);
  }
  .construction-tooling {
    grid-column: 2 / -1;
    min-width: 0;
  }
  .site-header { align-items: flex-start; flex-direction: column; }
  nav { width: 100%; justify-content: space-between; }
  .hero, .project, .contact { grid-template-columns: 1fr; }
  .hero { padding-top: 54px; }
  .hero-visual { min-height: 420px; }
  .signal-strip { grid-template-columns: 1fr; }
  .ops-grid { grid-template-columns: 1fr; }
  .timeline-list article { grid-template-columns: 1fr; }
  .ids-metrics { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ids-dashboard-grid { grid-template-columns: 1fr; }
  .ids-product-shell { grid-template-columns: 1fr; }
  .ids-sidebar {
    flex-direction: row;
    align-items: center;
    overflow-x: auto;
    border-right: 0;
    border-bottom: 1px solid rgba(255,255,255,.06);
  }
  .ids-brand { margin-bottom: 0; min-width: 210px; }
  .ids-nav { min-width: max-content; }
  .overview-screen .ids-kpis { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .overview-dashboard-grid { grid-template-columns: 1fr; }
  .main-chart { grid-row: auto; }
  .featured-screen { grid-row: auto; }
}

@media (max-width: 560px) {
  .section-band { width: min(100% - 24px, 1180px); }
  .intro-copy {
    left: 18px;
    right: 18px;
    bottom: 72px;
  }
  .intro-copy strong { font-size: 34px; }
  .construction-banner { grid-template-columns: auto minmax(0, 1fr); }
  .tool-window-dots { display: none; }
  .construction-logo { width: 54px; }
  .construction-tooling {
    grid-column: 1 / -1;
    grid-template-columns: 1fr;
  }
  nav { overflow-x: auto; justify-content: flex-start; padding-bottom: 4px; }
  h1 { font-size: 50px; }
  .hero-visual { min-height: 360px; }
  .orbit-one { width: 310px; height: 310px; }
  .orbit-two { width: 230px; height: 230px; }
  .rabbit-core { transform: scale(.82); }
  .scanner-card { right: 10px; bottom: 36px; }
  .ids-map { grid-template-columns: 1fr; }
  .ids-topbar { align-items: flex-start; flex-direction: column; }
  .ids-metrics { grid-template-columns: 1fr; }
  .alert-row { grid-template-columns: 1fr; }
  .alert-time { text-align: left; }
  .attack-map { min-height: 320px; }
  .node.attacker { left: 16px; top: 24px; }
  .node.waf { left: 22px; top: 120px; }
  .node.snort { right: 18px; top: 80px; }
  .node.soc { right: 18px; bottom: 26px; }
  .ids-window-top { align-items: flex-start; flex-direction: column; }
  .ids-screen-grid { padding: 12px; }
  .ids-kpis, .intel-grid { grid-template-columns: 1fr; }
  .overview-screen .ids-kpis { grid-template-columns: 1fr; }
  .threat-banner { grid-template-columns: 1fr; }
  .threat-chart { height: 220px; }
  .attack-bars div { grid-template-columns: 1fr; }
  .mini-stream div { grid-template-columns: auto minmax(0, 1fr); }
  .mini-stream em { grid-column: 2; }
  .filter-row { grid-template-columns: 1fr; }
  .ids-tr { grid-template-columns: 1fr; }
  .event-meta { grid-template-columns: 1fr; }
  .donut-row { grid-template-columns: 1fr; }
  .terminal-form { grid-template-columns: auto 1fr; }
  .terminal-form button { grid-column: 2; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
  }
}
