/* ============================================================
   ADAM.TECH — EXPERTISE
   Four expertise areas, each as its own full-bleed section with a
   live, interactive "proof" instead of a static card.
   Inherits tokens (--void, --ink, brand colors, fonts) from landing.css
   ============================================================ */

/* ---- intro jump-nav (in #expertise) -------------------------- */
.exp-jump { margin-top: clamp(34px, 5vh, 56px); display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.exp-jump a {
  --c: var(--blue);
  position: relative; display: flex; flex-direction: column; gap: 6px;
  padding: 22px 22px 24px; border-radius: 16px; overflow: hidden;
  border: 1px solid var(--line-bright); background: rgba(255,255,255,0.025);
  transition: transform 0.3s ease, border-color 0.3s ease, background 0.3s ease;
}
.exp-jump a::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--c); }
.exp-jump a:hover { transform: translateY(-5px); border-color: var(--c); background: color-mix(in oklab, var(--c) 8%, transparent); }
.exp-jump .ej-n { font-family: 'JetBrains Mono', monospace; font-size: 13px; letter-spacing: 0.16em; color: var(--c); }
.exp-jump .ej-t { font-size: clamp(17px, 1.4vw, 20px); font-weight: 700; letter-spacing: -0.015em; line-height: 1.1; }
.exp-jump .ej-e { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--dim); }

/* ---- shared section frame ------------------------------------ */
.xsec {
  position: relative;
  padding: clamp(80px, 13vh, 150px) 0;
  overflow: hidden;
  --c: var(--blue);
}
.xsec .wrap { position: relative; z-index: 2; }
.xsec .bg-grid { z-index: 0; }
.xsec::after { /* faint accent wash */
  content: ''; position: absolute; inset: 0; z-index: 0; pointer-events: none;
}
.xsec.x-enterprise::after { background: radial-gradient(circle at 88% 16%, color-mix(in oklab, var(--c) 22%, transparent) 0%, transparent 46%); }
.xsec.x-ai::after        { background: radial-gradient(circle at 12% 18%, color-mix(in oklab, var(--c) 22%, transparent) 0%, transparent 46%); }
.xsec.x-verticals::after { background: radial-gradient(circle at 50% -10%, color-mix(in oklab, var(--c) 18%, transparent) 0%, transparent 50%); }
.xsec.x-iot::after       { background: radial-gradient(circle at 50% 120%, color-mix(in oklab, var(--c) 24%, transparent) 0%, transparent 55%); }

/* kicker: big number + mono label + hairline */
.xkick { display: flex; align-items: baseline; gap: 18px; }
.xkick .xnum {
  font-family: 'JetBrains Mono', monospace; font-weight: 800;
  font-size: clamp(40px, 5vw, 76px); line-height: 0.8; letter-spacing: -0.04em;
  -webkit-text-stroke: 1.5px var(--c); color: transparent;
}
.xkick .xlabel {
  font-family: 'JetBrains Mono', monospace; font-size: 13px; letter-spacing: 0.24em;
  text-transform: uppercase; color: var(--c);
  padding: 7px 14px; border: 1px solid color-mix(in oklab, var(--c) 50%, transparent);
  border-radius: 999px; background: color-mix(in oklab, var(--c) 8%, transparent);
}
.xtitle {
  font-size: clamp(34px, 4.6vw, 66px); font-weight: 800; line-height: 0.98;
  letter-spacing: -0.035em; margin: 22px 0 0; text-wrap: balance;
}
.xen {
  font-family: 'JetBrains Mono', monospace; font-size: clamp(12px, 1.3vw, 15px);
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--c); margin-top: 16px;
}
.xdesc { margin-top: 20px; max-width: 46ch; font-size: clamp(17px, 1.5vw, 20px); line-height: 1.5; color: var(--dim); }

/* two-column layout for sections 01 & 02 */
.xgrid { display: grid; grid-template-columns: 0.92fr 1.08fr; gap: clamp(34px, 5vw, 80px); align-items: center; }
.xgrid.flip .xtext { order: 2; }
.xgrid.flip .xdemo { order: 1; }

/* capability list (used by 01 & 02) */
.xlist { list-style: none; margin-top: 30px; display: grid; gap: 10px; }
.xlist li {
  position: relative; padding: 13px 16px 13px 40px; border-radius: 12px;
  border: 1px solid var(--line); background: rgba(255,255,255,0.025);
  font-size: 16px; font-weight: 600; line-height: 1.2;
  transition: border-color 0.25s, background 0.25s, transform 0.25s;
}
.xlist li span { display: block; font-weight: 400; font-size: 13px; color: var(--dim); margin-top: 3px; }
.xlist li::before {
  content: ''; position: absolute; left: 16px; top: 18px; width: 9px; height: 9px;
  border-radius: 2px; background: var(--c); box-shadow: 0 0 10px var(--c);
}
.xlist li:hover { border-color: var(--c); background: color-mix(in oklab, var(--c) 7%, transparent); transform: translateX(4px); }

/* ============================================================
   01 · ENTERPRISE — live BI command center
   ============================================================ */
.dash {
  border: 1px solid var(--line-bright); border-radius: 20px; overflow: hidden;
  background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.012));
  box-shadow: 0 30px 90px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,255,255,0.02) inset;
}
.dash-top {
  display: flex; align-items: center; gap: 9px; padding: 14px 18px;
  border-bottom: 1px solid var(--line); background: rgba(0,0,0,0.25);
}
.dash-top .dash-dot { width: 11px; height: 11px; border-radius: 50%; background: var(--line-bright); }
.dash-top .dash-dot:nth-child(1) { background: #ff5f57; }
.dash-top .dash-dot:nth-child(2) { background: #febc2e; }
.dash-top .dash-dot:nth-child(3) { background: #28c840; }
.dash-top .dash-title { margin-left: 8px; font-size: 12px; letter-spacing: 0.1em; color: var(--dim); }
.dash-top .dash-live { margin-left: auto; font-size: 11px; letter-spacing: 0.18em; color: var(--c); display: inline-flex; align-items: center; gap: 7px; }
.dash-top .dash-live i { width: 7px; height: 7px; border-radius: 50%; background: var(--c); box-shadow: 0 0 9px var(--c); animation: blink 1.4s ease-in-out infinite; }
@keyframes blink { 0%,100% { opacity: 1; } 50% { opacity: 0.25; } }

.dash-kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); }
.kpi { background: var(--void-2); padding: 20px 18px 18px; }
.kpi-l { font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--dimmer); }
.kpi-n { font-size: clamp(26px, 3vw, 40px); font-weight: 800; letter-spacing: -0.03em; line-height: 1.05; margin-top: 8px; font-variant-numeric: tabular-nums; }
.kpi-trend { font-family: 'JetBrains Mono', monospace; font-size: 11px; margin-top: 8px; color: var(--dim); }
.kpi-trend.up { color: var(--green); }

.dash-chart { padding: 22px 20px 16px; border-top: 1px solid var(--line); }
.dash-chart .ch-head { display: flex; justify-content: space-between; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--dimmer); margin-bottom: 16px; }
.bars { display: flex; align-items: flex-end; gap: 7px; height: 120px; }
.bars .bar {
  flex: 1; border-radius: 4px 4px 0 0; height: 4px;
  background: linear-gradient(180deg, var(--c), color-mix(in oklab, var(--c) 30%, transparent));
  transition: height 0.9s cubic-bezier(.2,.7,.2,1);
}
.dash.live .bars .bar { height: calc(var(--h) * 1%); }
.bars .bar:nth-child(7) { background: linear-gradient(180deg, var(--green), color-mix(in oklab, var(--green) 25%, transparent)); }

.dash-modules { display: flex; flex-wrap: wrap; gap: 8px; padding: 16px 20px 22px; border-top: 1px solid var(--line); }
.dash-modules .mod {
  font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.1em;
  padding: 7px 12px; border-radius: 8px; border: 1px solid var(--line);
  color: var(--dim); opacity: 0.35; transform: translateY(4px);
  transition: opacity 0.4s, transform 0.4s, color 0.4s, border-color 0.4s, background 0.4s;
}
.dash.live .dash-modules .mod { opacity: 1; transform: none; color: var(--ink); border-color: color-mix(in oklab, var(--c) 40%, transparent); background: color-mix(in oklab, var(--c) 8%, transparent); }

/* ============================================================
   02 · AI — multimodal engine console (vision + voice + chat + local LLM)
   ============================================================ */
.x-ai .xhead { max-width: 1000px; margin-bottom: clamp(34px, 5vh, 56px); }
.aicon {
  border: 1px solid var(--line-bright); border-radius: 20px; overflow: hidden;
  background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.012));
  box-shadow: 0 30px 90px rgba(0,0,0,0.5);
}
.aicon-bar { display: flex; align-items: center; gap: 9px; padding: 14px 18px; border-bottom: 1px solid var(--line); background: rgba(0,0,0,0.25); }
.aicon-bar .dash-dot { width: 11px; height: 11px; border-radius: 50%; background: var(--line-bright); }
.aicon-bar .dash-dot:nth-child(1) { background: #ff5f57; }
.aicon-bar .dash-dot:nth-child(2) { background: #febc2e; }
.aicon-bar .dash-dot:nth-child(3) { background: #28c840; }
.aicon-bar .ab-title { margin-left: 8px; font-family: 'JetBrains Mono', monospace; font-size: 12px; letter-spacing: 0.1em; color: var(--dim); }
.aicon-badge { margin-left: auto; display: inline-flex; align-items: center; gap: 7px; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--c); border: 1px solid color-mix(in oklab, var(--c) 45%, transparent); border-radius: 999px; padding: 5px 11px; }
.aicon-badge i { width: 7px; height: 7px; border-radius: 50%; background: var(--c); box-shadow: 0 0 9px var(--c); animation: blink 1.4s ease-in-out infinite; }

.aicon-body { display: grid; grid-template-columns: 1.18fr 0.82fr; gap: 1px; background: var(--line); }
.aicon-side { display: grid; grid-auto-rows: 1fr; gap: 1px; background: var(--line); }
.ai-mod { background: var(--void-2); padding: 18px; display: flex; flex-direction: column; }
.am-h { display: flex; align-items: center; gap: 10px; font-size: 14.5px; font-weight: 700; letter-spacing: -0.01em; margin-bottom: 14px; }
.am-h .am-n { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--c); border: 1px solid color-mix(in oklab, var(--c) 40%, transparent); border-radius: 6px; padding: 2px 7px; }
.am-h small { margin-left: auto; font-family: 'JetBrains Mono', monospace; font-weight: 400; font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--dim); }
.ai-vision .vision-feed { min-height: 300px; flex: 1; }

/* voice */
.wave { display: flex; align-items: flex-end; gap: 3px; height: 56px; margin-bottom: 12px; }
.wave i { flex: 1; min-width: 2px; height: 100%; transform-origin: bottom; transform: scaleY(0.18); border-radius: 2px 2px 0 0;
  background: linear-gradient(180deg, var(--c), color-mix(in oklab, var(--c) 22%, transparent)); }
.aicon.live .wave i { animation: wv var(--d, 900ms) ease-in-out infinite; }
@keyframes wv { 0%, 100% { transform: scaleY(0.18); } 50% { transform: scaleY(var(--p, 0.8)); } }
.am-transcript { font-family: 'JetBrains Mono', monospace; font-size: 12.5px; line-height: 1.55; color: var(--dim); min-height: 2.6em; }
.am-transcript b { color: var(--ink); font-weight: 500; }
.cur { display: inline-block; width: 7px; height: 14px; background: var(--c); vertical-align: -2px; margin-left: 1px; animation: blink 1s steps(1) infinite; }

/* chat */
.chat { display: flex; flex-direction: column; gap: 9px; justify-content: flex-end; flex: 1; }
.bub { max-width: 88%; padding: 9px 13px; border-radius: 13px; font-size: 13px; line-height: 1.45; }
.bub.user { align-self: flex-end; background: color-mix(in oklab, var(--c) 17%, transparent); border: 1px solid color-mix(in oklab, var(--c) 32%, transparent); border-bottom-right-radius: 4px; color: var(--ink); }
.bub.bot { align-self: flex-start; background: rgba(255,255,255,0.05); border: 1px solid var(--line); border-bottom-left-radius: 4px; color: var(--dim); min-height: 1.4em; }
.bub.bot b { color: var(--ink); font-weight: 600; }

/* local LLM / privacy */
.local-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.local-row .lc b { display: block; font-size: clamp(18px, 1.8vw, 22px); font-weight: 800; letter-spacing: -0.02em; line-height: 1; }
.local-row .lc small { display: block; margin-top: 5px; font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--dim); line-height: 1.3; }
.local-note { margin-top: auto; display: flex; align-items: center; gap: 11px; font-size: 12.5px; line-height: 1.35; color: var(--dim);
  padding: 12px 14px; border-radius: 11px; border: 1px dashed color-mix(in oklab, var(--c) 42%, transparent); background: color-mix(in oklab, var(--c) 6%, transparent); }
.local-note .shield { width: 24px; height: 24px; border-radius: 50%; display: grid; place-items: center; color: #05060c; background: var(--c); font-size: 13px; font-weight: 800; flex-shrink: 0; }
.local-note b { color: var(--ink); font-weight: 600; }

.vision-feed {
  position: relative; border-radius: 14px; overflow: hidden; min-height: 360px;
  border: 1px solid var(--line-bright); background: #0a0a14;
  background-image:
    repeating-linear-gradient(45deg, rgba(255,255,255,0.03) 0 2px, transparent 2px 11px);
}
.vision-feed image-slot { position: absolute; inset: 0; width: 100%; height: 100%; }
.vision-feed .feed-cap {
  position: absolute; left: 14px; bottom: 12px; z-index: 4;
  font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--dim);
}
.vision-feed .vgrid {
  position: absolute; inset: 0; z-index: 3; pointer-events: none;
  background-image: linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 40px 40px; opacity: 0.4;
  mask-image: radial-gradient(ellipse 70% 70% at 50% 50%, #000 40%, transparent 100%);
}
.scanline {
  position: absolute; left: 0; right: 0; top: 0; height: 3px; z-index: 5; pointer-events: none;
  background: linear-gradient(90deg, transparent, var(--c), transparent);
  box-shadow: 0 0 22px 3px color-mix(in oklab, var(--c) 70%, transparent);
  opacity: 0;
}
.vision-feed.live .scanline { opacity: 1; animation: scan 3.4s cubic-bezier(.5,0,.5,1) infinite; }
@keyframes scan { 0% { top: -2%; } 50% { top: 100%; } 50.01% { top: -2%; } 100% { top: 100%; } }

.vbox { position: absolute; z-index: 6; border: 1.5px solid var(--c); border-radius: 3px;
  box-shadow: 0 0 0 1px rgba(0,0,0,0.4); opacity: 0; transform: scale(0.92);
  transition: opacity 0.4s ease, transform 0.4s cubic-bezier(.2,.9,.2,1); }
.vision-feed.live .vbox { opacity: 1; transform: none; }
.vision-feed.live .vbox.b2 { transition-delay: 0.5s; }
.vision-feed.live .vbox.b3 { transition-delay: 1s; }
.vbox::before, .vbox::after { content: ''; position: absolute; width: 12px; height: 12px; border: 2px solid var(--c); }
.vbox::before { top: -2px; left: -2px; border-right: 0; border-bottom: 0; }
.vbox::after { bottom: -2px; right: -2px; border-left: 0; border-top: 0; }
.vbox .vlabel {
  position: absolute; top: -11px; left: -2px; transform: translateY(-100%);
  font-family: 'JetBrains Mono', monospace; font-size: 10.5px; letter-spacing: 0.08em;
  background: var(--c); color: #05060c; font-weight: 700; padding: 3px 7px; border-radius: 4px; white-space: nowrap;
}

/* ============================================================
   03 · VERTICALS — dossier grid with roaming spotlight
   ============================================================ */
.x-verticals .xhead { max-width: 940px; margin-bottom: clamp(34px, 5vh, 56px); }
.vgridx { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.vtile {
  position: relative; overflow: hidden; cursor: pointer; text-align: left;
  border: 1px solid var(--line); border-radius: 18px; padding: 24px 22px;
  background: rgba(255,255,255,0.022); min-height: 210px;
  display: flex; flex-direction: column;
  transition: border-color 0.4s, background 0.4s, transform 0.4s, box-shadow 0.4s;
}
.vtile::before { content: ''; position: absolute; inset: 0; opacity: 0; transition: opacity 0.4s; pointer-events: none;
  background: radial-gradient(circle at 50% 0%, color-mix(in oklab, var(--c) 16%, transparent), transparent 72%); }
.vt-top { position: relative; z-index: 2; display: flex; align-items: baseline; gap: 12px; }
.vt-n { font-family: 'JetBrains Mono', monospace; font-size: 14px; color: var(--dimmer); transition: color 0.4s; }
.vt-name { font-size: clamp(22px, 2vw, 30px); font-weight: 800; letter-spacing: -0.025em; }
.vt-line { position: relative; z-index: 2; margin-top: 12px; font-size: 15px; line-height: 1.45; color: var(--dim); }
.vt-mods { position: relative; z-index: 2; display: flex; flex-wrap: wrap; gap: 7px;
  max-height: 0; opacity: 0; overflow: hidden; transition: max-height 0.45s ease, opacity 0.35s, margin-top 0.45s; }
.vt-mods span { font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.06em; color: var(--ink);
  padding: 6px 11px; border-radius: 8px; border: 1px solid color-mix(in oklab, var(--c) 35%, transparent); background: color-mix(in oklab, var(--c) 9%, transparent); }
.vt-watermark { position: absolute; right: -8px; bottom: -34px; z-index: 1; font-family: 'JetBrains Mono', monospace; font-weight: 800;
  font-size: 128px; line-height: 1; color: rgba(255,255,255,0.028); pointer-events: none; transition: color 0.4s; }
.vtile.spot, .vtile:hover {
  border-color: var(--c); background: color-mix(in oklab, var(--c) 7%, transparent);
  transform: translateY(-5px); box-shadow: 0 22px 60px color-mix(in oklab, var(--c) 16%, transparent);
}
.vtile.spot::before, .vtile:hover::before { opacity: 1; }
.vtile.spot .vt-n, .vtile:hover .vt-n { color: var(--c); }
.vtile.spot .vt-watermark, .vtile:hover .vt-watermark { color: color-mix(in oklab, var(--c) 14%, transparent); }
.vtile.spot .vt-mods, .vtile:hover .vt-mods { max-height: 140px; opacity: 1; margin-top: 18px; }

/* ============================================================
   04 · IOT — live device network
   ============================================================ */
.x-iot .xhead { max-width: 900px; margin-bottom: clamp(30px, 4vh, 48px); }
.net {
  position: relative; height: clamp(440px, 56vw, 560px);
  border-radius: 22px; border: 1px solid var(--line-bright); overflow: hidden;
  background:
    radial-gradient(circle at 50% 50%, color-mix(in oklab, var(--c) 9%, transparent) 0%, transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.008));
}
.net .net-bp { /* blueprint grid */
  position: absolute; inset: 0; pointer-events: none;
  background-image: linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 38px 38px; opacity: 0.5;
}
.net svg.net-lines { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 1; }
.net svg .wire { fill: none; stroke: color-mix(in oklab, var(--c) 40%, transparent); stroke-width: 1.5; }
.net svg .pulse { fill: none; stroke: var(--c); stroke-width: 2.5; stroke-linecap: round;
  stroke-dasharray: 4 100; stroke-dashoffset: 104; filter: drop-shadow(0 0 5px var(--c)); }
.net.live svg .pulse { animation: flow 2.6s linear infinite; }
.net.live svg .pulse.p1 { animation-delay: 0s; }
.net.live svg .pulse.p2 { animation-delay: .4s; }
.net.live svg .pulse.p3 { animation-delay: .8s; }
.net.live svg .pulse.p4 { animation-delay: 1.2s; }
.net.live svg .pulse.p5 { animation-delay: 1.6s; }
.net.live svg .pulse.p6 { animation-delay: 2.0s; }
@keyframes flow { from { stroke-dashoffset: 104; } to { stroke-dashoffset: 4; } }

.net-hub {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); z-index: 3;
  width: clamp(120px, 13vw, 158px); height: clamp(120px, 13vw, 158px); border-radius: 50%;
  display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center;
  background: radial-gradient(circle at 50% 35%, color-mix(in oklab, var(--c) 30%, var(--void-2)), var(--void-2));
  border: 1.5px solid var(--c); box-shadow: 0 0 0 6px color-mix(in oklab, var(--c) 10%, transparent), 0 0 50px color-mix(in oklab, var(--c) 35%, transparent);
}
.net-hub b { font-family: 'JetBrains Mono', monospace; font-weight: 800; font-size: clamp(15px, 1.5vw, 19px); letter-spacing: -0.01em; }
.net-hub small { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.24em; color: var(--c); margin-top: 3px; }
.net-hub::after { content: ''; position: absolute; inset: -6px; border-radius: 50%; border: 1px solid color-mix(in oklab, var(--c) 45%, transparent); }
.net.live .net-hub::after { animation: ring 2.6s ease-out infinite; }
@keyframes ring { 0% { transform: scale(1); opacity: 0.8; } 100% { transform: scale(1.7); opacity: 0; } }

.net-node {
  position: absolute; z-index: 3; transform: translate(-50%, -50%);
  display: flex; align-items: center; gap: 10px;
  padding: 11px 15px; border-radius: 12px; white-space: nowrap;
  background: rgba(10,10,20,0.85); border: 1px solid var(--line-bright); backdrop-filter: blur(4px);
  opacity: 0; transition: opacity 0.5s ease, transform 0.5s ease;
}
.net.live .net-node { opacity: 1; }
.net-node .led { width: 9px; height: 9px; border-radius: 50%; background: var(--c); box-shadow: 0 0 9px var(--c); }
.net.live .net-node .led { animation: blink 1.6s ease-in-out infinite; }
.net-node b { font-size: 14.5px; font-weight: 700; letter-spacing: -0.01em; }
.net-node small { display: block; font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.06em; color: var(--dim); margin-top: 1px; }
.net-node:hover { border-color: var(--c); box-shadow: 0 0 24px color-mix(in oklab, var(--c) 28%, transparent); }
/* node positions (around the hub) */
.net-node.n1 { left: 17%;  top: 20%; }
.net-node.n2 { left: 83%;  top: 18%; }
.net-node.n3 { left: 9%;   top: 53%; }
.net-node.n4 { left: 91%;  top: 52%; }
.net-node.n5 { left: 23%;  top: 84%; }
.net-node.n6 { left: 77%;  top: 86%; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px) {
  .exp-jump { grid-template-columns: repeat(2, 1fr); }
  .xgrid { grid-template-columns: 1fr; }
  .xgrid.flip .xtext { order: 1; }
  .xgrid.flip .xdemo { order: 2; }
  .aicon-body { grid-template-columns: 1fr; }
  .vision-feed { min-height: 300px; }
  .vgridx { grid-template-columns: repeat(2, 1fr); }
  .net-node b { font-size: 13px; }
}
@media (max-width: 600px) {
  .exp-jump { grid-template-columns: 1fr; }
  .xkick { flex-direction: column; align-items: flex-start; gap: 12px; }
  .dash-kpis { grid-template-columns: 1fr; }
  .local-row { grid-template-columns: 1fr 1fr; }
  .vgridx { grid-template-columns: 1fr; }
  .vt-watermark { display: none; }
  .net { height: 520px; }
  .net-node { padding: 8px 10px; gap: 7px; }
  .net-node b { font-size: 12.5px; }
  .net-node small { display: none; }
  .net-node.n1 { left: 20%; top: 16%; } .net-node.n2 { left: 80%; top: 15%; }
  .net-node.n3 { left: 14%; top: 50%; } .net-node.n4 { left: 86%; top: 50%; }
  .net-node.n5 { left: 24%; top: 86%; } .net-node.n6 { left: 76%; top: 87%; }
}
@media (prefers-reduced-motion: reduce) {
  .dash.live .bars .bar { transition: none; }
  .vision-feed.live .scanline { animation: none; opacity: 0.5; }
  .aicon.live .wave i { animation: none; transform: scaleY(var(--p, 0.6)); }
  .net.live svg .pulse, .net.live .net-hub::after, .net.live .net-node .led { animation: none; }
}
