/* Interactive Athena platform architecture diagram.
   Structure (per docs/design/Athena_Naming_and_Architecture.md §2): Athena is the
   container; Functions (7) + Foundations (6) are the two sections inside it; humans
   on the loop above; service lines + existing stack below. Hover/focus a node →
   glass tooltip + the dependency subgraph lights up (connectors flow); click → its
   page. Motion is CSS-driven (GPU-friendly), reduced-motion honored, keyboard-parity. */

.ax{max-width:1140px;margin:34px auto 0;font-family:'Inter',sans-serif;position:relative}

/* flow bands + labels */
.ax-humans{display:flex;align-items:center;justify-content:center;gap:10px;text-align:center;padding:13px 20px;border:1px solid rgba(62,224,240,.4);border-radius:13px;background:linear-gradient(180deg,rgba(62,224,240,.08),rgba(62,224,240,.02));font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#3EE0F0;box-shadow:inset 0 0 34px -12px rgba(62,224,240,.5)}
.ax-flow{display:flex;align-items:center;justify-content:center;gap:9px;color:#5e6b87;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;padding:10px 0}
.ax-flow .ar{color:#3EE0F0;font-size:12px;line-height:1}
.ax-flow.vio .ar{color:#9d8fe0}

/* Athena platform container */
.ax-platform{position:relative;border:1.5px solid rgba(62,224,240,.32);border-radius:24px;background:linear-gradient(180deg,rgba(10,16,28,.82),rgba(8,12,22,.9));overflow:hidden;padding:22px 22px 26px;box-shadow:inset 0 0 0 1px rgba(62,224,240,.05),0 50px 130px -60px rgba(62,224,240,.45)}
.ax-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;opacity:.2;pointer-events:none}
.ax-veil{position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(130% 80% at 50% 0%,rgba(62,224,240,.07),transparent 58%),linear-gradient(180deg,rgba(8,12,22,.55),rgba(8,12,22,.8))}
.ax-phead{position:relative;z-index:3;display:flex;align-items:baseline;gap:13px;flex-wrap:wrap;margin-bottom:16px}
.ax-phead .k{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#3EE0F0}
.ax-phead b{font-family:'Saira',sans-serif;font-size:clamp(19px,2.3vw,25px);font-weight:800;letter-spacing:-.01em;color:#fff}
.ax-phead .sub{font-size:12.5px;color:#8aa0c0}

/* connector overlay (drawn by JS, sits behind nodes) */
.ax-wires{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none;overflow:visible}
.ax-wire{fill:none;stroke:rgba(70,90,124,.38);stroke-width:1.5;transition:stroke .25s,opacity .25s,stroke-width .25s}
.ax.dim .ax-wire:not(.on){opacity:.07}
.ax-wire.on{stroke:#3EE0F0;stroke-width:2;stroke-dasharray:6 10;filter:drop-shadow(0 0 4px rgba(62,224,240,.6))}
.ax-wire.on.vio{stroke:#9d8fe0;filter:drop-shadow(0 0 4px rgba(122,104,214,.6))}
.ax-wire.sup{stroke-dasharray:2 7}

/* sections + rows */
.ax-sec{position:relative;z-index:2}
.ax-seclabel{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;margin:0 0 11px;color:#6b7c9c}
.ax-seclabel.cy{color:#3EE0F0}.ax-seclabel.vi{color:#9d8fe0}
.ax-seclabel em{font-style:normal;color:#6b7c9c;letter-spacing:.02em;text-transform:none;font-size:11.5px;margin-left:6px}
.ax-row{display:grid;gap:10px}
.ax-fns{grid-template-columns:repeat(7,1fr)}
.ax-fos{grid-template-columns:repeat(6,1fr)}
.ax-runon{position:relative;z-index:2;text-align:center;font-family:'JetBrains Mono',monospace;font-size:9.5px;letter-spacing:.26em;text-transform:uppercase;color:#9d8fe0;padding:15px 0 13px}

/* node */
.ax-node{position:relative;display:flex;flex-direction:column;justify-content:center;gap:3px;min-height:60px;padding:10px 12px;border:1px solid rgba(40,55,85,.9);border-radius:13px;background:linear-gradient(180deg,rgba(15,23,40,.72),rgba(10,16,28,.82));text-decoration:none;cursor:pointer;outline:none;transition:border-color .22s,background .22s,box-shadow .22s,opacity .22s,transform .22s,filter .22s}
.ax-node .nm{font-size:12.5px;font-weight:600;letter-spacing:-.01em;color:#dbe6f5;line-height:1.16}
.ax-node .tg{font-family:'JetBrains Mono',monospace;font-size:8.5px;letter-spacing:.05em;text-transform:uppercase;color:#6b7c9c}
.ax-node .pin{position:absolute;left:50%;width:8px;height:8px;border-radius:50%;background:#15233d;border:1.5px solid rgba(48,64,96,.95);transform:translateX(-50%);transition:background .22s,border-color .22s,box-shadow .22s;z-index:1}
.ax-fns .ax-node .pin{bottom:-4px}
.ax-fos .ax-node .pin{top:-4px}
.ax-node .bolt{position:absolute;top:9px;right:10px;width:13px;height:13px;color:#3EE0F0;opacity:.85}

/* hover / focus / lit / source / dim */
.ax-node.fn:hover,.ax-node.fn:focus-visible,.ax-node.fn.lit{border-color:#3EE0F0;background:rgba(62,224,240,.08);box-shadow:0 0 0 1px rgba(62,224,240,.28),0 16px 36px -16px rgba(62,224,240,.6)}
.ax-node.fo:hover,.ax-node.fo:focus-visible,.ax-node.fo.lit{border-color:#7A68D6;background:rgba(122,104,214,.1);box-shadow:0 0 0 1px rgba(122,104,214,.32),0 16px 36px -16px rgba(122,104,214,.6)}
.ax-node.src{transform:translateY(-2px)}
.ax-node.fn:hover .pin,.ax-node.fn.lit .pin{background:#3EE0F0;border-color:#3EE0F0;box-shadow:0 0 9px rgba(62,224,240,.85)}
.ax-node.fo:hover .pin,.ax-node.fo.lit .pin{background:#7A68D6;border-color:#9d8fe0;box-shadow:0 0 9px rgba(122,104,214,.85)}
.ax-node.eng .nm{color:#3EE0F0}
.ax-node.eng{border-color:rgba(62,224,240,.4)}
.ax.dim .ax-node:not(.lit):not(.src){opacity:.32;filter:saturate(.45)}

/* service lines */
.ax-buy{text-align:center;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:#5e6b87;padding:14px 0 12px}
.ax-services{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ax-sv{position:relative;display:block;padding:18px 20px;border:1px solid rgba(40,55,85,.9);border-radius:16px;background:linear-gradient(180deg,rgba(15,23,40,.7),rgba(10,16,28,.82));text-decoration:none;transition:border-color .22s,box-shadow .22s,transform .22s,opacity .22s}
.ax-sv .nm{display:block;font-family:'Saira',sans-serif;font-size:18px;font-weight:800;letter-spacing:-.01em;line-height:1.1}
.ax-sv .ds{display:block;font-size:13px;color:#cbd6e8;margin-top:4px}
.ax-sv .bd{display:block;font-family:'JetBrains Mono',monospace;font-size:10.5px;color:#7e8fb3;margin-top:9px;letter-spacing:.02em;line-height:1.4}
.ax-sv.vigil .nm{color:#3EE0F0}
.ax-sv.citadel .nm{color:#9d8fe0}
.ax-sv.vigil:hover,.ax-sv.vigil:focus-visible,.ax-sv.vigil.lit{border-color:#3EE0F0;box-shadow:0 0 0 1px rgba(62,224,240,.3),0 18px 40px -18px rgba(62,224,240,.6);transform:translateY(-2px)}
.ax-sv.citadel:hover,.ax-sv.citadel:focus-visible,.ax-sv.citadel.lit{border-color:#7A68D6;box-shadow:0 0 0 1px rgba(122,104,214,.34),0 18px 40px -18px rgba(122,104,214,.6);transform:translateY(-2px)}
.ax-stack{text-align:center;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.06em;color:#5e6b87;margin-top:16px}
.ax-stack b{color:#8aa0c0;font-weight:600}

/* glass tooltip */
.ax-tip{position:absolute;z-index:40;max-width:296px;padding:13px 15px;border:1px solid rgba(62,224,240,.3);border-radius:13px;background:rgba(8,12,20,.92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 24px 64px -22px rgba(0,0,0,.85);pointer-events:none;opacity:0;transform:translateY(5px);transition:opacity .16s ease,transform .16s ease}
.ax-tip.vio{border-color:rgba(122,104,214,.35)}
.ax-tip.show{opacity:1;transform:none}
.ax-tip .tt{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:#3EE0F0;margin-bottom:5px}
.ax-tip.vio .tt{color:#9d8fe0}
.ax-tip h5{margin:0 0 6px;font-family:'Saira',sans-serif;font-size:15px;font-weight:700;color:#fff}
.ax-tip p{margin:0;font-size:12.5px;line-height:1.5;color:#a8b8d4}
.ax-tip .go{margin-top:9px;font-size:11px;color:#3EE0F0;font-weight:600}
.ax-tip.vio .go{color:#9d8fe0}

/* controls */
.ax-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-top:18px}
.ax-trace{display:inline-flex;align-items:center;gap:9px;font-family:'Inter',sans-serif;font-size:13px;font-weight:600;color:#05080d;background:#3EE0F0;border:0;border-radius:999px;padding:10px 18px;cursor:pointer;box-shadow:0 0 0 1px rgba(62,224,240,.4),0 12px 30px -10px rgba(62,224,240,.6);transition:transform .15s,box-shadow .15s}
.ax-trace:hover{transform:translateY(-1px)}
.ax-trace[disabled]{opacity:.6;cursor:default;transform:none}
.ax-hint{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.05em;color:#5e6b87}

/* reveal-on-scroll — content is VISIBLE BY DEFAULT; the .in class (added when the
   diagram scrolls into view) just plays a subtle entrance. It never gates
   visibility, so the diagram still shows if the observer never fires. */
@media (prefers-reduced-motion: no-preference){
  .ax.in [data-axr]{animation:axrise .6s ease both;animation-delay:var(--d,0s)}
  @keyframes axrise{from{opacity:0;transform:translateY(10px)}}
  .ax-wire.on{animation:axflow 1s linear infinite}
  @keyframes axflow{to{stroke-dashoffset:-16}}
  .ax-node.eng .bolt{animation:axpulse 2.6s ease-in-out infinite}
  @keyframes axpulse{50%{opacity:.4}}
}

/* responsive */
@media(max-width:880px){
  .ax-fns{grid-template-columns:repeat(4,1fr)}
  .ax-fos{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:620px){
  .ax-fns,.ax-fos{grid-template-columns:repeat(2,1fr)}
  .ax-wires{display:none}
  .ax-services{grid-template-columns:1fr}
  .ax-humans{font-size:10.5px;letter-spacing:.1em}
}
