/* =========================================================================
   AEGIS // SPANOS — Status / Attack Map page
   Cyan command-center adaptation: red = high-intensity attack, amber = medium,
   cyan = low / normal traffic. Built on the shared Aegis tokens + chrome.
   ========================================================================= */

/* ---- hero shell ------------------------------------------------------ */
.status-hero { position: relative; min-height: auto; border-top: 0;
  padding-top: clamp(96px, 12vh, 150px); padding-bottom: clamp(40px, 6vw, 80px); overflow: hidden; }
.status-hero .cmark { position: absolute; }
.status-hero .cmark.tl { top: 78px; left: var(--gutter); }
.status-hero .cmark.tr { top: 78px; right: var(--gutter); }
.status-hero .cmark.bl { bottom: 24px; left: var(--gutter); }
.status-hero .cmark.br { bottom: 24px; right: var(--gutter); }

.status-grid { display: grid; grid-template-columns: minmax(330px, 430px) 1fr; gap: clamp(28px, 4vw, 60px); align-items: center; width: 100%; }

/* new full-width header + two-column body layout */
.status-head { width: 100%; margin-bottom: clamp(28px, 4vw, 48px); }
.status-head .crumb { margin-bottom: 14px; }
.status-head .status-title { max-width: none; }
.status-head .tagline { max-width: 60ch; }
.status-body { display: grid; grid-template-columns: minmax(320px, 440px) 1fr; gap: clamp(26px, 3vw, 48px); align-items: stretch; width: 100%; }
.status-left { display: flex; flex-direction: column; }
.status-left .legend { margin-top: auto; }
.status-body .attack-map { align-self: stretch; height: 100%; aspect-ratio: auto; min-height: 420px; }
.status-lead .crumb { margin-bottom: 16px; }
.status-lead .status-title, .status-head .status-title { font-family: var(--font-display); font-weight: 700; text-transform: uppercase;
  font-size: clamp(38px, 5vw, 72px); line-height: 1.06; color: var(--cyan-50);
  text-shadow: 0 0 20px rgba(31,199,255,.28); margin: 16px 0 20px; text-wrap: wrap; max-width: 18ch; }
.status-head .kicker { margin-bottom: 4px; }
.status-lead .tagline { max-width: 46ch; }

/* ---- operational status panel ---------------------------------------- */
.op-panel { position: relative; display: grid; grid-template-columns: auto 1fr auto; align-items: center;
  gap: 20px; padding: 20px 22px; margin-top: 30px; }
.op-panel .shield { width: 44px; height: 50px; flex: 0 0 auto; }
.op-panel .shield .s { stroke: var(--signal-ok); stroke-width: 1.4; fill: none; filter: drop-shadow(0 0 6px var(--signal-ok)); }
.op-panel .shield .tick { stroke: var(--signal-ok); stroke-width: 1.8; fill: none; }
.op-panel .b-k { font-family: var(--font-mono); font-size: 9px; letter-spacing: .2em; text-transform: uppercase; color: var(--cyan-500); display: block; margin-bottom: 4px; }
.op-panel .b-v { font-family: var(--font-display); font-weight: 700; font-size: 19px; letter-spacing: .04em; text-transform: uppercase; color: var(--signal-ok); text-shadow: 0 0 10px rgba(92,255,179,.4); }
.op-panel .b-s { font-family: var(--font-display); font-weight: 400; font-size: 12px; color: rgba(213,246,255,.6); display: block; margin-top: 3px; }
.op-panel .up { text-align: right; }
.op-panel .up .b-v { color: var(--cyan-50); text-shadow: 0 0 10px rgba(31,199,255,.3); }
.op-panel .divider { width: 1px; align-self: stretch; background: var(--hairline); }

/* ---- stat cards ------------------------------------------------------ */
.stat-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-top: 14px; }
.scard { position: relative; padding: 16px 16px 18px; }
.scard .glyph { width: 24px; height: 24px; margin-bottom: 14px; }
.scard .glyph .s { stroke: var(--cyan-300); stroke-width: 1.3; fill: none; filter: drop-shadow(0 0 4px var(--cyan-500)); }
.scard .glyph .f { fill: var(--cyan-400); }
.scard .num { font-family: var(--font-display); font-weight: 700; font-size: clamp(19px, 2vw, 24px); letter-spacing: .01em; color: var(--cyan-50); line-height: 1; }
.scard .lbl { font-family: var(--font-mono); font-size: 8.5px; letter-spacing: .16em; text-transform: uppercase; color: var(--cyan-500); margin-top: 8px; }
.scard .sub { font-family: var(--font-display); font-weight: 400; font-size: 12px; color: rgba(213,246,255,.6); margin-top: 4px; }
.scard .sub.alert { color: var(--signal-alert); }

/* ---- legend ---------------------------------------------------------- */
.legend { display: flex; flex-wrap: wrap; gap: 8px 20px; margin-top: 22px; }
.legend .li { display: inline-flex; align-items: center; gap: 9px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .08em; color: rgba(213,246,255,.72); }
.legend .li .ln { width: 22px; height: 0; border-top: 2px solid; }
.legend .li.high .ln { border-color: var(--signal-alert); box-shadow: 0 0 6px var(--signal-alert); }
.legend .li.med .ln { border-color: var(--signal-watch); box-shadow: 0 0 6px var(--signal-watch); }
.legend .li.low .ln { border-color: var(--cyan-400); box-shadow: 0 0 6px var(--cyan-500); }
.legend .li.norm .ln { border-top-style: dashed; border-color: rgba(125,217,255,.5); }

/* =========================================================================
   ATTACK MAP — canvas dotted continents + SVG nodes/arcs/pings
   ========================================================================= */
.attack-map { position: relative; width: 100%; aspect-ratio: 2 / 1;
  border: var(--hairline); background:
    radial-gradient(ellipse 60% 70% at 50% 45%, rgba(10,40,80,.35), transparent 70%),
    rgba(4,12,26,.5);
  box-shadow: inset 0 0 50px rgba(8,60,110,.3), 0 0 40px rgba(8,40,90,.25); overflow: hidden; }
.attack-map .br { position: absolute; width: 16px; height: 16px; border: 1px solid var(--cyan-300); filter: drop-shadow(0 0 4px var(--cyan-500)); z-index: 4; pointer-events: none; }
.attack-map .br.tl { top: -1px; left: -1px; border-right: 0; border-bottom: 0; }
.attack-map .br.tr { top: -1px; right: -1px; border-left: 0; border-bottom: 0; }
.attack-map .br.bl { bottom: -1px; left: -1px; border-right: 0; border-top: 0; }
.attack-map .br.br2 { bottom: -1px; right: -1px; border-left: 0; border-top: 0; }
.attack-map canvas, .attack-map .amap-svg { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }
.attack-map .amap-svg { z-index: 2; }
.attack-map .amap-scanline { position: absolute; inset: 0; z-index: 3; pointer-events: none;
  background: repeating-linear-gradient(0deg, rgba(125,220,255,.035) 0 1px, transparent 1px 3px); mix-blend-mode: overlay; }
.attack-map .amap-tag { position: absolute; z-index: 4; font-family: var(--font-mono); font-size: 9px; letter-spacing: .14em; color: var(--cyan-300); text-shadow: var(--glow-text); pointer-events: none; }
.attack-map .amap-tag.tl { top: 9px; left: 11px; } .attack-map .amap-tag.br { bottom: 9px; right: 11px; color: var(--cyan-500); }

/* svg sub-elements */
.amap-svg .grat { stroke: rgba(125,220,255,.07); stroke-width: .5; fill: none; }
.amap-svg .arc { fill: none; stroke-width: 1; opacity: .55; }
.amap-svg .arc.high { stroke: var(--signal-alert); filter: drop-shadow(0 0 3px var(--signal-alert)); }
.amap-svg .arc.med { stroke: var(--signal-watch); filter: drop-shadow(0 0 3px var(--signal-watch)); }
.amap-svg .arc.low { stroke: var(--cyan-400); filter: drop-shadow(0 0 3px var(--cyan-500)); }
.amap-svg .arc.norm { stroke: rgba(125,217,255,.45); stroke-dasharray: 3 5; opacity: .4; }
.amap-svg .spark { filter: drop-shadow(0 0 4px currentColor); }
.amap-svg .spark.high { fill: #ffd9d2; color: var(--signal-alert); }
.amap-svg .spark.med { fill: #ffe9c2; color: var(--signal-watch); }
.amap-svg .spark.low { fill: var(--cyan-50); color: var(--cyan-400); }
.amap-svg .node-core { filter: drop-shadow(0 0 5px currentColor); }
.amap-svg .node-core.high { fill: #fff; color: var(--signal-alert); }
.amap-svg .node-core.med { fill: #fff; color: var(--signal-watch); }
.amap-svg .node-core.low { fill: var(--cyan-50); color: var(--cyan-300); }
.amap-svg .ping { fill: none; stroke-width: 1.2; }
.amap-svg .ping.high { stroke: var(--signal-alert); }
.amap-svg .ping.med { stroke: var(--signal-watch); }
.amap-svg .ping.low { stroke: var(--cyan-400); }
.amap-svg .node-glow.high { color: var(--signal-alert); }
.amap-svg .node-glow.med { color: var(--signal-watch); }
.amap-svg .node-glow.low { color: var(--cyan-400); }
.amap-svg .node-lbl { font-family: var(--font-mono); font-size: 8px; letter-spacing: .1em; fill: var(--cyan-200); text-shadow: var(--glow-text); }

/* =========================================================================
   LIVE ATTACK FEED
   ========================================================================= */
.feed-section { padding-block: clamp(20px, 4vw, 44px); }
.feed-head { display: flex; align-items: center; gap: 14px; margin-bottom: 18px; flex-wrap: wrap; }
.feed-head .lbl { font-family: var(--font-display); font-weight: 600; font-size: 13px; letter-spacing: .2em; text-transform: uppercase; color: var(--cyan-200); display: inline-flex; align-items: center; gap: 10px; }
.feed-head .lbl .rec { width: 7px; height: 7px; border-radius: 50%; background: var(--signal-alert); box-shadow: 0 0 8px var(--signal-alert); animation: recblink 1.4s ease-in-out infinite; }
@keyframes recblink { 0%,100% { opacity: 1; } 50% { opacity: .35; } }
.feed-head .meta { margin-left: auto; font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; color: var(--cyan-500); }
.feed-list { display: grid; gap: 0; }
.feed-row { display: grid; grid-template-columns: 86px 1fr 150px 120px; gap: 16px; align-items: center;
  padding: 13px 14px; border-bottom: var(--hairline); font-family: var(--font-mono); font-size: 12.5px;
  animation: feedIn .5s var(--ease-hud); }
.feed-row:first-child { border-top: var(--hairline); }
@keyframes feedIn { from { opacity: 0; transform: translateY(-6px); background: rgba(31,199,255,.08); } to { opacity: 1; transform: none; } }
.feed-row .ftime { color: var(--cyan-500); letter-spacing: .06em; }
.feed-row .floc { color: var(--cyan-50); font-family: var(--font-display); font-weight: 600; font-size: 14px; letter-spacing: .02em; display: inline-flex; align-items: center; gap: 9px; }
.feed-row .floc .reg { font-family: var(--font-mono); font-size: 9px; color: var(--cyan-500); border: var(--hairline); padding: 2px 6px; letter-spacing: .1em; }
.feed-row .ftype { letter-spacing: .04em; }
.feed-row .fgbps { text-align: right; letter-spacing: .04em; }
.feed-row.high .ftype, .feed-row.high .fgbps { color: var(--signal-alert); }
.feed-row.med .ftype, .feed-row.med .fgbps { color: var(--signal-watch); }
.feed-row.low .ftype, .feed-row.low .fgbps { color: var(--cyan-300); }
.feed-row .ftype .dot { display: inline-block; width: 5px; height: 5px; border-radius: 50%; background: currentColor; box-shadow: 0 0 6px currentColor; margin-right: 8px; vertical-align: middle; }

/* ---- components status list ------------------------------------------ */
.components { padding-block: clamp(30px, 5vw, 70px); }
.comp-list { display: grid; gap: 10px; }
.comp-row { position: relative; display: grid; grid-template-columns: 1fr auto auto; gap: 18px; align-items: center; padding: 16px 20px; }
.comp-row .cname { font-family: var(--font-display); font-weight: 600; font-size: 16px; letter-spacing: .02em; color: var(--cyan-50); }
.comp-row .cname .cdesc { display: block; font-weight: 400; font-size: 12px; color: rgba(213,246,255,.55); margin-top: 3px; letter-spacing: 0; }
.comp-row .cbars { display: flex; gap: 2px; }
.comp-row .cbars i { width: 4px; height: 18px; background: var(--signal-ok); opacity: .8; box-shadow: 0 0 4px var(--signal-ok); }
.comp-row .cbars i.warn { background: var(--signal-watch); box-shadow: 0 0 4px var(--signal-watch); }
.comp-row .cbars i.down { background: var(--signal-alert); box-shadow: 0 0 4px var(--signal-alert); }
.comp-row .cstat { font-family: var(--font-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--signal-ok); display: inline-flex; align-items: center; gap: 8px; min-width: 130px; justify-content: flex-end; }
.comp-row .cstat .d { width: 6px; height: 6px; border-radius: 50%; background: currentColor; box-shadow: 0 0 6px currentColor; }
.comp-row.watch .cstat { color: var(--signal-watch); }

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 1080px) {
  .stat-cards { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .stat-cards { grid-template-columns: 1fr; }
}
@media (max-width: 900px) {
  .status-grid { grid-template-columns: 1fr; }
  .status-body { grid-template-columns: 1fr; }
  .status-body .attack-map { order: -1; aspect-ratio: 2 / 1; min-height: 0; height: auto; }
  .attack-map { order: -1; }
  .feed-row { grid-template-columns: 70px 1fr auto; }
  .feed-row .fgbps { grid-column: 2 / -1; text-align: left; }
}
@media (max-width: 560px) {
  .op-panel { grid-template-columns: auto 1fr; }
  .op-panel .up { grid-column: 1 / -1; text-align: left; border-top: var(--hairline); padding-top: 12px; }
  .op-panel .divider { display: none; }
  .feed-row { grid-template-columns: 64px 1fr; }
  .feed-row .ftype, .feed-row .fgbps { grid-column: 2; text-align: left; }
  .comp-row { grid-template-columns: 1fr auto; }
  .comp-row .cbars { display: none; }
}
