/*
  ┌────────────────────────────────────────────────────────┐
  │  dhlmnn · 2026 redesign                                │
  │  Entra-cyan + Entra-blue · Aurora orbs · Glass pill    │
  │  Inspired by link.dhlmnn.de adminportals palette       │
  └────────────────────────────────────────────────────────┘
*/

/* ── Tokens ──────────────────────────────────────────────── */
:root {
  --bg:             #07090d;
  --surface:        rgba(20, 22, 28, 0.62);
  --surface-hover:  rgba(36, 38, 44, 0.92);
  --surface-strong: rgba(26, 28, 34, 0.85);
  --border:         rgba(255, 255, 255, 0.09);
  --border-strong:  rgba(255, 255, 255, 0.18);
  --border-hover:   rgba(255, 255, 255, 0.30);

  --text:        #f1f3f6;
  --text-muted:  #c4c8d0;
  --text-subtle: #8a8f99;
  --text-faint:  rgba(255,255,255,0.32);

  /* Entra ID palette (kept as reference for status colors) */
  --entra-cyan: #50E6FF;
  --entra-blue: #0078D4;
  --entra-deep: #002050;

  /* Default: monochrome white (adminportals.cloud picker look) */
  --accent:      #ffffff;
  --accent-2:    #b8c0cc;
  --accent-glow: rgba(255, 255, 255, 0.20);
  --accent-grad: linear-gradient(135deg, #ffffff 0%, #b8c0cc 55%, #6b7280 100%);

  /* Status colors (kept) */
  --cyan:    #22d3ee;
  --green:   #4ade80;
  --yellow:  #fbbf24;
  --red:     #f87171;
  --orange:  #fb923c;

  --radius-sm: 10px;
  --radius:    14px;
  --radius-lg: 20px;
  --shadow-card: 0 1px 0 rgba(255,255,255,0.04) inset, 0 8px 30px -10px rgba(0,0,0,0.6);

  --navbar-h: 50px;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ── Reset ───────────────────────────────────────────────── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html, body { height: 100%; }
html {
  scroll-behavior: smooth;
  background: var(--bg);
}
body {
  font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background: transparent;
  color: var(--text-muted);
  height: 100%; display: flex; flex-direction: column;
  overflow: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: 'cv11','ss01','ss02';
  line-height: 1.5;
  transition: background 0.4s var(--ease);
}
::selection { background: var(--accent-glow); color: #fff; }

/* ── Background (orbs + grid + noise) ────────────────────── */
/* Legacy nodes left in HTML — render the new layered bg via body::before/after.
   Existing .aurora is repurposed to host the orbs. */
.aurora { position: fixed; inset: 0; z-index: 0; pointer-events: none; overflow: hidden; }
.aurora::before,
.aurora::after { content: ''; position: absolute; border-radius: 50%; filter: blur(80px); will-change: transform; }
/* Orb 1 — top-left, color follows --orb-1 */
.aurora::before {
  width: 620px; height: 620px; left: -120px; top: -160px;
  background: radial-gradient(circle, var(--orb-1, #ffffff) 0%, transparent 70%);
  opacity: .28;
  filter: blur(80px) brightness(0.85);
  animation: orbDrift1 28s ease-in-out infinite alternate;
}
/* Orb 2 — right, color follows --orb-2 */
.aurora::after {
  width: 560px; height: 560px; right: -140px; top: 30%;
  background: radial-gradient(circle, var(--orb-2, #b8c0cc) 0%, transparent 70%);
  opacity: .22;
  filter: blur(80px) brightness(0.7);
  animation: orbDrift2 34s ease-in-out infinite alternate;
}
/* Base radial gradient + subtle dot-grid + film noise behind everything */
body::before {
  content: '';
  position: fixed; inset: 0; z-index: -2; pointer-events: none;
  background:
    radial-gradient(120% 80% at 50% 0%, #14161a 0%, #0a0c10 55%, #020305 100%);
}
body::after {
  content: '';
  position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background-image:
    radial-gradient(rgba(255,255,255,0.06) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 35%, #000 0%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 35%, #000 0%, transparent 80%);
  opacity: .45;
}
@keyframes orbDrift1 {
  0%   { transform: translate3d(0,0,0)         scale(1);    }
  50%  { transform: translate3d(8vw, 4vh, 0)   scale(1.08); }
  100% { transform: translate3d(-4vw, 8vh, 0)  scale(0.96); }
}
@keyframes orbDrift2 {
  0%   { transform: translate3d(0,0,0)         scale(1);    }
  50%  { transform: translate3d(-6vw, -3vh, 0) scale(1.06); }
  100% { transform: translate3d(4vw, 6vh, 0)   scale(0.94); }
}

/* ── Cursor glow (mouse follower) ────────────────────────── */
.cursor-glow {
  position: fixed; width: 640px; height: 640px; border-radius: 50%;
  background: radial-gradient(circle,
    rgba(255,255,255,0.08) 0%,
    rgba(255,255,255,0.03) 35%,
    transparent 65%);
  pointer-events: none; z-index: 3; left: 0; top: 0;
  transform: translate(var(--cx,-9999px), var(--cy,-9999px));
  will-change: transform; mix-blend-mode: screen;
}

/* Hide legacy bg layers */
.forest-bg, .forest-overlay, .mist-layer,
.circuit-bg, .grid-overlay { display: none !important; }

/* ── Navbar (full-width topbar) ─────────────────────────── */
.navbar {
  flex-shrink: 0; position: sticky; top: 0; z-index: 100;
  /* Glassmorphism: semi-transparent + strong blur */
  background: rgba(10, 13, 18, 0.55);
  backdrop-filter: blur(32px) saturate(180%) brightness(1.05);
  -webkit-backdrop-filter: blur(32px) saturate(180%) brightness(1.05);
  /* Shimmer line only on desktop, not mobile (would create double-bar with links border) */
  box-shadow: 0 6px 32px -6px rgba(0,0,0,0.6);
}
@media (min-width: 769px) {
  .navbar { box-shadow: 0 1px 0 rgba(255,255,255,0.10), 0 -1px 0 rgba(255,255,255,0.04) inset, 0 6px 32px -6px rgba(0,0,0,0.6); }
}
}
/* Soft gradient fade below navbar into content */
.navbar::after {
  content: '';
  position: absolute; bottom: -40px; left: 0; right: 0;
  height: 40px; pointer-events: none;
  background: linear-gradient(to bottom, rgba(10,13,18,0.38) 0%, transparent 100%);
  z-index: 99;
}
.navbar-inner {
  max-width: 1200px; margin: 0 auto;
  display: flex; align-items: center; flex-wrap: wrap;
  padding: 0 32px;
  gap: 0;
}

/* ── Logo with [brackets] ────────────────────────────────── */
.logo {
  display: inline-flex; align-items: center; gap: 1px;
  text-decoration: none; cursor: pointer; user-select: none;
  padding: 7px 12px; border-radius: 8px;
  font-family: ui-monospace, 'JetBrains Mono', 'Cascadia Code', Menlo, Consolas, monospace;
  font-size: 0.92rem; font-weight: 500; letter-spacing: 0.02em;
  line-height: 1; white-space: nowrap; height: 60px;
  color: var(--text);
  transition: background 0.2s var(--ease);
}
.logo:hover { background: rgba(255,255,255,0.05); }
/* Brackets via ::before / ::after */
.logo::before, .logo::after {
  color: var(--text-subtle);
  font: 500 1em/1 'JetBrains Mono', ui-monospace, monospace;
  display: inline-block;
  transition: transform 0.3s var(--ease);
}
.logo::before { content: '['; margin-right: 5px; }
.logo::after  { content: ']'; margin-left: 5px; }
.logo .char {
  display: inline-block;
  color: var(--text);
  opacity: 0;
  animation: charFadeIn .45s var(--ease) forwards;
}
.logo .char:nth-child(1) { animation-delay: .08s; }
.logo .char:nth-child(2) { animation-delay: .13s; }
.logo .char:nth-child(3) { animation-delay: .18s; }
.logo .char:nth-child(4) { animation-delay: .23s; }
.logo .char:nth-child(5) { animation-delay: .28s; }
.logo .char:nth-child(6) { animation-delay: .33s; }
@keyframes charFadeIn { to { opacity: 1; } }
.logo-cursor {
  display: inline-block; width: 5px; height: 0.85em; margin-left: 3px;
  background: var(--text-subtle);
  vertical-align: -0.10em;
  animation: blink 1.2s steps(2) infinite;
}
@keyframes blink { 50% { opacity: 0; } }

/* ── Navbar right side ──────────────────────────────────── */
.navbar-right { display: flex; align-items: center; gap: 8px; flex-shrink: 0; margin-left: auto; height: 60px; }

/* ── Navbar links — full-width row 2 ─────────────────────── */
.navbar-links {
  flex: 0 0 100%; order: 10;
  display: flex; align-items: center;
  border-top: 1px solid rgba(255,255,255,0.06);
  justify-content: center; gap: 2px;
  padding: 4px 0;
}
.navbar-links a {
  font-family: ui-monospace, 'JetBrains Mono', 'Cascadia Code', Menlo, Consolas, monospace;
  font-size: 0.92rem; font-weight: 500; letter-spacing: 0.02em;
  padding: 8px 14px; border-radius: 8px; line-height: 1;
  border: 1px solid transparent;
  color: var(--text-subtle); background: transparent;
  text-decoration: none;
  transition: all 0.2s var(--ease);
}
.navbar-links a:hover {
  color: var(--text); background: rgba(255,255,255,0.06); border-color: var(--border);
}
.navbar-links a.active {
  color: var(--text);
  font-weight: 500;
  background: transparent;
  border-color: transparent;
  text-decoration: none;
}

/* ── Nav status dot ──────────────────────────────────────── */
.nav-status-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 6px rgba(74, 222, 128, 0.5);
  flex-shrink: 0;
  transition: background 0.3s, box-shadow 0.3s;
}
.nav-status-dot.bad {
  background: var(--red);
  box-shadow: 0 0 6px rgba(248, 113, 113, 0.5);
  animation: qsPulse 1.4s ease-in-out infinite;
}
.nav-status-dot.warn {
  background: var(--yellow);
  box-shadow: 0 0 6px rgba(251, 191, 36, 0.5);
}

.navbar-clock {
  display: flex; flex-direction: column; align-items: flex-end;
  font-family: 'JetBrains Mono', monospace;
  color: var(--text-subtle); padding: 2px 10px 2px 0;
  line-height: 1.2;
}
.navbar-clock .clock-time { font-size: .80rem; color: var(--text-muted); letter-spacing: .04em; }
.navbar-clock .clock-date { font-size: .56rem; letter-spacing: .12em; text-transform: uppercase; opacity: .6; }

/* ── Page / container ────────────────────────────────────── */
.page {
  flex: 1; overflow-y: auto; overflow-x: hidden; min-height: 0;
  scrollbar-width: none;
  position: relative; z-index: 10;
}
.page::-webkit-scrollbar { display: none; }
.container {
  max-width: 1100px; margin: 0 auto;
  padding: 0 24px 60px;
  min-height: 100%;
  display: flex; flex-direction: column;
}
main { padding: 32px 0; display: flex; flex-direction: column; gap: 32px; flex: 1; }

/* ── Hero clock ──────────────────────────────────────────── */
.clock-hero {
  text-align: center;
  padding: 48px 24px 32px;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
}
.clock-hero .clock-time {
  font-family: 'JetBrains Mono', monospace;
  font-size: clamp(2.6rem, 8vw, 4.2rem);
  font-weight: 600; letter-spacing: -0.01em; line-height: 1;
  color: var(--text);
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 100%, white 20%) 0%, var(--accent) 50%, color-mix(in srgb, var(--accent) 70%, white 0%) 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 0 24px color-mix(in srgb, var(--accent) 22%, transparent);
}
.clock-hero .clock-date {
  font-family: 'JetBrains Mono', monospace;
  font-size: .74rem; letter-spacing: .12em; text-transform: lowercase;
  color: var(--text-subtle);
}
.clock-time { font-family: 'JetBrains Mono', monospace; }
.clock-date { font-family: 'JetBrains Mono', monospace; color: var(--text-subtle); }
.clock-widget { text-align: center; margin-bottom: 24px; }

/* ── Weather strip ───────────────────────────────────────── */
.weather-strip {
  font-family: 'JetBrains Mono', monospace; font-size: .76rem;
  color: var(--text-muted); display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 16px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 999px;
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  margin-top: 6px;
}
.wsep { color: var(--text-subtle); opacity: .4; }
.weather-strip .wdot { width: 1px; height: 10px; background: var(--border); opacity: .6; margin: 0 4px; }
#weatherIcon svg, #weatherRain svg { width: 14px; height: 14px; vertical-align: middle; margin-right: 2px; }

/* ── Section labels (eyebrow) ────────────────────────────── */
.section-label {
  font-size: 0.78rem; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: 0.18em; font-weight: 600;
  display: inline-flex; align-items: center; gap: 0.65rem;
  margin-bottom: 8px;
}
.section-label::before {
  content: ''; width: 18px; height: 1px;
  background: linear-gradient(90deg, var(--accent), transparent);
}
.section-label::after { display: none; }

/* ── Quick links / bento grid ────────────────────────────── */
.quick-links, #quickLinks { display: flex; flex-direction: column; gap: 36px; }
.link-section { display: flex; flex-direction: column; gap: 14px; }
.bento-link-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 12px;
}
.bento-link-card {
  position: relative; overflow: hidden;
  display: flex; align-items: center; gap: 16px;
  padding: 22px 22px;
  min-height: 96px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius);
  text-decoration: none;
  backdrop-filter: blur(18px) saturate(160%); -webkit-backdrop-filter: blur(18px) saturate(160%);
  box-shadow: var(--shadow-card);
  transition: all 0.25s var(--ease);
  will-change: transform;
}
.bento-link-card::before {
  content: ''; position: absolute; inset: 0; border-radius: var(--radius);
  padding: 1px; background: var(--accent-grad);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity: 0; transition: opacity 0.3s var(--ease); pointer-events: none;
}
.bento-link-card:hover {
  background: var(--surface-hover);
  transform: translateY(-3px);
  box-shadow: 0 18px 44px -16px rgba(255,255,255,0.18), 0 1px 0 rgba(255,255,255,0.10) inset;
}
.bento-link-card:hover::before { opacity: 0.7; }
.bento-icon {
  width: 40px; height: 40px; object-fit: contain; flex-shrink: 0;
  opacity: 0.95;
  filter: drop-shadow(0 6px 14px rgba(0,0,0,0.45));
  transition: transform 0.3s var(--ease);
}
.bento-icon.invert { filter: invert(1) brightness(.9) drop-shadow(0 6px 14px rgba(0,0,0,0.45)); }
.bento-link-card:hover .bento-icon { transform: scale(1.10); }
.bento-name {
  font-size: 1.0rem; font-weight: 500; color: var(--text-muted);
  letter-spacing: -0.005em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  transition: color 0.2s;
}
.bento-link-card:hover .bento-name { color: var(--text); }

/* Hide legacy / unused */
.link-icon-wrap { display: none; }
.link-card, .link-grid { display: none; }
.hero-title, .hero-cursor { display: none; }

/* ── Service bento (monitoring) ──────────────────────────── */
.svc-bento-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 8px;
}
.svc-bento-card {
  display: flex; flex-direction: column; gap: 6px;
  padding: 12px 14px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  backdrop-filter: blur(18px) saturate(160%); -webkit-backdrop-filter: blur(18px) saturate(160%);
  transition: all 0.2s var(--ease);
}
.svc-bento-card:hover { border-color: var(--border-strong); }
.svc-bento-card.has-incident { border-color: rgba(248,113,113,.35); background: rgba(248,113,113,.05); }
.svc-bento-card.has-advisory { border-color: rgba(251,191,36,.30);  background: rgba(251,191,36,.04); }
.svc-dot-row { display: flex; align-items: center; gap: 7px; }
.svc-sticker { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.svc-sticker.healthy  { background: var(--green); box-shadow: 0 0 6px rgba(74,222,128,.4); }
.svc-sticker.advisory { background: var(--yellow); box-shadow: 0 0 6px rgba(251,191,36,.4); }
.svc-sticker.incident { background: var(--red); box-shadow: 0 0 8px rgba(248,113,113,.6); animation: pulse 2s ease-in-out infinite; }
.svc-title { font-family: 'Inter', sans-serif; font-size: .78rem; font-weight: 500; color: var(--text-muted); }
.svc-status-text { font-family: 'JetBrains Mono', monospace; font-size: .60rem; letter-spacing: .06em; text-transform: uppercase; opacity: .6; }
.svc-status-text.incident { color: var(--red); opacity: .9; }
.svc-status-text.advisory { color: var(--yellow); opacity: .9; }
.svc-status-text.healthy  { color: var(--green); opacity: .55; }

/* ── All-OK banner ───────────────────────────────────────── */
.all-ok-banner {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 16px; border-radius: var(--radius-sm);
  background: linear-gradient(135deg, rgba(74,222,128,0.10), rgba(74,222,128,0.02));
  border: 1px solid rgba(74,222,128,.25);
  color: var(--green);
  font-family: 'JetBrains Mono', monospace; font-size: .76rem;
}
.all-ok-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); box-shadow: 0 0 6px rgba(74,222,128,.5); flex-shrink: 0; }

/* ── Uptime ──────────────────────────────────────────────── */
.uptime-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 8px;
}
.uptime-groups { display: flex; flex-direction: column; gap: 18px; }
.uptime-group-label {
  font-family: 'JetBrains Mono', monospace; font-size: .60rem;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--text-subtle);
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 8px;
}
.uptime-group-label::after { content: ''; flex: 1; height: 1px; background: var(--border); }
.uptime-item {
  display: flex; gap: 10px; align-items: center;
  padding: 10px 12px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
  transition: all .2s var(--ease);
}
.uptime-item:hover { border-color: var(--border-strong); }
.uptime-item.down { border-color: rgba(248,113,113,.30); background: rgba(248,113,113,.05); }
.uptime-body { display: flex; flex-direction: column; gap: 5px; flex: 1; min-width: 0; }
.uptime-top { display: flex; align-items: center; justify-content: space-between; gap: 6px; }
.uptime-name { font-family: 'Inter', sans-serif; font-size: .80rem; font-weight: 500; color: var(--text-muted); }
.uptime-ping { font-family: 'JetBrains Mono', monospace; font-size: .60rem; color: var(--text-subtle); }
.uptime-bars { display: flex; gap: 2px; align-items: flex-end; height: 16px; }
.uptime-bar { width: 4px; border-radius: 2px; flex-shrink: 0; }
.uptime-bar.up       { background: rgba(74,222,128,.65); }
.uptime-bar.down-bar { background: rgba(248,113,113,.75); }
.uptime-bar.unknown  { background: rgba(255,255,255,.10); }

/* ── History ─────────────────────────────────────────────── */
.history-list { display: flex; flex-direction: column; gap: 6px; }
.history-item {
  padding: 12px 14px; background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-sm); display: flex; flex-direction: column; gap: 5px;
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
}
.history-svc { font-family: 'JetBrains Mono', monospace; font-size: .60rem; letter-spacing: .06em; text-transform: uppercase; color: var(--text-subtle); }
.history-title { font-family: 'Inter', sans-serif; font-size: .82rem; font-weight: 500; color: var(--text-muted); }
.history-meta { display: flex; gap: 14px; flex-wrap: wrap; font-family: 'JetBrains Mono', monospace; font-size: .62rem; color: var(--text-subtle); opacity: .7; }
.history-resolved { color: var(--green); }

/* ── Card primitive ──────────────────────────────────────── */
.card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); display: flex; flex-direction: column;
  backdrop-filter: blur(22px) saturate(160%); -webkit-backdrop-filter: blur(22px) saturate(160%);
  box-shadow: var(--shadow-card);
}
.card-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.card-title {
  font-family: 'JetBrains Mono', monospace; font-size: .65rem;
  text-transform: uppercase; letter-spacing: .12em; color: var(--text-subtle);
  display: flex; align-items: center; gap: 8px;
}
.card-title .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 8px var(--accent-glow); }
.card-body { padding: 18px; display: flex; flex-direction: column; gap: 10px; }
.card-body.scrollable { max-height: 420px; overflow-y: auto; scrollbar-width: none; }
.card-body.scrollable::-webkit-scrollbar { display: none; }

/* ── Stat pills ──────────────────────────────────────────── */
.stats-row { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 4px; }
.stat-pill {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 12px 20px; border-radius: 999px;
  background: var(--surface); border: 1px solid var(--border);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  font-family: 'JetBrains Mono', monospace; font-size: .82rem; letter-spacing: .04em;
  color: var(--text-muted);
}
.stat-pill .stat-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.stat-pill.incident   { border-color: rgba(248,113,113,.30); }
.stat-pill.incident .stat-dot { background: var(--red); box-shadow: 0 0 6px rgba(248,113,113,.6); animation: pulse 2.4s ease-in-out infinite; }
.stat-pill.incident .stat-num { color: var(--red); }
.stat-pill.advisory   { border-color: rgba(251,191,36,.28); }
.stat-pill.advisory .stat-dot { background: var(--yellow); box-shadow: 0 0 6px rgba(251,191,36,.5); }
.stat-pill.advisory .stat-num { color: var(--yellow); }
.stat-pill.healthy .stat-dot  { background: var(--green); box-shadow: 0 0 6px rgba(74,222,128,.5); }
.stat-pill.healthy .stat-num  { color: var(--green); }
.stat-num { font-weight: 700; }
.stat-lbl { color: var(--text-subtle); }

/* ── Issues / detail ─────────────────────────────────────── */
.issues-stack { display: flex; flex-direction: column; }
.issues-stack .issue-detail { padding: 16px; border-bottom: 1px solid var(--border); }
.issues-stack .issue-detail:last-child { border-bottom: none; }
.issue-detail  { display: flex; flex-direction: column; gap: 10px; }
.issue-badge   {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: 'JetBrains Mono', monospace; font-size: .62rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .08em;
  padding: 3px 10px; border-radius: 999px;
}
.issue-badge.incident { background: rgba(248,113,113,.10); color: var(--red);    border: 1px solid rgba(248,113,113,.30); }
.issue-badge.advisory { background: rgba(251,191,36,.10); color: var(--yellow); border: 1px solid rgba(251,191,36,.28); }
.issue-service     { font-family: 'JetBrains Mono', monospace; font-size: .68rem; color: var(--accent); text-transform: uppercase; letter-spacing: .06em; }
.issue-title       { font-family: 'Inter', sans-serif; font-size: .92rem; font-weight: 600; color: var(--text); line-height: 1.4; letter-spacing: -0.01em; }
.issue-description { font-family: 'Inter', sans-serif; font-size: .82rem; color: var(--text-muted); line-height: 1.65; }
.issue-meta        { display: flex; flex-wrap: wrap; gap: 16px; padding-top: 12px; border-top: 1px solid var(--border); flex-shrink: 0; }
.meta-item   { display: flex; flex-direction: column; gap: 2px; }
.meta-label  { font-family: 'JetBrains Mono', monospace; font-size: .55rem; text-transform: uppercase; letter-spacing: .12em; color: var(--text-subtle); opacity: .8; }
.meta-value  { font-family: 'JetBrains Mono', monospace; font-size: .72rem; color: var(--text-muted); }
.issue-list  { display: flex; flex-direction: column; gap: 6px; }
.issue-item  {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 10px 12px; border: 1px solid var(--border); border-radius: var(--radius-sm);
  background: var(--surface);
  cursor: pointer; transition: all .2s var(--ease);
}
.issue-item:hover                { background: var(--surface-hover); border-color: var(--border-strong); }
.issue-item.active               { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.45); box-shadow: 0 0 0 3px rgba(255,255,255,.10); }
.issue-item.incident-item.active { background: rgba(248,113,113,.06); border-color: rgba(248,113,113,.35); box-shadow: 0 0 0 3px rgba(248,113,113,.10); }
.item-dot          { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; margin-top: 5px; }
.item-dot.incident { background: var(--red); box-shadow: 0 0 5px rgba(248,113,113,.6); animation: pulse 2.5s ease-in-out infinite; }
.item-dot.advisory { background: var(--yellow); box-shadow: 0 0 5px rgba(251,191,36,.5); }
.item-info    { flex: 1; min-width: 0; }
.item-service { font-family: 'JetBrains Mono', monospace; font-size: .58rem; color: var(--text-subtle); text-transform: uppercase; letter-spacing: .06em; }
.item-name    { font-family: 'Inter', sans-serif; font-size: .80rem; color: var(--text-muted); line-height: 1.35; }

/* ── States / spinners ───────────────────────────────────── */
.state-center  { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; text-align: center; padding: 24px 0; }
.spinner       { width: 24px; height: 24px; border: 2px solid rgba(255,255,255,.08); border-top-color: var(--accent); border-radius: 50%; animation: spin .8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.state-text    { font-family: 'JetBrains Mono', monospace; font-size: .72rem; color: var(--text-subtle); }
.state-icon    { font-size: 2rem; color: var(--accent); }
.news-loading  { display: flex; flex-direction: column; align-items: center; gap: 12px; padding: 60px 0; }
.news-empty    { padding: 40px 0; font-family: 'JetBrains Mono', monospace; font-size: .72rem; color: var(--text-subtle); opacity: .5; text-align: center; }
.show-more-btn {
  background: var(--surface); border: 1px solid var(--border); color: var(--text-muted);
  font-family: 'JetBrains Mono', monospace; font-size: .70rem;
  padding: 8px 22px; border-radius: 999px; cursor: pointer;
  display: block; margin: 8px auto 0;
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  transition: all .2s var(--ease);
}
.show-more-btn:hover { border-color: var(--accent); color: var(--accent); box-shadow: 0 0 0 4px rgba(255,255,255,0.12); }

/* ── Tools section ───────────────────────────────────────── */
.tools-section { display: flex; flex-direction: column; gap: 14px; }
.tools-twin {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
@media (max-width: 800px) { .tools-twin { grid-template-columns: 1fr; } }

.tool-card-label {
  font-family: 'JetBrains Mono', monospace; font-size: .60rem;
  letter-spacing: .14em; text-transform: uppercase; color: var(--text-subtle);
  margin-bottom: 6px; padding-left: 4px;
}

.domain-tool-card { display: flex; flex-direction: column; gap: 16px; padding: 18px 20px; }
.tool-group       { display: flex; flex-direction: column; gap: 8px; }
.tool-group-label { font-size: .58rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; color: var(--text-subtle); }
.tool-chips       { display: flex; flex-wrap: wrap; gap: 5px; }
.ip-info-twin     { display: grid; grid-template-columns: 1fr auto; gap: 12px; align-items: start; }
.ip-info-chips    { flex-direction: column; flex-wrap: nowrap; align-items: flex-start; }
#sourceCard       { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 12px 14px; min-height: 48px; backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); }

/* Tool chip */
.tool-chip {
  padding: 10px 18px; border-radius: 999px;
  font-family: 'JetBrains Mono', monospace; font-size: .80rem; font-weight: 500;
  color: var(--text-muted);
  background: var(--surface); border: 1px solid var(--border);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  cursor: pointer; user-select: none;
  transition: all .2s var(--ease);
  letter-spacing: .02em;
}
.tool-chip:hover  { background: var(--surface-hover); border-color: var(--border-strong); color: var(--text); transform: translateY(-1px); }
.tool-chip.active { color: #fff; border-color: rgba(255,255,255,.50); background: linear-gradient(135deg, rgba(200,205,215,.16), rgba(255,255,255,.10)); box-shadow: 0 8px 22px -10px var(--accent-glow); }
.tool-chip-accent { color: var(--accent) !important; border-color: rgba(255,255,255,.30) !important; }
.tool-chip-accent:hover { background: rgba(255,255,255,.10) !important; border-color: rgba(255,255,255,.50) !important; box-shadow: 0 0 0 4px rgba(255,255,255,.10); }

/* ── Tool tabs ───────────────────────────────────────────── */
.tool-tabs-card { padding: 0 !important; overflow: hidden; }
.tool-tab-bar {
  display: flex; flex-wrap: wrap;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,0.03), transparent);
}
.tool-tab {
  background: none; border: none;
  border-bottom: 2px solid transparent;
  padding: 22px 30px;
  font-family: 'JetBrains Mono', monospace; font-size: .92rem; font-weight: 500;
  color: var(--text-subtle); cursor: pointer;
  transition: color .15s, border-color .15s, background .15s;
  letter-spacing: .05em; margin-bottom: -1px;
}
.tool-tab:hover { color: var(--text-muted); background: rgba(255,255,255,0.04); }
.tool-tab.active {
  color: var(--accent); border-bottom-color: var(--accent);
  text-shadow: 0 0 12px var(--accent-glow);
  background: rgba(255,255,255,0.025);
}
.tool-tab-pane { display: none; padding: 32px 34px; flex-direction: column; gap: 20px; }
.tool-tab-pane.active { display: flex; }
.tab-quick { display: flex; flex-wrap: wrap; gap: 10px; }

/* ── Input group (iig) ───────────────────────────────────── */
.iig {
  display: flex; align-items: stretch;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  overflow: hidden;
  backdrop-filter: blur(18px) saturate(160%); -webkit-backdrop-filter: blur(18px) saturate(160%);
  transition: border-color .15s, box-shadow .15s;
  position: relative;
}
.iig:focus-within { border-color: rgba(255,255,255,.55); box-shadow: 0 0 0 4px rgba(255,255,255,.10); }
.iig-input {
  flex: 1; background: transparent; border: none;
  padding: 20px 22px; color: var(--text);
  font-family: 'JetBrains Mono', monospace;
  font-size: 17px; outline: none; min-width: 0;
}
.iig-input::placeholder { color: var(--text-faint); }
.iig-divider { width: 1px; background: var(--border); flex-shrink: 0; align-self: stretch; }
.iig-select {
  background: transparent; border: none; border-left: 1px solid var(--border);
  padding: 0 20px; color: var(--text-muted);
  font-family: 'JetBrains Mono', monospace; font-size: .88rem;
  outline: none; cursor: pointer; flex-shrink: 0;
}
.iig-select option { background: #0a0e16; color: var(--text); }
.iig-btn {
  background: linear-gradient(135deg, rgba(200,205,215,0.16), rgba(255,255,255,0.14));
  border: none; border-left: 1px solid var(--border);
  padding: 0 32px; color: var(--accent);
  font-family: 'JetBrains Mono', monospace; font-size: .92rem; font-weight: 600;
  cursor: pointer; white-space: nowrap; flex-shrink: 0;
  transition: background .2s, box-shadow .2s;
  text-shadow: 0 0 10px var(--accent-glow);
  letter-spacing: .03em;
}
.iig-btn:hover { background: linear-gradient(135deg, rgba(200,205,215,0.30), rgba(255,255,255,0.24)); box-shadow: inset 0 0 0 1px rgba(255,255,255,0.30); }

/* ── Subnet calc ─────────────────────────────────────────── */
.subnet-bento { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 6px; }
.subnet-cell  { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 10px 12px; display: flex; flex-direction: column; gap: 4px; backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); }
.subnet-cell.hl { border-color: rgba(255,255,255,.40); background: rgba(255,255,255,.06); }
.subnet-cell-label { font-size: .55rem; letter-spacing: .14em; text-transform: uppercase; color: var(--text-subtle); }
.subnet-cell-value { font-family: 'JetBrains Mono', monospace; font-size: .76rem; color: var(--text); }
.subnet-cell-value.dim { color: var(--text-muted); }
.subnet-hosts-grid { display: flex; flex-wrap: wrap; gap: 6px; max-height: 280px; overflow-y: auto; padding: 2px 0; }
.subnet-host-ip    { font-family: 'JetBrains Mono', monospace; font-size: .70rem; color: var(--text-muted); background: var(--surface); border: 1px solid var(--border); border-radius: 6px; padding: 3px 8px; }

/* ── Propagation grid ────────────────────────────────────── */
.prop-grid { display: flex; flex-direction: column; gap: 0; margin-top: 8px; border: 1px solid var(--border); border-radius: var(--radius-sm); overflow: hidden; }
.prop-row  { display: grid; grid-template-columns: 88px 1fr auto; align-items: baseline; gap: 10px; padding: 8px 14px; border-bottom: 1px solid var(--border); font-family: 'JetBrains Mono', monospace; font-size: .72rem; }
.prop-row:last-child { border-bottom: none; }
.prop-name  { color: var(--text-subtle); font-size: .64rem; letter-spacing: .04em; white-space: nowrap; }
.prop-val   { color: var(--text-muted); word-break: break-all; line-height: 1.6; }
.prop-odd   { background: rgba(251,191,36,.05); }
.prop-odd .prop-val { color: var(--yellow); }
.prop-err   { opacity: .45; }

/* ── SSL ─────────────────────────────────────────────────── */
.ssl-expiry { font-family: 'JetBrains Mono', monospace; font-size: 1.6rem; font-weight: 600; line-height: 1; }
.ssl-expiry.ok   { color: var(--green); }
.ssl-expiry.warn { color: var(--yellow); }
.ssl-expiry.err  { color: var(--red); }

/* ── Tool input / button (legacy) ────────────────────────── */
.tool-input-wrap { display: flex; flex-direction: column; gap: 8px; }
.tool-input-row  { display: flex; gap: 8px; }
.tool-input {
  flex: 1; padding: 12px 16px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-family: 'JetBrains Mono', monospace; font-size: 16px;
  outline: none; transition: all .15s; min-width: 0;
}
.tool-input:focus { border-color: rgba(255,255,255,.55); box-shadow: 0 0 0 4px rgba(255,255,255,.10); }
.tool-select {
  padding: 12px 14px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text-muted);
  font-family: 'JetBrains Mono', monospace; font-size: .78rem;
  outline: none; cursor: pointer; transition: border-color .15s;
}
.tool-btn {
  padding: 12px 22px;
  background: linear-gradient(135deg, rgba(200,205,215,0.18), rgba(255,255,255,0.14));
  border: 1px solid rgba(255,255,255,.35);
  border-radius: var(--radius-sm);
  color: var(--accent);
  font-family: 'JetBrains Mono', monospace; font-size: .80rem; font-weight: 600;
  cursor: pointer; transition: all .2s; white-space: nowrap;
  text-shadow: 0 0 8px var(--accent-glow);
}
.tool-btn:hover { background: linear-gradient(135deg, rgba(200,205,215,0.28), rgba(255,255,255,0.20)); box-shadow: 0 0 0 4px rgba(255,255,255,.12); }

.extra-row { display: none; gap: 8px; }

/* ── Result card ─────────────────────────────────────────── */
.result-wrap { position: relative; display: none; }
.result-wrap.visible { display: block; }
.result-card {
  font-family: 'JetBrains Mono', monospace; font-size: .80rem;
  color: var(--text-muted); padding: 18px; padding-right: 58px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius);
  line-height: 1.7;
  backdrop-filter: blur(20px) saturate(160%); -webkit-backdrop-filter: blur(20px) saturate(160%);
  box-shadow: var(--shadow-card);
}
.result-copy { position: absolute; top: 10px; right: 10px; background: var(--surface-strong); border: 1px solid var(--border-strong); border-radius: 7px; color: var(--text-muted); font-family: 'JetBrains Mono', monospace; font-size: .66rem; padding: 4px 10px; cursor: pointer; transition: all .15s; }
.result-copy:hover { color: var(--accent); border-color: rgba(255,255,255,.40); }

/* ── DNS / generic result innards ────────────────────────── */
.dns-section { display: flex; flex-direction: column; gap: 8px; }
.dns-tool    { display: flex; gap: 8px; }
.dns-input   { flex: 1; padding: 12px 16px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-sm); color: var(--text); font-family: 'JetBrains Mono', monospace; font-size: 16px; outline: none; transition: all .15s; }
.dns-input:focus { border-color: rgba(255,255,255,.55); box-shadow: 0 0 0 4px rgba(255,255,255,.10); }
.dns-btn { padding: 12px 18px; background: linear-gradient(135deg, rgba(200,205,215,0.16), rgba(255,255,255,0.14)); border: 1px solid rgba(255,255,255,.35); border-radius: var(--radius-sm); color: var(--accent); font-family: 'JetBrains Mono', monospace; font-size: .80rem; cursor: pointer; transition: all .2s; }
.dns-btn:hover { background: linear-gradient(135deg, rgba(200,205,215,0.28), rgba(255,255,255,0.22)); }
.dns-result-wrap { position: relative; display: none; }
.dns-result-wrap.visible { display: block; }
.dns-result { font-family: 'JetBrains Mono', monospace; font-size: .80rem; color: var(--text-muted); padding: 16px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); }
.dns-host   { color: var(--text); margin-bottom: 12px; word-break: break-all; }
.dns-type-block { margin-top: 8px; }
.dns-type-label { color: var(--accent); font-size: .68rem; margin-bottom: 4px; letter-spacing: .05em; }
.dns-resolver { display: flex; flex-direction: column; gap: 4px; }
.dns-row      { display: flex; gap: 12px; align-items: baseline; }
.dns-row-name { color: var(--text-subtle); width: 80px; flex-shrink: 0; }
.dns-row-data { word-break: break-all; }
.dns-copy { position: absolute; top: 10px; right: 10px; background: var(--surface-strong); border: 1px solid var(--border-strong); border-radius: 7px; color: var(--text-muted); font-family: 'JetBrains Mono', monospace; font-size: .66rem; padding: 4px 10px; cursor: pointer; }

.res-host    { color: var(--text); margin-bottom: 16px; font-size: .92rem; word-break: break-all; }
.res-section { margin-bottom: 16px; }
.res-label   { font-size: .66rem; color: var(--text-subtle); text-transform: uppercase; letter-spacing: .1em; margin-bottom: 8px; display: flex; align-items: center; gap: 8px; }
.res-divider { border: none; border-top: 1px solid var(--border); margin: 14px 0; }
.check-row   { display: flex; align-items: baseline; gap: 12px; padding: 6px 0; border-bottom: 1px solid var(--border); }
.check-name  { color: var(--text-muted); min-width: 160px; flex-shrink: 0; font-size: .80rem; }
.check-value { color: var(--text-subtle); flex: 1; word-break: break-all; font-size: .80rem; }
.rec-row     { display: flex; gap: 8px; align-items: baseline; padding: 3px 0; }
.rec-prio    { color: var(--text-subtle); min-width: 32px; text-align: right; font-size: .66rem; }
.rec-val     { color: var(--text-muted); word-break: break-all; flex: 1; }
.chain-step  { display: flex; align-items: center; gap: 8px; padding: 4px 0; color: var(--text-muted); }
.chain-arrow { color: var(--accent); }
.res-loading { color: var(--text-subtle); font-size: .80rem; display: flex; align-items: center; gap: 8px; }

/* ── Generic badges ──────────────────────────────────────── */
.badge { display: inline-block; padding: 2px 8px; border-radius: 999px; font-size: .66rem; font-weight: 600; letter-spacing: .05em; white-space: nowrap; flex-shrink: 0; }
.badge.ok    { background: rgba(74,222,128,.12); color: var(--green); border: 1px solid rgba(74,222,128,.30); }
.badge.warn  { background: rgba(251,191,36,.12); color: var(--yellow); border: 1px solid rgba(251,191,36,.30); }
.badge.err   { background: rgba(248,113,113,.12); color: var(--red); border: 1px solid rgba(248,113,113,.30); }

.score-wrap   { display: flex; align-items: center; gap: 12px; margin-top: 16px; }
.score-bar    { flex: 1; height: 4px; background: rgba(255,255,255,.06); border-radius: 2px; overflow: hidden; }
.score-bar-lg { height: 6px; }
.score-fill   { height: 100%; border-radius: 2px; background: var(--accent-grad); transition: width .6s ease; box-shadow: 0 0 10px var(--accent-glow); }
.score-label  { font-size: .70rem; color: var(--text-subtle); white-space: nowrap; }

.subscore-row    { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; margin: 10px 0 4px; }
.subscore        { display: flex; flex-direction: column; gap: 5px; }
.subscore-label  { font-size: .60rem; text-transform: uppercase; letter-spacing: .12em; color: var(--text-subtle); }
.subscore-pts    { font-size: .66rem; color: var(--text-muted); text-align: right; }
.score-total-wrap{ display: flex; align-items: center; gap: 12px; margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--border); }
.score-total-num { font-size: .76rem; font-weight: 700; color: var(--text); white-space: nowrap; }

.bl-row     { display: flex; align-items: center; gap: 12px; padding: 5px 0; border-bottom: 1px solid var(--border); }
.bl-name    { flex: 1; color: var(--text-muted); font-size: .80rem; }
.kv-row     { display: flex; gap: 12px; padding: 5px 0; border-bottom: 1px solid var(--border); }
.kv-key     { color: var(--text-subtle); min-width: 130px; flex-shrink: 0; font-size: .80rem; }
.kv-val     { color: var(--text-muted); word-break: break-all; font-size: .80rem; }
.sec-rec    { display: flex; gap: 10px; padding: 9px 0; border-bottom: 1px solid var(--border); align-items: flex-start; }
.sec-rec-icon { font-size: .80rem; flex-shrink: 0; margin-top: 2px; }
.sec-rec-text { font-size: .80rem; color: var(--text-muted); line-height: 1.5; }

/* ── Source grid (whois etc.) ────────────────────────────── */
.source-grid { display: grid; grid-template-columns: 120px 1fr; gap: 0; font-family: 'JetBrains Mono', monospace; font-size: .80rem; }
.src-key     { color: var(--text-subtle); font-size: .66rem; letter-spacing: .06em; padding: 6px 12px 6px 0; border-bottom: 1px solid var(--border); align-self: center; }
.src-val     { color: var(--text-muted); padding: 6px 0; border-bottom: 1px solid var(--border); word-break: break-all; }
.src-loading { opacity: .4; }
.src-divider { grid-column: 1/-1; border: none; border-top: 1px solid var(--border); margin: 10px 0; }
.src-section-label { grid-column: 1/-1; font-size: .66rem; color: var(--accent); text-transform: uppercase; letter-spacing: .1em; padding-bottom: 4px; }

/* ── News / RSS ──────────────────────────────────────────── */
.search-row  { display: flex; align-items: center; gap: 10px; }
.news-search {
  flex: 1; padding: 12px 18px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-family: 'JetBrains Mono', monospace; font-size: 16px;
  outline: none;
  backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
  transition: all .15s;
}
.news-search:focus { border-color: rgba(255,255,255,.55); box-shadow: 0 0 0 4px rgba(255,255,255,.10); }
.refresh-label { font-family: 'JetBrains Mono', monospace; font-size: .60rem; color: var(--text-subtle); opacity: .6; white-space: nowrap; flex-shrink: 0; }
.source-row    { display: flex; align-items: center; gap: 10px; }
.source-select {
  padding: 8px 14px; background: var(--surface); border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--text-muted); font-family: 'JetBrains Mono', monospace; font-size: .72rem;
  outline: none; cursor: pointer;
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
}

.article-list { display: flex; flex-direction: column; gap: 10px; }
.a-card {
  display: flex; flex-direction: column; gap: 8px;
  background: var(--surface); border: 1px solid var(--border);
  border-left: 3px solid transparent;
  border-radius: var(--radius-sm);
  text-decoration: none;
  padding: 18px 20px;
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  transition: all .2s var(--ease);
}
.a-card:hover { background: var(--surface-hover); border-color: var(--border-strong); transform: translateY(-1px); box-shadow: 0 8px 22px -10px var(--accent-glow); }
.a-card.unread { border-left-color: var(--accent); }
.a-top   { display: flex; align-items: center; gap: 10px; min-width: 0; }
/* Unified monochrome badge — variants only differ by subtle accent */
.a-badge {
  font-family: 'JetBrains Mono', monospace; font-size: .60rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .12em;
  padding: 3px 8px; border-radius: 4px;
  flex-shrink: 0; white-space: nowrap;
  background: rgba(255,255,255,.06); color: var(--text-muted);
  border: 1px solid rgba(255,255,255,.12);
}
/* Urgent / breaking — subtle red */
.a-badge.action,
.a-badge.security,
.a-badge.breaking,
.a-badge.retiring  { background: rgba(248,113,113,.10); color: #fca5a5; border-color: rgba(248,113,113,.28); }
/* Fix — neutral white emphasis */
.a-badge.fix       { background: rgba(255,255,255,.10); color: var(--text); border-color: rgba(255,255,255,.22); }
/* Info / new feature / cloud / dev / ai — neutral muted */
.a-badge.info,
.a-badge.cloud,
.a-badge.dev,
.a-badge.ai        { background: rgba(255,255,255,.04); color: var(--text-subtle); border-color: rgba(255,255,255,.10); }
.a-source { font-family: 'JetBrains Mono', monospace; font-size: .70rem; color: var(--text-subtle); opacity: .9; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.a-time   { font-family: 'JetBrains Mono', monospace; font-size: .66rem; color: var(--text-subtle); opacity: .65; flex-shrink: 0; margin-left: auto; }
.a-title  { font-family: 'Inter', sans-serif; font-size: 1.02rem; font-weight: 600; color: var(--text); line-height: 1.4; letter-spacing: -.01em; }
.a-excerpt{ font-family: 'Inter', sans-serif; font-size: .88rem; color: var(--text-muted); line-height: 1.65; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

/* Read tracking + bookmark */
.a-card.read .a-title   { color: var(--text-muted); font-weight: 500; }
.a-card.read .a-excerpt { opacity: .55; }
.a-card.read .a-badge   { opacity: .55; }
.bm-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 26px; height: 26px; padding: 0; margin-left: 4px;
  background: transparent; border: 1px solid transparent;
  border-radius: 6px; color: var(--text-faint);
  cursor: pointer; flex-shrink: 0;
  transition: all .15s var(--ease);
}
.bm-btn:hover { color: var(--text); background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.10); }
.bm-btn.saved { color: var(--accent); border-color: rgba(255,255,255,.18); }

/* DNS history chips */
.dns-history-row {
  display: flex; flex-wrap: wrap; align-items: center; gap: 6px;
  margin: 8px 0 6px 0; font-family: 'JetBrains Mono', monospace;
}
.dns-hist-label { font-size: .60rem; color: var(--text-subtle); opacity: .55; text-transform: uppercase; letter-spacing: .08em; margin-right: 4px; }
.dns-hist-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08);
  color: var(--text-muted); font-family: inherit; font-size: .68rem;
  padding: 4px 10px; border-radius: 999px; cursor: pointer;
  transition: all .15s var(--ease);
}
.dns-hist-chip:hover { background: rgba(255,255,255,.08); color: var(--text); border-color: rgba(255,255,255,.18); }
.dns-hist-type { color: var(--accent); opacity: .8; font-size: .58rem; letter-spacing: .04em; }
.dns-hist-clear { color: var(--text-faint); padding: 4px 9px; }

/* Header inspector */
.hdr-loading { font-family: 'JetBrains Mono', monospace; font-size: .76rem; color: var(--text-subtle); padding: 12px 14px; }
.hdr-loading code { color: var(--text); background: rgba(255,255,255,.05); padding: 2px 6px; border-radius: 4px; }
.hdr-summary { display: flex; align-items: center; gap: 16px; padding: 12px 16px; border-radius: 10px; background: rgba(255,255,255,.025); border: 1px solid rgba(255,255,255,.06); margin-bottom: 14px; }
.hdr-grade { font-family: 'JetBrains Mono', monospace; font-size: 1.5rem; font-weight: 700; padding: 8px 14px; border-radius: 8px; min-width: 56px; text-align: center; }
.hdr-grade-aplus, .hdr-grade-a { background: rgba(110,231,183,.12); color: var(--accent); border: 1px solid rgba(110,231,183,.25); }
.hdr-grade-b { background: rgba(253,224,71,.10); color: #fde047; border: 1px solid rgba(253,224,71,.25); }
.hdr-grade-c, .hdr-grade-d { background: rgba(252,165,165,.10); color: #fca5a5; border: 1px solid rgba(252,165,165,.25); }
.hdr-summary-title { font-family: 'JetBrains Mono', monospace; font-size: .82rem; color: var(--text); margin-bottom: 4px; }
.hdr-summary-sub { font-family: 'JetBrains Mono', monospace; font-size: .66rem; color: var(--text-subtle); word-break: break-all; }
.hdr-row { display: grid; grid-template-columns: 22px 170px 1fr; gap: 10px; padding: 6px 4px; font-family: 'JetBrains Mono', monospace; font-size: .72rem; align-items: baseline; border-bottom: 1px solid rgba(255,255,255,.04); }
.hdr-icon { font-weight: 700; text-align: center; }
.hdr-ok .hdr-icon { color: var(--accent); }
.hdr-fail .hdr-icon { color: #fca5a5; }
.hdr-name { color: var(--text-muted); }
.hdr-detail { color: var(--text-subtle); word-break: break-word; }
.hdr-raw { margin-top: 14px; font-family: 'JetBrains Mono', monospace; font-size: .70rem; }
.hdr-raw summary { cursor: pointer; color: var(--text-subtle); padding: 6px 0; }
.hdr-raw-row { display: grid; grid-template-columns: 220px 1fr; gap: 10px; padding: 3px 4px; }
.hdr-raw-k { color: var(--text-subtle); }
.hdr-raw-v { color: var(--text); word-break: break-all; }

/* MAC vendor */
.mac-row { display: grid; grid-template-columns: 110px 1fr; gap: 12px; padding: 6px 4px; font-family: 'JetBrains Mono', monospace; font-size: .76rem; border-bottom: 1px solid rgba(255,255,255,.04); }
.mac-label { color: var(--text-subtle); opacity: .7; }
.mac-val { color: var(--text); word-break: break-word; }
.mac-mono { font-family: 'JetBrains Mono', monospace; }
.mac-fail { color: #fca5a5; }

/* PTR batch */
.ptr-summary { font-family: 'JetBrains Mono', monospace; font-size: .72rem; color: var(--text-subtle); margin-bottom: 8px; }
.ptr-grid { display: grid; grid-template-columns: 1fr; gap: 2px; }
.ptr-row { display: grid; grid-template-columns: 140px 1fr; gap: 12px; padding: 5px 8px; font-family: 'JetBrains Mono', monospace; font-size: .72rem; border-radius: 6px; }
.ptr-row:nth-child(odd) { background: rgba(255,255,255,.02); }
.ptr-ip { color: var(--text); }
.ptr-name { color: var(--accent); word-break: break-all; }
.ptr-empty .ptr-name { color: var(--text-faint); opacity: .55; }

/* Speedtest */
.speed-card { display: flex; flex-direction: column; padding: 14px 18px; background: rgba(255,255,255,.025); border: 1px solid rgba(255,255,255,.06); border-radius: 10px; margin-bottom: 8px; }
.speed-card-main { background: rgba(110,231,183,.05); border-color: rgba(110,231,183,.20); }
.speed-num { font-family: 'JetBrains Mono', monospace; font-size: 1.6rem; font-weight: 600; color: var(--accent); }
.speed-card:not(.speed-card-main) .speed-num { color: var(--text); font-size: 1.2rem; }
.speed-unit { font-size: .9rem; opacity: .6; }
.speed-label { font-family: 'JetBrains Mono', monospace; font-size: .66rem; color: var(--text-subtle); margin-top: 2px; }
.speed-detail { display: flex; flex-wrap: wrap; gap: 8px 16px; font-family: 'JetBrains Mono', monospace; font-size: .66rem; color: var(--text-faint); padding: 8px 4px; }
@media (max-width: 600px) {
  .hdr-row { grid-template-columns: 22px 1fr; }
  .hdr-detail { grid-column: 2; }
  .hdr-raw-row { grid-template-columns: 1fr; }
}

/* Service heatmap (last 7 days) */
.svc-heatmap { display: flex; gap: 3px; margin-top: 10px; }
.hm-cell { width: 12px; height: 12px; border-radius: 3px; background: rgba(110,231,183,.18); border: 1px solid rgba(110,231,183,.30); }
.hm-cell.hm-ok    { background: rgba(110,231,183,.18); border-color: rgba(110,231,183,.30); }
.hm-cell.hm-warn  { background: rgba(253,224,71,.20);  border-color: rgba(253,224,71,.35); }
.hm-cell.hm-down  { background: rgba(252,165,165,.22); border-color: rgba(252,165,165,.40); }
.svc-filter-row { display: flex; gap: 6px; flex-wrap: wrap; }

/* Password generator */
.pw-controls { margin-top: 14px; display: flex; flex-direction: column; gap: 14px; }
.pw-strength { display: flex; align-items: center; gap: 12px; }
.pw-bar { flex: 1; height: 4px; background: rgba(255,255,255,.06); border-radius: 999px; overflow: hidden; }
.pw-bar-fill { height: 100%; width: 0%; transition: width .25s var(--ease), background .25s var(--ease); border-radius: 999px; background: rgba(252,165,165,.7); }
.pw-bar-fill.ok     { background: rgba(253,224,71,.7); }
.pw-bar-fill.good   { background: rgba(110,231,183,.65); }
.pw-bar-fill.strong { background: var(--accent); }
.pw-bar-label { font-family: 'JetBrains Mono', monospace; font-size: .68rem; color: var(--text-subtle); min-width: 110px; text-align: right; }
.pw-len-row { display: flex; align-items: center; gap: 14px; }
.pw-label { font-family: 'JetBrains Mono', monospace; font-size: .70rem; color: var(--text-subtle); min-width: 90px; }
.pw-len-num { color: var(--text); }
.pw-range { flex: 1; accent-color: var(--accent); }
.pw-toggles { display: flex; flex-wrap: wrap; gap: 8px 18px; font-family: 'JetBrains Mono', monospace; font-size: .72rem; color: var(--text-muted); }
.pw-toggles label { display: inline-flex; align-items: center; gap: 6px; cursor: pointer; }
.pw-toggles input[type=checkbox] { accent-color: var(--accent); }

/* Diff viewer */
.diff-input-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 8px; }
.diff-input { width: 100%; min-height: 140px; resize: vertical; font-family: 'JetBrains Mono', monospace; font-size: .76rem; line-height: 1.5; padding: 10px 12px; background: rgba(255,255,255,.025); border: 1px solid rgba(255,255,255,.08); border-radius: 8px; color: var(--text); }
.diff-input:focus { outline: none; border-color: rgba(110,231,183,.30); }
.diff-out { margin-top: 14px; background: rgba(255,255,255,.025); border: 1px solid rgba(255,255,255,.06); border-radius: 8px; padding: 6px 0; max-height: 460px; overflow: auto; font-family: 'JetBrains Mono', monospace; font-size: .74rem; line-height: 1.55; }
.diff-line { display: grid; grid-template-columns: 36px 36px 18px 1fr; padding: 0 8px; }
.diff-ln { color: var(--text-faint); opacity: .5; font-size: .66rem; padding-right: 6px; user-select: none; }
.diff-sign { color: var(--text-subtle); font-weight: 600; }
.diff-content { white-space: pre-wrap; word-break: break-all; }
.diff-add { background: rgba(110,231,183,.10); }
.diff-add .diff-sign { color: var(--accent); }
.diff-del { background: rgba(252,165,165,.10); }
.diff-del .diff-sign { color: #fca5a5; }
.diff-eq  { color: var(--text-muted); }
.diff-stats { font-family: 'JetBrains Mono', monospace; font-size: .70rem; margin-left: auto; }
.diff-stats .diff-add { background: transparent; color: var(--accent); padding: 0 6px; }
.diff-stats .diff-del { background: transparent; color: #fca5a5; padding: 0 6px; }
@media (max-width: 700px) { .diff-input-row { grid-template-columns: 1fr; } }

/* DNSSEC chain */
.dnssec-loading { font-family: 'JetBrains Mono', monospace; font-size: .76rem; color: var(--text-subtle); padding: 12px 14px; }
.dnssec-loading code { color: var(--text); background: rgba(255,255,255,.05); padding: 2px 6px; border-radius: 4px; }
.dnssec-summary { padding: 12px 16px; border-radius: 10px; margin-bottom: 14px; border: 1px solid; }
.dnssec-summary.ok { background: rgba(110,231,183,.06); border-color: rgba(110,231,183,.25); }
.dnssec-summary.fail { background: rgba(252,165,165,.05); border-color: rgba(252,165,165,.20); }
.dnssec-summary-title { font-family: 'JetBrains Mono', monospace; font-size: .82rem; color: var(--text); margin-bottom: 4px; }
.dnssec-summary.ok .dnssec-summary-title { color: var(--accent); }
.dnssec-summary.fail .dnssec-summary-title { color: #fca5a5; }
.dnssec-summary-sub { font-family: 'JetBrains Mono', monospace; font-size: .68rem; color: var(--text-subtle); }
.dnssec-chain { display: flex; flex-direction: column; gap: 0; }
.dnssec-step { background: rgba(255,255,255,.025); border: 1px solid rgba(255,255,255,.06); border-radius: 10px; padding: 10px 14px; }
.dnssec-step-head { font-family: 'JetBrains Mono', monospace; font-size: .82rem; color: var(--text); margin-bottom: 8px; }
.dnssec-step-zone { color: var(--accent); }
.dnssec-arrow { text-align: center; font-family: 'JetBrains Mono', monospace; color: var(--text-faint); padding: 4px 0; opacity: .5; }
.dnssec-row { display: grid; grid-template-columns: 22px 140px 1fr; gap: 8px; padding: 4px 0; font-family: 'JetBrains Mono', monospace; font-size: .72rem; align-items: baseline; }
.dnssec-icon { color: var(--text-subtle); font-weight: 600; text-align: center; }
.dnssec-ok .dnssec-icon { color: var(--accent); }
.dnssec-fail .dnssec-icon { color: #fca5a5; }
.dnssec-label { color: var(--text-muted); }
.dnssec-detail { color: var(--text-subtle); word-break: break-word; }
@media (max-width: 600px) {
  .dnssec-row { grid-template-columns: 22px 1fr; }
  .dnssec-detail { grid-column: 2; }
}

/* Latency sparkline (monitoring) */
.svc-spark { margin-top: 10px; }
.svc-spark svg { display: block; width: 100%; height: 24px; }
.svc-spark-meta { display: flex; justify-content: space-between; margin-top: 3px; font-family: 'JetBrains Mono', monospace; font-size: .58rem; color: var(--text-faint); opacity: .55; }

/* Entra / Roadmap cards */
.entra-card {
  display: flex; flex-direction: column; gap: 8px;
  background: var(--surface); border: 1px solid var(--border);
  border-left: 3px solid transparent;
  border-radius: var(--radius-sm);
  text-decoration: none;
  padding: 18px 20px;
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  transition: all .2s var(--ease);
  color: inherit;
}
.entra-card:hover    { background: var(--surface-hover); border-color: var(--border-strong); transform: translateY(-1px); }
.entra-card.retiring { border-left-color: var(--red); }
.entra-card.breaking { border-left-color: var(--red); border-color: rgba(248,113,113,.22); }
.entra-card.preview  { border-left-color: var(--cyan); }
.entra-card.new      { border-left-color: var(--accent); }
.e-badge          { font-family: 'JetBrains Mono', monospace; font-size: .65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; padding: 3px 9px; border-radius: 999px; flex-shrink: 0; }
.e-badge.retiring { background: rgba(248,113,113,.14); color: var(--red);    border: 1px solid rgba(248,113,113,.30); }
.e-badge.breaking { background: rgba(248,113,113,.22); color: var(--red);    border: 1px solid rgba(248,113,113,.45); }
.e-badge.preview  { background: rgba(34,211,238,.12); color: var(--cyan);   border: 1px solid rgba(34,211,238,.30); }
.e-badge.new      { background: rgba(200,205,215,.10); color: var(--accent); border: 1px solid rgba(255,255,255,.30); }
.rm-badge          { font-family: 'JetBrains Mono', monospace; font-size: .65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; padding: 3px 9px; border-radius: 999px; flex-shrink: 0; }
.rm-badge.launched { background: rgba(74,222,128,.14); color: var(--green);  border: 1px solid rgba(74,222,128,.28); }
.rm-badge.rolling  { background: rgba(34,211,238,.12); color: var(--cyan);   border: 1px solid rgba(34,211,238,.28); }
.rm-badge.dev      { background: rgba(251,191,36,.12); color: var(--yellow); border: 1px solid rgba(251,191,36,.28); }

/* ── CVE ─────────────────────────────────────────────────── */
.cve-list { display: flex; flex-direction: column; gap: 6px; }
.cve-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  display: grid; grid-template-columns: auto 1fr auto;
  grid-template-rows: auto auto auto;
  column-gap: 12px; row-gap: 2px;
  text-decoration: none; color: inherit;
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  transition: all .15s var(--ease);
}
.cve-card:hover          { border-color: var(--border-strong); background: var(--surface-hover); }
.cve-card.cve-kev        { border-color: rgba(251,191,36,.30); }
.cve-card.cve-ransomware { border-color: rgba(248,113,113,.50); animation: cvePulse 2.4s ease-in-out infinite; }
@keyframes cvePulse { 0%,100%{border-color:rgba(248,113,113,.50)} 50%{border-color:rgba(248,113,113,.85);box-shadow:0 0 12px 2px rgba(248,113,113,.18)} }
.cve-kev-badge { grid-row:1/4; grid-column:1; align-self:center; font-family:'JetBrains Mono',monospace; font-size:.52rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; padding:3px 7px; border-radius:6px; white-space:nowrap; background:rgba(251,191,36,.12); color:var(--yellow); border:1px solid rgba(251,191,36,.30); }
.cve-card.cve-ransomware .cve-kev-badge { background:rgba(248,113,113,.18); color:var(--red); border-color:rgba(248,113,113,.40); }
.cve-id     { grid-column:2; grid-row:1; font-family:'JetBrains Mono',monospace; font-size:.95rem; font-weight:700; color:var(--accent); align-self:end; text-shadow: 0 0 8px var(--accent-glow); }
.cve-card.cve-ransomware .cve-id { color:var(--red); text-shadow: 0 0 8px rgba(248,113,113,.5); }
.cve-date   { grid-column:3; grid-row:1; font-family:'JetBrains Mono',monospace; font-size:.70rem; color:var(--text-subtle); opacity:.7; text-align:right; align-self:end; white-space:nowrap; }
.cve-vendor { grid-column:2/4; grid-row:2; font-family:'JetBrains Mono',monospace; font-size:.78rem; color:var(--text); }
.cve-desc   { grid-column:2/4; grid-row:3; font-family:'Inter',sans-serif; font-size:.86rem; color:var(--text-muted); line-height:1.55; }
.cve-score          { font-family:'JetBrains Mono',monospace; font-size:.60rem; font-weight:700; padding:2px 7px; border-radius:5px; white-space:nowrap; }
.cve-score.critical { background:rgba(248,113,113,.16); color:var(--red);    border:1px solid rgba(248,113,113,.32); }
.cve-score.high     { background:rgba(251,191,36,.14);  color:var(--yellow); border:1px solid rgba(251,191,36,.28); }
.cve-badge-count    { font-size:.58rem; padding:2px 8px; border-radius:999px; background:rgba(248,113,113,.14); color:var(--red); border:1px solid rgba(248,113,113,.28); margin-left:4px; }
.cve-state          { font-family:'JetBrains Mono',monospace; font-size:.72rem; color:var(--text-subtle); padding:24px 0; text-align:center; }
.cve-state.cve-error { color:var(--red); }
.cve-filter-row     { display:flex; gap:6px; flex-wrap:wrap; }
.cve-filter-pill {
  padding: 10px 18px; background: var(--surface); border: 1px solid var(--border);
  border-radius: 999px; color: var(--text-muted);
  font-family: 'JetBrains Mono', monospace; font-size: .80rem; font-weight: 500;
  letter-spacing: .05em; cursor: pointer; transition: all .2s var(--ease);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
}
.cve-filter-pill:hover  { color: var(--text); border-color: var(--border-strong); background: var(--surface-hover); }
.cve-filter-pill.active {
  color: #fff;
  background: linear-gradient(135deg, rgba(200,205,215,0.16), rgba(255,255,255,0.10));
  border-color: rgba(255,255,255,.45);
  box-shadow: 0 8px 22px -10px var(--accent-glow), 0 0 0 1px rgba(255,255,255,0.25) inset;
}
.cve-status              { font-family:'JetBrains Mono',monospace; font-size:.55rem; font-weight:700; padding:2px 7px; border-radius:5px; white-space:nowrap; letter-spacing:.06em; flex-shrink:0; }
.cve-status.kev            { background:rgba(248,113,113,.18); color:var(--red);    border:1px solid rgba(248,113,113,.40); }
.cve-status.kev-ransomware { background:rgba(248,113,113,.26); color:var(--red);    border:1px solid rgba(248,113,113,.60); }
.cve-status.weaponized     { background:rgba(251,146,60,.16);  color:var(--orange); border:1px solid rgba(251,146,60,.34); }
.cve-status.watch          { background:rgba(251,191,36,.12);  color:var(--yellow); border:1px solid rgba(251,191,36,.28); }
.cve-status.new            { background:rgba(255,255,255,.04); color:var(--text-subtle); border:1px solid var(--border); }
.epss-bar-wrap { display:flex; align-items:center; gap:6px; margin-top:3px; }
.epss-bar      { height:2px; border-radius:1px; flex:1; background:rgba(255,255,255,.08); }
.epss-fill     { height:100%; border-radius:1px; transition:width .4s ease; }
.epss-label    { font-family:'JetBrains Mono',monospace; font-size:.55rem; color:var(--text-subtle); opacity:.7; white-space:nowrap; }
.cve-card.intel { grid-template-columns:auto 1fr auto; grid-template-rows:auto auto auto auto; }
.cve-epss-row   { grid-column:2/4; grid-row:4; }

/* ── News tab bar ────────────────────────────────────────── */
.tab-bar {
  display: flex; gap: 0;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  margin: 0;
}
.tab-btn {
  font-family: 'JetBrains Mono', monospace; font-size: .92rem; font-weight: 500;
  letter-spacing: .06em; padding: 18px 24px;
  color: var(--text-subtle); background: none; border: none;
  border-bottom: 2px solid transparent;
  cursor: pointer; transition: all .2s var(--ease);
  white-space: nowrap; position: relative;
}
.tab-btn:hover  { color: var(--text-muted); background: rgba(255,255,255,0.04); }
.tab-btn.active { color: var(--accent); border-bottom-color: var(--accent); text-shadow: 0 0 12px var(--accent-glow); background: rgba(255,255,255,0.025); }
.tab-btn .tab-count {
  font-size: .65rem; padding: 2px 8px; border-radius: 999px;
  margin-left: 8px;
  background: rgba(255,255,255,.14); color: var(--accent); border: 1px solid rgba(255,255,255,.30);
  display: none;
}
.tab-btn.active .tab-count { display: inline; }
.tab-panel        { display: none; flex-direction: column; gap: 14px; flex: 1; min-height: 0; padding-top: 20px; }
.tab-panel.active { display: flex; }

/* ── Top stories ─────────────────────────────────────────── */
.top-stories         { display: none; flex-direction: column; gap: 6px; padding: 0 0 14px; margin-bottom: 6px; border-bottom: 1px solid var(--border); }
.top-stories.visible { display: flex; }
.ts-row  {
  display: flex; align-items: center; gap: 12px; padding: 10px 14px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  text-decoration: none; color: inherit;
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  transition: all .2s var(--ease);
}
.ts-row:hover    { background: var(--surface-hover); border-color: var(--border-strong); transform: translateY(-1px); }
.ts-row.retiring,
.ts-row.breaking { border-color: rgba(248,113,113,.20); }
.ts-row.action   { border-color: var(--border); }
.ts-title { flex: 1; font-family: 'Inter', sans-serif; font-size: .86rem; font-weight: 500; color: var(--text); min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ts-dead  { font-family: 'JetBrains Mono', monospace; font-size: .64rem; font-weight: 600; flex-shrink: 0; white-space: nowrap;
            padding: 2px 8px; border-radius: 4px; letter-spacing: .04em; }
.ts-dead.urgent { color: #fca5a5; background: rgba(248,113,113,.10); border: 1px solid rgba(248,113,113,.28); }
.ts-dead.plan   { color: var(--text-muted); background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.10); }

/* ── Easter egg overlay ──────────────────────────────────── */
#logoOverlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.78);
  backdrop-filter: blur(14px) saturate(140%); -webkit-backdrop-filter: blur(14px) saturate(140%);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  z-index: 9999; opacity: 0; pointer-events: none;
  transition: opacity .5s ease;
}
#logoOverlay.visible { opacity: 1; pointer-events: all; }
#logoOverlay.hiding  { opacity: 0; }
.overlay-text { font-family: 'JetBrains Mono', monospace; font-size: clamp(36px,12vw,180px); font-weight: 700; letter-spacing: .1em; color: var(--text); user-select: none; text-shadow: 0 0 40px var(--accent-glow); }
.overlay-sub  { font-family: 'JetBrains Mono', monospace; font-size: clamp(11px,3vw,16px); letter-spacing: .3em; color: var(--text-subtle); margin-top: 24px; opacity: .55; user-select: none; }

/* ── Theme toggle (inline in navbar) ────────────────────── */
.theme-toggle {
  display: flex; align-items: center; justify-content: center;
  width: 30px; height: 30px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text-muted); cursor: pointer;
  flex-shrink: 0;
  transition: all .2s var(--ease);
}
.theme-toggle:hover {
  border-color: var(--border-strong); color: var(--text);
  background: rgba(255,255,255,0.05);
}
.theme-toggle .theme-text { display: none; }

/* ── Back-to-top ─────────────────────────────────────────── */
.back-to-top {
  position: fixed; z-index: 200;
  right: 24px; bottom: 28px;
  width: 40px; height: 40px;
  display: flex; align-items: center; justify-content: center;
  background: var(--surface-strong);
  border: 1px solid var(--border-strong);
  border-radius: 50%;
  color: var(--text-muted); cursor: pointer;
  backdrop-filter: blur(20px) saturate(180%); -webkit-backdrop-filter: blur(20px) saturate(180%);
  box-shadow: 0 8px 28px -8px rgba(0,0,0,.6);
  opacity: 0; pointer-events: none; transform: translateY(10px);
  transition: opacity .25s, transform .25s, color .25s, border-color .25s, box-shadow .25s;
}
.back-to-top.visible { opacity: 1; pointer-events: all; transform: translateY(0); }
.back-to-top:hover   { color: var(--accent); border-color: var(--border-hover); transform: translateY(-2px) scale(1.04); box-shadow: 0 16px 40px -12px var(--accent-glow); }

/* ── Hidden / compat ─────────────────────────────────────── */
#statusContainer { display: none !important; }
.system-card, .system-header, .system-content, .system-line,
.system-prompt, .system-key, .system-value-inline, .system-separator,
.system-cursor, .system-divider, .system-row, .system-cmd, .system-output,
.system-header-dots, .system-header-dot, .system-header-title,
.system-header-left, .system-header-live, .system-path, .system-stat,
.system-stat-value, .system-stat-label, .system-stat-icon { display: none; }

/* ── Global status (monitoring) ──────────────────────────── */
.global-status {
  display: flex; align-items: center; gap: 14px;
  font-family: 'JetBrains Mono', monospace; font-size: .95rem;
  padding: 22px 24px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius);
  backdrop-filter: blur(20px) saturate(160%); -webkit-backdrop-filter: blur(20px) saturate(160%);
  box-shadow: var(--shadow-card);
  transition: all .3s;
}
.global-status.loading  { color: var(--text-subtle); }
.global-status.healthy  { color: var(--green);  border-color: rgba(74,222,128,.30); }
.global-status.degraded { color: var(--yellow); border-color: rgba(251,191,36,.30); }
.global-status.incident { color: var(--red);    border-color: rgba(248,113,113,.30); }
.gs-dot  { width: 10px; height: 10px; border-radius: 50%; background: currentColor; flex-shrink: 0; box-shadow: 0 0 10px currentColor; }
.gs-main { font-weight: 600; letter-spacing: .02em; }
.update-hint { font-family: 'JetBrains Mono', monospace; font-size: .72rem; color: var(--text-subtle); opacity: .8; }
.refresh-btn {
  font-family: 'JetBrains Mono', monospace; font-size: .80rem; font-weight: 500;
  padding: 10px 18px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--text-muted); cursor: pointer;
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  display: flex; align-items: center; gap: 8px;
  transition: all .2s var(--ease);
}
.refresh-btn:hover { color: var(--accent); border-color: rgba(255,255,255,.40); box-shadow: 0 0 0 4px rgba(255,255,255,.10); }
.ref-icon { display: inline-block; transition: transform .3s; }
.refresh-btn:hover .ref-icon { transform: rotate(180deg); }

/* ── Footer ──────────────────────────────────────────────── */
footer {
  padding: 32px 0;
  display: flex; justify-content: center; align-items: center;
  flex-shrink: 0; margin-top: auto;
  border-top: 1px solid var(--border);
}
.footer-text { font-family: 'JetBrains Mono', monospace; font-size: .70rem; color: var(--text-subtle); }

/* ── Shared keyframes ────────────────────────────────────── */
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.5} }

/* ── Light theme ─────────────────────────────────────────── */
html.light { background: #eef3fb; }
body.light {
  --surface:        rgba(255, 255, 255, 0.72);
  --surface-hover:  rgba(255, 255, 255, 0.96);
  --surface-strong: rgba(255, 255, 255, 0.88);
  --border:         rgba(15, 23, 42, 0.08);
  --border-strong:  rgba(15, 23, 42, 0.16);
  --border-hover:   rgba(255,255,255, 0.40);
  --text:           #0a1f3d;
  --text-muted:     #243b5c;
  --text-subtle:    #5a6f8a;
  --text-faint:     rgba(10,31,61,0.40);
  --accent:         #0078D4;
  --accent-2:       #50E6FF;
  --accent-glow:    rgba(255,255,255, 0.30);
  --shadow-card:    0 1px 0 rgba(255,255,255,0.6) inset, 0 14px 36px -14px rgba(0,32,80,0.18);
  color: var(--text-muted);
}
body.light::before {
  background: radial-gradient(120% 80% at 50% 0%, #f5f8fd 0%, #eaf0fa 55%, #dfe7f3 100%);
}
body.light::after {
  background-image: radial-gradient(rgba(0,80,200,0.10) 1px, transparent 1px);
  opacity: .45;
}
body.light .aurora::before { opacity: .32; }
body.light .aurora::after  { opacity: .22; }
body.light .cursor-glow {
  background: radial-gradient(circle, color-mix(in srgb, var(--entra-blue) 10%, transparent) 0%, transparent 60%);
  mix-blend-mode: multiply;
}
body.light .navbar         { background: rgba(245, 248, 253, 0.60); backdrop-filter: blur(32px) saturate(200%) brightness(1.06); -webkit-backdrop-filter: blur(32px) saturate(200%) brightness(1.06); box-shadow: 0 1px 0 rgba(255,255,255,0.80), 0 6px 28px -6px rgba(0,32,80,0.14); }
body.light .navbar::after  { background: linear-gradient(to bottom, rgba(238,243,251,0.40) 0%, transparent 100%); }
body.light .navbar-links a { color: var(--text-subtle); }
body.light .navbar-links a:hover  { color: var(--text); background: rgba(0,40,120,.06); border-color: transparent; }
body.light .navbar-links a.active { color: var(--text); }
body.light .logo            { color: var(--text); }
body.light .theme-toggle   { border-color: rgba(0,40,120,.18); }
body.light .theme-toggle:hover { background: rgba(0,40,120,.06); }
body.light .nav-status-dot { box-shadow: 0 0 6px rgba(74, 222, 128, 0.6); }

body.light .iig-select option { background: #fff; color: var(--text); }

/* light: keep dark surfaces obvious in legacy spots */
body.light .uptime-bar.unknown { background: rgba(15,23,42,.10); }

/* ── Mobile ──────────────────────────────────────────────── */
@media (max-width: 768px) {
  .navbar         { position: sticky; }
  .navbar-inner   { padding: 0 12px; }
  .navbar::after  { display: none; }
  .logo           { font-size: .88rem; height: 52px; padding: 0 8px; }
  .logo::before   { margin-right: 3px; }
  .logo::after    { margin-left: 3px; }
  .logo-cursor    { display: none; }
  .navbar-right   { height: 52px; gap: 6px; }
  .navbar-links   { justify-content: space-evenly; gap: 0; padding: 0; }
  .navbar-links a {
    flex: 1; justify-content: center; text-align: center;
    padding: 0 4px; font-size: .88rem; height: 44px;
    display: inline-flex; align-items: center; border-radius: 0;
  }
  .navbar-links a.active { font-weight: 600; }
  .nav-status-dot { display: none; }
  .palette-btn    { width: 38px; height: 38px; flex-shrink: 0; }
  .theme-toggle   { width: 38px; height: 38px; border-radius: 9px; flex-shrink: 0; }
  .clock-hero     { padding: 28px 18px 20px; }
  .container      { padding: 0 14px 100px; }
  main            { padding: 52px 0 80px; gap: 22px; }

  /* Tab bars — scrollable, larger touch targets */
  .tab-bar        { overflow-x: auto; scrollbar-width: none; flex-wrap: nowrap; }
  .tab-bar::-webkit-scrollbar { display: none; }
  .tab-btn        { font-size: .74rem; padding: 14px 16px; flex-shrink: 0; letter-spacing: .04em; }
  .tab-btn .tab-count { font-size: .60rem; padding: 1px 6px; margin-left: 5px; }

  /* Tool tabs: 4-col on mobile to avoid word-break in labels */
  .tool-tab-bar   {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    overflow-x: unset;
    border-bottom: 1px solid var(--border);
    gap: 1px;
    background: var(--border);
  }
  .tool-tab       {
    padding: 14px 4px;
    font-size: .82rem; letter-spacing: 0;
    height: auto; min-height: 54px; flex-shrink: unset;
    display: flex; align-items: center; justify-content: center;
    text-align: center; word-break: break-word;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    background: var(--bg-card, var(--surface));
  }
  .tool-tab.active {
    color: var(--accent);
    border-bottom-color: var(--accent);
    background: rgba(110,231,183,0.06);
  }
  .tool-tab-pane  { padding: 20px 16px; }

  /* Quick-action chips (full check / propagation) — full width, tall */
  .tool-chips     { gap: 8px; }
  .tool-chip      { padding: 14px 20px; font-size: .88rem; min-height: 52px;
                    display: inline-flex; align-items: center; justify-content: center; }

  /* Input groups — input + select on row 1, button full-width on row 2 */
  .iig            { flex-wrap: wrap; }
  .iig-input      { font-size: 16px !important; flex: 1 1 0; min-width: 0; padding: 14px 16px; }
  .iig-divider    { display: none; }
  .iig-select     { font-size: 15px; padding: 0 14px; flex: 0 0 auto; min-height: 52px;
                    border-left: 1px solid var(--border); border-top: none; }
  .iig-btn        { padding: 0 20px; font-size: .88rem; flex: 1 1 100%; min-height: 52px;
                    border-left: none; border-top: 1px solid var(--border); }

  /* Quick-action pills (full check / propagation etc.) sit closer */
  .tab-quick      { gap: 8px; }
  .tab-quick > *  { flex: 1 1 auto; }

  .tool-input-row { flex-wrap: wrap; gap: 8px; }
  .tool-btn       { width: 100%; min-height: 44px; }
  .tool-input     { font-size: 16px !important; }

  .check-name     { min-width: 100px; }
  .news-search    { font-size: 16px !important; padding: 14px 16px; }
  .refresh-label  { display: none; }

  /* News: top-stories rows allow wrapping titles for readability */
  .top-stories    { gap: 8px; }
  .ts-row         { align-items: flex-start; padding: 10px 12px; gap: 10px; }
  .ts-title       { white-space: normal; line-height: 1.35; font-size: .82rem; }
  .ts-dead        { align-self: center; }

  .bento-link-grid { grid-template-columns: repeat(auto-fill, minmax(96px, 1fr)); gap: 8px; }
  .bento-link-card { flex-direction: column; align-items: center; justify-content: center;
                     gap: 8px; padding: 14px 8px; min-height: 92px; text-align: center; }
  .bento-icon      { width: 32px; height: 32px; }
  .bento-name      { font-size: .76rem; white-space: normal; overflow: visible; text-overflow: clip;
                     line-height: 1.15; word-break: break-word; }
  .clock-hero .clock-time { font-size: clamp(2.2rem, 12vw, 3.2rem); }
  .theme-toggle, .back-to-top { width: 36px; height: 36px; bottom: 16px; }
  .theme-toggle { left: 16px; }
  .back-to-top  { right: 16px; }
  /* Hide cursor glow on mobile (no mouse) */
  .cursor-glow { display: none; }
  /* Picker panel repositioned on mobile */
  .theme-picker { top: 68px; right: 12px; }
}

/* ── Theme color picker ───────────────────────────────────── */
.palette-btn {
  display: flex; align-items: center; justify-content: center;
  width: 30px; height: 30px; flex-shrink: 0;
  border: 1px solid var(--border); border-radius: 8px;
  background: transparent; cursor: pointer;
  color: var(--text-subtle);
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.palette-btn:hover        { background: rgba(255,255,255,0.06); color: var(--text); }
.palette-btn.open         { background: rgba(255,255,255,0.08); color: var(--text); border-color: var(--border-strong); }
body.light .palette-btn   { border-color: rgba(0,40,120,.18); }
body.light .palette-btn:hover { background: rgba(0,40,120,.06); }

.theme-picker {
  position: fixed; top: 76px; right: 20px; z-index: 200;
  background: var(--surface-strong);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  padding: 14px 16px;
  width: 230px;
  backdrop-filter: blur(28px) saturate(180%); -webkit-backdrop-filter: blur(28px) saturate(180%);
  box-shadow: 0 8px 40px rgba(0,0,0,0.45);
  display: none; flex-direction: column; gap: 14px;
}
.theme-picker.open { display: flex; }

.tp-section { display: flex; flex-direction: column; gap: 8px; }
.tp-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: .68rem; font-weight: 500; letter-spacing: .10em;
  color: var(--text-subtle); text-transform: uppercase;
}
.tp-swatches { display: flex; gap: 7px; flex-wrap: wrap; }
.tp-swatch {
  width: 26px; height: 26px; border-radius: 50%;
  border: 2px solid transparent;
  cursor: pointer; flex-shrink: 0;
  transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s;
}
.tp-swatch:hover         { transform: scale(1.18); }
.tp-swatch.active        { border-color: rgba(255,255,255,0.85); box-shadow: 0 0 0 1px rgba(255,255,255,0.4); transform: scale(1.08); }
body.light .tp-swatch.active { border-color: rgba(0,0,0,0.55); box-shadow: 0 0 0 1px rgba(0,0,0,0.25); }

@media (max-width: 480px) {
  .navbar-inner   { padding: 0 10px; height: 56px; }
  .logo           { font-size: .82rem; padding: 0 8px; }
  .logo::before, .logo::after { opacity: .7; }
  .navbar-links a { padding: 0 10px; font-size: .82rem; }
  .tab-btn        { font-size: .68rem; padding: 12px 12px; }
  .tool-tab       { font-size: .72rem; padding: 12px 2px; min-height: 48px; }
  .container      { padding: 0 12px 100px; }
  /* News tags scaling */
  .a-badge        { font-size: .58rem; padding: 2px 7px; }
  .ts-title       { font-size: .78rem; }
}


/* ─────────────────────────────────────────────────────────────────
   HOMEPAGE WIDGETS (greeting, hourly, sun arc, heartbeat, network)
   ───────────────────────────────────────────────────────────────── */

/* Hero greeting + quote (replaces .clock-hero) */
.home-hero {
  text-align: center;
  padding: 32px 24px 16px;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
}
.hero-greeting {
  font-family: 'Inter', sans-serif;
  font-size: clamp(.9rem, 1.4vw, 1.05rem);
  font-weight: 400;
  color: var(--text-subtle);
  letter-spacing: 0.02em;
  margin-bottom: 4px;
  opacity: 0;
  animation: heroFadeIn .6s .1s ease forwards;
}
.greet-name {
  color: var(--text);
  font-weight: 600;
  background: linear-gradient(135deg, #ffffff 0%, #b8c0cc 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.home-hero .clock-time {
  font-family: 'JetBrains Mono', monospace;
  font-size: clamp(2.6rem, 8vw, 4.2rem);
  font-weight: 600; letter-spacing: -0.01em; line-height: 1;
  background: linear-gradient(135deg, #ffffff 0%, var(--accent) 50%, #b8c0cc 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 0 24px rgba(255,255,255,0.18);
  opacity: 0;
  animation: heroFadeIn .8s .2s ease forwards;
}
.home-hero .clock-date {
  font-family: 'JetBrains Mono', monospace;
  font-size: .82rem; letter-spacing: .12em; text-transform: lowercase;
  color: var(--text-subtle);
  opacity: 0;
  animation: heroFadeIn .6s .3s ease forwards;
}
.hero-quote {
  font-family: 'Inter', sans-serif;
  font-size: .82rem;
  color: var(--text-subtle);
  max-width: 540px;
  line-height: 1.55;
  font-style: italic;
  margin: 2px auto 0;
  opacity: 0;
  animation: heroFadeIn .8s .5s ease forwards;
  transition: opacity .4s ease;
}
.hero-quote .q-mark { color: var(--text-faint); font-size: 1.1em; }
.hero-quote .q-author { font-style: normal; opacity: .55; font-size: .78rem; letter-spacing: .02em; }
.hero-quote.copied { color: var(--text); }
.hero-quote.copied::after {
  content: 'copied'; display: inline-block; margin-left: 8px;
  font-family: 'JetBrains Mono', monospace; font-size: .58rem; letter-spacing: .08em;
  text-transform: uppercase; padding: 2px 8px; border-radius: 4px;
  background: rgba(255,255,255,.10); color: var(--text); border: 1px solid rgba(255,255,255,.20);
  vertical-align: middle;
}
.greet-hint { color: var(--text-subtle); opacity: .7; font-size: .92em; }
@keyframes heroFadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* CVE ticker */
.cve-ticker {
  display: flex; align-items: center; gap: 14px;
  margin: 14px auto 0;
  max-width: 1100px;
  padding: 8px 16px;
  font-family: 'JetBrains Mono', monospace; font-size: .76rem;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 999px;
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  overflow: hidden;
  box-shadow: var(--shadow-card);
}
.cve-ticker-label {
  display: flex; align-items: center; gap: 8px;
  color: var(--red);
  text-transform: uppercase; letter-spacing: .12em;
  font-size: .62rem; font-weight: 600;
  flex-shrink: 0; padding-right: 14px;
  border-right: 1px solid var(--border);
}
.cve-ticker-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--red);
  box-shadow: 0 0 8px rgba(248,113,113,.7);
  animation: pulse 1.6s ease-in-out infinite;
}
.cve-ticker-track { flex: 1; overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 5%, #000 95%, transparent 100%); mask-image: linear-gradient(90deg, transparent 0, #000 5%, #000 95%, transparent 100%); }
.cve-ticker-inner { display: inline-flex; gap: 36px; white-space: nowrap; animation: ticker 70s linear infinite; }
.cvet-item { display: inline-flex; align-items: center; gap: 8px; color: var(--text-muted); text-decoration: none; font-size: .72rem; }
.cvet-item:hover .cvet-id { text-shadow: 0 0 8px var(--accent-glow); }
.cvet-id { color: var(--accent); font-weight: 600; }
.cvet-rw .cvet-id { color: var(--red); }
.cvet-sep { opacity: .4; }
.cvet-name { color: var(--text-subtle); }
@keyframes ticker {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* Widget row */
.home-widgets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
}
.widget {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 22px 24px;
  backdrop-filter: blur(20px) saturate(160%); -webkit-backdrop-filter: blur(20px) saturate(160%);
  box-shadow: var(--shadow-card);
  display: flex; flex-direction: column; gap: 14px;
  position: relative;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: all .25s var(--ease);
}
.widget:hover { background: var(--surface-hover); border-color: var(--border-strong); transform: translateY(-2px); }
.widget-label {
  font-family: 'JetBrains Mono', monospace; font-size: .68rem;
  text-transform: uppercase; letter-spacing: .14em;
  color: var(--text-subtle); font-weight: 600;
  display: flex; align-items: center; gap: 10px;
}

/* Hourly weather strip */
.hourly-strip {
  display: flex; gap: 6px; align-items: flex-end;
  height: 96px;
  padding-top: 8px;
}
.hr-cell {
  flex: 1; min-width: 0;
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  font-family: 'JetBrains Mono', monospace;
  position: relative;
}
.hr-temp { font-size: .68rem; color: var(--text); font-weight: 500; }
.hr-bar-wrap { display: flex; align-items: flex-end; height: 36px; }
.hr-bar {
  width: 4px;
  background: linear-gradient(180deg, var(--accent), color-mix(in srgb, var(--accent) 30%, transparent));
  border-radius: 2px;
  opacity: 0.6;
  transition: opacity .2s, transform .2s;
}
.hr-cell:hover .hr-bar { opacity: 1; transform: scaleY(1.1); transform-origin: bottom; }
.hr-icon { font-size: .9rem; line-height: 1; opacity: .85; }
.hr-hr { font-size: .6rem; color: var(--text-subtle); opacity: .65; letter-spacing: .03em; }

/* Sun arc */
.sun-widget { align-items: stretch; }
.sun-arc { width: 100%; height: 90px; flex-shrink: 0; }
#sunDot { filter: drop-shadow(0 0 8px rgba(251,191,36,.7)); transition: cx .8s ease, cy .8s ease; }
.sun-times {
  display: flex; justify-content: space-between; align-items: center;
  font-family: 'JetBrains Mono', monospace; font-size: .72rem;
  color: var(--text-muted);
  gap: 8px;
}
.sun-times .sun-icon { color: var(--yellow); margin-right: 2px; }
.sun-mid { font-size: .60rem; color: var(--text-subtle); opacity: .7; text-align: center; flex: 1; padding: 0 8px; }
.sun-total { display: block; opacity: .5; font-size: .92em; margin-top: 2px; }

/* Heartbeat widget */
.heartbeat-widget { cursor: pointer; }
.hb-pulse {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--text-subtle);
  box-shadow: 0 0 8px var(--text-subtle);
  display: inline-block; margin-left: auto;
  animation: pulse 2s ease-in-out infinite;
}
.hb-pulse-up   { background: var(--green) !important; box-shadow: 0 0 8px var(--green) !important; }
.hb-pulse-down { background: var(--red) !important;   box-shadow: 0 0 8px var(--red) !important;   animation: pulse 1s ease-in-out infinite; }
.hb-status { font-family: 'JetBrains Mono', monospace; font-size: .82rem; color: var(--text); }
.hb-up { color: var(--green); font-weight: 600; }
.hb-down { color: var(--red); font-weight: 600; }
.hb-num { color: var(--text-subtle); opacity: .8; font-size: .72rem; }
.hb-bars { display: flex; gap: 2px; height: 22px; }
.hb-bar { flex: 1; border-radius: 1px; }
.hb-bar.hb-up      { background: var(--green); opacity: .55; }
.hb-bar.hb-down    { background: var(--red);   opacity: .85; }
.hb-bar.hb-pending { background: rgba(255,255,255,.10); }
.hb-foot {
  font-family: 'JetBrains Mono', monospace; font-size: .64rem;
  color: var(--text-subtle); opacity: .6;
  letter-spacing: .04em;
  margin-top: auto;
}
.heartbeat-widget:hover .hb-foot { opacity: 1; color: var(--accent); }
/* Down-monitor tags inside heartbeat widget */
.hb-down-list { display: flex; flex-wrap: wrap; gap: 4px; opacity: 1; }
.hb-down-tag {
  font-family: 'JetBrains Mono', monospace; font-size: .60rem;
  padding: 2px 8px; border-radius: 999px;
  background: rgba(248,113,113,.14); color: var(--red);
  border: 1px solid rgba(248,113,113,.32);
  letter-spacing: .04em; white-space: nowrap;
}

/* Network widget */
.net-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
.net-row { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.net-key { font-family: 'JetBrains Mono', monospace; font-size: .58rem; text-transform: uppercase; letter-spacing: .12em; color: var(--text-subtle); }
.net-val { font-family: 'JetBrains Mono', monospace; font-size: .80rem; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.net-pings { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 10px; padding-top: 8px; border-top: 1px solid var(--border); }
.net-ping {
  display: grid; grid-template-columns: 90px 1fr 50px;
  align-items: center; gap: 10px;
  font-family: 'JetBrains Mono', monospace; font-size: .72rem;
}
.np-name { color: var(--text-muted); }
.np-bar { height: 4px; background: rgba(255,255,255,.06); border-radius: 2px; overflow: hidden; }
.np-fill { display: block; height: 100%; width: 0%; background: var(--text-subtle); border-radius: 2px; transition: width .8s ease, background .3s; }
.np-fill.np-fast { background: var(--green); }
.np-fill.np-mid  { background: var(--yellow); }
.np-fill.np-slow { background: var(--red); }
.np-ms { color: var(--text-subtle); text-align: right; font-size: .68rem; }

@media (max-width: 600px) {
  .net-grid { grid-template-columns: 1fr; }
  .home-hero { padding: 52px 18px 18px; }
  .cve-ticker { margin: 10px 14px 0; padding: 6px 12px; gap: 10px; }
  .cve-ticker-label { font-size: .54rem; padding-right: 10px; }
}

/* ─────────────────────────────────────────────────────────────────
   COMMAND PALETTE (⌘K)
   ───────────────────────────────────────────────────────────────── */

.cmdk-hint {
  position: fixed; right: 16px; bottom: 80px; z-index: 60;
  display: flex; align-items: center; gap: 6px;
  padding: 8px 12px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 999px;
  backdrop-filter: blur(20px) saturate(160%); -webkit-backdrop-filter: blur(20px) saturate(160%);
  color: var(--text-muted);
  font-family: 'JetBrains Mono', monospace; font-size: .64rem;
  cursor: pointer; transition: all .2s;
  box-shadow: var(--shadow-card);
}
.cmdk-hint:hover { color: var(--text); border-color: var(--border-strong); transform: translateY(-1px); }
.cmdk-hint kbd {
  font-family: 'JetBrains Mono', monospace; font-size: .68rem;
  padding: 2px 6px;
  background: rgba(255,255,255,0.08);
  border: 1px solid var(--border);
  border-radius: 4px;
  color: var(--text);
}
.cmdk-hint-label { letter-spacing: .04em; opacity: .7; padding-left: 4px; }

.cmdk-overlay {
  position: fixed; inset: 0; z-index: 100;
  display: none;
  align-items: flex-start; justify-content: center;
  padding-top: 14vh;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  animation: ckFadeIn .15s ease;
}
.cmdk-overlay.visible { display: flex; }
.cmdk-modal {
  width: min(620px, 92vw);
  background: rgba(20,22,28,0.92);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  backdrop-filter: blur(40px) saturate(180%); -webkit-backdrop-filter: blur(40px) saturate(180%);
  box-shadow: 0 30px 60px -20px rgba(0,0,0,0.7), 0 1px 0 rgba(255,255,255,0.1) inset;
  display: flex; flex-direction: column;
  overflow: hidden;
  animation: ckSlideUp .2s ease;
}
.cmdk-input-wrap {
  display: flex; align-items: center; gap: 10px;
  padding: 18px 20px;
  border-bottom: 1px solid var(--border);
}
.cmdk-search-icon { color: var(--text-subtle); flex-shrink: 0; }
.cmdk-input {
  flex: 1;
  background: transparent; border: none; outline: none;
  color: var(--text);
  font-family: 'Inter', sans-serif; font-size: 1.05rem;
  padding: 0;
}
.cmdk-input::placeholder { color: var(--text-faint); }
.cmdk-results { max-height: 50vh; overflow-y: auto; padding: 8px; }
.cmdk-results::-webkit-scrollbar { width: 6px; }
.cmdk-results::-webkit-scrollbar-thumb { background: rgba(255,255,255,.12); border-radius: 3px; }
.ck-row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background .12s;
}
.ck-row:hover, .ck-row.active { background: rgba(255,255,255,0.08); }
.ck-row.active { box-shadow: 0 0 0 1px var(--border-strong) inset; }
.ck-ico { width: 22px; height: 22px; flex-shrink: 0; object-fit: contain; opacity: .9; }
.ck-ico-text { display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,0.08); border-radius: 5px; font-family: 'JetBrains Mono', monospace; font-size: .65rem; font-weight: 700; color: var(--text-muted); }
.ck-label { flex: 1; font-family: 'Inter', sans-serif; font-size: .92rem; color: var(--text); }
.ck-group { font-family: 'JetBrains Mono', monospace; font-size: .60rem; text-transform: uppercase; letter-spacing: .08em; color: var(--text-subtle); padding: 2px 8px; background: rgba(255,255,255,0.04); border-radius: 999px; }
.ck-ext { color: var(--text-subtle); opacity: .6; font-size: .85rem; }
.ck-empty { padding: 30px; text-align: center; font-family: 'JetBrains Mono', monospace; font-size: .8rem; color: var(--text-subtle); opacity: .6; }
.cmdk-foot {
  display: flex; gap: 16px; padding: 10px 16px;
  border-top: 1px solid var(--border);
  font-family: 'JetBrains Mono', monospace; font-size: .62rem;
  color: var(--text-subtle); opacity: .7;
}
.cmdk-foot kbd {
  font-family: 'JetBrains Mono', monospace; font-size: .62rem;
  padding: 1px 5px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border);
  border-radius: 3px;
  color: var(--text-muted);
  margin-right: 2px;
}
@keyframes ckFadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes ckSlideUp { from { opacity: 0; transform: translateY(-12px); } to { opacity: 1; transform: translateY(0); } }

@media (max-width: 600px) {
  .cmdk-hint { right: 12px; bottom: 76px; padding: 6px 10px; }
  .cmdk-hint-label { display: none; }
  .cmdk-modal { width: 96vw; }
  .cmdk-overlay { padding-top: 8vh; }
}

/* ─────────────────────────────────────────────────────────────────
   HOME COCKPIT (2026-04 batch — quick-status, widgets, bento, fx)
   ───────────────────────────────────────────────────────────────── */

/* #7 time-of-day tint — subtle layer above forest-bg */
html::after {
  content: ''; position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background: var(--tod-tint, transparent);
  transition: background 1.2s ease;
  mix-blend-mode: screen;
}

/* #9 status background tint */
html.status-warn::before {
  content: ''; position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background: radial-gradient(60% 50% at 50% 0%, rgba(252, 165, 165, .07), transparent 70%);
  animation: warnPulse 6s ease-in-out infinite;
}
@keyframes warnPulse { 0%,100% { opacity: .6; } 50% { opacity: 1; } }

/* #2 quick-status bar */
.quick-status {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-top: 14px; justify-content: center;
}
.qs-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: 999px;
  font-family: 'JetBrains Mono', monospace; font-size: .68rem;
  color: var(--text-muted); text-decoration: none;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
  backdrop-filter: blur(8px);
}
.qs-pill:hover { transform: translateY(-1px); border-color: var(--border-strong); background: rgba(255,255,255,.07); }
.qs-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 6px currentColor; }
.qs-num { color: var(--text); font-weight: 600; }
.qs-lbl { opacity: .75; }
.qs-ok .qs-dot   { background: #6ee7b7; }
.qs-bad .qs-dot  { background: #fca5a5; animation: qsPulse 1.4s ease-in-out infinite; }
.qs-warn .qs-dot { background: #fde047; }
.qs-info .qs-dot { background: #7dd3fc; }
@keyframes qsPulse { 0%,100% { opacity: 1; transform: scale(1); } 50% { opacity: .55; transform: scale(.85); } }

/* second-row widgets layout */
.home-widgets-2 {
  margin-top: 14px;
}

/* #10 pulse widget */
.pulse-widget { display: flex; flex-direction: column; gap: 6px; }
.pulse-mini { font-size: .55rem; opacity: .55; margin-left: auto; }
.pulse-stack { display: flex; flex-direction: column; gap: 8px; padding-top: 4px; }
.pulse-row {
  display: grid; grid-template-columns: 56px 1fr 64px;
  align-items: center; gap: 8px;
  font-family: 'JetBrains Mono', monospace; font-size: .65rem;
}
.pulse-name { color: var(--text-subtle); opacity: .7; }
.pulse-svg  { width: 100%; height: 22px; }
.pulse-val  { text-align: right; color: var(--text); opacity: .85; }

/* #13 ssl gauge */
.ssl-widget { display: flex; flex-direction: column; align-items: stretch; gap: 4px; }
.ssl-mini { font-size: .55rem; opacity: .55; margin-left: auto; }
.ssl-gauge { width: 100%; height: auto; max-height: 78px; }
.ssl-list { display: flex; flex-direction: column; gap: 3px; margin-top: 2px; }
.ssl-row {
  display: flex; justify-content: space-between; align-items: center;
  font-family: 'JetBrains Mono', monospace; font-size: .62rem;
  padding: 2px 6px; border-radius: 4px;
}
.ssl-row .ssl-d    { color: var(--text-muted); opacity: .85; }
.ssl-row .ssl-days { color: var(--text); font-weight: 600; }
.ssl-row.warn .ssl-days { color: #fde047; }
.ssl-row.crit .ssl-days { color: #fca5a5; }
.ssl-row.crit { background: rgba(252,165,165,.06); }
.ssl-empty { font-family: 'JetBrains Mono', monospace; font-size: .65rem; color: var(--text-subtle); opacity: .6; text-align: center; padding: 8px; }

/* #12 network map */
.netmap-widget { display: flex; flex-direction: column; gap: 6px; }
.netmap-svg { width: 100%; height: auto; max-height: 130px; }
.netmap-legend { display: flex; gap: 10px; justify-content: center; font-family: 'JetBrains Mono', monospace; font-size: .55rem; opacity: .6; }
.nm-leg.ok   { color: #6ee7b7; }
.nm-leg.warn { color: #fde047; }
.nm-leg.down { color: #fca5a5; }

/* #11 quick-deploy */
.deploy-widget { display: flex; flex-direction: column; gap: 6px; }
.deploy-mini {
  font-size: .55rem; padding: 1px 6px; margin-left: auto;
  background: rgba(251,191,36,.15); color: #fde047;
  border-radius: 999px; letter-spacing: .08em; font-weight: 600;
}
.deploy-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; margin-top: 2px; }
.deploy-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 10px;
  background: rgba(255,255,255,.04); border: 1px solid var(--border);
  color: var(--text); font-family: 'JetBrains Mono', monospace; font-size: .65rem;
  border-radius: 8px; cursor: pointer;
  transition: all .15s;
}
.deploy-btn:hover { background: rgba(255,255,255,.08); border-color: var(--border-strong); transform: translateY(-1px); }
.deploy-btn.running { background: rgba(110,231,183,.10); border-color: rgba(110,231,183,.35); }
.deploy-btn.running .deploy-icon { animation: deploySpin 1s linear infinite; }
@keyframes deploySpin { to { transform: rotate(360deg); } }
.deploy-icon { display: inline-block; width: 14px; text-align: center; opacity: .8; }
.deploy-name { letter-spacing: .03em; }
.deploy-log {
  margin-top: 6px; max-height: 90px; overflow-y: auto;
  font-family: 'JetBrains Mono', monospace; font-size: .58rem;
  padding: 6px 8px; background: rgba(0,0,0,.25); border-radius: 6px;
  color: var(--text-muted);
}
.deploy-log:empty { display: none; }
.deploy-log-line { padding: 1px 0; }
.deploy-log-ts   { color: var(--text-subtle); opacity: .5; margin-right: 6px; }
.deploy-log-line.ok { color: #6ee7b7; }
.deploy-log-line.pending { color: var(--text-muted); }
.deploy-action { color: var(--text); font-weight: 600; }

/* #4 recent row */
.recent-section { margin-bottom: 8px; }
.recent-pills { display: flex; flex-wrap: wrap; gap: 6px; }
.recent-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 10px 5px 5px;
  background: rgba(255,255,255,.04); border: 1px solid var(--border);
  border-radius: 999px;
  text-decoration: none; color: var(--text-muted);
  font-family: 'JetBrains Mono', monospace; font-size: .65rem;
  transition: all .15s;
}
.recent-pill:hover { color: var(--text); border-color: var(--border-strong); transform: translateY(-1px); }
.recent-pill-icon { width: 16px; height: 16px; object-fit: contain; }
.recent-pill-icon.invert { filter: invert(1); }

/* #18 pinned bento card */
.bento-link-card.pinned { position: relative; }
.bento-link-card.pinned::before {
  content: '★'; position: absolute; top: 4px; right: 6px;
  font-size: .6rem; color: var(--accent); opacity: .85;
  text-shadow: 0 0 4px currentColor;
  pointer-events: none;
}

/* #19 dragging state */
.bento-link-card { transition: transform .2s, opacity .2s, box-shadow .2s; }
.bento-link-card.dragging { opacity: .35; transform: scale(.96); }

/* #8 stagger fade-in */
.stagger-in { animation: staggerFade .5s ease both; }
@keyframes staggerFade {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* #8 hb-pulse rhythm tweak (defaults already exist; no override) */

/* responsive: 2nd-row widgets stack on narrow screens */
@media (max-width: 900px) {
  .home-widgets-2 { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .home-widgets-2 { grid-template-columns: 1fr; }
  .deploy-grid    { grid-template-columns: 1fr; }
}

/* pulse value extras */
.pulse-up { color: var(--text-subtle); opacity: .55; font-size: .55rem; }
.pulse-empty { color: var(--text-subtle); opacity: .5; font-style: italic; }
.pulse-val.pulse-degraded { color: #fca5a5; }

/* pulse widget — folded heartbeat summary */
.pulse-widget { text-decoration: none; color: inherit; }
.pulse-summary {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 8px; padding: 4px 0 2px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 6px;
}
.pulse-summary-status { font-family: 'Inter', sans-serif; font-size: .82rem; }
.pulse-summary-num { font-family: 'JetBrains Mono', monospace; font-size: .72rem; color: var(--text-muted); opacity: .8; }
.pulse-foot {
  margin-top: 6px; padding-top: 6px;
  border-top: 1px solid var(--border);
  font-family: 'JetBrains Mono', monospace; font-size: .58rem;
  color: var(--text-subtle); opacity: .75;
}
.pulse-foot:empty { display: none; }
.pulse-foot .hb-down-list { display: flex; flex-wrap: wrap; gap: 4px; }
.pulse-foot .hb-down-tag {
  display: inline-block; padding: 1px 6px;
  background: rgba(252,165,165,.10); border: 1px solid rgba(252,165,165,.25);
  border-radius: 999px; color: #fca5a5;
}

/* hourly widget gets sun info merged in */
.widget-label .widget-sub {
  font-family: 'JetBrains Mono', monospace;
  font-size: .58rem; font-weight: 400;
  color: var(--text-subtle); opacity: .75;
  margin-left: 8px; letter-spacing: .02em;
}
.sun-times-inline {
  margin-top: 8px; padding-top: 8px;
  border-top: 1px solid var(--border);
  display: flex; justify-content: space-between; align-items: center;
  font-family: 'JetBrains Mono', monospace; font-size: .68rem;
  color: var(--text-muted);
}
.sun-times-inline .sun-icon { color: #fbbf24; opacity: .85; margin-right: 4px; }
.sun-times-inline .sun-spacer { flex: 1; }
